forked from sheetjs/sheetjs
		
	
		
			
	
	
		
			152 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			152 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 
								 | 
							
								RELS.XLMETA = "http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata";
							 | 
						||
| 
								 | 
							
								function parse_xlmeta_xml(data, name, opts) {
							 | 
						||
| 
								 | 
							
								  var out = { Types: [] };
							 | 
						||
| 
								 | 
							
								  if (!data)
							 | 
						||
| 
								 | 
							
								    return out;
							 | 
						||
| 
								 | 
							
								  var pass = false;
							 | 
						||
| 
								 | 
							
								  data.replace(tagregex, function(x, idx) {
							 | 
						||
| 
								 | 
							
								    var y = parsexmltag(x);
							 | 
						||
| 
								 | 
							
								    switch (strip_ns(y[0])) {
							 | 
						||
| 
								 | 
							
								      case "<?xml":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<metadata":
							 | 
						||
| 
								 | 
							
								      case "</metadata>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<metadataTypes":
							 | 
						||
| 
								 | 
							
								      case "</metadataTypes>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<metadataType":
							 | 
						||
| 
								 | 
							
								        out.Types.push({ name: y.name });
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<futureMetadata":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "</futureMetadata>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<bk>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "</bk>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<rc":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "</rc>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<cellMetadata":
							 | 
						||
| 
								 | 
							
								      case "</cellMetadata>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<valueMetadata":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "</valueMetadata>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<extLst":
							 | 
						||
| 
								 | 
							
								      case "<extLst>":
							 | 
						||
| 
								 | 
							
								      case "</extLst>":
							 | 
						||
| 
								 | 
							
								      case "<extLst/>":
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "<ext":
							 | 
						||
| 
								 | 
							
								        pass = true;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case "</ext>":
							 | 
						||
| 
								 | 
							
								        pass = false;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      default:
							 | 
						||
| 
								 | 
							
								        if (!pass && opts.WTF)
							 | 
						||
| 
								 | 
							
								          throw new Error("unrecognized " + y[0] + " in metadata");
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    return x;
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								  return out;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function write_xlmeta_xml() {
							 | 
						||
| 
								 | 
							
								  var o = [XML_HEADER];
							 | 
						||
| 
								 | 
							
								  o.push('<metadata xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:xlrd="http://schemas.microsoft.com/office/spreadsheetml/2017/richdata" xmlns:xda="http://schemas.microsoft.com/office/spreadsheetml/2017/dynamicarray">\n  <metadataTypes count="1">\n    <metadataType name="XLDAPR" minSupportedVersion="120000" copy="1" pasteAll="1" pasteValues="1" merge="1" splitFirst="1" rowColShift="1" clearFormats="1" clearComments="1" assign="1" coerce="1" cellMeta="1"/>\n  </metadataTypes>\n  <futureMetadata name="XLDAPR" count="1">\n    <bk>\n      <extLst>\n        <ext uri="{bdbb8cdc-fa1e-496e-a857-3c3f30c029c3}">\n          <xda:dynamicArrayProperties fDynamic="1" fCollapsed="0"/>\n        </ext>\n      </extLst>\n    </bk>\n  </futureMetadata>\n  <cellMetadata count="1">\n    <bk>\n      <rc t="1" v="0"/>\n    </bk>\n  </cellMetadata>\n</metadata>');
							 | 
						||
| 
								 | 
							
								  return o.join("");
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function parse_BrtMdtinfo(data, length) {
							 | 
						||
| 
								 | 
							
								  return {
							 | 
						||
| 
								 | 
							
								    flags: data.read_shift(4),
							 | 
						||
| 
								 | 
							
								    version: data.read_shift(4),
							 | 
						||
| 
								 | 
							
								    name: parse_XLWideString(data, length - 8)
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function write_BrtMdtinfo(data) {
							 | 
						||
| 
								 | 
							
								  var o = new_buf(12 + 2 * data.name.length);
							 | 
						||
| 
								 | 
							
								  o.write_shift(4, data.flags);
							 | 
						||
| 
								 | 
							
								  o.write_shift(4, data.version);
							 | 
						||
| 
								 | 
							
								  write_XLWideString(data.name, o);
							 | 
						||
| 
								 | 
							
								  return o.slice(0, o.l);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function write_BrtMdb(mdb) {
							 | 
						||
| 
								 | 
							
								  var o = new_buf(4 + 8 * mdb.length);
							 | 
						||
| 
								 | 
							
								  o.write_shift(4, mdb.length);
							 | 
						||
| 
								 | 
							
								  for (var i = 0; i < mdb.length; ++i) {
							 | 
						||
| 
								 | 
							
								    o.write_shift(4, mdb[i][0]);
							 | 
						||
| 
								 | 
							
								    o.write_shift(4, mdb[i][1]);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								  return o;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function write_BrtBeginEsfmd(cnt, name) {
							 | 
						||
| 
								 | 
							
								  var o = new_buf(8 + 2 * name.length);
							 | 
						||
| 
								 | 
							
								  o.write_shift(4, cnt);
							 | 
						||
| 
								 | 
							
								  write_XLWideString(name, o);
							 | 
						||
| 
								 | 
							
								  return o.slice(0, o.l);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function write_BrtBeginEsmdb(cnt, cm) {
							 | 
						||
| 
								 | 
							
								  var o = new_buf(8);
							 | 
						||
| 
								 | 
							
								  o.write_shift(4, cnt);
							 | 
						||
| 
								 | 
							
								  o.write_shift(4, cm ? 1 : 0);
							 | 
						||
| 
								 | 
							
								  return o;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function parse_xlmeta_bin(data, name, _opts) {
							 | 
						||
| 
								 | 
							
								  var out = { Types: [] };
							 | 
						||
| 
								 | 
							
								  var opts = _opts || {};
							 | 
						||
| 
								 | 
							
								  var state = [];
							 | 
						||
| 
								 | 
							
								  var pass = false;
							 | 
						||
| 
								 | 
							
								  recordhopper(data, function(val, R_n, RT) {
							 | 
						||
| 
								 | 
							
								    switch (RT) {
							 | 
						||
| 
								 | 
							
								      case 335:
							 | 
						||
| 
								 | 
							
								        out.Types.push({ name: val.name });
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case 51:
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case 35:
							 | 
						||
| 
								 | 
							
								        state.push(R_n);
							 | 
						||
| 
								 | 
							
								        pass = true;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      case 36:
							 | 
						||
| 
								 | 
							
								        state.pop();
							 | 
						||
| 
								 | 
							
								        pass = false;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								      default:
							 | 
						||
| 
								 | 
							
								        if ((R_n || "").indexOf("Begin") > 0) {
							 | 
						||
| 
								 | 
							
								        } else if ((R_n || "").indexOf("End") > 0) {
							 | 
						||
| 
								 | 
							
								        } else if (!pass || opts.WTF && state[state.length - 1] != "BrtFRTBegin")
							 | 
						||
| 
								 | 
							
								          throw new Error("Unexpected record " + RT + " " + R_n);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								  return out;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								function write_xlmeta_bin() {
							 | 
						||
| 
								 | 
							
								  var ba = buf_array();
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtBeginMetadata");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtBeginEsmdtinfo", write_UInt32LE(1));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtMdtinfo", write_BrtMdtinfo({
							 | 
						||
| 
								 | 
							
								    name: "XLDAPR",
							 | 
						||
| 
								 | 
							
								    version: 12e4,
							 | 
						||
| 
								 | 
							
								    flags: 3496657072
							 | 
						||
| 
								 | 
							
								  }));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtEndEsmdtinfo");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtBeginEsfmd", write_BrtBeginEsfmd(1, "XLDAPR"));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtBeginFmd");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtFRTBegin", write_UInt32LE(514));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtBeginDynamicArrayPr", write_UInt32LE(0));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtEndDynamicArrayPr", writeuint16(1));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtFRTEnd");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtEndFmd");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtEndEsfmd");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtBeginEsmdb", write_BrtBeginEsmdb(1, true));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtMdb", write_BrtMdb([[1, 0]]));
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtEndEsmdb");
							 | 
						||
| 
								 | 
							
								  write_record(ba, "BrtEndMetadata");
							 | 
						||
| 
								 | 
							
								  return ba.end();
							 | 
						||
| 
								 | 
							
								}
							 |