From b6fd433a42cbb296409e52460f3f0a9614a7a8eb Mon Sep 17 00:00:00 2001 From: Matt Andrews <matt.andrews@biglotteryfund.org.uk> Date: Tue, 3 Jul 2018 13:04:15 +0100 Subject: [PATCH] json_to_sheet cell objects Fixes #1168, #1169 --- bits/90_utils.js | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/bits/90_utils.js b/bits/90_utils.js index b906e7c..03a4368 100644 --- a/bits/90_utils.js +++ b/bits/90_utils.js @@ -196,16 +196,20 @@ function sheet_add_json(_ws/*:?Worksheet*/, js/*:Array<any>*/, opts)/*:Worksheet var v = JS[k]; var t = 'z'; var z = ""; - if(typeof v == 'number') t = 'n'; - else if(typeof v == 'boolean') t = 'b'; - else if(typeof v == 'string') t = 's'; - else if(v instanceof Date) { - t = 'd'; - if(!o.cellDates) { t = 'n'; v = datenum(v); } - z = o.dateNF || SSF._table[14]; + if(v && typeof v === 'object' && !(v instanceof Date)){ + ws[encode_cell({c:_C + C,r:_R + R + offset})] = v; + } else { + if(typeof v == 'number') t = 'n'; + else if(typeof v == 'boolean') t = 'b'; + else if(typeof v == 'string') t = 's'; + else if(v instanceof Date) { + t = 'd'; + if(!o.cellDates) { t = 'n'; v = datenum(v); } + z = o.dateNF || SSF._table[14]; + } + ws[encode_cell({c:_C + C,r:_R + R + offset})] = cell = ({t:t, v:v}/*:any*/); + if(z) cell.z = z; } - ws[encode_cell({c:_C + C,r:_R + R + offset})] = cell = ({t:t, v:v}/*:any*/); - if(z) cell.z = z; }); }); range.e.c = Math.max(range.e.c, _C + hdr.length - 1);