@hellkite/pipkin 0.6.2 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/src/lib/replacement.d.ts +5 -3
- package/build/src/lib/replacement.js +6 -3
- package/build/src/lib/replacement.js.map +1 -1
- package/build/src/lib/template.d.ts +18 -26
- package/build/src/lib/template.js +197 -70
- package/build/src/lib/template.js.map +1 -1
- package/build/src/lib/types/containers.d.ts +14 -2
- package/build/src/lib/types/containers.js +2 -7
- package/build/src/lib/types/containers.js.map +1 -1
- package/build/src/lib/types/hypernode.d.ts +2 -0
- package/build/src/lib/types/hypernode.js +3 -0
- package/build/src/lib/types/hypernode.js.map +1 -0
- package/build/src/lib/types/image.d.ts +11 -5
- package/build/src/lib/types/image.js +2 -7
- package/build/src/lib/types/image.js.map +1 -1
- package/build/src/lib/types/index.d.ts +2 -0
- package/build/src/lib/types/index.js +2 -0
- package/build/src/lib/types/index.js.map +1 -1
- package/build/src/lib/types/layer.d.ts +6 -0
- package/build/src/lib/types/layer.js +7 -0
- package/build/src/lib/types/layer.js.map +1 -1
- package/build/src/lib/types/replacement.d.ts +2 -2
- package/build/src/lib/types/template.d.ts +13 -0
- package/build/src/lib/types/template.js +10 -0
- package/build/src/lib/types/template.js.map +1 -0
- package/build/src/lib/types/text.d.ts +9 -4
- package/build/src/lib/types/text.js +3 -10
- package/build/src/lib/types/text.js.map +1 -1
- package/build/src/lib/utils/container.js +10 -45
- package/build/src/lib/utils/container.js.map +1 -1
- package/build/src/lib/utils/htmlToImage.d.ts +2 -3
- package/build/src/lib/utils/htmlToImage.js.map +1 -1
- package/build/src/lib/utils/index.d.ts +1 -3
- package/build/src/lib/utils/index.js +1 -3
- package/build/src/lib/utils/index.js.map +1 -1
- package/build/src/lib/utils/placeBoundingBox.d.ts +2 -0
- package/build/src/lib/utils/placeBoundingBox.js +21 -0
- package/build/src/lib/utils/placeBoundingBox.js.map +1 -0
- package/build/src/lib/utils/placeImage.d.ts +7 -6
- package/build/src/lib/utils/placeImage.js +20 -20
- package/build/src/lib/utils/placeImage.js.map +1 -1
- package/build/src/lib/utils/placeText.d.ts +14 -0
- package/build/src/lib/utils/placeText.js +69 -0
- package/build/src/lib/utils/placeText.js.map +1 -0
- package/build/src/test.js +87 -15
- package/build/src/test.js.map +1 -1
- package/package.json +3 -1
- package/roadmap.md +3 -1
- package/src/lib/replacement.ts +6 -5
- package/src/lib/template.ts +336 -114
- package/src/lib/types/containers.ts +24 -8
- package/src/lib/types/hypernode.ts +4 -0
- package/src/lib/types/image.ts +20 -9
- package/src/lib/types/index.ts +2 -0
- package/src/lib/types/layer.ts +15 -0
- package/src/lib/types/replacement.ts +2 -2
- package/src/lib/types/template.ts +22 -0
- package/src/lib/types/text.ts +16 -12
- package/src/lib/utils/container.ts +13 -70
- package/src/lib/utils/htmlToImage.ts +3 -3
- package/src/lib/utils/index.ts +1 -3
- package/src/lib/utils/{drawBoundingBox.ts → placeBoundingBox.ts} +3 -9
- package/src/lib/utils/placeImage.ts +0 -62
- package/src/lib/utils/renderText.ts +0 -107
package/build/src/test.js
CHANGED
|
@@ -12,12 +12,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
const jimp_1 = require("jimp");
|
|
13
13
|
const lib_1 = require("./lib");
|
|
14
14
|
(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
15
|
-
const fireball = (yield jimp_1.Jimp.read('assets/fireball.png'));
|
|
16
15
|
const luigi = (yield jimp_1.Jimp.read('assets/luigi.png'));
|
|
17
16
|
const result = yield lib_1.Template.new({
|
|
18
17
|
defaultFontFamily: 'branela',
|
|
19
18
|
defaultAssetsPath: 'assets',
|
|
20
|
-
color:
|
|
19
|
+
color: 0xc3c3c3ff,
|
|
21
20
|
})
|
|
22
21
|
.text({ key: 'title' }, {
|
|
23
22
|
left: 25,
|
|
@@ -47,9 +46,9 @@ const lib_1 = require("./lib");
|
|
|
47
46
|
color: 'pink',
|
|
48
47
|
border: {
|
|
49
48
|
width: 2,
|
|
50
|
-
color: 'purple'
|
|
49
|
+
color: 'purple',
|
|
51
50
|
},
|
|
52
|
-
skip:
|
|
51
|
+
skip: entry => entry.title.toLowerCase() === 'luigi',
|
|
53
52
|
})
|
|
54
53
|
.font('assets/branela.otf', 'branela')
|
|
55
54
|
.image({ pathFn: entry => `${entry.title.toLowerCase()}.png` }, { left: 25, top: 225, width: 700, height: 700 }, {
|
|
@@ -62,14 +61,29 @@ const lib_1 = require("./lib");
|
|
|
62
61
|
width: 600,
|
|
63
62
|
height: 150,
|
|
64
63
|
}, {
|
|
64
|
+
renderBoundingBox: true,
|
|
65
65
|
font: {
|
|
66
66
|
size: 32,
|
|
67
67
|
},
|
|
68
|
-
|
|
69
|
-
.replace(['Fireball'], fireball)
|
|
70
|
-
.build(),
|
|
68
|
+
replacementFn: replacement => replacement.replace(['Fireball'], { path: 'fireball.png' }),
|
|
71
69
|
})
|
|
72
|
-
.
|
|
70
|
+
.debug()
|
|
71
|
+
.hbox(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
72
|
+
return [
|
|
73
|
+
{
|
|
74
|
+
image: {
|
|
75
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
76
|
+
},
|
|
77
|
+
options: { scale: 'keep-ratio' },
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
image: {
|
|
81
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
82
|
+
},
|
|
83
|
+
options: { scale: 'keep-ratio' },
|
|
84
|
+
},
|
|
85
|
+
];
|
|
86
|
+
}), {
|
|
73
87
|
left: 25,
|
|
74
88
|
top: 25,
|
|
75
89
|
width: 300,
|
|
@@ -77,7 +91,22 @@ const lib_1 = require("./lib");
|
|
|
77
91
|
}, {
|
|
78
92
|
gap: 100,
|
|
79
93
|
})
|
|
80
|
-
.vbox(() =>
|
|
94
|
+
.vbox(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
95
|
+
return [
|
|
96
|
+
{
|
|
97
|
+
image: {
|
|
98
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
99
|
+
},
|
|
100
|
+
options: { scale: 'stretch' },
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
image: {
|
|
104
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
105
|
+
},
|
|
106
|
+
options: { scale: 'stretch' },
|
|
107
|
+
},
|
|
108
|
+
];
|
|
109
|
+
}), {
|
|
81
110
|
left: 25,
|
|
82
111
|
top: 325,
|
|
83
112
|
width: 100,
|
|
@@ -86,11 +115,55 @@ const lib_1 = require("./lib");
|
|
|
86
115
|
scale: 'stretch',
|
|
87
116
|
gap: 50,
|
|
88
117
|
})
|
|
89
|
-
.grid(() =>
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
118
|
+
.grid(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
119
|
+
return [
|
|
120
|
+
{
|
|
121
|
+
image: {
|
|
122
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
{
|
|
126
|
+
image: {
|
|
127
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
128
|
+
},
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
image: {
|
|
132
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
133
|
+
},
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
image: {
|
|
137
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
138
|
+
},
|
|
139
|
+
},
|
|
140
|
+
{
|
|
141
|
+
image: {
|
|
142
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
143
|
+
},
|
|
144
|
+
},
|
|
145
|
+
{
|
|
146
|
+
image: {
|
|
147
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
148
|
+
},
|
|
149
|
+
},
|
|
150
|
+
{
|
|
151
|
+
image: {
|
|
152
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
153
|
+
},
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
image: {
|
|
157
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
158
|
+
},
|
|
159
|
+
},
|
|
160
|
+
{
|
|
161
|
+
image: {
|
|
162
|
+
buffer: yield luigi.clone().getBuffer('image/png'),
|
|
163
|
+
},
|
|
164
|
+
},
|
|
165
|
+
];
|
|
166
|
+
}), {
|
|
94
167
|
left: 300,
|
|
95
168
|
top: 325,
|
|
96
169
|
width: 400,
|
|
@@ -102,7 +175,6 @@ const lib_1 = require("./lib");
|
|
|
102
175
|
justifyContent: 'flex-start',
|
|
103
176
|
skip: true,
|
|
104
177
|
})
|
|
105
|
-
.debug()
|
|
106
178
|
.fromCsv('assets/data.csv', {
|
|
107
179
|
duplication: {
|
|
108
180
|
countField: 'copies',
|
package/build/src/test.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../src/test.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,+BAA4B;AAC5B,+BAAkE;AASlE,CAAC,GAAS,EAAE;IACR,MAAM,
|
|
1
|
+
{"version":3,"file":"test.js","sourceRoot":"","sources":["../../src/test.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hellkite/pipkin",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.8.0",
|
|
4
4
|
"description": "Library for board game card generation",
|
|
5
5
|
"main": "build/src/index.js",
|
|
6
6
|
"types": "build/src/index.d.ts",
|
|
@@ -20,6 +20,7 @@
|
|
|
20
20
|
"lodash.camelcase": "^4.3.0",
|
|
21
21
|
"lodash.chunk": "^4.2.0",
|
|
22
22
|
"lodash.concat": "^4.5.0",
|
|
23
|
+
"lodash.flatten": "^4.4.0",
|
|
23
24
|
"lodash.merge": "^4.6.2",
|
|
24
25
|
"node-html-to-image": "^5.0.0",
|
|
25
26
|
"papaparse": "^5.5.2",
|
|
@@ -30,6 +31,7 @@
|
|
|
30
31
|
"@types/lodash.camelcase": "^4.3.9",
|
|
31
32
|
"@types/lodash.chunk": "^4.2.9",
|
|
32
33
|
"@types/lodash.concat": "^4.5.9",
|
|
34
|
+
"@types/lodash.flatten": "^4.4.9",
|
|
33
35
|
"@types/lodash.merge": "^4.6.9",
|
|
34
36
|
"@types/node": "^22.7.5",
|
|
35
37
|
"@types/papaparse": "^5.3.15",
|
package/roadmap.md
CHANGED
|
@@ -6,14 +6,16 @@
|
|
|
6
6
|
- [ ] Draw geometry
|
|
7
7
|
- [ ] Noise/texture overlays
|
|
8
8
|
- [x] Text border
|
|
9
|
+
- [ ] Bundle to PDFs
|
|
9
10
|
|
|
10
11
|
### Bugfixes
|
|
11
12
|
- [x] Broken custom fonts
|
|
13
|
+
- [ ] keep-ration scale option seem broken
|
|
12
14
|
|
|
13
15
|
### Optimizations
|
|
14
16
|
- [ ] Optional image registry that reduce repeating loading of same images
|
|
15
17
|
- [ ] Stream processing support
|
|
16
|
-
- [
|
|
18
|
+
- [x] Overlay the entire card in HTML and render to image only once
|
|
17
19
|
|
|
18
20
|
|
|
19
21
|
### Quality of Life Improvements
|
package/src/lib/replacement.ts
CHANGED
|
@@ -1,19 +1,20 @@
|
|
|
1
|
-
import { ReplacementMap,
|
|
1
|
+
import { ReplacementMap, StaticImageRef } from "./types";
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
4
|
* Represents a replacement map between sets of words and symbols
|
|
5
5
|
*/
|
|
6
6
|
export class Replacement {
|
|
7
|
+
protected readonly replacementMap: ReplacementMap = {};
|
|
7
8
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
replace(words: Array<string>, symbol: ImageType): this {
|
|
9
|
+
replace(words: Array<string>, symbol: StaticImageRef): this {
|
|
11
10
|
words.forEach(word => {
|
|
12
|
-
this.replacementMap[word] = symbol
|
|
11
|
+
this.replacementMap[word] = symbol;
|
|
13
12
|
});
|
|
14
13
|
return this;
|
|
15
14
|
}
|
|
15
|
+
}
|
|
16
16
|
|
|
17
|
+
export class ReplacementBuilder extends Replacement {
|
|
17
18
|
build(): ReplacementMap {
|
|
18
19
|
return this.replacementMap;
|
|
19
20
|
}
|