Ajout de scripts manquants
darcs-hash:20090610100826-69ccb-32281005e3cc3d598d4b10a440fe9c29826e32a0.gz
This commit is contained in:
parent
4f69918eba
commit
c1d5e45ce1
3 changed files with 294 additions and 0 deletions
13
wiki/macro/BackgroundImage.py
Normal file
13
wiki/macro/BackgroundImage.py
Normal file
|
@ -0,0 +1,13 @@
|
|||
|
||||
def execute(macro, args):
|
||||
|
||||
argv = args.split(',')
|
||||
pic = argv[0].strip()
|
||||
|
||||
html_fmt = '''
|
||||
<div style="background: transparent url('%s') center left no-repeat;">
|
||||
%s
|
||||
</div>
|
||||
'''
|
||||
pic0 = AttachFile.getAttachUrl(pn, pic0, self.request)
|
||||
pic0 = wikiutil.escape(pic0)
|
44
wiki/macro/Latex.py
Normal file
44
wiki/macro/Latex.py
Normal file
|
@ -0,0 +1,44 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
"""
|
||||
See the latex parser, this is just a thin wrapper around it.
|
||||
"""
|
||||
# Imports
|
||||
from MoinMoin import wikiutil
|
||||
import re
|
||||
|
||||
Dependencies = []
|
||||
|
||||
splitre = re.compile(r'([^\\])%')
|
||||
|
||||
class latex:
|
||||
def __init__(self, macro, args):
|
||||
self.macro = macro
|
||||
self.formatter = macro.formatter
|
||||
self.text = args
|
||||
|
||||
def renderInPage(self):
|
||||
# return immediately if getting links for the current page
|
||||
if self.macro.request.mode_getpagelinks:
|
||||
return ''
|
||||
|
||||
if self.text is None: # macro call without parameters
|
||||
return ''
|
||||
|
||||
# get an exception? for moin before 1.3.2 use the following line instead:
|
||||
# L = wikiutil.importPlugin('parser', 'latex', 'Parser', self.macro.cfg.data_dir)
|
||||
L = wikiutil.importPlugin(self.macro.cfg, 'parser', 'latex', 'Parser')
|
||||
if L is None:
|
||||
return self.formatter.text("<<please install the latex parser>>")
|
||||
l = L('', self.macro.request)
|
||||
tmp = splitre.split(self.text, 1)
|
||||
if len(tmp) == 3:
|
||||
prologue,p2,tex=tmp
|
||||
prologue += p2
|
||||
else:
|
||||
prologue = ''
|
||||
tex = tmp[0]
|
||||
return l.get(self.formatter, tex, prologue)
|
||||
|
||||
|
||||
def execute(macro, args):
|
||||
return latex(macro, args).renderInPage()
|
237
wiki/theme/CransWifi.py
Normal file
237
wiki/theme/CransWifi.py
Normal file
|
@ -0,0 +1,237 @@
|
|||
# -*- coding: iso-8859-1 -*-
|
||||
"""
|
||||
MoinMoin cr@ns
|
||||
|
||||
|
||||
"""
|
||||
|
||||
from MoinMoin import wikiutil, version
|
||||
from MoinMoin import caching
|
||||
from MoinMoin.theme import ThemeBase
|
||||
from MoinMoin.Page import Page
|
||||
from MoinMoin.widget import html
|
||||
|
||||
class Theme(ThemeBase):
|
||||
name = "CransWifi"
|
||||
scripts = ['jquery-1.3.2.min.js', 'crans.js']
|
||||
stylesheets = (
|
||||
# media basename
|
||||
('all', 'reset-fonts-grids'),
|
||||
('all', 'base-min'),
|
||||
('all', 'common'),
|
||||
('screen', 'screen'),
|
||||
('print', 'print'),
|
||||
('projection', 'projection'),
|
||||
)
|
||||
|
||||
def header(self, d, **kw):
|
||||
""" Assemble wiki header
|
||||
|
||||
@param d: parameter dictionary
|
||||
@rtype: unicode
|
||||
@return: page header html
|
||||
"""
|
||||
# hack
|
||||
self.cfg.logo_string = u'<img src="/wiki/CransWifi/img/logo2.png" alt="cr@ns Logo">'
|
||||
html = [
|
||||
# Pre header custom html
|
||||
self.emit_custom_html(self.cfg.page_header1),
|
||||
|
||||
# Header
|
||||
u'<div id="doc4" class="yui-t2">',
|
||||
u'<div id="hd">',
|
||||
|
||||
u'</div>',
|
||||
# u'<div id="locationline">',
|
||||
# self.interwiki(d),
|
||||
# u'</div>',
|
||||
# u'<div id="pageline"><hr style="display:none;"></div>',
|
||||
|
||||
# self.editbar(d),
|
||||
# u'</div>',
|
||||
u'<div id="bd">',
|
||||
u'<div id="yui-main">',
|
||||
u'<div class="yui-b"><div class="yui-g PageContent">',
|
||||
self.msg(d),
|
||||
self.breadcrumbs(d),
|
||||
self.title(d),
|
||||
|
||||
# Post header custom html (not recommended)
|
||||
self.emit_custom_html(self.cfg.page_header2),
|
||||
|
||||
# Start of page
|
||||
self.startPage(),
|
||||
]
|
||||
return u'\n'.join(html)
|
||||
|
||||
def footer(self, d, **keywords):
|
||||
""" Assemble wiki footer
|
||||
|
||||
@param d: parameter dictionary
|
||||
@keyword ...:...
|
||||
@rtype: unicode
|
||||
@return: page footer html
|
||||
"""
|
||||
page = d['page']
|
||||
html = [
|
||||
# End of page
|
||||
u'<hr />',
|
||||
self.pageinfo(page),
|
||||
self.endPage(),
|
||||
# Pre footer custom html (not recommended!)
|
||||
self.emit_custom_html(self.cfg.page_footer1),
|
||||
u'</div>', # end of yui-g
|
||||
u'</div>', # end of yui-b
|
||||
u'</div>', # end of yui-main
|
||||
# NAVIGATION
|
||||
u'<div class="yui-b">',
|
||||
self.logo(),
|
||||
u'<h2>Navigation</h2>',
|
||||
self.navibar(d),
|
||||
u'</div>', # end of yui-b (navigation)
|
||||
u'</div>', # end of #bd
|
||||
# self.credits(d),
|
||||
# self.showversion(d, **keywords),
|
||||
u'</div>', # end of #doc4
|
||||
# Toolbar
|
||||
u'<div id="ToolBar">',
|
||||
self.editbar(d),
|
||||
self.searchform(d),
|
||||
u'</div>',
|
||||
# UserBar
|
||||
u'<div id="UserBar">',
|
||||
self.username(d),
|
||||
u'</div>',
|
||||
# Login
|
||||
u'<div id="loginBox">',
|
||||
self.loginform(d),
|
||||
u'</div>',
|
||||
# Post footer custom html
|
||||
self.emit_custom_html(self.cfg.page_footer2),
|
||||
]
|
||||
return u'\n'.join(html)
|
||||
|
||||
def title(self, d):
|
||||
""" Assemble the title
|
||||
|
||||
@param d: parameter dictionary
|
||||
@rtype: string
|
||||
@return: title html
|
||||
"""
|
||||
_ = self.request.getText
|
||||
page_title = ""
|
||||
if d['title_text'] == d['page'].split_title():
|
||||
curpage = ''
|
||||
segments = d['page_name'].split('/') # was: title_text
|
||||
page_title = segments[-1]
|
||||
else:
|
||||
page_title = wikiutil.escape(d['title_text'])
|
||||
html = '<h1 class="bigtitle">%s</h1>' % page_title
|
||||
return html
|
||||
|
||||
def breadcrumbs(self, d):
|
||||
""" Assemble the breadcrumbs
|
||||
|
||||
@param d: parameter dictionary
|
||||
@rtype: string
|
||||
@return: title html
|
||||
"""
|
||||
_ = self.request.getText
|
||||
content = []
|
||||
if d['title_text'] == d['page'].split_title():
|
||||
curpage = ''
|
||||
segments = d['page_name'].split('/') # was: title_text
|
||||
for s in segments[:-1]:
|
||||
curpage += s
|
||||
content.append("<li>%s</li>" % Page(self.request, curpage).link_to(self.request, s))
|
||||
curpage += '/'
|
||||
content.append(('<li><span class="disabled">%(text)s</span></li>') % {
|
||||
'text': wikiutil.escape(segments[-1]),
|
||||
})
|
||||
else:
|
||||
content.append('<li>%s</li>' % wikiutil.escape(d['title_text']))
|
||||
if len(content) < 2 :
|
||||
return ""
|
||||
html = '<ul id="breadcrumbs">%s</ul>' % "".join(content)
|
||||
return html
|
||||
|
||||
def loginform(self, d):
|
||||
""" Create the complete HTML form code. """
|
||||
def make_field(label, name, value="", type="text", size="32", **kw):
|
||||
p = html.P(**kw)
|
||||
if label:
|
||||
p.append(html.Raw('<label for="%s">%s</label>' % (name, label)))
|
||||
p.append(html.INPUT(type=type, value=value, size=size, name=name))
|
||||
return p
|
||||
_ = self.request.getText
|
||||
request = self.request
|
||||
sn = request.getScriptname()
|
||||
pi = request.getPathinfo()
|
||||
action = u"%s%s" % (sn, pi)
|
||||
hints = []
|
||||
for authm in request.cfg.auth:
|
||||
hint = authm.login_hint(request)
|
||||
if hint:
|
||||
hints.append(hint)
|
||||
form = html.FORM(action=action, name="loginform")
|
||||
form.append(html.INPUT(type="hidden", name="action", value="login"))
|
||||
for hint in hints:
|
||||
form.append(html.P().append(html.Raw(hint)))
|
||||
cfg = request.cfg
|
||||
if 'username' in cfg.auth_login_inputs:
|
||||
form.append(
|
||||
make_field(label=_('Name'), name="name"))
|
||||
|
||||
if 'password' in cfg.auth_login_inputs:
|
||||
form.append(
|
||||
make_field(label=_('Password'), name="password", type="password"))
|
||||
|
||||
if 'openid_identifier' in cfg.auth_login_inputs:
|
||||
form.append(
|
||||
make_field(label=_('OpenID'), name="openid_identifier", id="openididentifier"))
|
||||
buttons = html.P(CLASS="buttons").extend([
|
||||
html.A(CLASS="hideLoginBox", href="#").extend([html.Raw(_("Cancel"))]),
|
||||
html.Raw(' '),
|
||||
html.INPUT(name='login', type="submit", value=_('Login'))])
|
||||
form.append(buttons)
|
||||
|
||||
return unicode(form)
|
||||
|
||||
def headscript(self, d):
|
||||
link = '<script type="text/javascript" src="%s"></script>'
|
||||
|
||||
# Create stylesheets links
|
||||
html = []
|
||||
prefix = self.cfg.url_prefix_static
|
||||
jshref = '%s/%s/js' % (prefix, self.name)
|
||||
for script in self.scripts:
|
||||
href = '%s/%s' % (jshref, script)
|
||||
html.append(link % href)
|
||||
html = u"\n".join(html)
|
||||
|
||||
return ThemeBase.headscript(self, d)+html
|
||||
|
||||
# disable gui editor
|
||||
def guiEditorScript(self, d):
|
||||
return ""
|
||||
|
||||
def editorheader(self, d, **kw):
|
||||
""" Assemble wiki header for editor
|
||||
|
||||
@param d: parameter dictionary
|
||||
@rtype: unicode
|
||||
@return: page header html
|
||||
"""
|
||||
return self.header(d, **kw)
|
||||
|
||||
|
||||
def execute(request):
|
||||
"""
|
||||
Generate and return a theme object
|
||||
|
||||
@param request: the request object
|
||||
@rtype: MoinTheme
|
||||
@return: Theme object
|
||||
"""
|
||||
return Theme(request)
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue