2023-09-06 09:51:55 +08:00

1698 lines
65 KiB
JavaScript

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