2023-09-06 09:51:55 +08:00
|
|
|
"use strict";
|
|
|
|
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);
|
|
|
|
};
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
|
exports.encodeEngineData = exports.decodeEngineData = void 0;
|
|
|
|
var defaultFont = {
|
|
|
|
name: 'MyriadPro-Regular',
|
|
|
|
script: 0,
|
|
|
|
type: 0,
|
|
|
|
synthetic: 0,
|
|
|
|
};
|
|
|
|
var defaultParagraphStyle = {
|
|
|
|
justification: 'left',
|
|
|
|
firstLineIndent: 0,
|
|
|
|
startIndent: 0,
|
|
|
|
endIndent: 0,
|
|
|
|
spaceBefore: 0,
|
|
|
|
spaceAfter: 0,
|
|
|
|
autoHyphenate: true,
|
|
|
|
hyphenatedWordSize: 6,
|
|
|
|
preHyphen: 2,
|
|
|
|
postHyphen: 2,
|
|
|
|
consecutiveHyphens: 8,
|
|
|
|
zone: 36,
|
|
|
|
wordSpacing: [0.8, 1, 1.33],
|
|
|
|
letterSpacing: [0, 0, 0],
|
|
|
|
glyphSpacing: [1, 1, 1],
|
|
|
|
autoLeading: 1.2,
|
|
|
|
leadingType: 0,
|
|
|
|
hanging: false,
|
|
|
|
burasagari: false,
|
|
|
|
kinsokuOrder: 0,
|
|
|
|
everyLineComposer: false,
|
|
|
|
};
|
|
|
|
var defaultStyle = {
|
|
|
|
font: defaultFont,
|
|
|
|
fontSize: 12,
|
|
|
|
fauxBold: false,
|
|
|
|
fauxItalic: false,
|
|
|
|
autoLeading: true,
|
|
|
|
leading: 0,
|
|
|
|
horizontalScale: 1,
|
|
|
|
verticalScale: 1,
|
|
|
|
tracking: 0,
|
|
|
|
autoKerning: true,
|
|
|
|
kerning: 0,
|
|
|
|
baselineShift: 0,
|
|
|
|
fontCaps: 0,
|
|
|
|
fontBaseline: 0,
|
|
|
|
underline: false,
|
|
|
|
strikethrough: false,
|
|
|
|
ligatures: true,
|
|
|
|
dLigatures: false,
|
|
|
|
baselineDirection: 2,
|
|
|
|
tsume: 0,
|
|
|
|
styleRunAlignment: 2,
|
|
|
|
language: 0,
|
|
|
|
noBreak: false,
|
|
|
|
fillColor: { r: 0, g: 0, b: 0 },
|
|
|
|
strokeColor: { r: 0, g: 0, b: 0 },
|
|
|
|
fillFlag: true,
|
|
|
|
strokeFlag: false,
|
|
|
|
fillFirst: true,
|
|
|
|
yUnderline: 1,
|
|
|
|
outlineWidth: 1,
|
|
|
|
characterDirection: 0,
|
|
|
|
hindiNumbers: false,
|
|
|
|
kashida: 1,
|
|
|
|
diacriticPos: 2,
|
|
|
|
};
|
|
|
|
var defaultGridInfo = {
|
|
|
|
isOn: false,
|
|
|
|
show: false,
|
|
|
|
size: 18,
|
|
|
|
leading: 22,
|
|
|
|
color: { r: 0, g: 0, b: 255 },
|
|
|
|
leadingFillColor: { r: 0, g: 0, b: 255 },
|
|
|
|
alignLineHeightToGridFlags: false,
|
|
|
|
};
|
|
|
|
var paragraphStyleKeys = [
|
|
|
|
'justification', 'firstLineIndent', 'startIndent', 'endIndent', 'spaceBefore', 'spaceAfter',
|
|
|
|
'autoHyphenate', 'hyphenatedWordSize', 'preHyphen', 'postHyphen', 'consecutiveHyphens',
|
|
|
|
'zone', 'wordSpacing', 'letterSpacing', 'glyphSpacing', 'autoLeading', 'leadingType',
|
|
|
|
'hanging', 'burasagari', 'kinsokuOrder', 'everyLineComposer',
|
|
|
|
];
|
|
|
|
var styleKeys = [
|
|
|
|
'font', 'fontSize', 'fauxBold', 'fauxItalic', 'autoLeading', 'leading', 'horizontalScale',
|
|
|
|
'verticalScale', 'tracking', 'autoKerning', 'kerning', 'baselineShift', 'fontCaps', 'fontBaseline',
|
|
|
|
'underline', 'strikethrough', 'ligatures', 'dLigatures', 'baselineDirection', 'tsume',
|
|
|
|
'styleRunAlignment', 'language', 'noBreak', 'fillColor', 'strokeColor', 'fillFlag',
|
|
|
|
'strokeFlag', 'fillFirst', 'yUnderline', 'outlineWidth', 'characterDirection', 'hindiNumbers',
|
|
|
|
'kashida', 'diacriticPos',
|
|
|
|
];
|
|
|
|
var antialias = ['none', 'crisp', 'strong', 'smooth', 'sharp'];
|
|
|
|
var justification = ['left', 'right', 'center'];
|
|
|
|
function upperFirst(value) {
|
|
|
|
return value.substr(0, 1).toUpperCase() + value.substr(1);
|
|
|
|
}
|
|
|
|
function decodeColor(color) {
|
|
|
|
var c = color.Values;
|
|
|
|
if (color.Type === 0) { // grayscale
|
|
|
|
return { r: c[1] * 255, g: c[1] * 255, b: c[1] * 255 }; // , c[0] * 255];
|
|
|
|
}
|
|
|
|
else { // rgb
|
|
|
|
return { r: c[1] * 255, g: c[2] * 255, b: c[3] * 255, a: c[0] }; // , c[0] * 255];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function encodeColor(color) {
|
|
|
|
if (color && 'r' in color) {
|
|
|
|
return ['a' in color ? color.a : 1, color.r / 255, color.g / 255, color.b / 255];
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return [0, 0, 0, 0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function arraysEqual(a, b) {
|
|
|
|
if (!a || !b)
|
|
|
|
return false;
|
|
|
|
if (a.length !== b.length)
|
|
|
|
return false;
|
|
|
|
for (var i = 0; i < a.length; i++)
|
|
|
|
if (a[i] !== b[i])
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
function objectsEqual(a, b) {
|
|
|
|
if (!a || !b)
|
|
|
|
return false;
|
|
|
|
for (var _i = 0, _a = Object.keys(a); _i < _a.length; _i++) {
|
|
|
|
var key = _a[_i];
|
|
|
|
if (a[key] !== b[key])
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
for (var _b = 0, _c = Object.keys(b); _b < _c.length; _b++) {
|
|
|
|
var key = _c[_b];
|
|
|
|
if (a[key] !== b[key])
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
function findOrAddFont(fonts, font) {
|
|
|
|
for (var i = 0; i < fonts.length; i++) {
|
|
|
|
if (fonts[i].name === font.name)
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
fonts.push(font);
|
|
|
|
return fonts.length - 1;
|
|
|
|
}
|
|
|
|
function decodeObject(obj, keys, fonts) {
|
|
|
|
var result = {};
|
|
|
|
for (var _i = 0, keys_1 = keys; _i < keys_1.length; _i++) {
|
|
|
|
var key = keys_1[_i];
|
|
|
|
var Key = upperFirst(key);
|
|
|
|
if (obj[Key] === undefined)
|
|
|
|
continue;
|
|
|
|
if (key === 'justification') {
|
|
|
|
result[key] = justification[obj[Key]];
|
|
|
|
}
|
|
|
|
else if (key === 'font') {
|
|
|
|
result[key] = fonts[obj[Key]];
|
|
|
|
}
|
|
|
|
else if (key === 'fillColor' || key === 'strokeColor') {
|
|
|
|
result[key] = decodeColor(obj[Key]);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
result[key] = obj[Key];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
function encodeObject(obj, keys, fonts) {
|
|
|
|
var _a;
|
|
|
|
var result = {};
|
|
|
|
for (var _i = 0, keys_2 = keys; _i < keys_2.length; _i++) {
|
|
|
|
var key = keys_2[_i];
|
|
|
|
var Key = upperFirst(key);
|
|
|
|
if (obj[key] === undefined)
|
|
|
|
continue;
|
|
|
|
if (key === 'justification') {
|
|
|
|
result[Key] = justification.indexOf((_a = obj[key]) !== null && _a !== void 0 ? _a : 'left');
|
|
|
|
}
|
|
|
|
else if (key === 'font') {
|
|
|
|
result[Key] = findOrAddFont(fonts, obj[key]);
|
|
|
|
}
|
|
|
|
else if (key === 'fillColor' || key === 'strokeColor') {
|
|
|
|
result[Key] = { Type: 1, Values: encodeColor(obj[key]) };
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
result[Key] = obj[key];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
function decodeParagraphStyle(obj, fonts) {
|
|
|
|
return decodeObject(obj, paragraphStyleKeys, fonts);
|
|
|
|
}
|
|
|
|
function decodeStyle(obj, fonts) {
|
|
|
|
return decodeObject(obj, styleKeys, fonts);
|
|
|
|
}
|
|
|
|
function encodeParagraphStyle(obj, fonts) {
|
|
|
|
return encodeObject(obj, paragraphStyleKeys, fonts);
|
|
|
|
}
|
|
|
|
function encodeStyle(obj, fonts) {
|
|
|
|
return encodeObject(obj, styleKeys, fonts);
|
|
|
|
}
|
|
|
|
function deduplicateValues(base, runs, keys) {
|
|
|
|
if (!runs.length)
|
|
|
|
return;
|
|
|
|
var _loop_1 = function (key) {
|
|
|
|
var value = runs[0].style[key];
|
|
|
|
if (value !== undefined) {
|
|
|
|
var identical = false;
|
|
|
|
if (Array.isArray(value)) {
|
|
|
|
identical = runs.every(function (r) { return arraysEqual(r.style[key], value); });
|
|
|
|
}
|
|
|
|
else if (typeof value === 'object') {
|
|
|
|
identical = runs.every(function (r) { return objectsEqual(r.style[key], value); });
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
identical = runs.every(function (r) { return r.style[key] === value; });
|
|
|
|
}
|
|
|
|
if (identical) {
|
|
|
|
base[key] = value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var styleValue = base[key];
|
|
|
|
if (styleValue !== undefined) {
|
|
|
|
for (var _a = 0, runs_1 = runs; _a < runs_1.length; _a++) {
|
|
|
|
var r = runs_1[_a];
|
|
|
|
var same = false;
|
|
|
|
if (Array.isArray(value)) {
|
|
|
|
same = arraysEqual(r.style[key], value);
|
|
|
|
}
|
|
|
|
else if (typeof value === 'object') {
|
|
|
|
same = objectsEqual(r.style[key], value);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
same = r.style[key] === value;
|
|
|
|
}
|
|
|
|
if (same)
|
|
|
|
delete r.style[key];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
for (var _i = 0, keys_3 = keys; _i < keys_3.length; _i++) {
|
|
|
|
var key = keys_3[_i];
|
|
|
|
_loop_1(key);
|
|
|
|
}
|
|
|
|
if (runs.every(function (x) { return Object.keys(x.style).length === 0; })) {
|
|
|
|
runs.length = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function decodeEngineData(engineData) {
|
|
|
|
var _a, _b, _c, _d, _e, _f;
|
|
|
|
// console.log('engineData', require('util').inspect(engineData, false, 99, true));
|
|
|
|
var engineDict = engineData.EngineDict;
|
|
|
|
var resourceDict = engineData.ResourceDict;
|
|
|
|
var fonts = resourceDict.FontSet.map(function (f) { return ({
|
|
|
|
name: f.Name,
|
|
|
|
script: f.Script,
|
|
|
|
type: f.FontType,
|
|
|
|
synthetic: f.Synthetic,
|
|
|
|
}); });
|
|
|
|
var text = engineDict.Editor.Text.replace(/\r/g, '\n');
|
|
|
|
var removedCharacters = 0;
|
|
|
|
while (/\n$/.test(text)) {
|
|
|
|
text = text.substr(0, text.length - 1);
|
|
|
|
removedCharacters++;
|
|
|
|
}
|
|
|
|
var result = {
|
|
|
|
text: text,
|
|
|
|
antiAlias: (_a = antialias[engineDict.AntiAlias]) !== null && _a !== void 0 ? _a : 'smooth',
|
|
|
|
useFractionalGlyphWidths: !!engineDict.UseFractionalGlyphWidths,
|
|
|
|
superscriptSize: resourceDict.SuperscriptSize,
|
|
|
|
superscriptPosition: resourceDict.SuperscriptPosition,
|
|
|
|
subscriptSize: resourceDict.SubscriptSize,
|
|
|
|
subscriptPosition: resourceDict.SubscriptPosition,
|
|
|
|
smallCapSize: resourceDict.SmallCapSize,
|
|
|
|
};
|
|
|
|
// shape
|
|
|
|
var photoshop = (_f = (_e = (_d = (_c = (_b = engineDict.Rendered) === null || _b === void 0 ? void 0 : _b.Shapes) === null || _c === void 0 ? void 0 : _c.Children) === null || _d === void 0 ? void 0 : _d[0]) === null || _e === void 0 ? void 0 : _e.Cookie) === null || _f === void 0 ? void 0 : _f.Photoshop;
|
|
|
|
if (photoshop) {
|
|
|
|
result.shapeType = photoshop.ShapeType === 1 ? 'box' : 'point';
|
|
|
|
if (photoshop.PointBase)
|
|
|
|
result.pointBase = photoshop.PointBase;
|
|
|
|
if (photoshop.BoxBounds)
|
|
|
|
result.boxBounds = photoshop.BoxBounds;
|
|
|
|
}
|
|
|
|
// paragraph style
|
|
|
|
// const theNormalParagraphSheet = resourceDict.TheNormalParagraphSheet;
|
|
|
|
// const paragraphSheetSet = resourceDict.ParagraphSheetSet;
|
|
|
|
// const paragraphProperties = paragraphSheetSet[theNormalParagraphSheet].Properties;
|
|
|
|
var paragraphRun = engineData.EngineDict.ParagraphRun;
|
|
|
|
result.paragraphStyle = {}; // decodeParagraphStyle(paragraphProperties, fonts);
|
|
|
|
result.paragraphStyleRuns = [];
|
|
|
|
for (var i = 0; i < paragraphRun.RunArray.length; i++) {
|
|
|
|
var run_1 = paragraphRun.RunArray[i];
|
|
|
|
var length_1 = paragraphRun.RunLengthArray[i];
|
|
|
|
var style = decodeParagraphStyle(run_1.ParagraphSheet.Properties, fonts);
|
|
|
|
// const adjustments = {
|
|
|
|
// axis: run.Adjustments.Axis,
|
|
|
|
// xy: run.Adjustments.XY,
|
|
|
|
// };
|
|
|
|
result.paragraphStyleRuns.push({ length: length_1, style: style /*, adjustments*/ });
|
|
|
|
}
|
|
|
|
for (var counter = removedCharacters; result.paragraphStyleRuns.length && counter > 0; counter--) {
|
|
|
|
if (--result.paragraphStyleRuns[result.paragraphStyleRuns.length - 1].length === 0) {
|
|
|
|
result.paragraphStyleRuns.pop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
deduplicateValues(result.paragraphStyle, result.paragraphStyleRuns, paragraphStyleKeys);
|
|
|
|
if (!result.paragraphStyleRuns.length)
|
|
|
|
delete result.paragraphStyleRuns;
|
|
|
|
// style
|
|
|
|
// const theNormalStyleSheet = resourceDict.TheNormalStyleSheet;
|
|
|
|
// const styleSheetSet = resourceDict.StyleSheetSet;
|
|
|
|
// const styleSheetData = styleSheetSet[theNormalStyleSheet].StyleSheetData;
|
|
|
|
var styleRun = engineData.EngineDict.StyleRun;
|
|
|
|
result.style = {}; // decodeStyle(styleSheetData, fonts);
|
|
|
|
result.styleRuns = [];
|
|
|
|
for (var i = 0; i < styleRun.RunArray.length; i++) {
|
|
|
|
var length_2 = styleRun.RunLengthArray[i];
|
|
|
|
var style = decodeStyle(styleRun.RunArray[i].StyleSheet.StyleSheetData, fonts);
|
|
|
|
if (!style.font)
|
|
|
|
style.font = fonts[0];
|
|
|
|
result.styleRuns.push({ length: length_2, style: style });
|
|
|
|
}
|
|
|
|
for (var counter = removedCharacters; result.styleRuns.length && counter > 0; counter--) {
|
|
|
|
if (--result.styleRuns[result.styleRuns.length - 1].length === 0) {
|
|
|
|
result.styleRuns.pop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
deduplicateValues(result.style, result.styleRuns, styleKeys);
|
|
|
|
if (!result.styleRuns.length)
|
|
|
|
delete result.styleRuns;
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
exports.decodeEngineData = decodeEngineData;
|
|
|
|
function encodeEngineData(data) {
|
|
|
|
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
|
|
var text = "".concat((data.text || '').replace(/\r?\n/g, '\r'), "\r");
|
|
|
|
var fonts = [
|
|
|
|
{ name: 'AdobeInvisFont', script: 0, type: 0, synthetic: 0 },
|
|
|
|
];
|
|
|
|
var defFont = ((_a = data.style) === null || _a === void 0 ? void 0 : _a.font) || ((_c = (_b = data.styleRuns) === null || _b === void 0 ? void 0 : _b.find(function (s) { return s.style.font; })) === null || _c === void 0 ? void 0 : _c.style.font) || defaultFont;
|
|
|
|
var paragraphRunArray = [];
|
|
|
|
var paragraphRunLengthArray = [];
|
|
|
|
var paragraphRuns = data.paragraphStyleRuns;
|
|
|
|
if (paragraphRuns && paragraphRuns.length) {
|
|
|
|
var leftLength_1 = text.length;
|
|
|
|
for (var _i = 0, paragraphRuns_1 = paragraphRuns; _i < paragraphRuns_1.length; _i++) {
|
|
|
|
var run_2 = paragraphRuns_1[_i];
|
|
|
|
var runLength = Math.min(run_2.length, leftLength_1);
|
|
|
|
leftLength_1 -= runLength;
|
|
|
|
if (!runLength)
|
|
|
|
continue; // ignore 0 size runs
|
|
|
|
// extend last run if it's only for trailing \r
|
|
|
|
if (leftLength_1 === 1 && run_2 === paragraphRuns[paragraphRuns.length - 1]) {
|
|
|
|
runLength++;
|
|
|
|
leftLength_1--;
|
|
|
|
}
|
|
|
|
paragraphRunLengthArray.push(runLength);
|
|
|
|
paragraphRunArray.push({
|
|
|
|
ParagraphSheet: {
|
|
|
|
DefaultStyleSheet: 0,
|
|
|
|
Properties: encodeParagraphStyle(__assign(__assign(__assign({}, defaultParagraphStyle), data.paragraphStyle), run_2.style), fonts),
|
|
|
|
},
|
|
|
|
Adjustments: { Axis: [1, 0, 1], XY: [0, 0] },
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if (leftLength_1) {
|
|
|
|
paragraphRunLengthArray.push(leftLength_1);
|
|
|
|
paragraphRunArray.push({
|
|
|
|
ParagraphSheet: {
|
|
|
|
DefaultStyleSheet: 0,
|
|
|
|
Properties: encodeParagraphStyle(__assign(__assign({}, defaultParagraphStyle), data.paragraphStyle), fonts),
|
|
|
|
},
|
|
|
|
Adjustments: { Axis: [1, 0, 1], XY: [0, 0] },
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
for (var i = 0, last = 0; i < text.length; i++) {
|
|
|
|
if (text.charCodeAt(i) === 13) { // \r
|
|
|
|
paragraphRunLengthArray.push(i - last + 1);
|
|
|
|
paragraphRunArray.push({
|
|
|
|
ParagraphSheet: {
|
|
|
|
DefaultStyleSheet: 0,
|
|
|
|
Properties: encodeParagraphStyle(__assign(__assign({}, defaultParagraphStyle), data.paragraphStyle), fonts),
|
|
|
|
},
|
|
|
|
Adjustments: { Axis: [1, 0, 1], XY: [0, 0] },
|
|
|
|
});
|
|
|
|
last = i + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var styleSheetData = encodeStyle(__assign(__assign({}, defaultStyle), { font: defFont }), fonts);
|
|
|
|
var styleRuns = data.styleRuns || [{ length: text.length, style: data.style || {} }];
|
|
|
|
var styleRunArray = [];
|
|
|
|
var styleRunLengthArray = [];
|
|
|
|
var leftLength = text.length;
|
|
|
|
for (var _o = 0, styleRuns_1 = styleRuns; _o < styleRuns_1.length; _o++) {
|
|
|
|
var run_3 = styleRuns_1[_o];
|
|
|
|
var runLength = Math.min(run_3.length, leftLength);
|
|
|
|
leftLength -= runLength;
|
|
|
|
if (!runLength)
|
|
|
|
continue; // ignore 0 size runs
|
|
|
|
// extend last run if it's only for trailing \r
|
|
|
|
if (leftLength === 1 && run_3 === styleRuns[styleRuns.length - 1]) {
|
|
|
|
runLength++;
|
|
|
|
leftLength--;
|
|
|
|
}
|
|
|
|
styleRunLengthArray.push(runLength);
|
|
|
|
styleRunArray.push({
|
|
|
|
StyleSheet: {
|
|
|
|
StyleSheetData: encodeStyle(__assign(__assign({ kerning: 0, autoKerning: true, fillColor: { r: 0, g: 0, b: 0 } }, data.style), run_3.style), fonts),
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
// add extra run to the end if existing ones didn't fill it up
|
|
|
|
if (leftLength && styleRuns.length) {
|
|
|
|
styleRunLengthArray.push(leftLength);
|
|
|
|
styleRunArray.push({
|
|
|
|
StyleSheet: {
|
|
|
|
StyleSheetData: encodeStyle(__assign({ kerning: 0, autoKerning: true, fillColor: { r: 0, g: 0, b: 0 } }, data.style), fonts),
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
var gridInfo = __assign(__assign({}, defaultGridInfo), data.gridInfo);
|
|
|
|
var WritingDirection = data.orientation === 'vertical' ? 2 : 0;
|
|
|
|
var Procession = data.orientation === 'vertical' ? 1 : 0;
|
|
|
|
var ShapeType = data.shapeType === 'box' ? 1 : 0;
|
|
|
|
var Photoshop = {
|
|
|
|
ShapeType: ShapeType,
|
|
|
|
};
|
|
|
|
if (ShapeType === 0) {
|
|
|
|
Photoshop.PointBase = data.pointBase || [0, 0];
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
Photoshop.BoxBounds = data.boxBounds || [0, 0, 0, 0];
|
|
|
|
}
|
|
|
|
// needed for correct order of properties
|
|
|
|
Photoshop.Base = {
|
|
|
|
ShapeType: ShapeType,
|
|
|
|
TransformPoint0: [1, 0],
|
|
|
|
TransformPoint1: [0, 1],
|
|
|
|
TransformPoint2: [0, 0],
|
|
|
|
};
|
|
|
|
var defaultResources = {
|
|
|
|
KinsokuSet: [
|
|
|
|
{
|
|
|
|
Name: 'PhotoshopKinsokuHard',
|
|
|
|
NoStart: '、。,.・:;?!ー―’”)〕]}〉》」』】ヽヾゝゞ々ぁぃぅぇぉっゃゅょゎァィゥェォッャュョヮヵヶ゛゜?!)]},.:;℃℉¢%‰',
|
|
|
|
NoEnd: '‘“(〔[{〈《「『【([{¥$£@§〒#',
|
|
|
|
Keep: '―‥',
|
|
|
|
Hanging: '、。.,',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: 'PhotoshopKinsokuSoft',
|
|
|
|
NoStart: '、。,.・:;?!’”)〕]}〉》」』】ヽヾゝゞ々',
|
|
|
|
NoEnd: '‘“(〔[{〈《「『【',
|
|
|
|
Keep: '―‥',
|
|
|
|
Hanging: '、。.,',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
MojiKumiSet: [
|
|
|
|
{ InternalName: 'Photoshop6MojiKumiSet1' },
|
|
|
|
{ InternalName: 'Photoshop6MojiKumiSet2' },
|
|
|
|
{ InternalName: 'Photoshop6MojiKumiSet3' },
|
|
|
|
{ InternalName: 'Photoshop6MojiKumiSet4' },
|
|
|
|
],
|
|
|
|
TheNormalStyleSheet: 0,
|
|
|
|
TheNormalParagraphSheet: 0,
|
|
|
|
ParagraphSheetSet: [
|
|
|
|
{
|
|
|
|
Name: 'Normal RGB',
|
|
|
|
DefaultStyleSheet: 0,
|
|
|
|
Properties: encodeParagraphStyle(__assign(__assign({}, defaultParagraphStyle), data.paragraphStyle), fonts),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
StyleSheetSet: [
|
|
|
|
{
|
|
|
|
Name: 'Normal RGB',
|
|
|
|
StyleSheetData: styleSheetData,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
FontSet: fonts.map(function (f) { return ({
|
|
|
|
Name: f.name,
|
|
|
|
Script: f.script || 0,
|
|
|
|
FontType: f.type || 0,
|
|
|
|
Synthetic: f.synthetic || 0,
|
|
|
|
}); }),
|
|
|
|
SuperscriptSize: (_d = data.superscriptSize) !== null && _d !== void 0 ? _d : 0.583,
|
|
|
|
SuperscriptPosition: (_e = data.superscriptPosition) !== null && _e !== void 0 ? _e : 0.333,
|
|
|
|
SubscriptSize: (_f = data.subscriptSize) !== null && _f !== void 0 ? _f : 0.583,
|
|
|
|
SubscriptPosition: (_g = data.subscriptPosition) !== null && _g !== void 0 ? _g : 0.333,
|
|
|
|
SmallCapSize: (_h = data.smallCapSize) !== null && _h !== void 0 ? _h : 0.7,
|
|
|
|
};
|
|
|
|
var engineData = {
|
|
|
|
EngineDict: {
|
|
|
|
Editor: { Text: text },
|
|
|
|
ParagraphRun: {
|
|
|
|
DefaultRunData: {
|
|
|
|
ParagraphSheet: { DefaultStyleSheet: 0, Properties: {} },
|
|
|
|
Adjustments: { Axis: [1, 0, 1], XY: [0, 0] },
|
|
|
|
},
|
|
|
|
RunArray: paragraphRunArray,
|
|
|
|
RunLengthArray: paragraphRunLengthArray,
|
|
|
|
IsJoinable: 1,
|
|
|
|
},
|
|
|
|
StyleRun: {
|
|
|
|
DefaultRunData: { StyleSheet: { StyleSheetData: {} } },
|
|
|
|
RunArray: styleRunArray,
|
|
|
|
RunLengthArray: styleRunLengthArray,
|
|
|
|
IsJoinable: 2,
|
|
|
|
},
|
|
|
|
GridInfo: {
|
|
|
|
GridIsOn: !!gridInfo.isOn,
|
|
|
|
ShowGrid: !!gridInfo.show,
|
|
|
|
GridSize: (_j = gridInfo.size) !== null && _j !== void 0 ? _j : 18,
|
|
|
|
GridLeading: (_k = gridInfo.leading) !== null && _k !== void 0 ? _k : 22,
|
|
|
|
GridColor: { Type: 1, Values: encodeColor(gridInfo.color) },
|
|
|
|
GridLeadingFillColor: { Type: 1, Values: encodeColor(gridInfo.color) },
|
|
|
|
AlignLineHeightToGridFlags: !!gridInfo.alignLineHeightToGridFlags,
|
|
|
|
},
|
|
|
|
AntiAlias: antialias.indexOf((_l = data.antiAlias) !== null && _l !== void 0 ? _l : 'sharp'),
|
|
|
|
UseFractionalGlyphWidths: (_m = data.useFractionalGlyphWidths) !== null && _m !== void 0 ? _m : true,
|
|
|
|
Rendered: {
|
|
|
|
Version: 1,
|
|
|
|
Shapes: {
|
|
|
|
WritingDirection: WritingDirection,
|
|
|
|
Children: [
|
|
|
|
{
|
|
|
|
ShapeType: ShapeType,
|
|
|
|
Procession: Procession,
|
|
|
|
Lines: { WritingDirection: WritingDirection, Children: [] },
|
|
|
|
Cookie: { Photoshop: Photoshop },
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ResourceDict: __assign({}, defaultResources),
|
|
|
|
DocumentResources: __assign({}, defaultResources),
|
|
|
|
};
|
|
|
|
// console.log('encodeEngineData', require('util').inspect(engineData, false, 99, true));
|
|
|
|
return engineData;
|
|
|
|
}
|
|
|
|
exports.encodeEngineData = encodeEngineData;
|
|
|
|
//# sourceMappingURL=text.js.map
|