@paroicms/site-generator-plugin 0.9.0 → 0.10.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.
Files changed (59) hide show
  1. package/gen-backend/ddl/site-generator.ddl.sql +57 -9
  2. package/gen-backend/dist/commands/execute-command.js +35 -9
  3. package/gen-backend/dist/commands/generator-session.js +49 -10
  4. package/gen-backend/dist/data-format.js +32 -4
  5. package/gen-backend/dist/db/db-init.js +3 -1
  6. package/gen-backend/dist/db/db-read.queries.js +142 -0
  7. package/gen-backend/dist/db/db-write.queries.js +144 -0
  8. package/gen-backend/dist/db/ddl-migration.js +8 -6
  9. package/gen-backend/dist/db/formatters.js +46 -0
  10. package/gen-backend/dist/generator/fake-content-generator.ts/content-report.js +9 -5
  11. package/gen-backend/dist/generator/fake-content-generator.ts/create-database-with-fake-content.js +18 -13
  12. package/gen-backend/dist/generator/fake-content-generator.ts/generate-fake-content.js +16 -12
  13. package/gen-backend/dist/generator/fake-content-generator.ts/invoke-generate-fake-content.js +26 -17
  14. package/gen-backend/dist/generator/lib/calling-llm-anthropic.js +33 -0
  15. package/gen-backend/dist/generator/lib/calling-llm-mistral.js +156 -0
  16. package/gen-backend/dist/generator/lib/create-prompt.js +2 -2
  17. package/gen-backend/dist/generator/lib/debug-utils.js +74 -48
  18. package/gen-backend/dist/generator/lib/llm-tokens.js +7 -9
  19. package/gen-backend/dist/generator/lib/llm-utils.js +8 -0
  20. package/gen-backend/dist/generator/lib/prompt-template.js +10 -0
  21. package/gen-backend/dist/generator/lib/session-utils.js +31 -0
  22. package/gen-backend/dist/generator/llm-queries/invoke-message-guard.js +20 -9
  23. package/gen-backend/dist/generator/llm-queries/invoke-new-site-analysis.js +73 -47
  24. package/gen-backend/dist/generator/llm-queries/invoke-update-site-schema.js +106 -43
  25. package/gen-backend/dist/generator/site-generator/site-generator.js +26 -18
  26. package/gen-backend/dist/lib/create-raw-context.js +31 -0
  27. package/gen-backend/dist/lib/site-remover.js +1 -1
  28. package/gen-backend/dist/plugin.js +8 -54
  29. package/gen-backend/prompts/generate-fake-content-multiple-documents.md +5 -5
  30. package/gen-backend/prompts/generate-fake-content-multiple-parts.md +5 -5
  31. package/gen-backend/prompts/generate-fake-content-single.md +4 -4
  32. package/gen-backend/prompts/{new-site-1-analysis.md → initial-1-analysis.md} +38 -29
  33. package/gen-backend/prompts/{new-site-2-fields.md → initial-2-fields.md} +3 -3
  34. package/gen-backend/prompts/message-guard.md +1 -1
  35. package/gen-backend/prompts/update-site-schema-1-write-details.md +5 -5
  36. package/gen-backend/prompts/update-site-schema-2-execute.md +29 -29
  37. package/gen-front/dist/gen-front.css +1 -1
  38. package/gen-front/dist/gen-front.mjs +137 -1175
  39. package/package.json +30 -32
  40. package/gen-backend/dist/commands/actions.js +0 -49
  41. package/gen-backend/dist/db/db.queries.js +0 -60
  42. package/gen-backend/dist/errors.js +0 -20
  43. package/gen-backend/dist/generator/actions.js +0 -45
  44. package/gen-backend/dist/generator/fake-content-generator.ts/augment-fields.js +0 -51
  45. package/gen-backend/dist/generator/generator-session.js +0 -33
  46. package/gen-backend/dist/generator/generator-types.js +0 -1
  47. package/gen-backend/dist/generator/lib/token-tracking.js +0 -118
  48. package/gen-backend/dist/generator/session/generator-session.js +0 -33
  49. package/gen-backend/dist/generator/session/session-command.js +0 -17
  50. package/gen-backend/dist/generator/site-generator/theme-scss.js +0 -262
  51. package/gen-backend/dist/lib/generator-context.js +0 -14
  52. package/gen-backend/prompts/test-message1.txt +0 -1
  53. package/gen-front/dist/gen-front.eot +0 -0
  54. package/gen-front/dist/gen-front.svg +0 -345
  55. package/gen-front/dist/gen-front.ttf +0 -0
  56. package/gen-front/dist/gen-front.woff +0 -0
  57. package/gen-front/dist/gen-front.woff2 +0 -0
  58. package/gen-front/dist/gen-front2.woff2 +0 -0
  59. package/gen-front/dist/gen-front3.woff2 +0 -0
