| Setting table column widths non-intrusively using CSS and JQueryPosted on July 8, 2009 by Mikko OhtamaaFiled Under plone, technology Below is a Javascript snipped which will mark each table cell with a CSS class containing the column number. This allows you to set the table column widths using just one CSS rule and without hand editing the table HTML code. This is to workaround the lack of nth-child pseudoclass CSS selector in IE6, IE7 and IE8 – there is no direct Internet Explorer compatible way to set table column widths from CSS. This was originally created to workaround the limitation of Kupu : one couldn’t set table column widths from WYSIWYG editor. Instead, the content editor has predefined table classes and column width sets. The code is also available in the snipplr.
/* Add column index pseudoclasses to table cells.
A JQuery snippet to be executed after DOM model has been loaded.
Each table cell will be marked with a CSS class containing the cell's column number.
This is to workaround the lack of nth-child pseudoclass CSS selector support in
IE6, IE7 and IE8.
Read this sad fact sheet:
http://msdn.microsoft.com/en-us/library/cc351024(VS.85).aspx
This way we can style table columns without explicitly settings classes
for each cell in WYSIWYG editor.
<table>
<tbody>
<tr>
<td>
</td>
<td>
</td>
</tr>
</tbody>
</table>
will become
<table>
<tbody>
<tr>
<td class="column-1">
</td>
<td class="column-2">
</td>
</tr>
</tbody>
</table>
Both <tbody><td> and <thead><th> elements will be fixed.
Use the following CSS to style tables:
table.course-schedule-table .column-1 {
width: auto;
}
table.course-schedule-table .column-2 {
width: 150px;
}
table.course-schedule-table .column-3 {
width: 150px;
}
@author Mikko Ohtamaa
@license 3-clause BSD
http://www.twinapex.com
*/
function createTableColumnPseudoClasses() {
jq("tr").each( function() {
var counter = 1;
jq(this).children("td,th").each( function() {
jq(this).addClass("column-" + counter);
counter++;
});
});
}
// Run code on document load
jq(createTableColumnPseudoClasses);
Catching silent Javascript exceptions with a function decoratorPosted on August 19, 2008 by Mikko OhtamaaFiled Under javascript The one utterly annoying thing with the otherwise excellent Firefox/Firebug combo is that some exceptions are let silently through without being end up to be visible in the Firebug console. This makes debugging very difficult, unless you are aware of the phenomenon. I am not sure whether this is caused by some internal Firefox logic flow, since IE + Visual Web Developer doesn’t seem to be affected by this. Since this problem pops up constantly, I decided to create an easy way to deal with the situation. I decorate all functions which made have silent exceptions (e.g. one called from document load event) with a custom logger function which will first log the exception and then rethrow it. Thus instead of writing (JQuery example) myfunction() {
// crash here
var i = foobar; // missing variable foobar
}
$(document).ready(myfunction);
write myfunction() {
// crash here
var i = foobar; // missing variable foobar
}
$document.ready(logExceptions(myFunction));
or // myFunction can be bind to many events and exceptions are logged always
myfunction = logExceptions(function() {
// crash here
var i = foobar; // missing variable foobar
});
$document.ready(logExceptions(myFunction));
The Javascript code for the decorator: /**
* Enhancd Javascript logging and exception handler.
*
* Copyright 2008 Red Innovation Ltd.
*
* @author Mikko Ohtamaa
* @license 3-clause BSD
*
*/
// Browser specific logging output initialization
// Supports Firefox/Firebug. Other (Opera) can be hooked in here.
if(!console) {
// Install dummy functions, so that logging does not break the code if Firebug is not present
var console = {};
console.log = function(msg) {};
console.info = function(msg) {};
console.warn = function(msg) {};
} else {
// console.log provided by Firefox + Firebug
}
/**
* Try print human digestable exception stack trace to Firebug console.
*
* http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Error
*
* @param e: Error
*/
function printStackTrace(e) {
var msg = e.name + ":" + e.message;
if (e.fileName) {
msg += " at " + e.fileName + ":" + e.lineNumber;
}
console.log(msg);
if (e.stack) {
// Extract Firefox stack information. This tells how you ended up
// to the exception in the first place. I didn't find
// instructions how to parse this stuff.
console.log(e.stack);
}
}
/**
* Decorate function so that exceptions falling through are printed always.
*
* Returns a decorated function which will be used instead of the normal function.
* The decorated function has preplaced try ... catch block which will not let
* through any exceptions silently or without logging. Even though there is an
* exception it is normally throw upwards in the stack after logging.
*
* @param func: Javascript function reference
*/
function logExceptions(func) {
var orignal = func;
decorated = function() {
try {
orignal.apply(this, arguments);
} catch(exception) {
printStackTrace(exception);
throw exception;
}
}
return decorated;
}
Updated: Eclipse web developer plug-in memoPosted on July 14, 2008 by Mikko OhtamaaFiled Under Plone (old), Uncategorized, eclipse, python Below are my personal notes what plug-ins are needed to get “perfect” Eclipse web development set-up. Basically they are just my own notes so that I don’t need to Google everything all over again every time I reinstall. I hope the readers can find new pearls here or suggest improvements. This post is update to previous Eclipse web developer plug-in memo post. New versions are available and some plug-ins have become deprecated. This blog post reflects those changes. These instructions are good for:
Choosing Eclipse distribution
sudo apt-get install sun-java6 eclipse
EasyEclipse bundles some of the stuff listed here with it – when using EasyEclipse you don’t need to have separate PyDev and Subclipse downloads. Eclipse for 64-bit Linux has various problems. You might want to run 32-bit Eclipse (another relevant blog post). When you use Linux distribution specific Eclipse install, all your personal Eclipse files go to .eclipse folder under your home folder. Installing plug-insEclipse has internal updater/web installer. All plug-ins are downloaded as ZIP files and extracted to Eclipse folder or installed through the internal updater. Paste Eclipse update site URLs to menu Help -> Software updates -> Find and Install, New Remote Location. PythonPyDev is a plug-in for Python and Jython development. It has enhanced commercial extensions for professional developers with more intelligent autocomplete and debugger. Site URL: http://pydev.sourceforge.net PyDev Eclipse update URL: http://pydev.sourceforge.net/updates/ PyDev extensions Eclipse update URL (this commercial, but worth of every penny): http://www.fabioz.com/pydev/updates PDTPDT download provides Eclipse, HTML editor, PHP editor and CSS editor. Site URL: http://www.eclipse.org Eclipse update site URL: http://download.eclipse.org/tools/pdt/updates/ JavaIf you need to do J2EE development use IBM’s Web Tools Platform. If you don’t need Java capabilities don’t install these, since they just bloat Eclipse and make the start up time worse. SubclipseSubclipse provides Subversion version control integration to Eclipse. Eclipse update site URL: http://subclipse.tigris.org/update_1.4.x/ In the installer, uncheck the integration modules checkbox or the installer will complain about missing modules. Aptana Studio
Aptana Studio is state-of-the-art Web 2.0 development suite for Eclipse. It has Javascript, CSS and HTML editors. It supports various Javascript libraries out of the box and has support for Firefox and IE in-browser Javascript debugging. Eclipse update site URL: http://update.aptana.com/update/studio/3.2/site.xml ShellEdSyntax coloring for Unix shell scripts Project site: http://sourceforge.net/projects/shelled SQL ExplorerSQL terminal and SQL editor with some GUI capabilities. Eclipse update site URL http://eclipsesql.sourceforge.net/ SQL Explorer needs MySQL JDBC driver. Download from here. Install MySQL connector by extracting the file and adding it from SQL Explorer preferences. |
