@unhead/schema-org 0.6.0 → 1.3.9

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.
@@ -0,0 +1,2025 @@
1
+ 'use strict';
2
+
3
+ const ufo = require('ufo');
4
+ const shared = require('@unhead/shared');
5
+
6
+ function defineSchemaOrgResolver(schema) {
7
+ return schema;
8
+ }
9
+
10
+ function idReference(node) {
11
+ return {
12
+ "@id": typeof node !== "string" ? node["@id"] : node
13
+ };
14
+ }
15
+ function resolvableDateToDate(val) {
16
+ try {
17
+ const date = val instanceof Date ? val : new Date(Date.parse(val));
18
+ return `${date.getFullYear()}-${date.getMonth()}-${date.getDate()}`;
19
+ } catch (e) {
20
+ }
21
+ return typeof val === "string" ? val : val.toString();
22
+ }
23
+ function resolvableDateToIso(val) {
24
+ if (!val)
25
+ return val;
26
+ try {
27
+ if (val instanceof Date)
28
+ return val.toISOString();
29
+ else
30
+ return new Date(Date.parse(val)).toISOString();
31
+ } catch (e) {
32
+ }
33
+ return typeof val === "string" ? val : val.toString();
34
+ }
35
+ const IdentityId = "#identity";
36
+ function setIfEmpty(node, field, value) {
37
+ if (!node?.[field] && value)
38
+ node[field] = value;
39
+ }
40
+ function asArray(input) {
41
+ return Array.isArray(input) ? input : [input];
42
+ }
43
+ function dedupeMerge(node, field, value) {
44
+ const dedupeMerge2 = [];
45
+ const input = asArray(node[field]);
46
+ dedupeMerge2.push(...input);
47
+ const data = new Set(dedupeMerge2);
48
+ data.add(value);
49
+ node[field] = [...data.values()].filter(Boolean);
50
+ }
51
+ function prefixId(url, id) {
52
+ if (ufo.hasProtocol(id))
53
+ return url;
54
+ if (!id.startsWith("#"))
55
+ id = `#${id}`;
56
+ return ufo.joinURL(url, id);
57
+ }
58
+ function trimLength(val, length) {
59
+ if (!val)
60
+ return val;
61
+ if (val.length > length) {
62
+ const trimmedString = val.substring(0, length);
63
+ return trimmedString.substring(0, Math.min(trimmedString.length, trimmedString.lastIndexOf(" ")));
64
+ }
65
+ return val;
66
+ }
67
+ function resolveDefaultType(node, defaultType) {
68
+ const val = node["@type"];
69
+ if (val === defaultType)
70
+ return;
71
+ const types = /* @__PURE__ */ new Set([
72
+ ...asArray(defaultType),
73
+ ...asArray(val)
74
+ ]);
75
+ node["@type"] = types.size === 1 ? val : [...types.values()];
76
+ }
77
+ function resolveWithBase(base, urlOrPath) {
78
+ if (!urlOrPath || ufo.hasProtocol(urlOrPath) || !urlOrPath.startsWith("/") && !urlOrPath.startsWith("#"))
79
+ return urlOrPath;
80
+ return ufo.withBase(urlOrPath, base);
81
+ }
82
+ function resolveAsGraphKey(key) {
83
+ if (!key)
84
+ return key;
85
+ return key.substring(key.lastIndexOf("#"));
86
+ }
87
+ function stripEmptyProperties(obj) {
88
+ Object.keys(obj).forEach((k) => {
89
+ if (obj[k] && typeof obj[k] === "object") {
90
+ if (obj[k].__v_isReadonly || obj[k].__v_isRef)
91
+ return;
92
+ stripEmptyProperties(obj[k]);
93
+ return;
94
+ }
95
+ if (obj[k] === "" || obj[k] === null || typeof obj[k] === "undefined")
96
+ delete obj[k];
97
+ });
98
+ return obj;
99
+ }
100
+
101
+ const offerResolver = defineSchemaOrgResolver({
102
+ cast(node) {
103
+ if (typeof node === "number" || typeof node === "string") {
104
+ return {
105
+ price: node
106
+ };
107
+ }
108
+ return node;
109
+ },
110
+ defaults: {
111
+ "@type": "Offer",
112
+ "availability": "InStock"
113
+ },
114
+ resolve(node, ctx) {
115
+ setIfEmpty(node, "priceCurrency", ctx.meta.currency);
116
+ setIfEmpty(node, "priceValidUntil", new Date(Date.UTC((/* @__PURE__ */ new Date()).getFullYear() + 1, 12, -1, 0, 0, 0)));
117
+ if (node.url)
118
+ resolveWithBase(ctx.meta.host, node.url);
119
+ if (node.availability)
120
+ node.availability = ufo.withBase(node.availability, "https://schema.org/");
121
+ if (node.priceValidUntil)
122
+ node.priceValidUntil = resolvableDateToIso(node.priceValidUntil);
123
+ return node;
124
+ }
125
+ });
126
+
127
+ const aggregateOfferResolver = defineSchemaOrgResolver({
128
+ defaults: {
129
+ "@type": "AggregateOffer"
130
+ },
131
+ inheritMeta: [
132
+ { meta: "currency", key: "priceCurrency" }
133
+ ],
134
+ resolve(node, ctx) {
135
+ node.offers = resolveRelation(node.offers, ctx, offerResolver);
136
+ if (node.offers)
137
+ setIfEmpty(node, "offerCount", asArray(node.offers).length);
138
+ return node;
139
+ }
140
+ });
141
+
142
+ const aggregateRatingResolver = defineSchemaOrgResolver({
143
+ defaults: {
144
+ "@type": "AggregateRating"
145
+ }
146
+ });
147
+
148
+ const searchActionResolver = defineSchemaOrgResolver({
149
+ defaults: {
150
+ "@type": "SearchAction",
151
+ "target": {
152
+ "@type": "EntryPoint"
153
+ },
154
+ "query-input": {
155
+ "@type": "PropertyValueSpecification",
156
+ "valueRequired": true,
157
+ "valueName": "search_term_string"
158
+ }
159
+ },
160
+ resolve(node, ctx) {
161
+ if (typeof node.target === "string") {
162
+ node.target = {
163
+ "@type": "EntryPoint",
164
+ "urlTemplate": resolveWithBase(ctx.meta.host, node.target)
165
+ };
166
+ }
167
+ return node;
168
+ }
169
+ });
170
+
171
+ const PrimaryWebSiteId = "#website";
172
+ const webSiteResolver = defineSchemaOrgResolver({
173
+ defaults: {
174
+ "@type": "WebSite"
175
+ },
176
+ inheritMeta: [
177
+ "inLanguage",
178
+ { meta: "host", key: "url" }
179
+ ],
180
+ idPrefix: ["host", PrimaryWebSiteId],
181
+ resolve(node, ctx) {
182
+ node.potentialAction = resolveRelation(node.potentialAction, ctx, searchActionResolver, {
183
+ array: true
184
+ });
185
+ node.publisher = resolveRelation(node.publisher, ctx);
186
+ return node;
187
+ },
188
+ resolveRootNode(node, { find }) {
189
+ if (resolveAsGraphKey(node["@id"]) === PrimaryWebSiteId) {
190
+ const identity = find(IdentityId);
191
+ if (identity)
192
+ setIfEmpty(node, "publisher", idReference(identity));
193
+ const webPage = find(PrimaryWebPageId);
194
+ if (webPage)
195
+ setIfEmpty(webPage, "isPartOf", idReference(node));
196
+ }
197
+ return node;
198
+ }
199
+ });
200
+
201
+ const listItemResolver = defineSchemaOrgResolver({
202
+ cast(node) {
203
+ if (typeof node === "string") {
204
+ node = {
205
+ name: node
206
+ };
207
+ }
208
+ return node;
209
+ },
210
+ defaults: {
211
+ "@type": "ListItem"
212
+ },
213
+ resolve(node, ctx) {
214
+ if (typeof node.item === "string")
215
+ node.item = resolveWithBase(ctx.meta.host, node.item);
216
+ else if (typeof node.item === "object")
217
+ node.item = resolveRelation(node.item, ctx);
218
+ return node;
219
+ }
220
+ });
221
+
222
+ const PrimaryBreadcrumbId = "#breadcrumb";
223
+ const breadcrumbResolver = defineSchemaOrgResolver({
224
+ defaults: {
225
+ "@type": "BreadcrumbList"
226
+ },
227
+ idPrefix: ["url", PrimaryBreadcrumbId],
228
+ resolve(breadcrumb, ctx) {
229
+ if (breadcrumb.itemListElement) {
230
+ let index = 1;
231
+ breadcrumb.itemListElement = resolveRelation(breadcrumb.itemListElement, ctx, listItemResolver, {
232
+ array: true,
233
+ afterResolve(node) {
234
+ setIfEmpty(node, "position", index++);
235
+ }
236
+ });
237
+ }
238
+ return breadcrumb;
239
+ },
240
+ resolveRootNode(node, { find }) {
241
+ const webPage = find(PrimaryWebPageId);
242
+ if (webPage)
243
+ setIfEmpty(webPage, "breadcrumb", idReference(node));
244
+ }
245
+ });
246
+
247
+ const imageResolver = defineSchemaOrgResolver({
248
+ alias: "image",
249
+ cast(input) {
250
+ if (typeof input === "string") {
251
+ input = {
252
+ url: input
253
+ };
254
+ }
255
+ return input;
256
+ },
257
+ defaults: {
258
+ "@type": "ImageObject"
259
+ },
260
+ inheritMeta: [
261
+ // @todo possibly only do if there's a caption
262
+ "inLanguage"
263
+ ],
264
+ idPrefix: "host",
265
+ resolve(image, { meta }) {
266
+ image.url = resolveWithBase(meta.host, image.url);
267
+ setIfEmpty(image, "contentUrl", image.url);
268
+ if (image.height && !image.width)
269
+ delete image.height;
270
+ if (image.width && !image.height)
271
+ delete image.width;
272
+ return image;
273
+ }
274
+ });
275
+
276
+ const addressResolver = defineSchemaOrgResolver({
277
+ defaults: {
278
+ "@type": "PostalAddress"
279
+ }
280
+ });
281
+
282
+ const organizationResolver = defineSchemaOrgResolver({
283
+ defaults: {
284
+ "@type": "Organization"
285
+ },
286
+ idPrefix: ["host", IdentityId],
287
+ inheritMeta: [
288
+ { meta: "host", key: "url" }
289
+ ],
290
+ resolve(node, ctx) {
291
+ resolveDefaultType(node, "Organization");
292
+ node.address = resolveRelation(node.address, ctx, addressResolver);
293
+ return node;
294
+ },
295
+ resolveRootNode(node, ctx) {
296
+ const isIdentity = resolveAsGraphKey(node["@id"]) === IdentityId;
297
+ const webPage = ctx.find(PrimaryWebPageId);
298
+ if (node.logo) {
299
+ node.logo = resolveRelation(node.logo, ctx, imageResolver, {
300
+ root: true,
301
+ afterResolve(logo) {
302
+ if (isIdentity)
303
+ logo["@id"] = prefixId(ctx.meta.host, "#logo");
304
+ setIfEmpty(logo, "caption", node.name);
305
+ }
306
+ });
307
+ if (webPage)
308
+ setIfEmpty(webPage, "primaryImageOfPage", idReference(node.logo));
309
+ }
310
+ if (isIdentity && webPage)
311
+ setIfEmpty(webPage, "about", idReference(node));
312
+ const webSite = ctx.find(PrimaryWebSiteId);
313
+ if (webSite)
314
+ setIfEmpty(webSite, "publisher", idReference(node));
315
+ }
316
+ });
317
+
318
+ const personResolver = defineSchemaOrgResolver({
319
+ cast(node) {
320
+ if (typeof node === "string") {
321
+ return {
322
+ name: node
323
+ };
324
+ }
325
+ return node;
326
+ },
327
+ defaults: {
328
+ "@type": "Person"
329
+ },
330
+ idPrefix: ["host", IdentityId],
331
+ resolve(node, ctx) {
332
+ if (node.url)
333
+ node.url = resolveWithBase(ctx.meta.host, node.url);
334
+ return node;
335
+ },
336
+ resolveRootNode(node, { find, meta }) {
337
+ if (resolveAsGraphKey(node["@id"]) === IdentityId) {
338
+ setIfEmpty(node, "url", meta.host);
339
+ const webPage = find(PrimaryWebPageId);
340
+ if (webPage)
341
+ setIfEmpty(webPage, "about", idReference(node));
342
+ const webSite = find(PrimaryWebSiteId);
343
+ if (webSite)
344
+ setIfEmpty(webSite, "publisher", idReference(node));
345
+ }
346
+ const article = find(PrimaryArticleId);
347
+ if (article)
348
+ setIfEmpty(article, "author", idReference(node));
349
+ }
350
+ });
351
+
352
+ const readActionResolver = defineSchemaOrgResolver({
353
+ defaults: {
354
+ "@type": "ReadAction"
355
+ },
356
+ resolve(node, ctx) {
357
+ if (!node.target.includes(ctx.meta.url))
358
+ node.target.unshift(ctx.meta.url);
359
+ return node;
360
+ }
361
+ });
362
+
363
+ const PrimaryWebPageId = "#webpage";
364
+ const webPageResolver = defineSchemaOrgResolver({
365
+ defaults({ meta }) {
366
+ const endPath = ufo.withoutTrailingSlash(meta.url.substring(meta.url.lastIndexOf("/") + 1));
367
+ let type = "WebPage";
368
+ switch (endPath) {
369
+ case "about":
370
+ case "about-us":
371
+ type = "AboutPage";
372
+ break;
373
+ case "search":
374
+ type = "SearchResultsPage";
375
+ break;
376
+ case "checkout":
377
+ type = "CheckoutPage";
378
+ break;
379
+ case "contact":
380
+ case "get-in-touch":
381
+ case "contact-us":
382
+ type = "ContactPage";
383
+ break;
384
+ case "faq":
385
+ type = "FAQPage";
386
+ break;
387
+ }
388
+ const defaults = {
389
+ "@type": type
390
+ };
391
+ return defaults;
392
+ },
393
+ idPrefix: ["url", PrimaryWebPageId],
394
+ inheritMeta: [
395
+ { meta: "title", key: "name" },
396
+ "description",
397
+ "datePublished",
398
+ "dateModified",
399
+ "url"
400
+ ],
401
+ resolve(node, ctx) {
402
+ node.dateModified = resolvableDateToIso(node.dateModified);
403
+ node.datePublished = resolvableDateToIso(node.datePublished);
404
+ resolveDefaultType(node, "WebPage");
405
+ node.about = resolveRelation(node.about, ctx, organizationResolver);
406
+ node.breadcrumb = resolveRelation(node.breadcrumb, ctx, breadcrumbResolver);
407
+ node.author = resolveRelation(node.author, ctx, personResolver);
408
+ node.primaryImageOfPage = resolveRelation(node.primaryImageOfPage, ctx, imageResolver);
409
+ node.potentialAction = resolveRelation(node.potentialAction, ctx, readActionResolver);
410
+ if (node["@type"] === "WebPage") {
411
+ setIfEmpty(node, "potentialAction", [
412
+ {
413
+ "@type": "ReadAction",
414
+ "target": [ctx.meta.url]
415
+ }
416
+ ]);
417
+ }
418
+ return node;
419
+ },
420
+ resolveRootNode(webPage, { find, meta }) {
421
+ const identity = find(IdentityId);
422
+ const webSite = find(PrimaryWebSiteId);
423
+ const logo = find("#logo");
424
+ if (identity && meta.url === meta.host)
425
+ setIfEmpty(webPage, "about", idReference(identity));
426
+ if (logo)
427
+ setIfEmpty(webPage, "primaryImageOfPage", idReference(logo));
428
+ if (webSite)
429
+ setIfEmpty(webPage, "isPartOf", idReference(webSite));
430
+ const breadcrumb = find(PrimaryBreadcrumbId);
431
+ if (breadcrumb)
432
+ setIfEmpty(webPage, "breadcrumb", idReference(breadcrumb));
433
+ return webPage;
434
+ }
435
+ });
436
+
437
+ const PrimaryArticleId = "#article";
438
+ const articleResolver = defineSchemaOrgResolver({
439
+ defaults: {
440
+ "@type": "Article"
441
+ },
442
+ inheritMeta: [
443
+ "inLanguage",
444
+ "description",
445
+ "image",
446
+ "dateModified",
447
+ "datePublished",
448
+ { meta: "title", key: "headline" }
449
+ ],
450
+ idPrefix: ["url", PrimaryArticleId],
451
+ resolve(node, ctx) {
452
+ node.author = resolveRelation(node.author, ctx, personResolver, {
453
+ root: true
454
+ });
455
+ node.publisher = resolveRelation(node.publisher, ctx);
456
+ node.dateModified = resolvableDateToIso(node.dateModified);
457
+ node.datePublished = resolvableDateToIso(node.datePublished);
458
+ resolveDefaultType(node, "Article");
459
+ node.headline = trimLength(node.headline, 110);
460
+ return node;
461
+ },
462
+ resolveRootNode(node, { find, meta }) {
463
+ const webPage = find(PrimaryWebPageId);
464
+ const identity = find(IdentityId);
465
+ if (node.image && !node.thumbnailUrl) {
466
+ const firstImage = asArray(node.image)[0];
467
+ if (typeof firstImage === "string")
468
+ setIfEmpty(node, "thumbnailUrl", resolveWithBase(meta.host, firstImage));
469
+ else if (firstImage?.["@id"])
470
+ setIfEmpty(node, "thumbnailUrl", find(firstImage["@id"])?.url);
471
+ }
472
+ if (identity) {
473
+ setIfEmpty(node, "publisher", idReference(identity));
474
+ setIfEmpty(node, "author", idReference(identity));
475
+ }
476
+ if (webPage) {
477
+ setIfEmpty(node, "isPartOf", idReference(webPage));
478
+ setIfEmpty(node, "mainEntityOfPage", idReference(webPage));
479
+ setIfEmpty(webPage, "potentialAction", [
480
+ {
481
+ "@type": "ReadAction",
482
+ "target": [meta.url]
483
+ }
484
+ ]);
485
+ setIfEmpty(webPage, "dateModified", node.dateModified);
486
+ setIfEmpty(webPage, "datePublished", node.datePublished);
487
+ }
488
+ return node;
489
+ }
490
+ });
491
+
492
+ const bookEditionResolver = defineSchemaOrgResolver({
493
+ defaults: {
494
+ "@type": "Book"
495
+ },
496
+ inheritMeta: [
497
+ "inLanguage"
498
+ ],
499
+ resolve(node, ctx) {
500
+ if (node.bookFormat)
501
+ node.bookFormat = ufo.withBase(node.bookFormat, "https://schema.org/");
502
+ if (node.datePublished)
503
+ node.datePublished = resolvableDateToDate(node.datePublished);
504
+ node.author = resolveRelation(node.author, ctx);
505
+ return node;
506
+ },
507
+ resolveRootNode(node, { find }) {
508
+ const identity = find(IdentityId);
509
+ if (identity)
510
+ setIfEmpty(node, "provider", idReference(identity));
511
+ return node;
512
+ }
513
+ });
514
+ const PrimaryBookId = "#book";
515
+ const bookResolver = defineSchemaOrgResolver({
516
+ defaults: {
517
+ "@type": "Book"
518
+ },
519
+ inheritMeta: [
520
+ "description",
521
+ "url",
522
+ { meta: "title", key: "name" }
523
+ ],
524
+ idPrefix: ["url", PrimaryBookId],
525
+ resolve(node, ctx) {
526
+ node.workExample = resolveRelation(node.workExample, ctx, bookEditionResolver);
527
+ node.author = resolveRelation(node.author, ctx);
528
+ if (node.url)
529
+ ufo.withBase(node.url, ctx.meta.host);
530
+ return node;
531
+ },
532
+ resolveRootNode(node, { find }) {
533
+ const identity = find(IdentityId);
534
+ if (identity)
535
+ setIfEmpty(node, "author", idReference(identity));
536
+ return node;
537
+ }
538
+ });
539
+
540
+ const commentResolver = defineSchemaOrgResolver({
541
+ defaults: {
542
+ "@type": "Comment"
543
+ },
544
+ idPrefix: "url",
545
+ resolve(node, ctx) {
546
+ node.author = resolveRelation(node.author, ctx, personResolver, {
547
+ root: true
548
+ });
549
+ return node;
550
+ },
551
+ resolveRootNode(node, { find }) {
552
+ const article = find(PrimaryArticleId);
553
+ if (article)
554
+ setIfEmpty(node, "about", idReference(article));
555
+ }
556
+ });
557
+
558
+ const courseResolver = defineSchemaOrgResolver({
559
+ defaults: {
560
+ "@type": "Course"
561
+ },
562
+ resolve(node, ctx) {
563
+ node.provider = resolveRelation(node.provider, ctx, organizationResolver, {
564
+ root: true
565
+ });
566
+ return node;
567
+ },
568
+ resolveRootNode(node, { find }) {
569
+ const identity = find(IdentityId);
570
+ if (identity)
571
+ setIfEmpty(node, "provider", idReference(identity));
572
+ return node;
573
+ }
574
+ });
575
+
576
+ const placeResolver = defineSchemaOrgResolver({
577
+ defaults: {
578
+ "@type": "Place"
579
+ },
580
+ resolve(node, ctx) {
581
+ if (typeof node.address !== "string")
582
+ node.address = resolveRelation(node.address, ctx, addressResolver);
583
+ return node;
584
+ }
585
+ });
586
+
587
+ const virtualLocationResolver = defineSchemaOrgResolver({
588
+ cast(node) {
589
+ if (typeof node === "string") {
590
+ return {
591
+ url: node
592
+ };
593
+ }
594
+ return node;
595
+ },
596
+ defaults: {
597
+ "@type": "VirtualLocation"
598
+ }
599
+ });
600
+
601
+ const PrimaryEventId = "#event";
602
+ const eventResolver = defineSchemaOrgResolver({
603
+ defaults: {
604
+ "@type": "Event"
605
+ },
606
+ inheritMeta: [
607
+ "inLanguage",
608
+ "description",
609
+ "image",
610
+ { meta: "title", key: "name" }
611
+ ],
612
+ idPrefix: ["url", PrimaryEventId],
613
+ resolve(node, ctx) {
614
+ if (node.location) {
615
+ const isVirtual = node.location === "string" || node.location?.url !== "undefined";
616
+ node.location = resolveRelation(node.location, ctx, isVirtual ? virtualLocationResolver : placeResolver);
617
+ }
618
+ node.performer = resolveRelation(node.performer, ctx, personResolver, {
619
+ root: true
620
+ });
621
+ node.organizer = resolveRelation(node.organizer, ctx, organizationResolver, {
622
+ root: true
623
+ });
624
+ node.offers = resolveRelation(node.offers, ctx, offerResolver);
625
+ if (node.eventAttendanceMode)
626
+ node.eventAttendanceMode = ufo.withBase(node.eventAttendanceMode, "https://schema.org/");
627
+ if (node.eventStatus)
628
+ node.eventStatus = ufo.withBase(node.eventStatus, "https://schema.org/");
629
+ const isOnline = node.eventStatus === "https://schema.org/EventMovedOnline";
630
+ const dates = ["startDate", "previousStartDate", "endDate"];
631
+ dates.forEach((date) => {
632
+ if (!isOnline) {
633
+ if (node[date] instanceof Date && node[date].getHours() === 0 && node[date].getMinutes() === 0)
634
+ node[date] = resolvableDateToDate(node[date]);
635
+ } else {
636
+ node[date] = resolvableDateToIso(node[date]);
637
+ }
638
+ });
639
+ setIfEmpty(node, "endDate", node.startDate);
640
+ return node;
641
+ },
642
+ resolveRootNode(node, { find }) {
643
+ const identity = find(IdentityId);
644
+ if (identity)
645
+ setIfEmpty(node, "organizer", idReference(identity));
646
+ }
647
+ });
648
+
649
+ const howToStepDirectionResolver = defineSchemaOrgResolver({
650
+ cast(node) {
651
+ if (typeof node === "string") {
652
+ return {
653
+ text: node
654
+ };
655
+ }
656
+ return node;
657
+ },
658
+ defaults: {
659
+ "@type": "HowToDirection"
660
+ }
661
+ });
662
+
663
+ const howToStepResolver = defineSchemaOrgResolver({
664
+ cast(node) {
665
+ if (typeof node === "string") {
666
+ return {
667
+ text: node
668
+ };
669
+ }
670
+ return node;
671
+ },
672
+ defaults: {
673
+ "@type": "HowToStep"
674
+ },
675
+ resolve(step, ctx) {
676
+ if (step.url)
677
+ step.url = resolveWithBase(ctx.meta.url, step.url);
678
+ if (step.image) {
679
+ step.image = resolveRelation(step.image, ctx, imageResolver, {
680
+ root: true
681
+ });
682
+ }
683
+ if (step.itemListElement)
684
+ step.itemListElement = resolveRelation(step.itemListElement, ctx, howToStepDirectionResolver);
685
+ return step;
686
+ }
687
+ });
688
+
689
+ const HowToId = "#howto";
690
+ const howToResolver = defineSchemaOrgResolver({
691
+ defaults: {
692
+ "@type": "HowTo"
693
+ },
694
+ inheritMeta: [
695
+ "description",
696
+ "image",
697
+ "inLanguage",
698
+ { meta: "title", key: "name" }
699
+ ],
700
+ idPrefix: ["url", HowToId],
701
+ resolve(node, ctx) {
702
+ node.step = resolveRelation(node.step, ctx, howToStepResolver);
703
+ return node;
704
+ },
705
+ resolveRootNode(node, { find }) {
706
+ const webPage = find(PrimaryWebPageId);
707
+ if (webPage)
708
+ setIfEmpty(node, "mainEntityOfPage", idReference(webPage));
709
+ }
710
+ });
711
+
712
+ const itemListResolver = defineSchemaOrgResolver({
713
+ defaults: {
714
+ "@type": "ItemList"
715
+ },
716
+ resolve(node, ctx) {
717
+ if (node.itemListElement) {
718
+ let index = 1;
719
+ node.itemListElement = resolveRelation(node.itemListElement, ctx, listItemResolver, {
720
+ array: true,
721
+ afterResolve(node2) {
722
+ setIfEmpty(node2, "position", index++);
723
+ }
724
+ });
725
+ }
726
+ return node;
727
+ }
728
+ });
729
+
730
+ const quantitativeValueResolver = defineSchemaOrgResolver({
731
+ defaults: {
732
+ "@type": "QuantitativeValue"
733
+ }
734
+ });
735
+ const monetaryAmountResolver = defineSchemaOrgResolver({
736
+ defaults: {
737
+ "@type": "MonetaryAmount"
738
+ },
739
+ resolve(node, ctx) {
740
+ node.value = resolveRelation(node.value, ctx, quantitativeValueResolver);
741
+ return node;
742
+ }
743
+ });
744
+
745
+ const jobPostingResolver = defineSchemaOrgResolver({
746
+ defaults: {
747
+ "@type": "JobPosting"
748
+ },
749
+ resolve(node, ctx) {
750
+ node.datePosted = resolvableDateToIso(node.datePosted);
751
+ node.hiringOrganization = resolveRelation(node.hiringOrganization, ctx, organizationResolver);
752
+ node.jobLocation = resolveRelation(node.jobLocation, ctx, placeResolver);
753
+ node.baseSalary = resolveRelation(node.baseSalary, ctx, monetaryAmountResolver);
754
+ node.validThrough = resolvableDateToIso(node.validThrough);
755
+ return node;
756
+ }
757
+ });
758
+
759
+ const openingHoursResolver = defineSchemaOrgResolver({
760
+ defaults: {
761
+ "@type": "OpeningHoursSpecification",
762
+ "opens": "00:00",
763
+ "closes": "23:59"
764
+ }
765
+ });
766
+
767
+ const localBusinessResolver = defineSchemaOrgResolver({
768
+ defaults: {
769
+ "@type": ["Organization", "LocalBusiness"]
770
+ },
771
+ inheritMeta: [
772
+ { key: "url", meta: "host" },
773
+ { key: "currenciesAccepted", meta: "currency" }
774
+ ],
775
+ idPrefix: ["host", IdentityId],
776
+ resolve(node, ctx) {
777
+ resolveDefaultType(node, ["Organization", "LocalBusiness"]);
778
+ node.address = resolveRelation(node.address, ctx, addressResolver);
779
+ node.openingHoursSpecification = resolveRelation(node.openingHoursSpecification, ctx, openingHoursResolver);
780
+ node.logo = resolveRelation(node.logo, ctx, imageResolver, {
781
+ afterResolve(logo) {
782
+ const hasLogo = !!ctx.find("#logo");
783
+ if (!hasLogo)
784
+ logo["@id"] = prefixId(ctx.meta.host, "#logo");
785
+ setIfEmpty(logo, "caption", node.name);
786
+ }
787
+ });
788
+ return node;
789
+ }
790
+ });
791
+
792
+ const ratingResolver = defineSchemaOrgResolver({
793
+ cast(node) {
794
+ if (node === "number") {
795
+ return {
796
+ ratingValue: node
797
+ };
798
+ }
799
+ return node;
800
+ },
801
+ defaults: {
802
+ "@type": "Rating",
803
+ "bestRating": 5,
804
+ "worstRating": 1
805
+ }
806
+ });
807
+
808
+ const reviewResolver = defineSchemaOrgResolver({
809
+ defaults: {
810
+ "@type": "Review"
811
+ },
812
+ inheritMeta: [
813
+ "inLanguage"
814
+ ],
815
+ resolve(review, ctx) {
816
+ review.reviewRating = resolveRelation(review.reviewRating, ctx, ratingResolver);
817
+ review.author = resolveRelation(review.author, ctx, personResolver);
818
+ return review;
819
+ }
820
+ });
821
+
822
+ const videoResolver = defineSchemaOrgResolver({
823
+ cast(input) {
824
+ if (typeof input === "string") {
825
+ input = {
826
+ url: input
827
+ };
828
+ }
829
+ return input;
830
+ },
831
+ alias: "video",
832
+ defaults: {
833
+ "@type": "VideoObject"
834
+ },
835
+ inheritMeta: [
836
+ { meta: "title", key: "name" },
837
+ "description",
838
+ "image",
839
+ "inLanguage",
840
+ { meta: "datePublished", key: "uploadDate" }
841
+ ],
842
+ idPrefix: "host",
843
+ resolve(video, ctx) {
844
+ if (video.uploadDate)
845
+ video.uploadDate = resolvableDateToIso(video.uploadDate);
846
+ video.url = resolveWithBase(ctx.meta.host, video.url);
847
+ if (video.caption && !video.description)
848
+ video.description = video.caption;
849
+ if (!video.description)
850
+ video.description = "No description";
851
+ if (video.thumbnailUrl)
852
+ video.thumbnailUrl = resolveRelation(video.thumbnailUrl, ctx, imageResolver);
853
+ return video;
854
+ },
855
+ resolveRootNode(video, { find }) {
856
+ if (video.image && !video.thumbnailUrl) {
857
+ const firstImage = asArray(video.image)[0];
858
+ setIfEmpty(video, "thumbnailUrl", find(firstImage["@id"])?.url);
859
+ }
860
+ }
861
+ });
862
+
863
+ const movieResolver = defineSchemaOrgResolver({
864
+ defaults: {
865
+ "@type": "Movie"
866
+ },
867
+ resolve(node, ctx) {
868
+ node.aggregateRating = resolveRelation(node.aggregateRating, ctx, aggregateRatingResolver);
869
+ node.review = resolveRelation(node.review, ctx, reviewResolver);
870
+ node.director = resolveRelation(node.director, ctx, personResolver);
871
+ node.actor = resolveRelation(node.actor, ctx, personResolver);
872
+ node.trailer = resolveRelation(node.trailer, ctx, videoResolver);
873
+ if (node.dateCreated)
874
+ node.dateCreated = resolvableDateToDate(node.dateCreated);
875
+ return node;
876
+ }
877
+ });
878
+
879
+ const defaults = Object.freeze({
880
+ ignoreUnknown: false,
881
+ respectType: false,
882
+ respectFunctionNames: false,
883
+ respectFunctionProperties: false,
884
+ unorderedObjects: true,
885
+ unorderedArrays: false,
886
+ unorderedSets: false,
887
+ excludeKeys: void 0,
888
+ excludeValues: void 0,
889
+ replacer: void 0
890
+ });
891
+ function objectHash(object, options) {
892
+ if (options) {
893
+ options = { ...defaults, ...options };
894
+ } else {
895
+ options = defaults;
896
+ }
897
+ const hasher = createHasher(options);
898
+ hasher.dispatch(object);
899
+ return hasher.toString();
900
+ }
901
+ const defaultPrototypesKeys = Object.freeze([
902
+ "prototype",
903
+ "__proto__",
904
+ "constructor"
905
+ ]);
906
+ function createHasher(options) {
907
+ let buff = "";
908
+ let context = /* @__PURE__ */ new Map();
909
+ const write = (str) => {
910
+ buff += str;
911
+ };
912
+ return {
913
+ toString() {
914
+ return buff;
915
+ },
916
+ getContext() {
917
+ return context;
918
+ },
919
+ dispatch(value) {
920
+ if (options.replacer) {
921
+ value = options.replacer(value);
922
+ }
923
+ const type = value === null ? "null" : typeof value;
924
+ return this[type](value);
925
+ },
926
+ object(object) {
927
+ if (object && typeof object.toJSON === "function") {
928
+ return this.object(object.toJSON());
929
+ }
930
+ const objString = Object.prototype.toString.call(object);
931
+ let objType = "";
932
+ const objectLength = objString.length;
933
+ if (objectLength < 10) {
934
+ objType = "unknown:[" + objString + "]";
935
+ } else {
936
+ objType = objString.slice(8, objectLength - 1);
937
+ }
938
+ objType = objType.toLowerCase();
939
+ let objectNumber = null;
940
+ if ((objectNumber = context.get(object)) === void 0) {
941
+ context.set(object, context.size);
942
+ } else {
943
+ return this.dispatch("[CIRCULAR:" + objectNumber + "]");
944
+ }
945
+ if (typeof Buffer !== "undefined" && Buffer.isBuffer && Buffer.isBuffer(object)) {
946
+ write("buffer:");
947
+ return write(object.toString("utf8"));
948
+ }
949
+ if (objType !== "object" && objType !== "function" && objType !== "asyncfunction") {
950
+ if (this[objType]) {
951
+ this[objType](object);
952
+ } else if (!options.ignoreUnknown) {
953
+ this.unkown(object, objType);
954
+ }
955
+ } else {
956
+ let keys = Object.keys(object);
957
+ if (options.unorderedObjects) {
958
+ keys = keys.sort();
959
+ }
960
+ let extraKeys = [];
961
+ if (options.respectType !== false && !isNativeFunction(object)) {
962
+ extraKeys = defaultPrototypesKeys;
963
+ }
964
+ if (options.excludeKeys) {
965
+ keys = keys.filter((key) => {
966
+ return !options.excludeKeys(key);
967
+ });
968
+ extraKeys = extraKeys.filter((key) => {
969
+ return !options.excludeKeys(key);
970
+ });
971
+ }
972
+ write("object:" + (keys.length + extraKeys.length) + ":");
973
+ const dispatchForKey = (key) => {
974
+ this.dispatch(key);
975
+ write(":");
976
+ if (!options.excludeValues) {
977
+ this.dispatch(object[key]);
978
+ }
979
+ write(",");
980
+ };
981
+ for (const key of keys) {
982
+ dispatchForKey(key);
983
+ }
984
+ for (const key of extraKeys) {
985
+ dispatchForKey(key);
986
+ }
987
+ }
988
+ },
989
+ array(arr, unordered) {
990
+ unordered = unordered === void 0 ? options.unorderedArrays !== false : unordered;
991
+ write("array:" + arr.length + ":");
992
+ if (!unordered || arr.length <= 1) {
993
+ for (const entry of arr) {
994
+ this.dispatch(entry);
995
+ }
996
+ return;
997
+ }
998
+ const contextAdditions = /* @__PURE__ */ new Map();
999
+ const entries = arr.map((entry) => {
1000
+ const hasher = createHasher(options);
1001
+ hasher.dispatch(entry);
1002
+ for (const [key, value] of hasher.getContext()) {
1003
+ contextAdditions.set(key, value);
1004
+ }
1005
+ return hasher.toString();
1006
+ });
1007
+ context = contextAdditions;
1008
+ entries.sort();
1009
+ return this.array(entries, false);
1010
+ },
1011
+ date(date) {
1012
+ return write("date:" + date.toJSON());
1013
+ },
1014
+ symbol(sym) {
1015
+ return write("symbol:" + sym.toString());
1016
+ },
1017
+ unkown(value, type) {
1018
+ write(type);
1019
+ if (!value) {
1020
+ return;
1021
+ }
1022
+ write(":");
1023
+ if (value && typeof value.entries === "function") {
1024
+ return this.array(
1025
+ Array.from(value.entries()),
1026
+ true
1027
+ /* ordered */
1028
+ );
1029
+ }
1030
+ },
1031
+ error(err) {
1032
+ return write("error:" + err.toString());
1033
+ },
1034
+ boolean(bool) {
1035
+ return write("bool:" + bool);
1036
+ },
1037
+ string(string) {
1038
+ write("string:" + string.length + ":");
1039
+ write(string);
1040
+ },
1041
+ function(fn) {
1042
+ write("fn:");
1043
+ if (isNativeFunction(fn)) {
1044
+ this.dispatch("[native]");
1045
+ } else {
1046
+ this.dispatch(fn.toString());
1047
+ }
1048
+ if (options.respectFunctionNames !== false) {
1049
+ this.dispatch("function-name:" + String(fn.name));
1050
+ }
1051
+ if (options.respectFunctionProperties) {
1052
+ this.object(fn);
1053
+ }
1054
+ },
1055
+ number(number) {
1056
+ return write("number:" + number);
1057
+ },
1058
+ xml(xml) {
1059
+ return write("xml:" + xml.toString());
1060
+ },
1061
+ null() {
1062
+ return write("Null");
1063
+ },
1064
+ undefined() {
1065
+ return write("Undefined");
1066
+ },
1067
+ regexp(regex) {
1068
+ return write("regex:" + regex.toString());
1069
+ },
1070
+ uint8array(arr) {
1071
+ write("uint8array:");
1072
+ return this.dispatch(Array.prototype.slice.call(arr));
1073
+ },
1074
+ uint8clampedarray(arr) {
1075
+ write("uint8clampedarray:");
1076
+ return this.dispatch(Array.prototype.slice.call(arr));
1077
+ },
1078
+ int8array(arr) {
1079
+ write("int8array:");
1080
+ return this.dispatch(Array.prototype.slice.call(arr));
1081
+ },
1082
+ uint16array(arr) {
1083
+ write("uint16array:");
1084
+ return this.dispatch(Array.prototype.slice.call(arr));
1085
+ },
1086
+ int16array(arr) {
1087
+ write("int16array:");
1088
+ return this.dispatch(Array.prototype.slice.call(arr));
1089
+ },
1090
+ uint32array(arr) {
1091
+ write("uint32array:");
1092
+ return this.dispatch(Array.prototype.slice.call(arr));
1093
+ },
1094
+ int32array(arr) {
1095
+ write("int32array:");
1096
+ return this.dispatch(Array.prototype.slice.call(arr));
1097
+ },
1098
+ float32array(arr) {
1099
+ write("float32array:");
1100
+ return this.dispatch(Array.prototype.slice.call(arr));
1101
+ },
1102
+ float64array(arr) {
1103
+ write("float64array:");
1104
+ return this.dispatch(Array.prototype.slice.call(arr));
1105
+ },
1106
+ arraybuffer(arr) {
1107
+ write("arraybuffer:");
1108
+ return this.dispatch(new Uint8Array(arr));
1109
+ },
1110
+ url(url) {
1111
+ return write("url:" + url.toString());
1112
+ },
1113
+ map(map) {
1114
+ write("map:");
1115
+ const arr = [...map];
1116
+ return this.array(arr, options.unorderedSets !== false);
1117
+ },
1118
+ set(set) {
1119
+ write("set:");
1120
+ const arr = [...set];
1121
+ return this.array(arr, options.unorderedSets !== false);
1122
+ },
1123
+ file(file) {
1124
+ write("file:");
1125
+ return this.dispatch([file.name, file.size, file.type, file.lastModfied]);
1126
+ },
1127
+ blob() {
1128
+ if (options.ignoreUnknown) {
1129
+ return write("[blob]");
1130
+ }
1131
+ throw new Error(
1132
+ 'Hashing Blob objects is currently not supported\nUse "options.replacer" or "options.ignoreUnknown"\n'
1133
+ );
1134
+ },
1135
+ domwindow() {
1136
+ return write("domwindow");
1137
+ },
1138
+ bigint(number) {
1139
+ return write("bigint:" + number.toString());
1140
+ },
1141
+ /* Node.js standard native objects */
1142
+ process() {
1143
+ return write("process");
1144
+ },
1145
+ timer() {
1146
+ return write("timer");
1147
+ },
1148
+ pipe() {
1149
+ return write("pipe");
1150
+ },
1151
+ tcp() {
1152
+ return write("tcp");
1153
+ },
1154
+ udp() {
1155
+ return write("udp");
1156
+ },
1157
+ tty() {
1158
+ return write("tty");
1159
+ },
1160
+ statwatcher() {
1161
+ return write("statwatcher");
1162
+ },
1163
+ securecontext() {
1164
+ return write("securecontext");
1165
+ },
1166
+ connection() {
1167
+ return write("connection");
1168
+ },
1169
+ zlib() {
1170
+ return write("zlib");
1171
+ },
1172
+ context() {
1173
+ return write("context");
1174
+ },
1175
+ nodescript() {
1176
+ return write("nodescript");
1177
+ },
1178
+ httpparser() {
1179
+ return write("httpparser");
1180
+ },
1181
+ dataview() {
1182
+ return write("dataview");
1183
+ },
1184
+ signal() {
1185
+ return write("signal");
1186
+ },
1187
+ fsevent() {
1188
+ return write("fsevent");
1189
+ },
1190
+ tlswrap() {
1191
+ return write("tlswrap");
1192
+ }
1193
+ };
1194
+ }
1195
+ const nativeFunc = "[native code] }";
1196
+ const nativeFuncLength = nativeFunc.length;
1197
+ function isNativeFunction(f) {
1198
+ if (typeof f !== "function") {
1199
+ return false;
1200
+ }
1201
+ return Function.prototype.toString.call(f).slice(-nativeFuncLength) === nativeFunc;
1202
+ }
1203
+
1204
+ class WordArray {
1205
+ constructor(words, sigBytes) {
1206
+ words = this.words = words || [];
1207
+ this.sigBytes = sigBytes === void 0 ? words.length * 4 : sigBytes;
1208
+ }
1209
+ toString(encoder) {
1210
+ return (encoder || Hex).stringify(this);
1211
+ }
1212
+ concat(wordArray) {
1213
+ this.clamp();
1214
+ if (this.sigBytes % 4) {
1215
+ for (let i = 0; i < wordArray.sigBytes; i++) {
1216
+ const thatByte = wordArray.words[i >>> 2] >>> 24 - i % 4 * 8 & 255;
1217
+ this.words[this.sigBytes + i >>> 2] |= thatByte << 24 - (this.sigBytes + i) % 4 * 8;
1218
+ }
1219
+ } else {
1220
+ for (let j = 0; j < wordArray.sigBytes; j += 4) {
1221
+ this.words[this.sigBytes + j >>> 2] = wordArray.words[j >>> 2];
1222
+ }
1223
+ }
1224
+ this.sigBytes += wordArray.sigBytes;
1225
+ return this;
1226
+ }
1227
+ clamp() {
1228
+ this.words[this.sigBytes >>> 2] &= 4294967295 << 32 - this.sigBytes % 4 * 8;
1229
+ this.words.length = Math.ceil(this.sigBytes / 4);
1230
+ }
1231
+ clone() {
1232
+ return new WordArray([...this.words]);
1233
+ }
1234
+ }
1235
+ const Hex = {
1236
+ stringify(wordArray) {
1237
+ const hexChars = [];
1238
+ for (let i = 0; i < wordArray.sigBytes; i++) {
1239
+ const bite = wordArray.words[i >>> 2] >>> 24 - i % 4 * 8 & 255;
1240
+ hexChars.push((bite >>> 4).toString(16), (bite & 15).toString(16));
1241
+ }
1242
+ return hexChars.join("");
1243
+ }
1244
+ };
1245
+ const Base64 = {
1246
+ stringify(wordArray) {
1247
+ const keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
1248
+ const base64Chars = [];
1249
+ for (let i = 0; i < wordArray.sigBytes; i += 3) {
1250
+ const byte1 = wordArray.words[i >>> 2] >>> 24 - i % 4 * 8 & 255;
1251
+ const byte2 = wordArray.words[i + 1 >>> 2] >>> 24 - (i + 1) % 4 * 8 & 255;
1252
+ const byte3 = wordArray.words[i + 2 >>> 2] >>> 24 - (i + 2) % 4 * 8 & 255;
1253
+ const triplet = byte1 << 16 | byte2 << 8 | byte3;
1254
+ for (let j = 0; j < 4 && i * 8 + j * 6 < wordArray.sigBytes * 8; j++) {
1255
+ base64Chars.push(keyStr.charAt(triplet >>> 6 * (3 - j) & 63));
1256
+ }
1257
+ }
1258
+ return base64Chars.join("");
1259
+ }
1260
+ };
1261
+ const Latin1 = {
1262
+ parse(latin1Str) {
1263
+ const latin1StrLength = latin1Str.length;
1264
+ const words = [];
1265
+ for (let i = 0; i < latin1StrLength; i++) {
1266
+ words[i >>> 2] |= (latin1Str.charCodeAt(i) & 255) << 24 - i % 4 * 8;
1267
+ }
1268
+ return new WordArray(words, latin1StrLength);
1269
+ }
1270
+ };
1271
+ const Utf8 = {
1272
+ parse(utf8Str) {
1273
+ return Latin1.parse(unescape(encodeURIComponent(utf8Str)));
1274
+ }
1275
+ };
1276
+ class BufferedBlockAlgorithm {
1277
+ constructor() {
1278
+ this._data = new WordArray();
1279
+ this._nDataBytes = 0;
1280
+ this._minBufferSize = 0;
1281
+ this.blockSize = 512 / 32;
1282
+ }
1283
+ reset() {
1284
+ this._data = new WordArray();
1285
+ this._nDataBytes = 0;
1286
+ }
1287
+ _append(data) {
1288
+ if (typeof data === "string") {
1289
+ data = Utf8.parse(data);
1290
+ }
1291
+ this._data.concat(data);
1292
+ this._nDataBytes += data.sigBytes;
1293
+ }
1294
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1295
+ _doProcessBlock(_dataWords, _offset) {
1296
+ }
1297
+ _process(doFlush) {
1298
+ let processedWords;
1299
+ let nBlocksReady = this._data.sigBytes / (this.blockSize * 4);
1300
+ if (doFlush) {
1301
+ nBlocksReady = Math.ceil(nBlocksReady);
1302
+ } else {
1303
+ nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0);
1304
+ }
1305
+ const nWordsReady = nBlocksReady * this.blockSize;
1306
+ const nBytesReady = Math.min(nWordsReady * 4, this._data.sigBytes);
1307
+ if (nWordsReady) {
1308
+ for (let offset = 0; offset < nWordsReady; offset += this.blockSize) {
1309
+ this._doProcessBlock(this._data.words, offset);
1310
+ }
1311
+ processedWords = this._data.words.splice(0, nWordsReady);
1312
+ this._data.sigBytes -= nBytesReady;
1313
+ }
1314
+ return new WordArray(processedWords, nBytesReady);
1315
+ }
1316
+ }
1317
+ class Hasher extends BufferedBlockAlgorithm {
1318
+ update(messageUpdate) {
1319
+ this._append(messageUpdate);
1320
+ this._process();
1321
+ return this;
1322
+ }
1323
+ finalize(messageUpdate) {
1324
+ if (messageUpdate) {
1325
+ this._append(messageUpdate);
1326
+ }
1327
+ }
1328
+ }
1329
+
1330
+ const H = [
1331
+ 1779033703,
1332
+ -1150833019,
1333
+ 1013904242,
1334
+ -1521486534,
1335
+ 1359893119,
1336
+ -1694144372,
1337
+ 528734635,
1338
+ 1541459225
1339
+ ];
1340
+ const K = [
1341
+ 1116352408,
1342
+ 1899447441,
1343
+ -1245643825,
1344
+ -373957723,
1345
+ 961987163,
1346
+ 1508970993,
1347
+ -1841331548,
1348
+ -1424204075,
1349
+ -670586216,
1350
+ 310598401,
1351
+ 607225278,
1352
+ 1426881987,
1353
+ 1925078388,
1354
+ -2132889090,
1355
+ -1680079193,
1356
+ -1046744716,
1357
+ -459576895,
1358
+ -272742522,
1359
+ 264347078,
1360
+ 604807628,
1361
+ 770255983,
1362
+ 1249150122,
1363
+ 1555081692,
1364
+ 1996064986,
1365
+ -1740746414,
1366
+ -1473132947,
1367
+ -1341970488,
1368
+ -1084653625,
1369
+ -958395405,
1370
+ -710438585,
1371
+ 113926993,
1372
+ 338241895,
1373
+ 666307205,
1374
+ 773529912,
1375
+ 1294757372,
1376
+ 1396182291,
1377
+ 1695183700,
1378
+ 1986661051,
1379
+ -2117940946,
1380
+ -1838011259,
1381
+ -1564481375,
1382
+ -1474664885,
1383
+ -1035236496,
1384
+ -949202525,
1385
+ -778901479,
1386
+ -694614492,
1387
+ -200395387,
1388
+ 275423344,
1389
+ 430227734,
1390
+ 506948616,
1391
+ 659060556,
1392
+ 883997877,
1393
+ 958139571,
1394
+ 1322822218,
1395
+ 1537002063,
1396
+ 1747873779,
1397
+ 1955562222,
1398
+ 2024104815,
1399
+ -2067236844,
1400
+ -1933114872,
1401
+ -1866530822,
1402
+ -1538233109,
1403
+ -1090935817,
1404
+ -965641998
1405
+ ];
1406
+ const W = [];
1407
+ class SHA256 extends Hasher {
1408
+ constructor() {
1409
+ super(...arguments);
1410
+ this._hash = new WordArray([...H]);
1411
+ }
1412
+ reset() {
1413
+ super.reset();
1414
+ this._hash = new WordArray([...H]);
1415
+ }
1416
+ _doProcessBlock(M, offset) {
1417
+ const H2 = this._hash.words;
1418
+ let a = H2[0];
1419
+ let b = H2[1];
1420
+ let c = H2[2];
1421
+ let d = H2[3];
1422
+ let e = H2[4];
1423
+ let f = H2[5];
1424
+ let g = H2[6];
1425
+ let h = H2[7];
1426
+ for (let i = 0; i < 64; i++) {
1427
+ if (i < 16) {
1428
+ W[i] = M[offset + i] | 0;
1429
+ } else {
1430
+ const gamma0x = W[i - 15];
1431
+ const gamma0 = (gamma0x << 25 | gamma0x >>> 7) ^ (gamma0x << 14 | gamma0x >>> 18) ^ gamma0x >>> 3;
1432
+ const gamma1x = W[i - 2];
1433
+ const gamma1 = (gamma1x << 15 | gamma1x >>> 17) ^ (gamma1x << 13 | gamma1x >>> 19) ^ gamma1x >>> 10;
1434
+ W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16];
1435
+ }
1436
+ const ch = e & f ^ ~e & g;
1437
+ const maj = a & b ^ a & c ^ b & c;
1438
+ const sigma0 = (a << 30 | a >>> 2) ^ (a << 19 | a >>> 13) ^ (a << 10 | a >>> 22);
1439
+ const sigma1 = (e << 26 | e >>> 6) ^ (e << 21 | e >>> 11) ^ (e << 7 | e >>> 25);
1440
+ const t1 = h + sigma1 + ch + K[i] + W[i];
1441
+ const t2 = sigma0 + maj;
1442
+ h = g;
1443
+ g = f;
1444
+ f = e;
1445
+ e = d + t1 | 0;
1446
+ d = c;
1447
+ c = b;
1448
+ b = a;
1449
+ a = t1 + t2 | 0;
1450
+ }
1451
+ H2[0] = H2[0] + a | 0;
1452
+ H2[1] = H2[1] + b | 0;
1453
+ H2[2] = H2[2] + c | 0;
1454
+ H2[3] = H2[3] + d | 0;
1455
+ H2[4] = H2[4] + e | 0;
1456
+ H2[5] = H2[5] + f | 0;
1457
+ H2[6] = H2[6] + g | 0;
1458
+ H2[7] = H2[7] + h | 0;
1459
+ }
1460
+ finalize(messageUpdate) {
1461
+ super.finalize(messageUpdate);
1462
+ const nBitsTotal = this._nDataBytes * 8;
1463
+ const nBitsLeft = this._data.sigBytes * 8;
1464
+ this._data.words[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32;
1465
+ this._data.words[(nBitsLeft + 64 >>> 9 << 4) + 14] = Math.floor(
1466
+ nBitsTotal / 4294967296
1467
+ );
1468
+ this._data.words[(nBitsLeft + 64 >>> 9 << 4) + 15] = nBitsTotal;
1469
+ this._data.sigBytes = this._data.words.length * 4;
1470
+ this._process();
1471
+ return this._hash;
1472
+ }
1473
+ }
1474
+ function sha256base64(message) {
1475
+ return new SHA256().finalize(message).toString(Base64);
1476
+ }
1477
+
1478
+ function hash(object, options = {}) {
1479
+ const hashed = typeof object === "string" ? object : objectHash(object, options);
1480
+ return sha256base64(hashed).slice(0, 10);
1481
+ }
1482
+
1483
+ const ProductId = "#product";
1484
+ const productResolver = defineSchemaOrgResolver({
1485
+ defaults: {
1486
+ "@type": "Product"
1487
+ },
1488
+ inheritMeta: [
1489
+ "description",
1490
+ "image",
1491
+ { meta: "title", key: "name" }
1492
+ ],
1493
+ idPrefix: ["url", ProductId],
1494
+ resolve(node, ctx) {
1495
+ setIfEmpty(node, "sku", hash(node.name));
1496
+ node.aggregateOffer = resolveRelation(node.aggregateOffer, ctx, aggregateOfferResolver);
1497
+ node.aggregateRating = resolveRelation(node.aggregateRating, ctx, aggregateRatingResolver);
1498
+ node.offers = resolveRelation(node.offers, ctx, offerResolver);
1499
+ node.review = resolveRelation(node.review, ctx, reviewResolver);
1500
+ return node;
1501
+ },
1502
+ resolveRootNode(product, { find }) {
1503
+ const webPage = find(PrimaryWebPageId);
1504
+ const identity = find(IdentityId);
1505
+ if (identity)
1506
+ setIfEmpty(product, "brand", idReference(identity));
1507
+ if (webPage)
1508
+ setIfEmpty(product, "mainEntityOfPage", idReference(webPage));
1509
+ return product;
1510
+ }
1511
+ });
1512
+
1513
+ const answerResolver = defineSchemaOrgResolver({
1514
+ cast(node) {
1515
+ if (typeof node === "string") {
1516
+ return {
1517
+ text: node
1518
+ };
1519
+ }
1520
+ return node;
1521
+ },
1522
+ defaults: {
1523
+ "@type": "Answer"
1524
+ }
1525
+ });
1526
+
1527
+ const questionResolver = defineSchemaOrgResolver({
1528
+ defaults: {
1529
+ "@type": "Question"
1530
+ },
1531
+ inheritMeta: [
1532
+ "inLanguage"
1533
+ ],
1534
+ idPrefix: "url",
1535
+ resolve(question, ctx) {
1536
+ if (question.question)
1537
+ question.name = question.question;
1538
+ if (question.answer)
1539
+ question.acceptedAnswer = question.answer;
1540
+ question.acceptedAnswer = resolveRelation(question.acceptedAnswer, ctx, answerResolver);
1541
+ return question;
1542
+ },
1543
+ resolveRootNode(question, { find }) {
1544
+ const webPage = find(PrimaryWebPageId);
1545
+ if (webPage && asArray(webPage["@type"]).includes("FAQPage"))
1546
+ dedupeMerge(webPage, "mainEntity", idReference(question));
1547
+ }
1548
+ });
1549
+
1550
+ const RecipeId = "#recipe";
1551
+ const recipeResolver = defineSchemaOrgResolver({
1552
+ defaults: {
1553
+ "@type": "Recipe"
1554
+ },
1555
+ inheritMeta: [
1556
+ { meta: "title", key: "name" },
1557
+ "description",
1558
+ "image",
1559
+ "datePublished"
1560
+ ],
1561
+ idPrefix: ["url", RecipeId],
1562
+ resolve(node, ctx) {
1563
+ node.recipeInstructions = resolveRelation(node.recipeInstructions, ctx, howToStepResolver);
1564
+ return node;
1565
+ },
1566
+ resolveRootNode(node, { find }) {
1567
+ const article = find(PrimaryArticleId);
1568
+ const webPage = find(PrimaryWebPageId);
1569
+ if (article)
1570
+ setIfEmpty(node, "mainEntityOfPage", idReference(article));
1571
+ else if (webPage)
1572
+ setIfEmpty(node, "mainEntityOfPage", idReference(webPage));
1573
+ if (article?.author)
1574
+ setIfEmpty(node, "author", article.author);
1575
+ return node;
1576
+ }
1577
+ });
1578
+
1579
+ const softwareAppResolver = defineSchemaOrgResolver({
1580
+ defaults: {
1581
+ "@type": "SoftwareApplication"
1582
+ },
1583
+ resolve(node, ctx) {
1584
+ resolveDefaultType(node, "SoftwareApplication");
1585
+ node.offers = resolveRelation(node.offers, ctx, offerResolver);
1586
+ node.aggregateRating = resolveRelation(node.aggregateRating, ctx, aggregateRatingResolver);
1587
+ node.review = resolveRelation(node.review, ctx, reviewResolver);
1588
+ return node;
1589
+ }
1590
+ });
1591
+
1592
+ function loadResolver(resolver) {
1593
+ switch (resolver) {
1594
+ case "address":
1595
+ return addressResolver;
1596
+ case "aggregateOffer":
1597
+ return aggregateOfferResolver;
1598
+ case "aggregateRating":
1599
+ return aggregateRatingResolver;
1600
+ case "article":
1601
+ return articleResolver;
1602
+ case "breadcrumb":
1603
+ return breadcrumbResolver;
1604
+ case "comment":
1605
+ return commentResolver;
1606
+ case "event":
1607
+ return eventResolver;
1608
+ case "virtualLocation":
1609
+ return virtualLocationResolver;
1610
+ case "place":
1611
+ return placeResolver;
1612
+ case "howTo":
1613
+ return howToResolver;
1614
+ case "howToStep":
1615
+ return howToStepResolver;
1616
+ case "image":
1617
+ return imageResolver;
1618
+ case "localBusiness":
1619
+ return localBusinessResolver;
1620
+ case "offer":
1621
+ return offerResolver;
1622
+ case "openingHours":
1623
+ return openingHoursResolver;
1624
+ case "organization":
1625
+ return organizationResolver;
1626
+ case "person":
1627
+ return personResolver;
1628
+ case "product":
1629
+ return productResolver;
1630
+ case "question":
1631
+ return questionResolver;
1632
+ case "recipe":
1633
+ return recipeResolver;
1634
+ case "review":
1635
+ return reviewResolver;
1636
+ case "video":
1637
+ return videoResolver;
1638
+ case "webPage":
1639
+ return webPageResolver;
1640
+ case "webSite":
1641
+ return webSiteResolver;
1642
+ case "book":
1643
+ return bookResolver;
1644
+ case "course":
1645
+ return courseResolver;
1646
+ case "itemList":
1647
+ return itemListResolver;
1648
+ case "jobPosting":
1649
+ return jobPostingResolver;
1650
+ case "listItem":
1651
+ return listItemResolver;
1652
+ case "movie":
1653
+ return movieResolver;
1654
+ case "searchAction":
1655
+ return searchActionResolver;
1656
+ case "readAction":
1657
+ return readActionResolver;
1658
+ case "softwareApp":
1659
+ return softwareAppResolver;
1660
+ case "bookEdition":
1661
+ return bookEditionResolver;
1662
+ }
1663
+ return null;
1664
+ }
1665
+
1666
+ const resolver = {
1667
+ __proto__: null,
1668
+ loadResolver: loadResolver
1669
+ };
1670
+
1671
+ function resolveMeta(meta) {
1672
+ if (!meta.host && meta.canonicalHost)
1673
+ meta.host = meta.canonicalHost;
1674
+ if (!meta.tagPosition && meta.position)
1675
+ meta.tagPosition = meta.position;
1676
+ if (!meta.currency && meta.defaultCurrency)
1677
+ meta.currency = meta.defaultCurrency;
1678
+ if (!meta.inLanguage && meta.defaultLanguage)
1679
+ meta.inLanguage = meta.defaultLanguage;
1680
+ if (!meta.path)
1681
+ meta.path = "/";
1682
+ if (!meta.host && typeof document !== "undefined")
1683
+ meta.host = document.location.host;
1684
+ if (!meta.url && meta.canonicalUrl)
1685
+ meta.url = meta.canonicalUrl;
1686
+ if (meta.path !== "/") {
1687
+ if (meta.trailingSlash && !ufo.hasTrailingSlash(meta.path))
1688
+ meta.path = ufo.withTrailingSlash(meta.path);
1689
+ else if (!meta.trailingSlash && ufo.hasTrailingSlash(meta.path))
1690
+ meta.path = ufo.withoutTrailingSlash(meta.path);
1691
+ }
1692
+ meta.url = ufo.joinURL(meta.host, meta.path);
1693
+ return {
1694
+ ...meta,
1695
+ host: meta.host,
1696
+ url: meta.url,
1697
+ currency: meta.currency,
1698
+ image: meta.image,
1699
+ inLanguage: meta.inLanguage,
1700
+ title: meta.title,
1701
+ description: meta.description,
1702
+ datePublished: meta.datePublished,
1703
+ dateModified: meta.dateModified
1704
+ };
1705
+ }
1706
+ function resolveNode(node, ctx, resolver) {
1707
+ if (resolver?.cast)
1708
+ node = resolver.cast(node, ctx);
1709
+ if (resolver?.defaults) {
1710
+ let defaults = resolver.defaults || {};
1711
+ if (typeof defaults === "function")
1712
+ defaults = defaults(ctx);
1713
+ node = {
1714
+ ...defaults,
1715
+ ...node
1716
+ };
1717
+ }
1718
+ resolver.inheritMeta?.forEach((entry) => {
1719
+ if (typeof entry === "string")
1720
+ setIfEmpty(node, entry, ctx.meta[entry]);
1721
+ else
1722
+ setIfEmpty(node, entry.key, ctx.meta[entry.meta]);
1723
+ });
1724
+ if (resolver?.resolve)
1725
+ node = resolver.resolve(node, ctx);
1726
+ for (const k in node) {
1727
+ const v = node[k];
1728
+ if (typeof v === "object" && v?._resolver)
1729
+ node[k] = resolveRelation(v, ctx, v._resolver);
1730
+ }
1731
+ stripEmptyProperties(node);
1732
+ return node;
1733
+ }
1734
+ function resolveNodeId(node, ctx, resolver, resolveAsRoot = false) {
1735
+ const prefix = Array.isArray(resolver.idPrefix) ? resolver.idPrefix[0] : resolver.idPrefix;
1736
+ if (!prefix)
1737
+ return node;
1738
+ if (node["@id"] && !node["@id"].startsWith(ctx.meta.host)) {
1739
+ node["@id"] = prefixId(ctx.meta[prefix], node["@id"]);
1740
+ return node;
1741
+ }
1742
+ const rootId = Array.isArray(resolver.idPrefix) ? resolver.idPrefix?.[1] : void 0;
1743
+ if (resolveAsRoot && rootId) {
1744
+ node["@id"] = prefixId(ctx.meta[prefix], rootId);
1745
+ }
1746
+ if (!node["@id"]) {
1747
+ let alias = resolver?.alias;
1748
+ if (!alias) {
1749
+ const type = asArray(node["@type"])?.[0] || "";
1750
+ alias = type.toLowerCase();
1751
+ }
1752
+ const hashNodeData = {};
1753
+ Object.entries(node).forEach(([key, val]) => {
1754
+ if (!key.startsWith("_"))
1755
+ hashNodeData[key] = val;
1756
+ });
1757
+ node["@id"] = prefixId(ctx.meta[prefix], `#/schema/${alias}/${shared.hashCode(JSON.stringify(hashNodeData))}`);
1758
+ }
1759
+ return node;
1760
+ }
1761
+ function resolveRelation(input, ctx, fallbackResolver, options = {}) {
1762
+ if (!input)
1763
+ return input;
1764
+ const ids = asArray(input).map((a) => {
1765
+ if (Object.keys(a).length === 1 && a["@id"])
1766
+ return a;
1767
+ let resolver = fallbackResolver;
1768
+ if (a._resolver) {
1769
+ resolver = a._resolver;
1770
+ if (typeof resolver === "string")
1771
+ resolver = loadResolver(resolver);
1772
+ delete a._resolver;
1773
+ }
1774
+ if (!resolver)
1775
+ return a;
1776
+ let node = resolveNode(a, ctx, resolver);
1777
+ if (options.afterResolve)
1778
+ options.afterResolve(node);
1779
+ if (options.generateId || options.root)
1780
+ node = resolveNodeId(node, ctx, resolver, false);
1781
+ if (options.root) {
1782
+ if (resolver.resolveRootNode)
1783
+ resolver.resolveRootNode(node, ctx);
1784
+ ctx.push(node);
1785
+ return idReference(node["@id"]);
1786
+ }
1787
+ return node;
1788
+ });
1789
+ if (!options.array && ids.length === 1)
1790
+ return ids[0];
1791
+ return ids;
1792
+ }
1793
+
1794
+ function isObject(value) {
1795
+ return value !== null && typeof value === "object";
1796
+ }
1797
+ function _defu(baseObject, defaults, namespace = ".", merger) {
1798
+ if (!isObject(defaults)) {
1799
+ return _defu(baseObject, {}, namespace, merger);
1800
+ }
1801
+ const object = Object.assign({}, defaults);
1802
+ for (const key in baseObject) {
1803
+ if (key === "__proto__" || key === "constructor") {
1804
+ continue;
1805
+ }
1806
+ const value = baseObject[key];
1807
+ if (value === null || value === void 0) {
1808
+ continue;
1809
+ }
1810
+ if (merger && merger(object, key, value, namespace)) {
1811
+ continue;
1812
+ }
1813
+ if (Array.isArray(value) && Array.isArray(object[key])) {
1814
+ object[key] = [...value, ...object[key]];
1815
+ } else if (isObject(value) && isObject(object[key])) {
1816
+ object[key] = _defu(
1817
+ value,
1818
+ object[key],
1819
+ (namespace ? `${namespace}.` : "") + key.toString(),
1820
+ merger
1821
+ );
1822
+ } else {
1823
+ object[key] = value;
1824
+ }
1825
+ }
1826
+ return object;
1827
+ }
1828
+ function createDefu(merger) {
1829
+ return (...arguments_) => (
1830
+ // eslint-disable-next-line unicorn/no-array-reduce
1831
+ arguments_.reduce((p, c) => _defu(p, c, "", merger), {})
1832
+ );
1833
+ }
1834
+ const defu = createDefu();
1835
+
1836
+ function groupBy(array, predicate) {
1837
+ return array.reduce((acc, value, index, array2) => {
1838
+ const key = predicate(value, index, array2);
1839
+ if (!acc[key])
1840
+ acc[key] = [];
1841
+ acc[key].push(value);
1842
+ return acc;
1843
+ }, {});
1844
+ }
1845
+ function dedupeNodes(nodes) {
1846
+ const dedupedNodes = {};
1847
+ for (const key of nodes.keys()) {
1848
+ const n = nodes[key];
1849
+ const nodeKey = resolveAsGraphKey(n["@id"] || hash(n));
1850
+ if (dedupedNodes[nodeKey])
1851
+ dedupedNodes[nodeKey] = defu(nodes[key], dedupedNodes[nodeKey]);
1852
+ else
1853
+ dedupedNodes[nodeKey] = nodes[key];
1854
+ }
1855
+ return Object.values(dedupedNodes);
1856
+ }
1857
+ function normaliseNodes(nodes) {
1858
+ const sortedNodeKeys = nodes.keys();
1859
+ const dedupedNodes = {};
1860
+ for (const key of sortedNodeKeys) {
1861
+ const n = nodes[key];
1862
+ const nodeKey = resolveAsGraphKey(n["@id"] || hash(n));
1863
+ const groupedKeys = groupBy(Object.keys(n), (key2) => {
1864
+ const val = n[key2];
1865
+ if (key2.startsWith("_"))
1866
+ return "ignored";
1867
+ if (Array.isArray(val) || typeof val === "object")
1868
+ return "relations";
1869
+ return "primitives";
1870
+ });
1871
+ const keys = [
1872
+ ...(groupedKeys.primitives || []).sort(),
1873
+ ...(groupedKeys.relations || []).sort()
1874
+ ];
1875
+ let newNode = {};
1876
+ for (const key2 of keys)
1877
+ newNode[key2] = n[key2];
1878
+ if (dedupedNodes[nodeKey])
1879
+ newNode = defu(newNode, dedupedNodes[nodeKey]);
1880
+ dedupedNodes[nodeKey] = newNode;
1881
+ }
1882
+ return Object.values(dedupedNodes);
1883
+ }
1884
+
1885
+ function createSchemaOrgGraph() {
1886
+ const ctx = {
1887
+ find(id) {
1888
+ const key = resolveAsGraphKey(id);
1889
+ return ctx.nodes.filter((n) => !!n["@id"]).find((n) => resolveAsGraphKey(n["@id"]) === key);
1890
+ },
1891
+ push(input) {
1892
+ asArray(input).forEach((node) => {
1893
+ const registeredNode = node;
1894
+ ctx.nodes.push(registeredNode);
1895
+ });
1896
+ },
1897
+ resolveGraph(meta) {
1898
+ ctx.meta = resolveMeta({ ...meta });
1899
+ ctx.nodes.forEach((node, key) => {
1900
+ const resolver = node._resolver;
1901
+ if (resolver) {
1902
+ node = resolveNode(node, ctx, resolver);
1903
+ node = resolveNodeId(node, ctx, resolver, true);
1904
+ }
1905
+ ctx.nodes[key] = node;
1906
+ });
1907
+ ctx.nodes = dedupeNodes(ctx.nodes);
1908
+ ctx.nodes.forEach((node) => {
1909
+ if (node.image && typeof node.image === "string") {
1910
+ node.image = resolveRelation(node.image, ctx, imageResolver, {
1911
+ root: true
1912
+ });
1913
+ }
1914
+ if (node._resolver?.resolveRootNode)
1915
+ node._resolver.resolveRootNode(node, ctx);
1916
+ delete node._resolver;
1917
+ });
1918
+ return normaliseNodes(ctx.nodes);
1919
+ },
1920
+ nodes: [],
1921
+ meta: {}
1922
+ };
1923
+ return ctx;
1924
+ }
1925
+
1926
+ function SchemaOrgUnheadPlugin(config, meta) {
1927
+ config = resolveMeta({ ...config });
1928
+ let graph;
1929
+ const resolvedMeta = {};
1930
+ return {
1931
+ hooks: {
1932
+ "entries:resolve": function() {
1933
+ graph = createSchemaOrgGraph();
1934
+ },
1935
+ "tag:normalise": async function({ tag }) {
1936
+ if (tag.key === "schema-org-graph") {
1937
+ const { loadResolver } = await Promise.resolve().then(function () { return resolver; });
1938
+ const nodes = await tag.props.nodes;
1939
+ for (const node of Array.isArray(nodes) ? nodes : [nodes]) {
1940
+ const newNode = {
1941
+ ...node,
1942
+ _resolver: loadResolver(await node._resolver)
1943
+ };
1944
+ graph.push(newNode);
1945
+ }
1946
+ tag.tagPosition = config.tagPosition === "head" ? "head" : "bodyClose";
1947
+ }
1948
+ if (tag.tag === "title")
1949
+ resolvedMeta.title = tag.textContent;
1950
+ else if (tag.tag === "meta" && tag.props.name === "description")
1951
+ resolvedMeta.description = tag.props.content;
1952
+ else if (tag.tag === "link" && tag.props.rel === "canonical")
1953
+ resolvedMeta.url = tag.props.href;
1954
+ else if (tag.tag === "meta" && tag.props.property === "og:image")
1955
+ resolvedMeta.image = tag.props.content;
1956
+ },
1957
+ "tags:resolve": async function(ctx) {
1958
+ for (const tag of ctx.tags) {
1959
+ if (tag.tag === "script" && tag.key === "schema-org-graph") {
1960
+ tag.innerHTML = JSON.stringify({
1961
+ "@context": "https://schema.org",
1962
+ "@graph": graph.resolveGraph({ ...config, ...resolvedMeta, ...await meta() })
1963
+ }, null, 2);
1964
+ delete tag.props.nodes;
1965
+ }
1966
+ }
1967
+ }
1968
+ }
1969
+ };
1970
+ }
1971
+
1972
+ exports.HowToId = HowToId;
1973
+ exports.PrimaryArticleId = PrimaryArticleId;
1974
+ exports.PrimaryBookId = PrimaryBookId;
1975
+ exports.PrimaryBreadcrumbId = PrimaryBreadcrumbId;
1976
+ exports.PrimaryEventId = PrimaryEventId;
1977
+ exports.PrimaryWebPageId = PrimaryWebPageId;
1978
+ exports.PrimaryWebSiteId = PrimaryWebSiteId;
1979
+ exports.ProductId = ProductId;
1980
+ exports.RecipeId = RecipeId;
1981
+ exports.SchemaOrgUnheadPlugin = SchemaOrgUnheadPlugin;
1982
+ exports.addressResolver = addressResolver;
1983
+ exports.aggregateOfferResolver = aggregateOfferResolver;
1984
+ exports.aggregateRatingResolver = aggregateRatingResolver;
1985
+ exports.articleResolver = articleResolver;
1986
+ exports.bookEditionResolver = bookEditionResolver;
1987
+ exports.bookResolver = bookResolver;
1988
+ exports.breadcrumbResolver = breadcrumbResolver;
1989
+ exports.commentResolver = commentResolver;
1990
+ exports.courseResolver = courseResolver;
1991
+ exports.createSchemaOrgGraph = createSchemaOrgGraph;
1992
+ exports.dedupeNodes = dedupeNodes;
1993
+ exports.defineSchemaOrgResolver = defineSchemaOrgResolver;
1994
+ exports.eventResolver = eventResolver;
1995
+ exports.howToResolver = howToResolver;
1996
+ exports.howToStepDirectionResolver = howToStepDirectionResolver;
1997
+ exports.howToStepResolver = howToStepResolver;
1998
+ exports.imageResolver = imageResolver;
1999
+ exports.itemListResolver = itemListResolver;
2000
+ exports.jobPostingResolver = jobPostingResolver;
2001
+ exports.listItemResolver = listItemResolver;
2002
+ exports.localBusinessResolver = localBusinessResolver;
2003
+ exports.movieResolver = movieResolver;
2004
+ exports.normaliseNodes = normaliseNodes;
2005
+ exports.offerResolver = offerResolver;
2006
+ exports.openingHoursResolver = openingHoursResolver;
2007
+ exports.organizationResolver = organizationResolver;
2008
+ exports.personResolver = personResolver;
2009
+ exports.placeResolver = placeResolver;
2010
+ exports.productResolver = productResolver;
2011
+ exports.questionResolver = questionResolver;
2012
+ exports.ratingResolver = ratingResolver;
2013
+ exports.readActionResolver = readActionResolver;
2014
+ exports.recipeResolver = recipeResolver;
2015
+ exports.resolveMeta = resolveMeta;
2016
+ exports.resolveNode = resolveNode;
2017
+ exports.resolveNodeId = resolveNodeId;
2018
+ exports.resolveRelation = resolveRelation;
2019
+ exports.reviewResolver = reviewResolver;
2020
+ exports.searchActionResolver = searchActionResolver;
2021
+ exports.softwareAppResolver = softwareAppResolver;
2022
+ exports.videoResolver = videoResolver;
2023
+ exports.virtualLocationResolver = virtualLocationResolver;
2024
+ exports.webPageResolver = webPageResolver;
2025
+ exports.webSiteResolver = webSiteResolver;