hard-coded primary key on first column
[MojoFacets.git] / public / edit_table.js
1 $(document).ready( function() {
2
3 var cell_blur = function() {
4         console.debug( 'cell_blur'
5 //              , this
6 //              , $(this).val()
7         );
8
9         // FIXME primary key is fixed to 1st column
10         var pk = $('table tr th:nth(0) > a').text();
11         var id = $(this).parent().siblings(':nth(0)').text()
12
13         var x = $(this).parent().attr('cellIndex');
14         var y = $(this).parent().parent().attr('rowIndex');
15
16         var content = $(this).val();
17         if ( 0 ) { // leave delimiters in edited cells visible
18                 var vals = content.split('¶');
19                 content = vals.join('<span class=d>¶</span>');
20         }
21
22 //      var cell = $('<td>'+content+'</td>');
23         $(this).replaceWith( content );
24
25         var name = $('table tr th:nth('+x+') > a').text();
26         console.info( x, y, pk, id, name, content );
27 }
28
29 var cell_click = function(event) {
30         console.debug( 'cell_click'
31                 , this
32                 , event
33                 , $(this).text()
34         );
35         var content = $(this).text(); // we don't want para markup
36         var rows = content.split('¶').length * 2 + 1;
37         var textarea = $('<textarea rows='+rows+'/>');
38         textarea.val( content );
39         $(this).html( textarea );
40         textarea.focus();
41         textarea.blur( cell_blur )
42 };
43
44
45 console.info('double-click on cell to edit it');
46 $('table td').live( 'dblclick', cell_click );
47
48 }); // document.ready
49
50