* Custom error pages.
<div class="{{ k }}">{{ v}}</div>
{% endfor %}
</div>
- <div id="header">
- <div id="tools" style="float: right;">
- {% include "registration/head_login.html" %}
- Wersja: <span id="document-revision">{{ document.revision }}</span> <button style="margin-left: 6px" id="save-button">Zapisz</button></div>
+ <div id="header">
<h1><a href="{% url wiki.views.document_list %}">Platforma</a></h1>
+ <div id="tools">
+ <a href="{{ REDMINE_URL }}projects/wl-publikacje/wiki/Pomoc" target="_blank">Pomoc</a>
+ | {% include "registration/head_login.html" %}
+ | Wersja: <span id="document-revision">{{ document.revision }}</span>
+ | <button style="margin-left: 6px" id="save-button">Zapisz</button>
+ </div>
<ol id="tabs">
<li id="simple-view-tab" ui:related="simple-editor"><span id="document-name">{{ document.name }}</span></li>
<li id="source-view-tab" ui:related="source-editor">Kod źródłowy</li>
<li id="history-view-tab" ui:related="history-viewer">Historia</li>
</ol>
- <div style="clear: both"></div>
+
</div>
<div id="splitter">
<div id="editor">
<input type="hidden" name="comment" value="no comment" />
<input type="hidden" name="revision" value="{{ document.revision }}" />
</div>
- <div id="simple-editor" class="editor" style="display: none">
- <div class="toolbar">
+ <div id="simple-editor" class="editor" style="display: none">
+ <div id="html-view" class="htmlview">
+ </div>
+
+ <div class="toolbar">
<button id="insert-theme-button">Wstaw motyw</button> <button id="insert-annotation-button">Wstaw przypis</button>
<div class="toolbar-end"> </div>
</div>
- <div id="html-view" class="htmlview">
- </div>
</div>
<div id="history-viewer" class="editor" style="display: none">
</div>
</div>
- <div class="vsplitbar"> </div>
+ <div class="vsplitbar" title="Klinknij aby (ro)zwinąć galerię."> </div>
<div id="sidebar">
<div class="toolbar">
<button class="previous-page">
{% endblock extrahead %}
{% block maincontent %}
-<div id="main-page-widgets">
+<h1><img src="{{STATIC_URL}}/img/logo.png">Platforma Redakcyjna</h1>
-<div class="file-list-widget">
+<div class="document-list">
<form action="#" method="GET">
- <p><input autocomplete="off" name="filter" id="file-list-filter" type="text" size="60" />
+ <p>Filtr: <input autocomplete="off" name="filter" id="file-list-filter" type="text" size="60" />
<input type="submit" value="Znajdź" id="file-list-find-button"/>
<input type="reset" value="Wyczyść" id="file-list-reset-button"/>
</p>
- </form>
+ </form>
+
<div id="file-list">
{% for file in document_list %}
<p><a href="{% url wiki.views.document_detail file|urlencode %}">{{ file }}</a></p>
def document_detail(request, name, template_name = 'wiki/document_details.html'):
try:
document = storage.get(name)
- except DocumentNotFound:
- # WTF ?!
- raise Http404
- # document = Document(storage, name = name, text = '')
+ except DocumentNotFound:
+ raise Http404
+
+# access_time = datetime.ctime();
+# last_documents = request.session.get("wiki_last_docs", [])
+#
+# if name not in last_documents:
+# last_documents.insert(0, (name, access_time))
if request.method == 'POST':
+
form = DocumentForm(request.POST, instance = document)
if form.is_valid():
document = form.save()
PROJECT_ROOT = path.realpath(path.dirname(__file__))
-DEBUG = True
+DEBUG = False
TEMPLATE_DEBUG = DEBUG
+MAINTENANCE_MODE = True
+INTERNAL_IPS = ()
+
ADMINS = (
(u'Marek Stępniowski', 'marek@stepniowski.com'),
(u'Łukasz Rekucki', 'lrekucki@gmail.com'),
Dodatkowe style dla listy plików na stronie głównej.
*/
-#main-page-widgets > div {
- float: left;
+body {
+ background-color: #84BF2A;
+}
+
+#content {
+ background: #EFEFEF;
border: 1px solid black;
padding: 0.5em 2em;
- margin: 1em;
+ margin: 1em;
+ overflow: hidden;
}
-.file-list-widget {
- background: #DDF;
- max-width: 60%;
+#content h1 img {
+ vertical-align: middle;
}
-.file-list-widget .page-nav-wrap button {
- width: 2.5em;
+#content h1 {
+ border-bottom: 2px solid black;
+ padding: 0.5em;
+ font-size: 2opt;
+ font-family: sans-serif;
}
-.upload-file-widget {
- min-width: 20%;
- width: 35%;
+.document-list {
+ overflow: visible;
+ float: left;
+ max-width: 60%;
+}
+
+.document-list .page-nav-wrap button {
+ width: 2.5em;
}
ul.file-tree-part {
ul.file-tree-part a {
padding: 0em;
}
-
-
-
-
-
font-family: "Georgia", "Times New Roman", serif;
line-height: 1.5em;
padding: 3em;
- padding-left: 55px;
+ padding-left: 45px;
+ overflow-y: scroll;
+ overflow-x: auto;
+}
+
+.htmlview[data-tag-names-visible] {
+ padding-left: 90px;
+}
+
+.htmlview[data-tag-names-visible] *[x-editable]:not(*[x-common])::before {
+ display: block;
+ float: left;
+ clear: left;
+ content: attr(x-node);
+ font-weight: bold;
+ font-style: normal;
+ font-variant:normal;
+ font-size: 8px;
+ line-height: 8px;
+ margin-bottom: 4px;
+
+ padding: 3px 4px;
+ vertical-align: super;
+ background-color:#add8e6;
+ margin-left: -80px;
+ width: 70px;
+ text-align: center;
+
+ -webkit-border-radius: 4px;
}
.htmlview *[x-node='RDF'] {
}
.htmlview * {
- position: relative;
- overflow: visibl;
+ position: relative;
}
.htmlview div {
}
.htmlview .dzielo_nadrzedne {
- font-size: 1.5em;
- display: block;
- line-height: 1.5em;
- margin-bottom: -0.25em;
+ /* */
}
.htmlview .podtytul {
- font-size: 0.5em;
- display: block;
- line-height: 1.5em;
- margin-top: -0.25em;
+ /* */
}
.htmlview .didaskalia {
}
.htmlview .strofa {
- margin: 1.5em 0 0 auto;
+ margin: 1.5em 0 0.5em auto;
}
/* wersy */
.vsplitbar {
position: absolute;
- top: 25px;
+ top: 0px;
bottom: 0;
right: 0;;
width: 13px;
background: #C1C1C1 url(../img/gallery.png) no-repeat scroll center center;
+ text-
border-left: 1px solid #999;
border-right: 1px solid #999;
- cursor: w-resize;
+ cursor: pointer;
+}
+
+.vsplitbar:hover {
+ background-color: #e6e6fa;
}
.vsplitbar.active {
- cursor: e-resize;
+ background-
+
}
#source-editor, #simple-editor, #history-viewer {
position: absolute;
- top: 25px;
+ top: 0px;
bottom: 0;
left: 0;
right: 15px;
#html-view, #history-view {
overflow: auto;
position: absolute;
- top: 27px;
+ top: 30px;
bottom: 0;
left: 0;
right: 0;
+ z-index: 1;
}
#sidebar {
position: absolute;
overflow: hidden;
- top: 25px;
+ top: 0px;
right: 0;
bottom: 0;
width: 0;
background-color: #FFF;
}
+
+#splitter {
+ position: fixed;
+ top: 31px;
+ left: 0px;
+ right: 0px;
+ bottom: 0px;
+ overflow: hidden;
+}
+
+
#header {
+ position: fixed;
+ top: 0px;
+ right: 0px;
+ left: 0px;
+ height: 30px;
+ border-bottom: 1px solid #999;
+
margin: 0;
padding: 0;
background-color: #C1C1C1;
background-image: -webkit-gradient(linear, left top, left bottom, from(#C1C1C1), color-stop(0.9, #A2A2A2));
+
+ /* Firefox 3.6 */
+ background-image: -moz-linear-gradient(top left, #C1C1C1, #A2A2A2, 90%);
+
font: 11px Helvetica, Verdana, sans-serif;
font-weight: bold;
}
}
#tabs {
+ overflow: hidden;
margin: 0;
- padding: 0;
-
- width: 100%;
- height: 22px;
- padding-top: 2px;
- border-bottom: 1px solid #999;
+ height: 30px;
+ padding-left: 1em;
}
#tabs li {
- -webkit-user-select: none;
- cursor: default;
+ height: 24px;
+ margin-top: 6px;
+
+ -webkit-user-select: none;
+ cursor: pointer;
display: block;
float: left;
- padding: 5px 12px 3px 12px;
- border: 1px solid #999;
- -webkit-border-radius: 4px;
- -webkit-border-bottom-left-radius: 0;
- -webkit-border-bottom-right-radius: 0;
+
+ padding-left: 12px;
+ padding-right: 12px;
+ padding-top: 5px;
+
font-weight: bold;
color: #222;
- height: 13px;
- -webkit-box-shadow: 1px -1px 2px rgba(127, 127, 127, 0.25);
- margin-left: 4px;
- margin-bottom: -1px;
+ margin-left: 4px;
+
background-color: #A2A2A2;
+
+ -moz-box-shadow: 1px -1px 2px rgba(127, 127, 127, 0.25);
+ -webkit-box-shadow: 1px -1px 2px rgba(127, 127, 127, 0.25);
+
+ border: 1px solid #999;
+ -moz-border-radius: 4px 4px 0px 0px;
+ -webkit-border-radius: 4px;
+ -webkit-border-bottom-left-radius: 0px;
+ -webkit-border-bottom-right-radius: 0px;
}
#tabs li.active {
- background-color: #C1C1C1;
- border-bottom: 1px solid #C1C1C1;
+ background-color: #C1C1C1;
}
+#tools {
+ float: right;
+ clear: right;
+ overflow: hidden;
+ margin: 0;
+ padding: 0;
+ height: 30px;
+ margin-right: 5px;
+ line-height: 30px;
+ font-size: 10px;
+ vertical-align: middle;
+}
+
+
+/*
+ * Toolbars
+ */
+
.toolbar {
width: 100%;
border-bottom: 1px solid #777;
background-color: #C1C1C1;
margin: 0;
padding: 2px;
- z-index: 10;
+ z-index: 100;
/* height: 22px;*/
}
color: #FFF;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
- border-radius: 10px;
}
/* Remove extra padding in Firefox */
p { margin: 0;}
-.htmlview *[x-editable] {
- background-color: white;
-}
-
-.htmlview .active[x-editable] {
- background-color: #FAFAFA;
- border: 1px solid #DDD;
-/* -webkit-transition: all 1s linear;*/
-}
-
-
/* =========== */
/* = Gallery = */
/* =========== */
}
-.xml-iframe {
- margin-left: 40px;
-}
+
/*
* CodeMirror
*/
+
.CodeMirror-line-numbers {
- background: #e6ddd5;
- padding-top: 0.35em;
+ padding: 0px;
+ padding-top: 5px;
+ text-align: right;
+ overflow: hidden;
+ width: 40px;
+ border-right: 1px solid black;
+ background-color: #e6e6fa;
}
.CodeMirror-line-numbers div {
- padding: 0;
- padding-right: 4px;
-
- font-size: 8pt;
- line-height: 17px;
- text-align: right;
-
- width: 40px;
-}
+ display: block;
+ font-family:"Lucida Console", monospace;
+ font-size: 13px;
+ line-height: 18px;
+ padding-right: 5px;
+}
/* DIFFS */
#history-view table {
.diff_add {
background-color: #40ef40;
}
+
+
+/*
+ * HTML Editor view
+ */
+
+.htmlview {
+ z-index: 1;
+ overflow: hidden;
+}
+
+.htmlview *[x-editable] {
+ background-color: white;
+
+}
+.htmlview .active[x-editable] {
+ background-color: #FAFAFA;
+ border: 1px solid #DDD;
+/* -webkit-transition: all 1s linear;*/
+}
\ No newline at end of file
-.editbox {
+.editbox {
margin: .4em;
+ margin-top: 5px;
+ margin-left: 45px;
padding: 0;
- font-family: monospace;
- font-size: 10pt;
+
+ font-family:"Lucida Console", monospace;
+ font-size: 13px;
+ line-height: 18px;
+
color: black;
}
margin: 0;
}
+.editbox span {
+ display: inline;
+ font-size: 13px;
+ line-height: 18px;
+}
+
span.xml-tagname {
- color: #A0B;
+ color: #a31727;
}
span.xml-attribute {
- color: #281;
+ color: #8b8b8b;
}
span.xml-punctuation {
}
span.xml-attname {
- color: #00F;
+ color: #817aff;
}
span.xml-comment {
parserConfig: {
useHTMLKludges: false
},
- iframeClass: 'xml-iframe',
+ iframeClass: 'xml-iframe',
textWrapping: true,
- /* lineNumbers: true, */
+ lineNumbers: true,
+ width: "100%",
tabMode: 'spaces',
indentUnit: 0,
initCallback: function(editor) {
Przypisy i motywy
-->
<xsl:template match="pr|pa|pe|pt">
- <span x-editable="true">
+ <span x-editable="true" x-common="common">
<xsl:call-template name="standard-attributes">
<xsl:with-param name="extra-class" select="'annotation-inline-box'" />
</xsl:call-template>
</xsl:template>
<xsl:template match="extra|uwaga">
- <span>
+ <span x-common="common">
<xsl:call-template name="standard-attributes" />
<xsl:apply-templates select="child::node()">
<xsl:with-param name="mixed" select="true()" />
</xsl:template>
<xsl:template match="motyw">
- <span x-editable="true">
+ <span x-editable="true" x-common="common">
<xsl:call-template name="standard-attributes" />
<xsl:attribute name="theme-class">
<xsl:value-of select="substring-after(@id, 'm')" />
--- /dev/null
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xmlns:p="http://platforma.wolnelektury.pl/">
+ <head>
+ <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
+ <title>Platforma Redakcyjna</title>
+ <style type="text/css">
+ body {
+ background-color: #84BF2A;
+ }
+
+ #main {
+ position: absolute;
+ top: 20%;
+ left: 20%;
+ right: 20%;
+ border-width: 3px;
+ border-color: black;
+ border-style: ridge;
+ padding: 1em;
+ background: white;
+ }
+
+ #logo {
+ vertical-align: middle;
+ }
+
+ p {
+ text-indent: 1em;
+ text-align: justify;
+ }
+
+ #main a {
+ text-decoration:none;
+ color: #325f70;
+ }
+
+ #main a:hover {
+ color: #f9c325;
+ }
+
+ </style>
+ </head>
+ <body>
+ <div id="main">
+ <h1><a href="http://stigma.nowoczesnapolska.org.pl/platforma">
+ <img id="logo" src="">
+ </a>
+ Nie odnaleziono strony</h1>
+ <p>Strona o podanym przez ciebie adresie:</p>
+ <pre style="margin-left: 2em;">{{request.build_absolute_uri}}</pre>
+ <p>nie instnieje.</p>
+ <ul>
+ <li>Sprawdź, czy adres nie zawiera literówek, np:
+ <em>bog_mnie_oposcil</em>, zamiast <em>bog_mnie_opuscil</em>.
+ </li>
+ <li>
+ Upewnij się, że dokument do którego chcesz się dostać jest na
+ <a href="http://stigma.nowoczesnapolska.org.pl/platforma">liście utworów</a>.
+ </li>
+ </ul>
+ <p>Jeśli nadal nie jesteś w stanie odszukać dokumentu, skontaktuj się
+ z <a href="mailto:platfroma@stigma.nowoczesnapolska.org.pl">administratorem</a>.</p>
+
+
+ </div>
+ </div>
+ </body>
+</html>
--- /dev/null
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xmlns:p="http://platforma.wolnelektury.pl/">
+ <head>
+ <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
+ <title>Platforma Redakcyjna</title>
+ <style type="text/css">
+ body {
+ background-color: #84BF2A;
+ }
+
+ #main {
+ position: absolute;
+ top: 20%;
+ left: 20%;
+ right: 20%;
+ border-width: 3px;
+ border-color: black;
+ border-style: ridge;
+ padding: 1em;
+ background: white;
+ }
+
+ #logo {
+ vertical-align: middle;
+ }
+
+ p {
+ text-indent: 1em;
+ text-align: justify;
+ }
+
+ #main a {
+ text-decoration:none;
+ color: #325f70;
+ }
+
+ #main a:hover {
+ color: #f9c325;
+ }
+ </style>
+ </head>
+ <body>
+ <div id="main">
+ <h1><a href="http://stigma.nowoczesnapolska.org.pl/platforma">
+ <img id="logo" src="">
+ </a>
+ Błąd po stronie serwera.</h1>
+ <p>Niestety nasz serwer WWW nie był w stanie dostarczyć Ci strony o którą prosiłeś.</p>
+ <p><b>Serdecznie przepraszamy.</b></p>
+ <p>Administrator został już powiadomiony o błędzie, ale jeśli chciałbyś
+ przekazać nam więcej informacji na temat błędu, napisz <a href="mailto:platforma@stigma.nowoczesnapolska.org.pl">nasz adres</a>.</p>
+ </div>
+ </div>
+ </body>
+</html>
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title>Platforma Redakcyjna</title>
-
+ <style type="text/css">
+ body {
+ background-color: #84BF2A;
+ }
+
+ #main {
+ position: absolute;
+ top: 20%;
+ left: 20%;
+ right: 20%;
+ border-width: 3px;
+ border-color: black;
+ border-style: ridge;
+ padding: 1em;
+ background: white;
+ }
+
+ #logo {
+ vertical-align: middle;
+ }
+
+ p {
+ text-indent: 1em;
+ text-align: justify;
+ }
+
+ #main a {
+ text-decoration:none;
+ color: #325f70;
+ }
+
+ #main a:hover {
+ color: #f9c325;
+ }
+ </style>
</head>
- <body id="base">
- <h2>Przepraszamy,</h2>
- <p>Platfroma Redakcyjna jest tymczasowo niedostępna
- z powodu prac administracyjnych.</p>
-
- <p>Prosimy o wyrozumiałość i ponowne odwiedziny :)</p>
+ <body>
+ <div id="main">
+ <h1><a href="http://stigma.nowoczesnapolska.org.pl/platforma">
+ <img id="logo" src="">
+ </a>
+ Serwis tymczasowo niedostępny</h1>
+ <p>Platfroma redakcyjna serwisu <a href="http://wolnelektury.pl/">wolnelektury.pl</a> jest
+ tymczasowo niedostępna z powodu prac administracyjnych.
+ </p>
+ <p>Prosimy o wyrozumiałość i ponowne odwiedziny.</p>
+ </div>
+ </div>
</body>
</html>
--- /dev/null
+import difflib
+import re
+
+def read_whole(path):
+ with open(path) as f:
+ return f.readlines()
+
+DIFF_RE = re.compile(r"""\x00([+^-])""" ,re.UNICODE)
+NAMES = { '+': 'added', '-': 'removed', '^': 'changed' }
+
+def diff_replace(match):
+ return """<span class="diff_mark diff_mark_%s">""" % NAMES[match.group(1)]
+
+
+def filter_line(line):
+ return DIFF_RE.sub(diff_replace, line).replace('\x01', '</span>')
+
+def group(diffs):
+ group_a = []
+ group_b = []
+
+ a, b, _ = diffs.next()
+ group_a.append(a[1])
+ group_b.append(b[1])
+
+
+ for _ in range(10):
+ a, b, _ = diffs.next()
+ group_a.append(a[1])
+ group_b.append(b[1])
+
+ while a[0] == '':
+ a, b, _ = diffs.next()
+ group_a.append(a[1])
+ group_b.append(b[1])
+
+ yield group_a[:-1], group_b[:-1]
+ group_a, group_b = group_a[-1:], group_b[-1:]
+
+def join_to_html(diffs):
+ for group_a, group_b in group(diffs):
+ yield """
+<div class="change_block">
+ <div class="old_block">%s</div>
+ <div class="new_block">%s</div>
+</div>""" % (
+ '\n'.join( filter_line(line) for line in group_a ),
+ '\n'.join( filter_line(line) for line in group_b ),
+ )
+
+fa = read_whole("file_a")
+fb = read_whole("file_b")
+
+print '\n'.join( repr(x) for x in difflib._mdiff(fa, fb) )
+print "**************************"
+print '\n'.join( join_to_html( difflib._mdiff(fa, fb) ) )
+# print '\n'.join( repr(x) for x in group(difflib._mdiff(fa, fb)) )