@@ -1,262 +0,0 @@
1
- export function getThemeCssContent() {
2
- return `/* Reset */
3
- * {
4
- box-sizing: border-box;
5
- }
6
-
7
- a,
8
- a:visited {
9
- color: inherit;
10
- text-decoration: none;
11
- }
12
-
13
- /* Elements */
14
-
15
- body {
16
- background-color: #aaa;
17
- margin: 0;
18
- padding: 0;
19
- }
20
-
21
- img {
22
- display: block;
23
- max-width: 100%;
24
- }
25
-
26
- picture {
27
- display: block;
28
- }
29
-
30
- /* Tile */
31
-
32
- a > article {
33
- background-color: #fff;
34
- border-radius: 6px;
35
- box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
36
- display: flex;
37
- max-width: 340px;
38
- overflow: hidden;
39
- }
40
- a > article div:first-child {
41
- flex: 0 0 120px;
42
- max-width: 120px;
43
- }
44
- a > article img {
45
- height: 100%;
46
- object-fit: cover;
47
- width: 100%;
48
- }
49
- a > article div:last-child {
50
- display: flex;
51
- flex: 1;
52
- flex-direction: column;
53
- padding: 15px;
54
- }
55
- a > article h3 {
56
- margin: 0 0 8px;
57
- font-size: 16px;
58
- font-weight: bold;
59
- color: #333;
60
- }
61
- a > article p {
62
- color: #666;
63
- font-size: 14px;
64
- line-height: 1.4;
65
- margin: 0;
66
- }
67
-
68
- a:hover > article {
69
- box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
70
- }
71
-
72
- /* Classes */
73
-
74
- ._bg2 {
75
- background-color: #444;
76
- color: #eee;
77
- }
78
-
79
- .Container {
80
- max-width: 1200px;
81
- margin: 0 auto;
82
- padding: 0 20px;
83
- }
84
-
85
- .Page {
86
- background-color: #fff;
87
- color: #333;
88
- padding: 5px 40px;
89
- }
90
-
91
- .TextWidth {
92
- max-width: 600px;
93
- margin: 0 auto;
94
- }
95
-
96
- .List {
97
- display: flex;
98
- gap: 20px;
99
- flex-wrap: wrap;
100
- }
101
-
102
- .Header {
103
- display: flex;
104
- align-items: center;
105
- justify-content: space-between;
106
- padding-bottom: 15px;
107
- padding-top: 15px;
108
- color: #fff;
109
- }
110
-
111
- @media (max-width: 768px) {
112
- .Header {
113
- flex-wrap: wrap;
114
- padding: 15px 0 5px;
115
- }
116
- }
117
-
118
- .Header-logo {
119
- display: flex;
120
- align-items: center;
121
- }
122
-
123
- .Header-logo img {
124
- margin-right: 10px;
125
- border-radius: 50%;
126
- }
127
-
128
- .Header-title {
129
- font-size: 20px;
130
- font-weight: bold;
131
- }
132
-
133
- .Header-search {
134
- padding: 0 10px;
135
- }
136
-
137
- .Text::after {
138
- clear: both;
139
- content: "";
140
- display: block;
141
- }
142
-
143
- .Text .Img {
144
- height: auto;
145
- }
146
-
147
- .Text .Img.left {
148
- float: left;
149
- margin: 5px 20px 10px 0;
150
- }
151
-
152
- .Text .Img.right {
153
- float: right;
154
- margin: 5px 0 10px 20px;
155
- }
156
-
157
- .Text .Img.left, .Text .Img.right {
158
- max-width: 50%;
159
- }
160
-
161
- .Text .Img.center {
162
- display: block;
163
- margin: 20px auto;
164
- }
165
-
166
- .Text a,
167
- .Text a:visited,
168
- .TextLink,
169
- .TextLink:visited {
170
- color: #007bff;
171
- cursor: pointer;
172
- text-decoration: underline;
173
- }
174
-
175
- .Hero img {
176
- height: auto;
177
- width: 100%;
178
- }
179
-
180
- .InfiniteLoading-actionArea {
181
- align-items: center;
182
- display: flex;
183
- justify-content: center;
184
- }
185
-
186
- .Button,
187
- .SearchOpenerBtn,
188
- .InfiniteLoading-btn {
189
- background-color: #3498db;
190
- border: 1px solid #3498db;
191
- border-radius: 5px;
192
- color: #fff;
193
- cursor: pointer;
194
- display: inline-block;
195
- font-size: 16px;
196
- margin: 10px 0;
197
- padding: 10px 20px;
198
- text-align: center;
199
- text-decoration: none;
200
- }
201
- .Button:hover,
202
- .SearchOpenerBtn:hover,
203
- .InfiniteLoading-btn:hover {
204
- background-color: #2980b9;
205
- border-color: #2980b9;
206
- }
207
-
208
- .SearchOpenerBtn {
209
- display: flex;
210
- }
211
-
212
- .Navbar {
213
- align-items: center;
214
- display: flex;
215
- flex-grow: 1;
216
- justify-content: center;
217
- margin: 0 15px;
218
- }
219
-
220
- @media (max-width: 768px) {
221
- .Navbar {
222
- flex-basis: 100%;
223
- order: 3;
224
- margin: 10px 0 5px;
225
- justify-content: flex-start;
226
- overflow-x: auto;
227
- padding-bottom: 5px;
228
- }
229
- }
230
-
231
- .NavButton {
232
- color: rgba(255, 255, 255, 0.85);
233
- padding: 8px;
234
- margin: 0 4px;
235
- border-radius: 4px;
236
- font-size: 17px;
237
- font-weight: bold;
238
- position: relative;
239
- transition: all 0.2s ease;
240
- }
241
-
242
- .NavButton:hover {
243
- color: #fff;
244
- background-color: rgba(255, 255, 255, 0.1);
245
- }
246
-
247
- .NavButton.active {
248
- color: #fff;
249
- }
250
-
251
- .NavButton.active::after {
252
- content: "";
253
- position: absolute;
254
- bottom: 0;
255
- left: 16px;
256
- right: 16px;
257
- height: 3px;
258
- background-color: #3498db;
259
- border-radius: 1.5px;
260
- }
261
- `;
262
- }
@@ -1,14 +0,0 @@
1
- export function createCommandContext(service, pluginConf, rawContext) {
2
- const packConf = service.connector.getSitePackConf(pluginConf.packName);
3
- const { sitesDir, packName } = packConf;
4
- if (!sitesDir) {
5
- throw new Error(`Site-generator plugin can generate sites only for pack with "sitesDir", but pack "${packName}" doesn't have it`);
6
- }
7
- return {
8
- ...rawContext,
9
- sitesDir,
10
- packName,
11
- service,
12
- logger: service.logger,
13
- };
14
- }
@@ -1 +0,0 @@
1
- Je souhaite créer un site web "Mon site personnel" qui contiendra une liste d'articles, ainsi qu'une section nommée "Moins Occidental", laquelle sera dédiée à un livre. Dans "Moins Occidental", il y aura les pages du livres, mais ces pages ne seront pas des pages web, elles seront plutôt des sous-sections et elles apparaîtront toutes dans la page web de "Moins Occidental". "Moins Occidental" contient aussi une liste de sous-pages web de critiques du livre.
Binary file