* Improved document layout in Firefox.
authorŁukasz Rekucki <lrekucki@gmail.com>
Fri, 12 Mar 2010 19:21:00 +0000 (20:21 +0100)
committerŁukasz Rekucki <lrekucki@gmail.com>
Fri, 12 Mar 2010 21:23:01 +0000 (22:23 +0100)
* Custom error pages.

14 files changed:
apps/wiki/templates/wiki/document_details.html
apps/wiki/templates/wiki/document_list.html
apps/wiki/views.py
platforma/settings.py
platforma/static/css/filelist.css
platforma/static/css/html.css
platforma/static/css/master.css
platforma/static/css/xmlcolors.css
platforma/static/js/main.js
platforma/static/xsl/wl2html_client.xsl
platforma/templates/404.html [new file with mode: 0644]
platforma/templates/500.html [new file with mode: 0644]
platforma/templates/503.html
scripts/nice_diff.py [new file with mode: 0644]

index 95a7c95..5f8d791 100644 (file)
             <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">
@@ -83,7 +87,7 @@
                                                        
                                </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">
index 5bc53e8..1f2c9b9 100644 (file)
@@ -23,15 +23,16 @@ $(function() {
 {% 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>
index 931cf78..ea6fa8b 100644 (file)
@@ -28,12 +28,17 @@ def document_list(request, template_name = 'wiki/document_list.html'):
 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()
index 83456f8..be27e36 100644 (file)
@@ -3,9 +3,12 @@ from os import path
 
 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'),
index 91e9b8d..732ebd9 100644 (file)
@@ -6,25 +6,37 @@
         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 {    
@@ -40,8 +52,3 @@ ul.file-tree-part li {
 ul.file-tree-part a {
     padding: 0em;
 }
-
-
-
-
-
index e3d9a4a..df8c54c 100644 (file)
@@ -6,7 +6,35 @@
     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'] {
@@ -14,8 +42,7 @@
 }
 
 .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 */
index d2768be..5fc28d0 100644 (file)
@@ -9,23 +9,29 @@ body {
 
 .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;
@@ -35,16 +41,17 @@ body {
 #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;
@@ -52,11 +59,33 @@ body {
     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;
 }
@@ -78,46 +107,70 @@ body {
 }
 
 #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;*/
 }
 
@@ -162,7 +215,6 @@ body {
     color: #FFF;
     -webkit-border-radius: 10px;
     -moz-border-radius: 10px;
-    border-radius: 10px;
 }
 
 /* Remove extra padding in Firefox */
@@ -173,17 +225,6 @@ button::-moz-focus-inner {
 
 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 = */
 /* =========== */
@@ -257,28 +298,29 @@ p { margin: 0;}
 }
 
 
-.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 {
@@ -314,3 +356,23 @@ p { margin: 0;}
  .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
index aa26579..1b60259 100644 (file)
@@ -1,8 +1,13 @@
-.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 {
@@ -23,7 +34,7 @@ span.xml-punctuation {
 }
 
 span.xml-attname {
-  color: #00F;
+  color: #817aff;
 }
 
 span.xml-comment {
index 270e3cc..3f4d30c 100644 (file)
@@ -767,9 +767,10 @@ $(function() {
         parserConfig: {
             useHTMLKludges: false
         },
-        iframeClass: 'xml-iframe',
+        iframeClass: 'xml-iframe',             
         textWrapping: true,
-               /* lineNumbers: true, */
+               lineNumbers: true, 
+               width: "100%",
         tabMode: 'spaces',
         indentUnit: 0,
         initCallback: function(editor) {
index c65eabf..a5db5a1 100644 (file)
         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')" />
diff --git a/platforma/templates/404.html b/platforma/templates/404.html
new file mode 100644 (file)
index 0000000..0618a5e
--- /dev/null
@@ -0,0 +1,69 @@
+<!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>
diff --git a/platforma/templates/500.html b/platforma/templates/500.html
new file mode 100644 (file)
index 0000000..ee72720
--- /dev/null
@@ -0,0 +1,56 @@
+<!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>
index 1c2e4d2..9d1e4fa 100644 (file)
@@ -4,13 +4,53 @@
     <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>
diff --git a/scripts/nice_diff.py b/scripts/nice_diff.py
new file mode 100644 (file)
index 0000000..3de9ad4
--- /dev/null
@@ -0,0 +1,57 @@
+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)) )