forked from sheetjs/sheetjs
		
	- opts.sheetRows limits parsing; default (0) parses all rows - added -n mode to xlsx2csv to control number of rows - !ref will be adjusted; !fullref holds full range
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/* 18.7.3 CT_Comment */
 | 
						|
function parse_comments_xml(data, opts) {
 | 
						|
	if(data.match(/<comments *\/>/)) return [];
 | 
						|
	var authors = [];
 | 
						|
	var commentList = [];
 | 
						|
	data.match(/<authors>([^\u2603]*)<\/authors>/m)[1].split('</author>').forEach(function(x) {
 | 
						|
		if(x === "" || x.trim() === "") return;
 | 
						|
		authors.push(x.match(/<author[^>]*>(.*)/)[1]);
 | 
						|
	});
 | 
						|
	data.match(/<commentList>([^\u2603]*)<\/commentList>/m)[1].split('</comment>').forEach(function(x, index) {
 | 
						|
		if(x === "" || x.trim() === "") return;
 | 
						|
		var y = parsexmltag(x.match(/<comment[^>]*>/)[0]);
 | 
						|
		var comment = { author: y.authorId && authors[y.authorId] ? authors[y.authorId] : undefined, ref: y.ref, guid: y.guid };
 | 
						|
		var cell = decode_cell(y.ref);
 | 
						|
		if(opts.sheetRows && opts.sheetRows <= cell.r) return;
 | 
						|
		var textMatch = x.match(/<text>([^\u2603]*)<\/text>/m);
 | 
						|
		if (!textMatch || !textMatch[1]) return; // a comment may contain an empty text tag.
 | 
						|
		var rt = parse_si(textMatch[1]);
 | 
						|
		comment.r = rt.r;
 | 
						|
		comment.t = rt.t;
 | 
						|
		if(opts.cellHTML) comment.h = rt.h;
 | 
						|
		commentList.push(comment);
 | 
						|
	});
 | 
						|
	return commentList;
 | 
						|
}
 | 
						|
 | 
						|
function parse_comments(zip, dirComments, sheets, sheetRels, opts) {
 | 
						|
	for(var i = 0; i != dirComments.length; ++i) {
 | 
						|
		var canonicalpath=dirComments[i];
 | 
						|
		var comments=parse_comments_xml(getzipdata(zip, canonicalpath.replace(/^\//,''), true), opts);
 | 
						|
		if(!comments || !comments.length) continue;
 | 
						|
		// find the sheets targeted by these comments
 | 
						|
		var sheetNames = Object.keys(sheets);
 | 
						|
		for(var j = 0; j != sheetNames.length; ++j) {
 | 
						|
			var sheetName = sheetNames[j];
 | 
						|
			var rels = sheetRels[sheetName];
 | 
						|
			if(rels) {
 | 
						|
				var rel = rels[canonicalpath];
 | 
						|
				if(rel) insertCommentsIntoSheet(sheetName, sheets[sheetName], comments);
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
function insertCommentsIntoSheet(sheetName, sheet, comments) {
 | 
						|
	comments.forEach(function(comment) {
 | 
						|
		var cell = sheet[comment.ref];
 | 
						|
		if (!cell) {
 | 
						|
			cell = {};
 | 
						|
			sheet[comment.ref] = cell;
 | 
						|
			var range = decode_range(sheet["!ref"]);
 | 
						|
			var thisCell = decode_cell(comment.ref);
 | 
						|
			if(range.s.r > thisCell.r) range.s.r = thisCell.r;
 | 
						|
			if(range.e.r < thisCell.r) range.e.r = thisCell.r;
 | 
						|
			if(range.s.c > thisCell.c) range.s.c = thisCell.c;
 | 
						|
			if(range.e.c < thisCell.c) range.e.c = thisCell.c;
 | 
						|
			var encoded = encode_range(range);
 | 
						|
			if (encoded !== sheet["!ref"]) sheet["!ref"] = encoded;
 | 
						|
		}
 | 
						|
 | 
						|
		if (!cell.c) cell.c = [];
 | 
						|
		var o = {a: comment.author, t: comment.t, r: comment.r};
 | 
						|
		if(comment.h) o.h = comment.h;
 | 
						|
		cell.c.push(o);
 | 
						|
	});
 | 
						|
}
 | 
						|
 |