* Fires when source document has been loaded
* @param {Pman.Gnumerci} this
*/
- "load" : true
+ 'load' : true
});
Roo.util.Observable.call(this,cfg);
* @type {Object} rowInfo - list of row sizes
*/
rowInfo : false,
-
+ /**
+ * @type {Object} rowInfoDom - dom elements with sizes
+ */
+ rowInfoDom : false,
/**
* @type {Number} cmax - maximum number of columns
*/
this.sheet = false;
this.grid = false;
this.colInfo = false;
+ this.colInfoDom = false;
this.rowInfo = false;
+ this.rowInfoDom = false;
this.cmax = false;
this.rmax = false;
Roo.each(merge, function(c) {
var rc = _t.rangeToRC(c.textContent);
- //Roo.log(JSON.stringify(rc))
+ //Roo.log(JSON.stringify(rc));
if (typeof(_t.grid[rc[0].r][rc[0].c]) == 'undefined') {
- _t.grid[rc[0].r][rc[0].c] = Roo.applyIf({ r : rc[0].r, c : rc[0].c }, _t.defaultCell);
+ //Roo.log(["creating empty cell for ",rc[0].r, rc[0].c ]);
+ _t.createCell(rc[0].r, rc[0].c );
+ //_t.grid[rc[0].r][rc[0].c] = //Roo.applyIf({ r : rc[0].r, c : rc[0].c }, _t.defaultCell);
}
_t.grid[rc[0].r][rc[0].c].colspan = (rc[1].c - rc[0].c) + 1;
_t.grid[rc[0].r][rc[0].c].rowspan = (rc[1].r - rc[0].r) + 1;
for(var r = (rc[0].r); r < (rc[1].r+1); r++) {
- for(var c = rc[0].c; c < (rc[1].c+1); c++) {
+ for(var cc = rc[0].c; cc < (rc[1].c+1); cc++) {
//Roo.log('adding alias : ' + r+','+c);
- _t.grid[r][c] = _t.grid[rc[0].r][rc[0].c];
+ _t.grid[r][cc] = _t.grid[rc[0].r][rc[0].c];
}
}
ci = this.sheet.getElementsByTagNameNS('*','RowInfo');
this.rowInfo = {};
+ this.rowInfoDom = {};
Roo.each(ci, function(c) {
var count = c.getAttribute('Count') || 1;
var s = c.getAttribute('No')*1;
for(var i =0; i < count; i++) {
+ _t.rowInfoDom[s+i] = c;
_t.rowInfo[s+i] = Math.floor(c.getAttribute('Unit')*1);
}
});
for (var c = s.c; c < s.c1;c++) {
if (c > _t.cmax) continue;
- if (typeof(_t.grid[r][c]) == 'undefined') _t.grid[r][c] = Roo.applyIf({ r: r , c : c }, _t.defaultCell);
+ if (typeof(_t.grid[r][c]) == 'undefined') {
+ _t.createCell(r,c);
+ //_t.grid[r][c] = Roo.applyIf({ r: r , c : c }, _t.defaultCell);
+ }
var g=_t.grid[r][c];
if (typeof(g.cls) =='undefined') {
g.cls = [];
set : function(cell, v, vt, vf) {
var cs= typeof(cell) == 'string' ? this.toRC(cell) : cell;
- //Roo.log( cs.r+ ',' + cs.c + ' = '+ v);
+
+
+ Roo.log( cs.r+ ',' + cs.c + ' = '+ v);
// need to generate clell if it doe
if (typeof(this.grid[cs.r]) == 'undefined') {
Roo.log('no row:' + cell);
Roo.log('cell not defined:' + cell);
this.createCell(cs.r,cs.c);
}
+ // cell might not be rendered yet... so if we try and create a cell, it overrides the default formating..
+
if (typeof(this.grid[cs.r][cs.c].dom) == 'undefined') {
Roo.log('no default content for cell:' + cell);
- this.createCell(cs.r,cs.c);
+ Roo.log(this.grid[cs.r][cs.c]);
+ //this.createCell(cs.r,cs.c);
//return;
}
this.grid[cs.r][cs.c].value= v;
- this.grid[cs.r][cs.c].dom.textContent= v;
+ if (this.grid[cs.r][cs.c].dom) {
+ this.grid[cs.r][cs.c].dom.textContent= v;
+ }
+
+
if (typeof(vt) != 'undefined') {
this.grid[cs.r][cs.c].valueType = vt;
this.grid[cs.r][cs.c].dom.setAttribute('ValueType', vt);
{
// read the first row.
var tds = Roo.get(table).select('tr').item(0).select('td');
- var nc = 0;
- tds.each(function(td) {
- var cs = td.dom.getAttribute('colspan');
- cs = cs ? cs * 1 : 1;
- nc += cs;
+ var maxnc = 0;
+
+ Roo.get(table).select('tr').each(function(trs) {
+ var nc = 0;
+
+ trs.select('td').each(function(td) {
+ var cs = td.dom.getAttribute('colspan');
+ cs = cs ? cs * 1 : 1;
+ nc += cs;
+ });
+ maxnc = Math.max(nc, maxnc);
});
+
var tr = document.createElement('tr');
table.appendChild(tr);
- var ar = {}
- for (i =0; i < nc; i++) {
+ var ar = {};
+ for (i =0; i < maxnc; i++) {
ar[i] = document.createElement('td');
tr.appendChild(ar[i]);
}
// find the left.
- var ret = { cols : nc, pos : {} };
- for (i =0; i < nc; i++) {
+ var ret = { cols : maxnc, pos : {} };
+ for (i =0; i < maxnc; i++) {
ret.pos[ Roo.get(ar[i]).getLeft()] =i;
}
+ ret.near = function(p) {
+ // which one is nearest..
+
+ if (this.pos[p]) {
+ return this.pos[p];
+ }
+ var prox = 100000;
+ var match = 0;
+ for(var i in this.pos) {
+ var dis = Math.abs(p-i);
+ if (dis < prox) {
+ prox = dis;
+ match = this.pos[i];
+ }
+ }
+ return match;
+
+ }
table.removeChild(tr);
return ret;
},
xoff = xoff || 0;
yoff = yoff || 0;
+
+ var table_data = this.readTableData(datagrid);
+
+ // oroginally this cleaned line breaks, but we acutally need them..
var cleanHTML = function (str) {
- var ret = str;
- ret = ret.replace(/ /g,'.');
- ret = ret.replace(/\n/g,'.');
- ret = ret.replace(/\r/g,'.');
+ var ret = str;
+ ret = ret.replace(/ /g,' ');
+ // ret = ret.replace(/\n/g,'.');
+ // ret = ret.replace(/\r/g,'.');
var i;
- while (-1 != (i = ret.indexOf(unescape('%A0')))) {
- ret = ret.substring(0,i) + ' ' + ret.substring(i+1,str.length);
- }
+
return ret;
};
for(var row=0;row<rows.length;row++) {
- //var style = document.defaultView.getComputedStyle(rows[row], "");
- //if (rows[row].getAttribute('xls:height')) {
- // this.setRowHeight(row+y_offset, 0 + rows[row].getAttribute('xls:height'));
- //} else {
- // this.setRowHeight(row+y_offset, 0 + style.height.replace(/[^0-9.]+/g,''));
- // }
+ // let's see what affect this has..
+ // it might mess things up..
- var coloffset = 0;
-
+ if (rows[row].getAttribute('xls:height')) {
+ this.setRowHeight(row + yoff +1, 1* rows[row].getAttribute('xls:height'));
+ } else {
+ this.setRowHeight( row + yoff +1, Roo.get(rows[row]).getHeight());
+ }
+
+
var cols = rows[row].getElementsByTagName('td');
for(var col=0;col < cols.length; col++) {
- //var colat = col + coloffset;
- var coloffsetadd = 0;
- var merged = false;
+
+
+ var colspan = cols[col].getAttribute('colspan');
+ colspan = colspan ? colspan *1 : 1;
+
+ var rowspan = cols[col].getAttribute('rowspan');
+ rowspan = rowspan ? rowspan * 1 : 1;
+
+ var realcol = table_data.near( Roo.get(cols[col]).getLeft() );
- //var realcol = table_data.pos[ Roo.get(cols[col]).getLeft() ];
- if (cols[col].getAttribute('colspan') && (cols[col].getAttribute('colspan') > 1)) {
+
+ if (colspan > 1 || rowspan > 1) {
- //row + yoff, c : col + xoff + coloffset
+ // getting thisese right is tricky..
this.mergeRegion(
- col + xoff + coloffset,
- row + yoff,
- col + xoff + coloffset + (cols[col].getAttribute('colspan') - 1),
- row + yoff + (
- (cols[col].getAttribute('rowspan') > 1) ?
- (cols[col].getAttribute('rowspan') - 1) : 0
- )
+ realcol + xoff,
+ row + yoff +1,
+ realcol+ xoff + (colspan -1),
+ row + yoff + rowspan
);
- coloffsetadd = (cols[col].getAttribute('colspan') * 1) - 1;
- }
- // if we hit a rowspan
- // then the following rows will skip this column..
-
-
- /*
- var style = this.newStyle();
- if (style.setFrom(cols[col])) {
- style.add(
- colat+x_offset,
- row+y_offset,
-
- colat+x_offset + ((cols[col].getAttribute('colspan') > 1) ?
- (cols[col].getAttribute('colspan') - 1) : 0),
- row+y_offset + ((cols[col].getAttribute('rowspan') > 1) ?
- (cols[col].getAttribute('rowspan') - 1) : 0)
- );
}
- */
// skip blank cells
// set the style first..
- this.parseHtmlStyle( cols[col], row + yoff, col + xoff + coloffset , coloffsetadd);
+ this.parseHtmlStyle( cols[col], row + yoff, realcol + xoff , colspan, rowspan);
if (!cols[col].childNodes.length) {
- coloffset += coloffsetadd;
+
continue;
}
break;
}
- /*
- if (cols[col].getAttribute('xls:src')) {
- //alert(cols[col].childNodes[0].width);
- if (this.writeImage(
- row+y_offset,
- colat+x_offset+coloffset,
- cols[col].getAttribute('xls:src'),
- cols[col].childNodes[0].width,
- cols[col].childNodes[0].height
- )) {
-
- }
- continue;
- }
- */
-
+
if (!cols[col].childNodes[0].nodeValue) {
- coloffset += coloffsetadd;
+
continue;
}
if (!cols[col].childNodes[0].nodeValue.replace(/^\s*|\s*$/g,"").length) {
- coloffset += coloffsetadd;
+
continue;
}
// strip me.!
vt = '';
cell_value_text = s.replace(/#row#/g,(row + yoff + 1));
}
- this.set({ r: row + yoff, c : col + xoff + coloffset }, cell_value_text, vt, vf);
+ this.set({ r: row + yoff, c : realcol + xoff }, cell_value_text, vt, vf);
- coloffset += coloffsetadd;
-
-
-
- parseHtmlStyle : function(dom, row, col, cspan) {
+ parseHtmlStyle : function(dom, row, col, colspan, rowspan) {
function toCol (rgb) {
- var ar = rgb.replace(/rgb\(/, '').replace(/\)/, '').replace(/ /, '').split(',');
+
+ var ar = rgb.replace(/rgb[a]?\(/, '').replace(/\)/, '').replace(/ /, '').split(',');
var rcs = [];
+ ar = ar.slice(0,3);
Roo.each(ar, function(c) {
-
- rcs.push((c*256).toString(16)) ;
+ rcs.push((c*c).toString(16)) ;
});
return rcs.join(':');
'color': function(ent,v) {
ent['Fore'] = toCol(v);
+ // this is a bit dumb.. we assume that if it's not black text, then it's shaded..
+ if (ent['Fore'] != '0:0:0') {
+ ent['Shade'] = 1;
+ }
+
},
'background-color' : function(ent,v) {
ent['Back'] = toCol(v);
-
+
}
}
}
map[k](ent,val);
}
+ // special flags..
+ if (el.dom.getAttribute('xls:wraptext')) {
+ ent.WrapText = 1;
+ }
+ if (el.dom.getAttribute('xls:valign')) {
+ ent.VAlign= 1;
+ }
+ if (el.dom.getAttribute('xls:halign')) {
+ ent.HAlign= 1;
+ }
// fonts..
var fmap = {
'font-size' : function(ent,v) {
- ent['FontUnit'] = v.replace(/px/, '');
+ ent['Unit'] = v.replace(/px/, '');
},
'font-weight' : function(ent,v) {
if (v != 'bold') return;
- ent['FontBold'] = 1;
+ ent['Bold'] = 1;
+ },
+ 'font-style' : function(ent,v) {
+ if (v != 'italic') return;
+ ent['Italic'] = 1;
}
- //FontItalic : function(ent,v) {
- // if (v*0 < 1) return;
- // //ent['font-weight'] = 'bold';
- //},
-
}
var fent = {
fmap[k](fent,val);
}
var font = el.getStyle('font-family') || 'Sans';
-
+ if (font.split(',').length > 1) {
+ font = font.split(',')[1].replace(/\s+/, '');
+ }
/// -- now create elements..
//<gnm:StyleRegion startCol="0" startRow="0" endCol="255" endRow="65535"
var sr = this.doc.createElementNS('http://www.gnumeric.org/v10.dtd', 'gnm:StyleRegion');
objs.appendChild(sr);
+ objs.appendChild(this.doc.createTextNode("\n"));// add a line break..
+
sr.setAttribute('startCol', col);
- sr.setAttribute('endCol', col+coloffsetadd);
+ sr.setAttribute('endCol', col+ colspan-1);
sr.setAttribute('startRow', row);
- sr.setAttribute('endRow', row);
+ sr.setAttribute('endRow', row + rowspan -1);
var st = this.doc.createElementNS('http://www.gnumeric.org/v10.dtd', 'gnm:Style');
sr.appendChild(st);
// do we need some defaults..
for(var k in ent) {
- Roo.log(k);
+ //Roo.log(k);
st.setAttribute(k, ent[k]);
}
st.appendChild(fo);
// do we need some defaults..
for(var k in fent) {
- fo.setAttribute(k, ent[k]);
+ fo.setAttribute(k, fent[k]);
}
fo.textContent = font;
// start adding them all together..
if (sb) {
- st.appendChild(sb)
+ st.appendChild(sb);
}
// step 1 - work out how many columns it will span..
// lets hope the spreadsheet is big enought..
var colwidth = 0;
- var endcol=col
+ var endcol=col;
for ( endcol=col;endcol <100; endcol++) {
if (!this.colInfo[endcol]) {
this.colInfo[endcol] = 100; // eak fudge
// return;
//}
- cell.textContent = this.RCtoCell(row1,col1) + ':' + this.RCtoCell(row2,col2)
+ cell.textContent = this.RCtoCell(row1,col1) + ':' + this.RCtoCell(row2,col2);
//var merges = this.gnumeric.getElementsByTagNameNS('*','MergedRegions');
var merges = this.sheet.getElementsByTagNameNS('*','MergedRegions');
this.sheet.insertBefore(merges,sl);
} else {
merges = merges[0];
- }
+ }
merges.appendChild(cell);
},
//<gmr:Rows DefaultSizePts="12.75">
// <gmr:RowInfo No="2" Unit="38.25" MarginA="0" MarginB="0" HardSize="1"/>
// < /gmr:Rows>
+
+ // this doesnt handle row ranges very well.. - with 'count in them..'
+
+ if (this.rowInfoDom[r]) {
+ this.rowInfoDom[r].setAttribute('Unit', height);
+ return;
+ }
+
var rows = this.sheet.getElementsByTagNameNS('*','Rows')[0]; // assume this exists..
var ri = this.doc.createElementNS('http://www.gnumeric.org/v10.dtd','gnm:RowInfo');
// assume we have no rows..
ri.setAttribute('MarginB', 0);
ri.setAttribute('HardSize', 1);
rows.appendChild(ri);
+ this.rowInfoDom[r] = ri;
},
/**
sheetnames = this.doc.getElementsByTagNameNS('*','Sheet');
sheetnames[0].parentNode.appendChild(sheetnames[sheetnames.length-1].cloneNode(true));
var sn = this.doc.getElementsByTagNameNS('*','Sheet')[sheet];
- var cls = sn.getElementsByTagNameNS('*','Cells')[0]
+ var cls = sn.getElementsByTagNameNS('*','Cells')[0];
while (cls.childNodes.length) {
cls.removeChild(cls.firstChild);
}
for (var r = 0; r < this.rmax;r++) {
out += '<tr style="height:'+this.rowInfo[r]+'px;">';
for (var c = 0; c < this.cmax;c++) {
- var g = (typeof(grid[r][c]) == 'undefined') ? defaultCell : grid[r][c];
+ if (typeof(grid[r][c]) == 'undefined') {
+ this.createCell(r,c);
+
+ }
+ var g = grid[r][c];
if (typeof(g.cls) =='undefined') g.cls = [];
var w= calcWidth(c,g.colspan);
var ser = new XMLSerializer();
var x = new Pman.Download({
method: 'POST',
+ timeout : 120000, // quite a long wait.. 2 minutes.
params : {
xml : ser.serializeToString(this.doc),
format : 'xls', //xml