var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; import { createEnum } from './helpers'; import { readSignature, readUnicodeString, readUint32, readUint8, readFloat64, readBytes, readAsciiString, readInt32, readFloat32, readInt32LE, readUnicodeStringWithLength } from './psdReader'; import { writeSignature, writeBytes, writeUint32, writeFloat64, writeUint8, writeUnicodeStringWithPadding, writeInt32, writeFloat32, writeUnicodeString } from './psdWriter'; function revMap(map) { var result = {}; Object.keys(map).forEach(function (key) { return result[map[key]] = key; }); return result; } var unitsMap = { '#Ang': 'Angle', '#Rsl': 'Density', '#Rlt': 'Distance', '#Nne': 'None', '#Prc': 'Percent', '#Pxl': 'Pixels', '#Mlm': 'Millimeters', '#Pnt': 'Points', 'RrPi': 'Picas', 'RrIn': 'Inches', 'RrCm': 'Centimeters', }; var unitsMapRev = revMap(unitsMap); var logErrors = false; export function setLogErrors(value) { logErrors = value; } function makeType(name, classID) { return { name: name, classID: classID }; } var nullType = makeType('', 'null'); var fieldToExtType = { strokeStyleContent: makeType('', 'solidColorLayer'), // printProofSetup: makeType('校样设置', 'proofSetup'), // TESTING printProofSetup: makeType('Proof Setup', 'proofSetup'), patternFill: makeType('', 'patternFill'), Grad: makeType('Gradient', 'Grdn'), ebbl: makeType('', 'ebbl'), SoFi: makeType('', 'SoFi'), GrFl: makeType('', 'GrFl'), sdwC: makeType('', 'RGBC'), hglC: makeType('', 'RGBC'), 'Clr ': makeType('', 'RGBC'), 'tintColor': makeType('', 'RGBC'), Ofst: makeType('', 'Pnt '), ChFX: makeType('', 'ChFX'), MpgS: makeType('', 'ShpC'), DrSh: makeType('', 'DrSh'), IrSh: makeType('', 'IrSh'), OrGl: makeType('', 'OrGl'), IrGl: makeType('', 'IrGl'), TrnS: makeType('', 'ShpC'), Ptrn: makeType('', 'Ptrn'), FrFX: makeType('', 'FrFX'), phase: makeType('', 'Pnt '), frameStep: nullType, duration: nullType, workInTime: nullType, workOutTime: nullType, audioClipGroupList: nullType, bounds: makeType('', 'Rctn'), customEnvelopeWarp: makeType('', 'customEnvelopeWarp'), warp: makeType('', 'warp'), 'Sz ': makeType('', 'Pnt '), origin: makeType('', 'Pnt '), autoExpandOffset: makeType('', 'Pnt '), keyOriginShapeBBox: makeType('', 'unitRect'), Vrsn: nullType, psVersion: nullType, docDefaultNewArtboardBackgroundColor: makeType('', 'RGBC'), artboardRect: makeType('', 'classFloatRect'), keyOriginRRectRadii: makeType('', 'radii'), keyOriginBoxCorners: nullType, rectangleCornerA: makeType('', 'Pnt '), rectangleCornerB: makeType('', 'Pnt '), rectangleCornerC: makeType('', 'Pnt '), rectangleCornerD: makeType('', 'Pnt '), compInfo: nullType, Trnf: makeType('Transform', 'Trnf'), quiltWarp: makeType('', 'quiltWarp'), generatorSettings: nullType, crema: nullType, FrIn: nullType, blendOptions: nullType, FXRf: nullType, Lefx: nullType, time: nullType, animKey: nullType, timeScope: nullType, inTime: nullType, outTime: nullType, sheetStyle: nullType, translation: nullType, Skew: nullType, 'Lnk ': makeType('', 'ExternalFileLink'), frameReader: makeType('', 'FrameReader'), effectParams: makeType('', 'motionTrackEffectParams'), Impr: makeType('None', 'none'), Anch: makeType('', 'Pnt '), 'Fwd ': makeType('', 'Pnt '), 'Bwd ': makeType('', 'Pnt '), meshBoundaryPath: makeType('', 'pathClass'), filterFX: makeType('', 'filterFXStyle'), Fltr: makeType('', 'rigidTransform'), FrgC: makeType('', 'RGBC'), BckC: makeType('', 'RGBC'), }; var fieldToArrayExtType = { 'Crv ': makeType('', 'CrPt'), Clrs: makeType('', 'Clrt'), Trns: makeType('', 'TrnS'), keyDescriptorList: nullType, solidFillMulti: makeType('', 'SoFi'), gradientFillMulti: makeType('', 'GrFl'), dropShadowMulti: makeType('', 'DrSh'), innerShadowMulti: makeType('', 'IrSh'), frameFXMulti: makeType('', 'FrFX'), FrIn: nullType, FSts: nullType, LaSt: nullType, sheetTimelineOptions: nullType, trackList: makeType('', 'animationTrack'), globalTrackList: makeType('', 'animationTrack'), keyList: nullType, audioClipGroupList: nullType, audioClipList: nullType, countObjectList: makeType('', 'countObject'), countGroupList: makeType('', 'countGroup'), slices: makeType('', 'slice'), 'Pts ': makeType('', 'Pthp'), SbpL: makeType('', 'SbpL'), pathComponents: makeType('', 'PaCm'), filterFXList: makeType('', 'filterFX'), puppetShapeList: makeType('', 'puppetShape'), }; var typeToField = { 'TEXT': [ 'Txt ', 'printerName', 'Nm ', 'Idnt', 'blackAndWhitePresetFileName', 'LUT3DFileName', 'presetFileName', 'curvesPresetFileName', 'mixerPresetFileName', 'placed', 'description', 'reason', 'artboardPresetName', 'json', 'clipID', 'relPath', 'fullPath', 'mediaDescriptor', 'Msge', 'altTag', 'url', 'cellText', ], 'tdta': ['EngineData', 'LUT3DFileData', 'indexArray', 'originalVertexArray', 'deformedVertexArray'], 'long': [ 'TextIndex', 'RndS', 'Mdpn', 'Smth', 'Lctn', 'strokeStyleVersion', 'LaID', 'Vrsn', 'Cnt ', 'Brgh', 'Cntr', 'means', 'vibrance', 'Strt', 'bwPresetKind', 'presetKind', 'comp', 'compID', 'originalCompID', 'curvesPresetKind', 'mixerPresetKind', 'uOrder', 'vOrder', 'PgNm', 'totalPages', 'Crop', 'numerator', 'denominator', 'frameCount', 'Annt', 'keyOriginType', 'unitValueQuadVersion', 'keyOriginIndex', 'major', 'minor', 'fix', 'docDefaultNewArtboardBackgroundType', 'artboardBackgroundType', 'numModifyingFX', 'deformNumRows', 'deformNumCols', 'FrID', 'FrDl', 'FsID', 'LCnt', 'AFrm', 'AFSt', 'numBefore', 'numAfter', 'Spcn', 'minOpacity', 'maxOpacity', 'BlnM', 'sheetID', 'gblA', 'globalAltitude', 'descVersion', 'frameReaderType', 'LyrI', 'zoomOrigin', 'fontSize', 'Rds ', 'sliceID', 'topOutset', 'leftOutset', 'bottomOutset', 'rightOutset', 'filterID', 'meshQuality', 'meshExpansion', 'meshRigidity', 'VrsM', 'VrsN', ], 'enum': [ 'textGridding', 'Ornt', 'warpStyle', 'warpRotate', 'Inte', 'Bltn', 'ClrS', 'sdwM', 'hglM', 'bvlT', 'bvlS', 'bvlD', 'Md ', 'glwS', 'GrdF', 'GlwT', 'strokeStyleLineCapType', 'strokeStyleLineJoinType', 'strokeStyleLineAlignment', 'strokeStyleBlendMode', 'PntT', 'Styl', 'lookupType', 'LUTFormat', 'dataOrder', 'tableOrder', 'enableCompCore', 'enableCompCoreGPU', 'compCoreSupport', 'compCoreGPUSupport', 'Engn', 'enableCompCoreThreads', 'gs99', 'FrDs', 'trackID', 'animInterpStyle', 'horzAlign', 'vertAlign', 'bgColorType', 'shapeOperation', ], 'bool': [ 'PstS', 'printSixteenBit', 'masterFXSwitch', 'enab', 'uglg', 'antialiasGloss', 'useShape', 'useTexture', 'uglg', 'antialiasGloss', 'useShape', 'Vsbl', 'useTexture', 'Algn', 'Rvrs', 'Dthr', 'Invr', 'VctC', 'ShTr', 'layerConceals', 'strokeEnabled', 'fillEnabled', 'strokeStyleScaleLock', 'strokeStyleStrokeAdjust', 'hardProof', 'MpBl', 'paperWhite', 'useLegacy', 'Auto', 'Lab ', 'useTint', 'keyShapeInvalidated', 'autoExpandEnabled', 'autoNestEnabled', 'autoPositionEnabled', 'shrinkwrapOnSaveEnabled', 'present', 'showInDialog', 'overprint', 'sheetDisclosed', 'lightsDisclosed', 'meshesDisclosed', 'materialsDisclosed', 'hasMotion', 'muted', 'Effc', 'selected', 'autoScope', 'fillCanvas', 'cellTextIsHTML', 'Smoo', 'Clsp', 'validAtPosition', 'rigidType', 'hasoptions', 'filterMaskEnable', 'filterMaskLinked', 'filterMaskExtendWithWhite', ], 'doub': [ 'warpValue', 'warpPerspective', 'warpPerspectiveOther', 'Intr', 'Wdth', 'Hght', 'strokeStyleMiterLimit', 'strokeStyleResolution', 'layerTime', 'keyOriginResolution', 'xx', 'xy', 'yx', 'yy', 'tx', 'ty', 'FrGA', 'frameRate', 'audioLevel', 'rotation', 'X ', 'Y ', 'redFloat', 'greenFloat', 'blueFloat', 'imageResolution', 'PuX0', 'PuX1', 'PuX2', 'PuX3', 'PuY0', 'PuY1', 'PuY2', 'PuY3' ], 'UntF': [ 'Scl ', 'sdwO', 'hglO', 'lagl', 'Lald', 'srgR', 'blur', 'Sftn', 'Opct', 'Dstn', 'Angl', 'Ckmt', 'Nose', 'Inpr', 'ShdN', 'strokeStyleLineWidth', 'strokeStyleLineDashOffset', 'strokeStyleOpacity', 'H ', 'Top ', 'Left', 'Btom', 'Rght', 'Rslt', 'topRight', 'topLeft', 'bottomLeft', 'bottomRight', ], 'VlLs': [ 'Crv ', 'Clrs', 'Mnm ', 'Mxm ', 'Trns', 'pathList', 'strokeStyleLineDashSet', 'FrLs', 'slices', 'LaSt', 'Trnf', 'nonAffineTransform', 'keyDescriptorList', 'guideIndeces', 'gradientFillMulti', 'solidFillMulti', 'frameFXMulti', 'innerShadowMulti', 'dropShadowMulti', 'FrIn', 'FSts', 'FsFr', 'sheetTimelineOptions', 'audioClipList', 'trackList', 'globalTrackList', 'keyList', 'audioClipList', 'warpValues', 'selectedPin', 'Pts ', 'SbpL', 'pathComponents', 'pinOffsets', 'posFinalPins', 'pinVertexIndices', 'PinP', 'PnRt', 'PnOv', 'PnDp', 'filterFXList', 'puppetShapeList', ], 'ObAr': ['meshPoints', 'quiltSliceX', 'quiltSliceY'], 'obj ': ['null'], }; var channels = [ 'Rd ', 'Grn ', 'Bl ', 'Yllw', 'Ylw ', 'Cyn ', 'Mgnt', 'Blck', 'Gry ', 'Lmnc', 'A ', 'B ', ]; var fieldToArrayType = { 'Mnm ': 'long', 'Mxm ': 'long', FrLs: 'long', strokeStyleLineDashSet: 'UntF', Trnf: 'doub', nonAffineTransform: 'doub', keyDescriptorList: 'Objc', gradientFillMulti: 'Objc', solidFillMulti: 'Objc', frameFXMulti: 'Objc', innerShadowMulti: 'Objc', dropShadowMulti: 'Objc', LaSt: 'Objc', FrIn: 'Objc', FSts: 'Objc', FsFr: 'long', blendOptions: 'Objc', sheetTimelineOptions: 'Objc', keyList: 'Objc', warpValues: 'doub', selectedPin: 'long', 'Pts ': 'Objc', SbpL: 'Objc', pathComponents: 'Objc', pinOffsets: 'doub', posFinalPins: 'doub', pinVertexIndices: 'long', PinP: 'doub', PnRt: 'long', PnOv: 'bool', PnDp: 'doub', filterFXList: 'Objc', puppetShapeList: 'Objc', }; var fieldToType = {}; for (var _i = 0, _a = Object.keys(typeToField); _i < _a.length; _i++) { var type = _a[_i]; for (var _b = 0, _c = typeToField[type]; _b < _c.length; _b++) { var field = _c[_b]; fieldToType[field] = type; } } for (var _d = 0, _e = Object.keys(fieldToExtType); _d < _e.length; _d++) { var field = _e[_d]; if (!fieldToType[field]) fieldToType[field] = 'Objc'; } for (var _f = 0, _g = Object.keys(fieldToArrayExtType); _f < _g.length; _f++) { var field = _g[_f]; fieldToArrayType[field] = 'Objc'; } function getTypeByKey(key, value, root, parent) { if (key === 'null' && root === 'slices') { return 'TEXT'; } else if (key === 'groupID') { return root === 'slices' ? 'long' : 'TEXT'; } else if (key === 'Sz ') { return ('Wdth' in value) ? 'Objc' : (('units' in value) ? 'UntF' : 'doub'); } else if (key === 'Type') { return typeof value === 'string' ? 'enum' : 'long'; } else if (key === 'AntA') { return typeof value === 'string' ? 'enum' : 'bool'; } else if ((key === 'Hrzn' || key === 'Vrtc') && parent.Type === 'keyType.Pstn') { return 'long'; } else if (key === 'Hrzn' || key === 'Vrtc' || key === 'Top ' || key === 'Left' || key === 'Btom' || key === 'Rght') { if (root === 'slices') return 'long'; return typeof value === 'number' ? 'doub' : 'UntF'; } else if (key === 'Vrsn') { return typeof value === 'number' ? 'long' : 'Objc'; } else if (key === 'Rd ' || key === 'Grn ' || key === 'Bl ') { return root === 'artd' ? 'long' : 'doub'; } else if (key === 'Trnf') { return Array.isArray(value) ? 'VlLs' : 'Objc'; } else { return fieldToType[key]; } } export function readAsciiStringOrClassId(reader) { var length = readInt32(reader); return readAsciiString(reader, length || 4); } function writeAsciiStringOrClassId(writer, value) { if (value.length === 4 && value !== 'warp' && value !== 'time' && value !== 'hold') { // write classId writeInt32(writer, 0); writeSignature(writer, value); } else { // write ascii string writeInt32(writer, value.length); for (var i = 0; i < value.length; i++) { writeUint8(writer, value.charCodeAt(i)); } } } export function readDescriptorStructure(reader) { var object = {}; // object.__struct = readClassStructure(reader); var itemsCount = readUint32(reader); // console.log('//', object.__struct); for (var i = 0; i < itemsCount; i++) { var key = readAsciiStringOrClassId(reader); var type = readSignature(reader); // console.log(`> '${key}' '${type}'`); var data = readOSType(reader, type); // if (!getTypeByKey(key, data)) console.log(`> '${key}' '${type}'`, data); object[key] = data; } return object; } export function writeDescriptorStructure(writer, name, classId, value, root) { if (logErrors && !classId) console.log('Missing classId for: ', name, classId, value); // write class structure writeUnicodeStringWithPadding(writer, name); writeAsciiStringOrClassId(writer, classId); var keys = Object.keys(value); writeUint32(writer, keys.length); for (var _i = 0, keys_1 = keys; _i < keys_1.length; _i++) { var key = keys_1[_i]; var type = getTypeByKey(key, value[key], root, value); var extType = fieldToExtType[key]; if (key === 'origin') { type = root === 'slices' ? 'enum' : 'Objc'; } else if (key === 'bounds' && root === 'slices') { type = 'Objc'; extType = makeType('', 'Rct1'); } else if (key === 'Scl ' && 'Hrzn' in value[key]) { type = 'Objc'; extType = nullType; } else if (key === 'audioClipGroupList' && keys.length === 1) { type = 'VlLs'; } else if ((key === 'Strt' || key === 'Brgh') && 'H ' in value) { type = 'doub'; } else if (key === 'Strt') { type = 'Objc'; extType = nullType; } else if (channels.indexOf(key) !== -1) { type = (classId === 'RGBC' && root !== 'artd') ? 'doub' : 'long'; } else if (key === 'profile') { type = classId === 'printOutput' ? 'TEXT' : 'tdta'; } else if (key === 'strokeStyleContent') { if (value[key]['Clr ']) { extType = makeType('', 'solidColorLayer'); } else if (value[key].Grad) { extType = makeType('', 'gradientLayer'); } else if (value[key].Ptrn) { extType = makeType('', 'patternLayer'); } else { logErrors && console.log('Invalid strokeStyleContent value', value[key]); } } else if (key === 'bounds' && root === 'quiltWarp') { extType = makeType('', 'classFloatRect'); } if (extType && extType.classID === 'RGBC') { if ('H ' in value[key]) extType = { classID: 'HSBC', name: '' }; // TODO: other color spaces } writeAsciiStringOrClassId(writer, key); writeSignature(writer, type || 'long'); writeOSType(writer, type || 'long', value[key], key, extType, root); if (logErrors && !type) console.log("Missing descriptor field type for: '".concat(key, "' in"), value); } } function readOSType(reader, type) { switch (type) { case 'obj ': // Reference return readReferenceStructure(reader); case 'Objc': // Descriptor case 'GlbO': // GlobalObject same as Descriptor return readDescriptorStructure(reader); case 'VlLs': { // List var length_1 = readInt32(reader); var items = []; for (var i = 0; i < length_1; i++) { var type_1 = readSignature(reader); // console.log(' >', type); items.push(readOSType(reader, type_1)); } return items; } case 'doub': // Double return readFloat64(reader); case 'UntF': { // Unit double var units = readSignature(reader); var value = readFloat64(reader); if (!unitsMap[units]) throw new Error("Invalid units: ".concat(units)); return { units: unitsMap[units], value: value }; } case 'UnFl': { // Unit float var units = readSignature(reader); var value = readFloat32(reader); if (!unitsMap[units]) throw new Error("Invalid units: ".concat(units)); return { units: unitsMap[units], value: value }; } case 'TEXT': // String return readUnicodeString(reader); case 'enum': { // Enumerated var type_2 = readAsciiStringOrClassId(reader); var value = readAsciiStringOrClassId(reader); return "".concat(type_2, ".").concat(value); } case 'long': // Integer return readInt32(reader); case 'comp': { // Large Integer var low = readUint32(reader); var high = readUint32(reader); return { low: low, high: high }; } case 'bool': // Boolean return !!readUint8(reader); case 'type': // Class case 'GlbC': // Class return readClassStructure(reader); case 'alis': { // Alias var length_2 = readInt32(reader); return readAsciiString(reader, length_2); } case 'tdta': { // Raw Data var length_3 = readInt32(reader); return readBytes(reader, length_3); } case 'ObAr': { // Object array readInt32(reader); // version: 16 readUnicodeString(reader); // name: '' readAsciiStringOrClassId(reader); // 'rationalPoint' var length_4 = readInt32(reader); var items = []; for (var i = 0; i < length_4; i++) { var type1 = readAsciiStringOrClassId(reader); // type Hrzn | Vrtc readSignature(reader); // UnFl readSignature(reader); // units ? '#Pxl' var valuesCount = readInt32(reader); var values = []; for (var j = 0; j < valuesCount; j++) { values.push(readFloat64(reader)); } items.push({ type: type1, values: values }); } return items; } case 'Pth ': { // File path /*const length =*/ readInt32(reader); var sig = readSignature(reader); /*const pathSize =*/ readInt32LE(reader); var charsCount = readInt32LE(reader); var path = readUnicodeStringWithLength(reader, charsCount); return { sig: sig, path: path }; } default: throw new Error("Invalid TySh descriptor OSType: ".concat(type, " at ").concat(reader.offset.toString(16))); } } var ObArTypes = { meshPoints: 'rationalPoint', quiltSliceX: 'UntF', quiltSliceY: 'UntF', }; function writeOSType(writer, type, value, key, extType, root) { switch (type) { case 'obj ': // Reference writeReferenceStructure(writer, key, value); break; case 'Objc': // Descriptor case 'GlbO': // GlobalObject same as Descriptor if (!extType) throw new Error("Missing ext type for: '".concat(key, "' (").concat(JSON.stringify(value), ")")); writeDescriptorStructure(writer, extType.name, extType.classID, value, root); break; case 'VlLs': // List writeInt32(writer, value.length); for (var i = 0; i < value.length; i++) { var type_3 = fieldToArrayType[key]; writeSignature(writer, type_3 || 'long'); writeOSType(writer, type_3 || 'long', value[i], "".concat(key, "[]"), fieldToArrayExtType[key], root); if (logErrors && !type_3) console.log("Missing descriptor array type for: '".concat(key, "' in"), value); } break; case 'doub': // Double writeFloat64(writer, value); break; case 'UntF': // Unit double if (!unitsMapRev[value.units]) throw new Error("Invalid units: ".concat(value.units, " in ").concat(key)); writeSignature(writer, unitsMapRev[value.units]); writeFloat64(writer, value.value); break; case 'UnFl': // Unit float if (!unitsMapRev[value.units]) throw new Error("Invalid units: ".concat(value.units, " in ").concat(key)); writeSignature(writer, unitsMapRev[value.units]); writeFloat32(writer, value.value); break; case 'TEXT': // String writeUnicodeStringWithPadding(writer, value); break; case 'enum': { // Enumerated var _a = value.split('.'), _type = _a[0], val = _a[1]; writeAsciiStringOrClassId(writer, _type); writeAsciiStringOrClassId(writer, val); break; } case 'long': // Integer writeInt32(writer, value); break; // case 'comp': // Large Integer // writeLargeInteger(reader); case 'bool': // Boolean writeUint8(writer, value ? 1 : 0); break; // case 'type': // Class // case 'GlbC': // Class // writeClassStructure(reader); // case 'alis': // Alias // writeAliasStructure(reader); case 'tdta': // Raw Data writeInt32(writer, value.byteLength); writeBytes(writer, value); break; case 'ObAr': { // Object array writeInt32(writer, 16); // version writeUnicodeStringWithPadding(writer, ''); // name var type_4 = ObArTypes[key]; if (!type_4) throw new Error("Not implemented ObArType for: ".concat(key)); writeAsciiStringOrClassId(writer, type_4); writeInt32(writer, value.length); for (var i = 0; i < value.length; i++) { writeAsciiStringOrClassId(writer, value[i].type); // Hrzn | Vrtc writeSignature(writer, 'UnFl'); writeSignature(writer, '#Pxl'); writeInt32(writer, value[i].values.length); for (var j = 0; j < value[i].values.length; j++) { writeFloat64(writer, value[i].values[j]); } } break; } // case 'Pth ': // File path // writeFilePath(reader); default: throw new Error("Not implemented descriptor OSType: ".concat(type)); } } function readReferenceStructure(reader) { var itemsCount = readInt32(reader); var items = []; for (var i = 0; i < itemsCount; i++) { var type = readSignature(reader); switch (type) { case 'prop': { // Property readClassStructure(reader); var keyID = readAsciiStringOrClassId(reader); items.push(keyID); break; } case 'Clss': // Class items.push(readClassStructure(reader)); break; case 'Enmr': { // Enumerated Reference readClassStructure(reader); var typeID = readAsciiStringOrClassId(reader); var value = readAsciiStringOrClassId(reader); items.push("".concat(typeID, ".").concat(value)); break; } case 'rele': { // Offset // const { name, classID } = readClassStructure(reader); items.push(readUint32(reader)); break; } case 'Idnt': // Identifier items.push(readInt32(reader)); break; case 'indx': // Index items.push(readInt32(reader)); break; case 'name': { // Name readClassStructure(reader); items.push(readUnicodeString(reader)); break; } default: throw new Error("Invalid descriptor reference type: ".concat(type)); } } return items; } function writeReferenceStructure(writer, _key, items) { writeInt32(writer, items.length); for (var i = 0; i < items.length; i++) { var value = items[i]; var type = 'unknown'; if (typeof value === 'string') { if (/^[a-z]+\.[a-z]+$/i.test(value)) { type = 'Enmr'; } else { type = 'name'; } } writeSignature(writer, type); switch (type) { // case 'prop': // Property // case 'Clss': // Class case 'Enmr': { // Enumerated Reference var _a = value.split('.'), typeID = _a[0], enumValue = _a[1]; writeClassStructure(writer, '\0', typeID); writeAsciiStringOrClassId(writer, typeID); writeAsciiStringOrClassId(writer, enumValue); break; } // case 'rele': // Offset // case 'Idnt': // Identifier // case 'indx': // Index case 'name': { // Name writeClassStructure(writer, '\0', 'Lyr '); writeUnicodeString(writer, value + '\0'); break; } default: throw new Error("Invalid descriptor reference type: ".concat(type)); } } return items; } function readClassStructure(reader) { var name = readUnicodeString(reader); var classID = readAsciiStringOrClassId(reader); // console.log({ name, classID }); return { name: name, classID: classID }; } function writeClassStructure(writer, name, classID) { writeUnicodeString(writer, name); writeAsciiStringOrClassId(writer, classID); } export function readVersionAndDescriptor(reader) { var version = readUint32(reader); if (version !== 16) throw new Error("Invalid descriptor version: ".concat(version)); var desc = readDescriptorStructure(reader); // console.log(require('util').inspect(desc, false, 99, true)); return desc; } export function writeVersionAndDescriptor(writer, name, classID, descriptor, root) { if (root === void 0) { root = ''; } writeUint32(writer, 16); // version writeDescriptorStructure(writer, name, classID, descriptor, root); } export function horzVrtcToXY(hv) { return { x: hv.Hrzn, y: hv.Vrtc }; } export function xyToHorzVrtc(xy) { return { Hrzn: xy.x, Vrtc: xy.y }; } function parseFxObject(fx) { var stroke = { enabled: !!fx.enab, position: FStl.decode(fx.Styl), fillType: FrFl.decode(fx.PntT), blendMode: BlnM.decode(fx['Md ']), opacity: parsePercent(fx.Opct), size: parseUnits(fx['Sz ']), }; if (fx.present !== undefined) stroke.present = fx.present; if (fx.showInDialog !== undefined) stroke.showInDialog = fx.showInDialog; if (fx.overprint !== undefined) stroke.overprint = fx.overprint; if (fx['Clr ']) stroke.color = parseColor(fx['Clr ']); if (fx.Grad) stroke.gradient = parseGradientContent(fx); if (fx.Ptrn) stroke.pattern = parsePatternContent(fx); return stroke; } function serializeFxObject(stroke) { var FrFX = {}; FrFX.enab = !!stroke.enabled; if (stroke.present !== undefined) FrFX.present = !!stroke.present; if (stroke.showInDialog !== undefined) FrFX.showInDialog = !!stroke.showInDialog; FrFX.Styl = FStl.encode(stroke.position); FrFX.PntT = FrFl.encode(stroke.fillType); FrFX['Md '] = BlnM.encode(stroke.blendMode); FrFX.Opct = unitsPercent(stroke.opacity); FrFX['Sz '] = unitsValue(stroke.size, 'size'); if (stroke.color) FrFX['Clr '] = serializeColor(stroke.color); if (stroke.gradient) FrFX = __assign(__assign({}, FrFX), serializeGradientContent(stroke.gradient)); if (stroke.pattern) FrFX = __assign(__assign({}, FrFX), serializePatternContent(stroke.pattern)); if (stroke.overprint !== undefined) FrFX.overprint = !!stroke.overprint; return FrFX; } export function serializeEffects(e, log, multi) { var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o; var info = multi ? { 'Scl ': unitsPercent((_a = e.scale) !== null && _a !== void 0 ? _a : 1), masterFXSwitch: !e.disabled, } : { masterFXSwitch: !e.disabled, 'Scl ': unitsPercent((_b = e.scale) !== null && _b !== void 0 ? _b : 1), }; var arrayKeys = ['dropShadow', 'innerShadow', 'solidFill', 'gradientOverlay', 'stroke']; for (var _i = 0, arrayKeys_1 = arrayKeys; _i < arrayKeys_1.length; _i++) { var key = arrayKeys_1[_i]; if (e[key] && !Array.isArray(e[key])) throw new Error("".concat(key, " should be an array")); } if (((_c = e.dropShadow) === null || _c === void 0 ? void 0 : _c[0]) && !multi) info.DrSh = serializeEffectObject(e.dropShadow[0], 'dropShadow', log); if (((_d = e.dropShadow) === null || _d === void 0 ? void 0 : _d[0]) && multi) info.dropShadowMulti = e.dropShadow.map(function (i) { return serializeEffectObject(i, 'dropShadow', log); }); if (((_e = e.innerShadow) === null || _e === void 0 ? void 0 : _e[0]) && !multi) info.IrSh = serializeEffectObject(e.innerShadow[0], 'innerShadow', log); if (((_f = e.innerShadow) === null || _f === void 0 ? void 0 : _f[0]) && multi) info.innerShadowMulti = e.innerShadow.map(function (i) { return serializeEffectObject(i, 'innerShadow', log); }); if (e.outerGlow) info.OrGl = serializeEffectObject(e.outerGlow, 'outerGlow', log); if (((_g = e.solidFill) === null || _g === void 0 ? void 0 : _g[0]) && multi) info.solidFillMulti = e.solidFill.map(function (i) { return serializeEffectObject(i, 'solidFill', log); }); if (((_h = e.gradientOverlay) === null || _h === void 0 ? void 0 : _h[0]) && multi) info.gradientFillMulti = e.gradientOverlay.map(function (i) { return serializeEffectObject(i, 'gradientOverlay', log); }); if (((_j = e.stroke) === null || _j === void 0 ? void 0 : _j[0]) && multi) info.frameFXMulti = e.stroke.map(function (i) { return serializeFxObject(i); }); if (e.innerGlow) info.IrGl = serializeEffectObject(e.innerGlow, 'innerGlow', log); if (e.bevel) info.ebbl = serializeEffectObject(e.bevel, 'bevel', log); if (((_k = e.solidFill) === null || _k === void 0 ? void 0 : _k[0]) && !multi) info.SoFi = serializeEffectObject(e.solidFill[0], 'solidFill', log); if (e.patternOverlay) info.patternFill = serializeEffectObject(e.patternOverlay, 'patternOverlay', log); if (((_l = e.gradientOverlay) === null || _l === void 0 ? void 0 : _l[0]) && !multi) info.GrFl = serializeEffectObject(e.gradientOverlay[0], 'gradientOverlay', log); if (e.satin) info.ChFX = serializeEffectObject(e.satin, 'satin', log); if (((_m = e.stroke) === null || _m === void 0 ? void 0 : _m[0]) && !multi) info.FrFX = serializeFxObject((_o = e.stroke) === null || _o === void 0 ? void 0 : _o[0]); if (multi) { info.numModifyingFX = 0; for (var _p = 0, _q = Object.keys(e); _p < _q.length; _p++) { var key = _q[_p]; var value = e[key]; if (Array.isArray(value)) { for (var _r = 0, value_1 = value; _r < value_1.length; _r++) { var effect = value_1[_r]; if (effect.enabled) info.numModifyingFX++; } } } } return info; } export function parseEffects(info, log) { var effects = {}; if (!info.masterFXSwitch) effects.disabled = true; if (info['Scl ']) effects.scale = parsePercent(info['Scl ']); if (info.DrSh) effects.dropShadow = [parseEffectObject(info.DrSh, log)]; if (info.dropShadowMulti) effects.dropShadow = info.dropShadowMulti.map(function (i) { return parseEffectObject(i, log); }); if (info.IrSh) effects.innerShadow = [parseEffectObject(info.IrSh, log)]; if (info.innerShadowMulti) effects.innerShadow = info.innerShadowMulti.map(function (i) { return parseEffectObject(i, log); }); if (info.OrGl) effects.outerGlow = parseEffectObject(info.OrGl, log); if (info.IrGl) effects.innerGlow = parseEffectObject(info.IrGl, log); if (info.ebbl) effects.bevel = parseEffectObject(info.ebbl, log); if (info.SoFi) effects.solidFill = [parseEffectObject(info.SoFi, log)]; if (info.solidFillMulti) effects.solidFill = info.solidFillMulti.map(function (i) { return parseEffectObject(i, log); }); if (info.patternFill) effects.patternOverlay = parseEffectObject(info.patternFill, log); if (info.GrFl) effects.gradientOverlay = [parseEffectObject(info.GrFl, log)]; if (info.gradientFillMulti) effects.gradientOverlay = info.gradientFillMulti.map(function (i) { return parseEffectObject(i, log); }); if (info.ChFX) effects.satin = parseEffectObject(info.ChFX, log); if (info.FrFX) effects.stroke = [parseFxObject(info.FrFX)]; if (info.frameFXMulti) effects.stroke = info.frameFXMulti.map(function (i) { return parseFxObject(i); }); return effects; } function parseKeyList(keyList, logMissingFeatures) { var keys = []; for (var j = 0; j < keyList.length; j++) { var key = keyList[j]; var time = key.time, selected = key.selected, animKey = key.animKey; var interpolation = animInterpStyleEnum.decode(key.animInterpStyle); switch (animKey.Type) { case 'keyType.Opct': keys.push({ interpolation: interpolation, time: time, selected: selected, type: 'opacity', value: parsePercent(animKey.Opct) }); break; case 'keyType.Pstn': keys.push({ interpolation: interpolation, time: time, selected: selected, type: 'position', x: animKey.Hrzn, y: animKey.Vrtc }); break; case 'keyType.Trnf': keys.push({ interpolation: interpolation, time: time, selected: selected, type: 'transform', scale: horzVrtcToXY(animKey['Scl ']), skew: horzVrtcToXY(animKey.Skew), rotation: animKey.rotation, translation: horzVrtcToXY(animKey.translation) }); break; case 'keyType.sheetStyle': { var key_1 = { interpolation: interpolation, time: time, selected: selected, type: 'style' }; if (animKey.sheetStyle.Lefx) key_1.style = parseEffects(animKey.sheetStyle.Lefx, logMissingFeatures); keys.push(key_1); break; } case 'keyType.globalLighting': { keys.push({ interpolation: interpolation, time: time, selected: selected, type: 'globalLighting', globalAngle: animKey.gblA, globalAltitude: animKey.globalAltitude }); break; } default: throw new Error("Unsupported keyType value"); } } return keys; } function serializeKeyList(keys) { var keyList = []; for (var j = 0; j < keys.length; j++) { var key = keys[j]; var time = key.time, _a = key.selected, selected = _a === void 0 ? false : _a, interpolation = key.interpolation; var animInterpStyle = animInterpStyleEnum.encode(interpolation); var animKey = void 0; switch (key.type) { case 'opacity': animKey = { Type: 'keyType.Opct', Opct: unitsPercent(key.value) }; break; case 'position': animKey = { Type: 'keyType.Pstn', Hrzn: key.x, Vrtc: key.y }; break; case 'transform': animKey = { Type: 'keyType.Trnf', 'Scl ': xyToHorzVrtc(key.scale), Skew: xyToHorzVrtc(key.skew), rotation: key.rotation, translation: xyToHorzVrtc(key.translation) }; break; case 'style': animKey = { Type: 'keyType.sheetStyle', sheetStyle: { Vrsn: 1, blendOptions: {} } }; if (key.style) animKey.sheetStyle = { Vrsn: 1, Lefx: serializeEffects(key.style, false, false), blendOptions: {} }; break; case 'globalLighting': { animKey = { Type: 'keyType.globalLighting', gblA: key.globalAngle, globalAltitude: key.globalAltitude }; break; } default: throw new Error("Unsupported keyType value"); } keyList.push({ Vrsn: 1, animInterpStyle: animInterpStyle, time: time, animKey: animKey, selected: selected }); } return keyList; } export function parseTrackList(trackList, logMissingFeatures) { var tracks = []; for (var i = 0; i < trackList.length; i++) { var tr = trackList[i]; var track = { type: stdTrackID.decode(tr.trackID), enabled: tr.enab, keys: parseKeyList(tr.keyList, logMissingFeatures), }; if (tr.effectParams) { track.effectParams = { fillCanvas: tr.effectParams.fillCanvas, zoomOrigin: tr.effectParams.zoomOrigin, keys: parseKeyList(tr.effectParams.keyList, logMissingFeatures), }; } tracks.push(track); } return tracks; } export function serializeTrackList(tracks) { var trackList = []; for (var i = 0; i < tracks.length; i++) { var t = tracks[i]; trackList.push(__assign(__assign({ trackID: stdTrackID.encode(t.type), Vrsn: 1, enab: !!t.enabled, Effc: !!t.effectParams }, (t.effectParams ? { effectParams: { keyList: serializeKeyList(t.keys), fillCanvas: t.effectParams.fillCanvas, zoomOrigin: t.effectParams.zoomOrigin, } } : {})), { keyList: serializeKeyList(t.keys) })); } return trackList; } function parseEffectObject(obj, reportErrors) { var result = {}; for (var _i = 0, _a = Object.keys(obj); _i < _a.length; _i++) { var key = _a[_i]; var val = obj[key]; switch (key) { case 'enab': result.enabled = !!val; break; case 'uglg': result.useGlobalLight = !!val; break; case 'AntA': result.antialiased = !!val; break; case 'Algn': result.align = !!val; break; case 'Dthr': result.dither = !!val; break; case 'Invr': result.invert = !!val; break; case 'Rvrs': result.reverse = !!val; break; case 'Clr ': result.color = parseColor(val); break; case 'hglC': result.highlightColor = parseColor(val); break; case 'sdwC': result.shadowColor = parseColor(val); break; case 'Styl': result.position = FStl.decode(val); break; case 'Md ': result.blendMode = BlnM.decode(val); break; case 'hglM': result.highlightBlendMode = BlnM.decode(val); break; case 'sdwM': result.shadowBlendMode = BlnM.decode(val); break; case 'bvlS': result.style = BESl.decode(val); break; case 'bvlD': result.direction = BESs.decode(val); break; case 'bvlT': result.technique = bvlT.decode(val); break; case 'GlwT': result.technique = BETE.decode(val); break; case 'glwS': result.source = IGSr.decode(val); break; case 'Type': result.type = GrdT.decode(val); break; case 'gs99': result.interpolationMethod = gradientInterpolationMethodType.decode(val); break; case 'Opct': result.opacity = parsePercent(val); break; case 'hglO': result.highlightOpacity = parsePercent(val); break; case 'sdwO': result.shadowOpacity = parsePercent(val); break; case 'lagl': result.angle = parseAngle(val); break; case 'Angl': result.angle = parseAngle(val); break; case 'Lald': result.altitude = parseAngle(val); break; case 'Sftn': result.soften = parseUnits(val); break; case 'srgR': result.strength = parsePercent(val); break; case 'blur': result.size = parseUnits(val); break; case 'Nose': result.noise = parsePercent(val); break; case 'Inpr': result.range = parsePercent(val); break; case 'Ckmt': result.choke = parseUnits(val); break; case 'ShdN': result.jitter = parsePercent(val); break; case 'Dstn': result.distance = parseUnits(val); break; case 'Scl ': result.scale = parsePercent(val); break; case 'Ptrn': result.pattern = { name: val['Nm '], id: val.Idnt }; break; case 'phase': result.phase = { x: val.Hrzn, y: val.Vrtc }; break; case 'Ofst': result.offset = { x: parsePercent(val.Hrzn), y: parsePercent(val.Vrtc) }; break; case 'MpgS': case 'TrnS': result.contour = { name: val['Nm '], curve: val['Crv '].map(function (p) { return ({ x: p.Hrzn, y: p.Vrtc }); }), }; break; case 'Grad': result.gradient = parseGradient(val); break; case 'useTexture': case 'useShape': case 'layerConceals': case 'present': case 'showInDialog': case 'antialiasGloss': result[key] = val; break; default: reportErrors && console.log("Invalid effect key: '".concat(key, "', value:"), val); } } return result; } function serializeEffectObject(obj, objName, reportErrors) { var result = {}; for (var _i = 0, _a = Object.keys(obj); _i < _a.length; _i++) { var objKey = _a[_i]; var key = objKey; var val = obj[key]; switch (key) { case 'enabled': result.enab = !!val; break; case 'useGlobalLight': result.uglg = !!val; break; case 'antialiased': result.AntA = !!val; break; case 'align': result.Algn = !!val; break; case 'dither': result.Dthr = !!val; break; case 'invert': result.Invr = !!val; break; case 'reverse': result.Rvrs = !!val; break; case 'color': result['Clr '] = serializeColor(val); break; case 'highlightColor': result.hglC = serializeColor(val); break; case 'shadowColor': result.sdwC = serializeColor(val); break; case 'position': result.Styl = FStl.encode(val); break; case 'blendMode': result['Md '] = BlnM.encode(val); break; case 'highlightBlendMode': result.hglM = BlnM.encode(val); break; case 'shadowBlendMode': result.sdwM = BlnM.encode(val); break; case 'style': result.bvlS = BESl.encode(val); break; case 'direction': result.bvlD = BESs.encode(val); break; case 'technique': if (objName === 'bevel') { result.bvlT = bvlT.encode(val); } else { result.GlwT = BETE.encode(val); } break; case 'source': result.glwS = IGSr.encode(val); break; case 'type': result.Type = GrdT.encode(val); break; case 'interpolationMethod': result.gs99 = gradientInterpolationMethodType.encode(val); break; case 'opacity': result.Opct = unitsPercent(val); break; case 'highlightOpacity': result.hglO = unitsPercent(val); break; case 'shadowOpacity': result.sdwO = unitsPercent(val); break; case 'angle': if (objName === 'gradientOverlay') { result.Angl = unitsAngle(val); } else { result.lagl = unitsAngle(val); } break; case 'altitude': result.Lald = unitsAngle(val); break; case 'soften': result.Sftn = unitsValue(val, key); break; case 'strength': result.srgR = unitsPercent(val); break; case 'size': result.blur = unitsValue(val, key); break; case 'noise': result.Nose = unitsPercent(val); break; case 'range': result.Inpr = unitsPercent(val); break; case 'choke': result.Ckmt = unitsValue(val, key); break; case 'jitter': result.ShdN = unitsPercent(val); break; case 'distance': result.Dstn = unitsValue(val, key); break; case 'scale': result['Scl '] = unitsPercent(val); break; case 'pattern': result.Ptrn = { 'Nm ': val.name, Idnt: val.id }; break; case 'phase': result.phase = { Hrzn: val.x, Vrtc: val.y }; break; case 'offset': result.Ofst = { Hrzn: unitsPercent(val.x), Vrtc: unitsPercent(val.y) }; break; case 'contour': { result[objName === 'satin' ? 'MpgS' : 'TrnS'] = { 'Nm ': val.name, 'Crv ': val.curve.map(function (p) { return ({ Hrzn: p.x, Vrtc: p.y }); }), }; break; } case 'gradient': result.Grad = serializeGradient(val); break; case 'useTexture': case 'useShape': case 'layerConceals': case 'present': case 'showInDialog': case 'antialiasGloss': result[key] = val; break; default: reportErrors && console.log("Invalid effect key: '".concat(key, "', value:"), val); } } return result; } function parseGradient(grad) { if (grad.GrdF === 'GrdF.CstS') { var samples_1 = grad.Intr || 4096; return { type: 'solid', name: grad['Nm '], smoothness: grad.Intr / 4096, colorStops: grad.Clrs.map(function (s) { return ({ color: parseColor(s['Clr ']), location: s.Lctn / samples_1, midpoint: s.Mdpn / 100, }); }), opacityStops: grad.Trns.map(function (s) { return ({ opacity: parsePercent(s.Opct), location: s.Lctn / samples_1, midpoint: s.Mdpn / 100, }); }), }; } else { return { type: 'noise', name: grad['Nm '], roughness: grad.Smth / 4096, colorModel: ClrS.decode(grad.ClrS), randomSeed: grad.RndS, restrictColors: !!grad.VctC, addTransparency: !!grad.ShTr, min: grad['Mnm '].map(function (x) { return x / 100; }), max: grad['Mxm '].map(function (x) { return x / 100; }), }; } } function serializeGradient(grad) { var _a, _b; if (grad.type === 'solid') { var samples_2 = Math.round(((_a = grad.smoothness) !== null && _a !== void 0 ? _a : 1) * 4096); return { 'Nm ': grad.name || '', GrdF: 'GrdF.CstS', Intr: samples_2, Clrs: grad.colorStops.map(function (s) { var _a; return ({ 'Clr ': serializeColor(s.color), Type: 'Clry.UsrS', Lctn: Math.round(s.location * samples_2), Mdpn: Math.round(((_a = s.midpoint) !== null && _a !== void 0 ? _a : 0.5) * 100), }); }), Trns: grad.opacityStops.map(function (s) { var _a; return ({ Opct: unitsPercent(s.opacity), Lctn: Math.round(s.location * samples_2), Mdpn: Math.round(((_a = s.midpoint) !== null && _a !== void 0 ? _a : 0.5) * 100), }); }), }; } else { return { GrdF: 'GrdF.ClNs', 'Nm ': grad.name || '', ShTr: !!grad.addTransparency, VctC: !!grad.restrictColors, ClrS: ClrS.encode(grad.colorModel), RndS: grad.randomSeed || 0, Smth: Math.round(((_b = grad.roughness) !== null && _b !== void 0 ? _b : 1) * 4096), 'Mnm ': (grad.min || [0, 0, 0, 0]).map(function (x) { return x * 100; }), 'Mxm ': (grad.max || [1, 1, 1, 1]).map(function (x) { return x * 100; }), }; } } function parseGradientContent(descriptor) { var result = parseGradient(descriptor.Grad); result.style = GrdT.decode(descriptor.Type); if (descriptor.Dthr !== undefined) result.dither = descriptor.Dthr; if (descriptor.Rvrs !== undefined) result.reverse = descriptor.Rvrs; if (descriptor.Angl !== undefined) result.angle = parseAngle(descriptor.Angl); if (descriptor['Scl '] !== undefined) result.scale = parsePercent(descriptor['Scl ']); if (descriptor.Algn !== undefined) result.align = descriptor.Algn; if (descriptor.Ofst !== undefined) { result.offset = { x: parsePercent(descriptor.Ofst.Hrzn), y: parsePercent(descriptor.Ofst.Vrtc) }; } return result; } function parsePatternContent(descriptor) { var result = { name: descriptor.Ptrn['Nm '], id: descriptor.Ptrn.Idnt, }; if (descriptor.Lnkd !== undefined) result.linked = descriptor.Lnkd; if (descriptor.phase !== undefined) result.phase = { x: descriptor.phase.Hrzn, y: descriptor.phase.Vrtc }; return result; } export function parseVectorContent(descriptor) { if ('Grad' in descriptor) { return parseGradientContent(descriptor); } else if ('Ptrn' in descriptor) { return __assign({ type: 'pattern' }, parsePatternContent(descriptor)); } else if ('Clr ' in descriptor) { return { type: 'color', color: parseColor(descriptor['Clr ']) }; } else { throw new Error('Invalid vector content'); } } function serializeGradientContent(content) { var result = {}; if (content.dither !== undefined) result.Dthr = content.dither; if (content.reverse !== undefined) result.Rvrs = content.reverse; if (content.angle !== undefined) result.Angl = unitsAngle(content.angle); result.Type = GrdT.encode(content.style); if (content.align !== undefined) result.Algn = content.align; if (content.scale !== undefined) result['Scl '] = unitsPercent(content.scale); if (content.offset) { result.Ofst = { Hrzn: unitsPercent(content.offset.x), Vrtc: unitsPercent(content.offset.y), }; } result.Grad = serializeGradient(content); return result; } function serializePatternContent(content) { var result = { Ptrn: { 'Nm ': content.name || '', Idnt: content.id || '', } }; if (content.linked !== undefined) result.Lnkd = !!content.linked; if (content.phase !== undefined) result.phase = { Hrzn: content.phase.x, Vrtc: content.phase.y }; return result; } export function serializeVectorContent(content) { if (content.type === 'color') { return { key: 'SoCo', descriptor: { 'Clr ': serializeColor(content.color) } }; } else if (content.type === 'pattern') { return { key: 'PtFl', descriptor: serializePatternContent(content) }; } else { return { key: 'GdFl', descriptor: serializeGradientContent(content) }; } } export function parseColor(color) { if ('H ' in color) { return { h: parsePercentOrAngle(color['H ']), s: color.Strt, b: color.Brgh }; } else if ('Rd ' in color) { return { r: color['Rd '], g: color['Grn '], b: color['Bl '] }; } else if ('Cyn ' in color) { return { c: color['Cyn '], m: color.Mgnt, y: color['Ylw '], k: color.Blck }; } else if ('Gry ' in color) { return { k: color['Gry '] }; } else if ('Lmnc' in color) { return { l: color.Lmnc, a: color['A '], b: color['B '] }; } else if ('redFloat' in color) { return { fr: color.redFloat, fg: color.greenFloat, fb: color.blueFloat }; } else { throw new Error('Unsupported color descriptor'); } } export function serializeColor(color) { if (!color) { return { 'Rd ': 0, 'Grn ': 0, 'Bl ': 0 }; } else if ('r' in color) { return { 'Rd ': color.r || 0, 'Grn ': color.g || 0, 'Bl ': color.b || 0 }; } else if ('fr' in color) { return { redFloat: color.fr, greenFloat: color.fg, blueFloat: color.fb }; } else if ('h' in color) { return { 'H ': unitsAngle(color.h * 360), Strt: color.s || 0, Brgh: color.b || 0 }; } else if ('c' in color) { return { 'Cyn ': color.c || 0, Mgnt: color.m || 0, 'Ylw ': color.y || 0, Blck: color.k || 0 }; } else if ('l' in color) { return { Lmnc: color.l || 0, 'A ': color.a || 0, 'B ': color.b || 0 }; } else if ('k' in color) { return { 'Gry ': color.k }; } else { throw new Error('Invalid color value'); } } export function parseAngle(x) { if (x === undefined) return 0; if (x.units !== 'Angle') throw new Error("Invalid units: ".concat(x.units)); return x.value; } export function parsePercent(x) { if (x === undefined) return 1; if (x.units !== 'Percent') throw new Error("Invalid units: ".concat(x.units)); return x.value / 100; } export function parsePercentOrAngle(x) { if (x === undefined) return 1; if (x.units === 'Percent') return x.value / 100; if (x.units === 'Angle') return x.value / 360; throw new Error("Invalid units: ".concat(x.units)); } export function parseUnits(_a) { var units = _a.units, value = _a.value; if (units !== 'Pixels' && units !== 'Millimeters' && units !== 'Points' && units !== 'None' && units !== 'Picas' && units !== 'Inches' && units !== 'Centimeters' && units !== 'Density') { throw new Error("Invalid units: ".concat(JSON.stringify({ units: units, value: value }))); } return { value: value, units: units }; } export function parseUnitsOrNumber(value, units) { if (units === void 0) { units = 'Pixels'; } if (typeof value === 'number') return { value: value, units: units }; return parseUnits(value); } export function parseUnitsToNumber(_a, expectedUnits) { var units = _a.units, value = _a.value; if (units !== expectedUnits) throw new Error("Invalid units: ".concat(JSON.stringify({ units: units, value: value }))); return value; } export function unitsAngle(value) { return { units: 'Angle', value: value || 0 }; } export function unitsPercent(value) { return { units: 'Percent', value: Math.round((value || 0) * 100) }; } export function unitsValue(x, key) { if (x == null) return { units: 'Pixels', value: 0 }; if (typeof x !== 'object') throw new Error("Invalid value: ".concat(JSON.stringify(x), " (key: ").concat(key, ") (should have value and units)")); var units = x.units, value = x.value; if (typeof value !== 'number') throw new Error("Invalid value in ".concat(JSON.stringify(x), " (key: ").concat(key, ")")); if (units !== 'Pixels' && units !== 'Millimeters' && units !== 'Points' && units !== 'None' && units !== 'Picas' && units !== 'Inches' && units !== 'Centimeters' && units !== 'Density') { throw new Error("Invalid units in ".concat(JSON.stringify(x), " (key: ").concat(key, ")")); } return { units: units, value: value }; } export var textGridding = createEnum('textGridding', 'none', { none: 'None', round: 'Rnd ', }); export var Ornt = createEnum('Ornt', 'horizontal', { horizontal: 'Hrzn', vertical: 'Vrtc', }); export var Annt = createEnum('Annt', 'sharp', { none: 'Anno', sharp: 'antiAliasSharp', crisp: 'AnCr', strong: 'AnSt', smooth: 'AnSm', platform: 'antiAliasPlatformGray', platformLCD: 'antiAliasPlatformLCD', }); export var warpStyle = createEnum('warpStyle', 'none', { none: 'warpNone', arc: 'warpArc', arcLower: 'warpArcLower', arcUpper: 'warpArcUpper', arch: 'warpArch', bulge: 'warpBulge', shellLower: 'warpShellLower', shellUpper: 'warpShellUpper', flag: 'warpFlag', wave: 'warpWave', fish: 'warpFish', rise: 'warpRise', fisheye: 'warpFisheye', inflate: 'warpInflate', squeeze: 'warpSqueeze', twist: 'warpTwist', cylinder: 'warpCylinder', custom: 'warpCustom', }); export var BlnM = createEnum('BlnM', 'normal', { 'normal': 'Nrml', 'dissolve': 'Dslv', 'darken': 'Drkn', 'multiply': 'Mltp', 'color burn': 'CBrn', 'linear burn': 'linearBurn', 'darker color': 'darkerColor', 'lighten': 'Lghn', 'screen': 'Scrn', 'color dodge': 'CDdg', 'linear dodge': 'linearDodge', 'lighter color': 'lighterColor', 'overlay': 'Ovrl', 'soft light': 'SftL', 'hard light': 'HrdL', 'vivid light': 'vividLight', 'linear light': 'linearLight', 'pin light': 'pinLight', 'hard mix': 'hardMix', 'difference': 'Dfrn', 'exclusion': 'Xclu', 'subtract': 'blendSubtraction', 'divide': 'blendDivide', 'hue': 'H ', 'saturation': 'Strt', 'color': 'Clr ', 'luminosity': 'Lmns', // used in ABR 'linear height': 'linearHeight', 'height': 'Hght', 'subtraction': 'Sbtr', // 2nd version of subtract ? }); export var BESl = createEnum('BESl', 'inner bevel', { 'inner bevel': 'InrB', 'outer bevel': 'OtrB', 'emboss': 'Embs', 'pillow emboss': 'PlEb', 'stroke emboss': 'strokeEmboss', }); export var bvlT = createEnum('bvlT', 'smooth', { 'smooth': 'SfBL', 'chisel hard': 'PrBL', 'chisel soft': 'Slmt', }); export var BESs = createEnum('BESs', 'up', { up: 'In ', down: 'Out ', }); export var BETE = createEnum('BETE', 'softer', { softer: 'SfBL', precise: 'PrBL', }); export var IGSr = createEnum('IGSr', 'edge', { edge: 'SrcE', center: 'SrcC', }); export var GrdT = createEnum('GrdT', 'linear', { linear: 'Lnr ', radial: 'Rdl ', angle: 'Angl', reflected: 'Rflc', diamond: 'Dmnd', }); export var animInterpStyleEnum = createEnum('animInterpStyle', 'linear', { linear: 'Lnr ', hold: 'hold', }); export var stdTrackID = createEnum('stdTrackID', 'opacity', { opacity: 'opacityTrack', style: 'styleTrack', sheetTransform: 'sheetTransformTrack', sheetPosition: 'sheetPositionTrack', globalLighting: 'globalLightingTrack', }); export var gradientInterpolationMethodType = createEnum('gradientInterpolationMethodType', 'perceptual', { perceptual: 'Perc', linear: 'Lnr', classic: 'Gcls', }); export var ClrS = createEnum('ClrS', 'rgb', { rgb: 'RGBC', hsb: 'HSBl', lab: 'LbCl', }); export var FStl = createEnum('FStl', 'outside', { outside: 'OutF', center: 'CtrF', inside: 'InsF' }); export var FrFl = createEnum('FrFl', 'color', { color: 'SClr', gradient: 'GrFl', pattern: 'Ptrn', }); export var ESliceType = createEnum('ESliceType', 'image', { image: 'Img ', noImage: 'noImage', }); export var ESliceHorzAlign = createEnum('ESliceHorzAlign', 'default', { default: 'default', }); export var ESliceVertAlign = createEnum('ESliceVertAlign', 'default', { default: 'default', }); export var ESliceOrigin = createEnum('ESliceOrigin', 'userGenerated', { userGenerated: 'userGenerated', autoGenerated: 'autoGenerated', layer: 'layer', }); export var ESliceBGColorType = createEnum('ESliceBGColorType', 'none', { none: 'None', matte: 'matte', color: 'Clr ', }); export var strokeStyleLineCapType = createEnum('strokeStyleLineCapType', 'butt', { butt: 'strokeStyleButtCap', round: 'strokeStyleRoundCap', square: 'strokeStyleSquareCap', }); export var strokeStyleLineJoinType = createEnum('strokeStyleLineJoinType', 'miter', { miter: 'strokeStyleMiterJoin', round: 'strokeStyleRoundJoin', bevel: 'strokeStyleBevelJoin', }); export var strokeStyleLineAlignment = createEnum('strokeStyleLineAlignment', 'inside', { inside: 'strokeStyleAlignInside', center: 'strokeStyleAlignCenter', outside: 'strokeStyleAlignOutside', }); //# sourceMappingURL=descriptor.js.map