forked from sheetjs/sheetjs
		
	- option bookFiles controls whether zip files and keys are written to object *** Default has been flipped from "true" to "false" - updated SSF to 0.5.8 - updated test_files to 20140216 (tests also look at 2013 XLSB) - added dist files (make dist)
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| function parse_BrtFmt(data, length) {
 | |
| 	var ifmt = data.read_shift(2);
 | |
| 	var stFmtCode = parse_XLWideString(data,length-2);
 | |
| 	return [ifmt, stFmtCode];
 | |
| }
 | |
| 
 | |
| function parse_BrtXF(data, length) {
 | |
| 	var ixfeParent = data.read_shift(2);
 | |
| 	var ifmt = data.read_shift(2);
 | |
| 	parsenoop(data, length-4);
 | |
| 	return {ixfe:ixfeParent, ifmt:ifmt };
 | |
| }
 | |
| 
 | |
| function parse_sty_bin(data) {
 | |
| 	styles.NumberFmt = [];
 | |
| 	for(var y in SSF._table) styles.NumberFmt[y] = SSF._table[y];
 | |
| 
 | |
| 	styles.CellXf = [];
 | |
| 	var state = ""; /* TODO: this should be a stack */
 | |
| 	var pass = false;
 | |
| 	recordhopper(data, function(val, R, RT) {
 | |
| 		switch(R.n) {
 | |
| 			case 'BrtFmt':
 | |
| 				styles.NumberFmt[val[0]] = val[1]; SSF.load(val[1], val[0]);
 | |
| 				break;
 | |
| 			case 'BrtFont': break; /* TODO */
 | |
| 			case 'BrtKnownFonts': break; /* TODO */
 | |
| 			case 'BrtFill': break; /* TODO */
 | |
| 			case 'BrtBorder': break; /* TODO */
 | |
| 			case 'BrtXF':
 | |
| 				if(state === "CELLXFS") {
 | |
| 					styles.CellXf.push(val);
 | |
| 				}
 | |
| 				break; /* TODO */
 | |
| 			case 'BrtStyle': break; /* TODO */
 | |
| 			case 'BrtRowHdr': break; /* TODO */
 | |
| 			case 'BrtCellMeta': break; /* ?? */
 | |
| 			case 'BrtDXF': break; /* TODO */
 | |
| 			case 'BrtMRUColor': break; /* TODO */
 | |
| 			case 'BrtIndexedColor': break; /* TODO */
 | |
| 			case 'BrtBeginStyleSheet': break;
 | |
| 			case 'BrtEndStyleSheet': break;
 | |
| 			case 'BrtBeginTableStyle': break;
 | |
| 			case 'BrtTableStyleElement': break;
 | |
| 			case 'BrtEndTableStyle': break;
 | |
| 			case 'BrtBeginFmts': state = "FMTS"; break;
 | |
| 			case 'BrtEndFmts': state = ""; break;
 | |
| 			case 'BrtBeginFonts': state = "FONTS"; break;
 | |
| 			case 'BrtEndFonts': state = ""; break;
 | |
| 			case 'BrtACBegin': state = "ACFONTS"; break;
 | |
| 			case 'BrtACEnd': state = ""; break;
 | |
| 			case 'BrtBeginFills': state = "FILLS"; break;
 | |
| 			case 'BrtEndFills': state = ""; break;
 | |
| 			case 'BrtBeginBorders': state = "BORDERS"; break;
 | |
| 			case 'BrtEndBorders': state = ""; break;
 | |
| 			case 'BrtBeginCellStyleXFs': state = "CELLSTYLEXFS"; break;
 | |
| 			case 'BrtEndCellStyleXFs': state = ""; break;
 | |
| 			case 'BrtBeginCellXFs': state = "CELLXFS"; break;
 | |
| 			case 'BrtEndCellXFs': state = ""; break;
 | |
| 			case 'BrtBeginStyles': state = "STYLES"; break;
 | |
| 			case 'BrtEndStyles': state = ""; break;
 | |
| 			case 'BrtBeginDXFs': state = "DXFS"; break;
 | |
| 			case 'BrtEndDXFs': state = ""; break;
 | |
| 			case 'BrtBeginTableStyles': state = "TABLESTYLES"; break;
 | |
| 			case 'BrtEndTableStyles': state = ""; break;
 | |
| 			case 'BrtBeginColorPalette': state = "COLORPALETTE"; break;
 | |
| 			case 'BrtBeginIndexedColors': state = "INDEXEDCOLORS"; break;
 | |
| 			case 'BrtEndIndexedColors': state = ""; break;
 | |
| 			case 'BrtBeginMRUColors': state = "MRUCOLORS"; break;
 | |
| 			case 'BrtEndMRUColors': state = ""; break;
 | |
| 			case 'BrtEndColorPalette': state = ""; break;
 | |
| 			case 'BrtFRTBegin': pass = true; break;
 | |
| 			case 'BrtFRTEnd': pass = false; break;
 | |
| 			//default: if(!pass) throw new Error("Unexpected record " + RT + " " + R.n);
 | |
| 		}
 | |
| 	});
 | |
| 	return styles;
 | |
| }
 |