1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074 |
- import React from 'react';
- import Head from 'next/head';
- function _extends() {
- _extends = Object.assign ? Object.assign.bind() : function (target) {
- for (var i = 1; i < arguments.length; i++) {
- var source = arguments[i];
- for (var key in source) {
- if (Object.prototype.hasOwnProperty.call(source, key)) {
- target[key] = source[key];
- }
- }
- }
- return target;
- };
- return _extends.apply(this, arguments);
- }
- function _objectWithoutPropertiesLoose(source, excluded) {
- if (source == null) return {};
- var target = {};
- var sourceKeys = Object.keys(source);
- var key, i;
- for (i = 0; i < sourceKeys.length; i++) {
- key = sourceKeys[i];
- if (excluded.indexOf(key) >= 0) continue;
- target[key] = source[key];
- }
- return target;
- }
- var _excluded$x = ["keyOverride"];
- var defaults = {
- templateTitle: '',
- noindex: false,
- nofollow: false,
- defaultOpenGraphImageWidth: 0,
- defaultOpenGraphImageHeight: 0,
- defaultOpenGraphVideoWidth: 0,
- defaultOpenGraphVideoHeight: 0
- };
- var buildOpenGraphMediaTags = function buildOpenGraphMediaTags(mediaType, media, _temp) {
- if (media === void 0) {
- media = [];
- }
- var _ref = _temp === void 0 ? {} : _temp,
- defaultWidth = _ref.defaultWidth,
- defaultHeight = _ref.defaultHeight;
- return media.reduce(function (tags, medium, index) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":0" + index,
- property: "og:" + mediaType,
- content: medium.url
- }));
- if (medium.alt) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":alt0" + index,
- property: "og:" + mediaType + ":alt",
- content: medium.alt
- }));
- }
- if (medium.secureUrl) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":secure_url0" + index,
- property: "og:" + mediaType + ":secure_url",
- content: medium.secureUrl.toString()
- }));
- }
- if (medium.type) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":type0" + index,
- property: "og:" + mediaType + ":type",
- content: medium.type.toString()
- }));
- }
- if (medium.width) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":width0" + index,
- property: "og:" + mediaType + ":width",
- content: medium.width.toString()
- }));
- } else if (defaultWidth) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":width0" + index,
- property: "og:" + mediaType + ":width",
- content: defaultWidth.toString()
- }));
- }
- if (medium.height) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":height" + index,
- property: "og:" + mediaType + ":height",
- content: medium.height.toString()
- }));
- } else if (defaultHeight) {
- tags.push( React.createElement("meta", {
- key: "og:" + mediaType + ":height" + index,
- property: "og:" + mediaType + ":height",
- content: defaultHeight.toString()
- }));
- }
- return tags;
- }, []);
- };
- var buildTags = function buildTags(config) {
- var _config$openGraph, _config$openGraph3, _config$additionalLin;
- var tagsToRender = [];
- if (config.titleTemplate) {
- defaults.templateTitle = config.titleTemplate;
- }
- var updatedTitle = '';
- if (config.title) {
- updatedTitle = config.title;
- if (defaults.templateTitle) {
- updatedTitle = defaults.templateTitle.replace(/%s/g, function () {
- return updatedTitle;
- });
- }
- } else if (config.defaultTitle) {
- updatedTitle = config.defaultTitle;
- }
- if (updatedTitle) {
- tagsToRender.push( React.createElement("title", {
- key: "title"
- }, updatedTitle));
- }
- var noindex = config.noindex || defaults.noindex || config.dangerouslySetAllPagesToNoIndex;
- var nofollow = config.nofollow || defaults.nofollow || config.dangerouslySetAllPagesToNoFollow;
- var robotsParams = '';
- if (config.robotsProps) {
- var _config$robotsProps = config.robotsProps,
- nosnippet = _config$robotsProps.nosnippet,
- maxSnippet = _config$robotsProps.maxSnippet,
- maxImagePreview = _config$robotsProps.maxImagePreview,
- maxVideoPreview = _config$robotsProps.maxVideoPreview,
- noarchive = _config$robotsProps.noarchive,
- noimageindex = _config$robotsProps.noimageindex,
- notranslate = _config$robotsProps.notranslate,
- unavailableAfter = _config$robotsProps.unavailableAfter;
- robotsParams = "" + (nosnippet ? ',nosnippet' : '') + (maxSnippet ? ",max-snippet:" + maxSnippet : '') + (maxImagePreview ? ",max-image-preview:" + maxImagePreview : '') + (noarchive ? ',noarchive' : '') + (unavailableAfter ? ",unavailable_after:" + unavailableAfter : '') + (noimageindex ? ',noimageindex' : '') + (maxVideoPreview ? ",max-video-preview:" + maxVideoPreview : '') + (notranslate ? ',notranslate' : '');
- }
- if (noindex || nofollow) {
- if (config.dangerouslySetAllPagesToNoIndex) {
- defaults.noindex = true;
- }
- if (config.dangerouslySetAllPagesToNoFollow) {
- defaults.nofollow = true;
- }
- tagsToRender.push( React.createElement("meta", {
- key: "robots",
- name: "robots",
- content: (noindex ? 'noindex' : 'index') + "," + (nofollow ? 'nofollow' : 'follow') + robotsParams
- }));
- } else {
- tagsToRender.push( React.createElement("meta", {
- key: "robots",
- name: "robots",
- content: "index,follow" + robotsParams
- }));
- }
- if (config.description) {
- tagsToRender.push( React.createElement("meta", {
- key: "description",
- name: "description",
- content: config.description
- }));
- }
- if (config.themeColor) {
- tagsToRender.push( React.createElement("meta", {
- key: "theme-color",
- name: "theme-color",
- content: config.themeColor
- }));
- }
- if (config.mobileAlternate) {
- tagsToRender.push( React.createElement("link", {
- rel: "alternate",
- key: "mobileAlternate",
- media: config.mobileAlternate.media,
- href: config.mobileAlternate.href
- }));
- }
- if (config.languageAlternates && config.languageAlternates.length > 0) {
- config.languageAlternates.forEach(function (languageAlternate) {
- tagsToRender.push( React.createElement("link", {
- rel: "alternate",
- key: "languageAlternate-" + languageAlternate.hrefLang,
- hrefLang: languageAlternate.hrefLang,
- href: languageAlternate.href
- }));
- });
- }
- if (config.twitter) {
- if (config.twitter.cardType) {
- tagsToRender.push( React.createElement("meta", {
- key: "twitter:card",
- name: "twitter:card",
- content: config.twitter.cardType
- }));
- }
- if (config.twitter.site) {
- tagsToRender.push( React.createElement("meta", {
- key: "twitter:site",
- name: "twitter:site",
- content: config.twitter.site
- }));
- }
- if (config.twitter.handle) {
- tagsToRender.push( React.createElement("meta", {
- key: "twitter:creator",
- name: "twitter:creator",
- content: config.twitter.handle
- }));
- }
- }
- if (config.facebook) {
- if (config.facebook.appId) {
- tagsToRender.push( React.createElement("meta", {
- key: "fb:app_id",
- property: "fb:app_id",
- content: config.facebook.appId
- }));
- }
- }
- if ((_config$openGraph = config.openGraph) != null && _config$openGraph.title || updatedTitle) {
- var _config$openGraph2;
- tagsToRender.push( React.createElement("meta", {
- key: "og:title",
- property: "og:title",
- content: ((_config$openGraph2 = config.openGraph) == null ? void 0 : _config$openGraph2.title) || updatedTitle
- }));
- }
- if ((_config$openGraph3 = config.openGraph) != null && _config$openGraph3.description || config.description) {
- var _config$openGraph4;
- tagsToRender.push( React.createElement("meta", {
- key: "og:description",
- property: "og:description",
- content: ((_config$openGraph4 = config.openGraph) == null ? void 0 : _config$openGraph4.description) || config.description
- }));
- }
- if (config.openGraph) {
- if (config.openGraph.url || config.canonical) {
- tagsToRender.push( React.createElement("meta", {
- key: "og:url",
- property: "og:url",
- content: config.openGraph.url || config.canonical
- }));
- }
- if (config.openGraph.type) {
- var type = config.openGraph.type.toLowerCase();
- tagsToRender.push( React.createElement("meta", {
- key: "og:type",
- property: "og:type",
- content: type
- }));
- if (type === 'profile' && config.openGraph.profile) {
- if (config.openGraph.profile.firstName) {
- tagsToRender.push( React.createElement("meta", {
- key: "profile:first_name",
- property: "profile:first_name",
- content: config.openGraph.profile.firstName
- }));
- }
- if (config.openGraph.profile.lastName) {
- tagsToRender.push( React.createElement("meta", {
- key: "profile:last_name",
- property: "profile:last_name",
- content: config.openGraph.profile.lastName
- }));
- }
- if (config.openGraph.profile.username) {
- tagsToRender.push( React.createElement("meta", {
- key: "profile:username",
- property: "profile:username",
- content: config.openGraph.profile.username
- }));
- }
- if (config.openGraph.profile.gender) {
- tagsToRender.push( React.createElement("meta", {
- key: "profile:gender",
- property: "profile:gender",
- content: config.openGraph.profile.gender
- }));
- }
- } else if (type === 'book' && config.openGraph.book) {
- if (config.openGraph.book.authors && config.openGraph.book.authors.length) {
- config.openGraph.book.authors.forEach(function (author, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "book:author:0" + index,
- property: "book:author",
- content: author
- }));
- });
- }
- if (config.openGraph.book.isbn) {
- tagsToRender.push( React.createElement("meta", {
- key: "book:isbn",
- property: "book:isbn",
- content: config.openGraph.book.isbn
- }));
- }
- if (config.openGraph.book.releaseDate) {
- tagsToRender.push( React.createElement("meta", {
- key: "book:release_date",
- property: "book:release_date",
- content: config.openGraph.book.releaseDate
- }));
- }
- if (config.openGraph.book.tags && config.openGraph.book.tags.length) {
- config.openGraph.book.tags.forEach(function (tag, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "book:tag:0" + index,
- property: "book:tag",
- content: tag
- }));
- });
- }
- } else if (type === 'article' && config.openGraph.article) {
- if (config.openGraph.article.publishedTime) {
- tagsToRender.push( React.createElement("meta", {
- key: "article:published_time",
- property: "article:published_time",
- content: config.openGraph.article.publishedTime
- }));
- }
- if (config.openGraph.article.modifiedTime) {
- tagsToRender.push( React.createElement("meta", {
- key: "article:modified_time",
- property: "article:modified_time",
- content: config.openGraph.article.modifiedTime
- }));
- }
- if (config.openGraph.article.expirationTime) {
- tagsToRender.push( React.createElement("meta", {
- key: "article:expiration_time",
- property: "article:expiration_time",
- content: config.openGraph.article.expirationTime
- }));
- }
- if (config.openGraph.article.authors && config.openGraph.article.authors.length) {
- config.openGraph.article.authors.forEach(function (author, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "article:author:0" + index,
- property: "article:author",
- content: author
- }));
- });
- }
- if (config.openGraph.article.section) {
- tagsToRender.push( React.createElement("meta", {
- key: "article:section",
- property: "article:section",
- content: config.openGraph.article.section
- }));
- }
- if (config.openGraph.article.tags && config.openGraph.article.tags.length) {
- config.openGraph.article.tags.forEach(function (tag, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "article:tag:0" + index,
- property: "article:tag",
- content: tag
- }));
- });
- }
- } else if ((type === 'video.movie' || type === 'video.episode' || type === 'video.tv_show' || type === 'video.other') && config.openGraph.video) {
- if (config.openGraph.video.actors && config.openGraph.video.actors.length) {
- config.openGraph.video.actors.forEach(function (actor, index) {
- if (actor.profile) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:actor:0" + index,
- property: "video:actor",
- content: actor.profile
- }));
- }
- if (actor.role) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:actor:role:0" + index,
- property: "video:actor:role",
- content: actor.role
- }));
- }
- });
- }
- if (config.openGraph.video.directors && config.openGraph.video.directors.length) {
- config.openGraph.video.directors.forEach(function (director, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:director:0" + index,
- property: "video:director",
- content: director
- }));
- });
- }
- if (config.openGraph.video.writers && config.openGraph.video.writers.length) {
- config.openGraph.video.writers.forEach(function (writer, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:writer:0" + index,
- property: "video:writer",
- content: writer
- }));
- });
- }
- if (config.openGraph.video.duration) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:duration",
- property: "video:duration",
- content: config.openGraph.video.duration.toString()
- }));
- }
- if (config.openGraph.video.releaseDate) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:release_date",
- property: "video:release_date",
- content: config.openGraph.video.releaseDate
- }));
- }
- if (config.openGraph.video.tags && config.openGraph.video.tags.length) {
- config.openGraph.video.tags.forEach(function (tag, index) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:tag:0" + index,
- property: "video:tag",
- content: tag
- }));
- });
- }
- if (config.openGraph.video.series) {
- tagsToRender.push( React.createElement("meta", {
- key: "video:series",
- property: "video:series",
- content: config.openGraph.video.series
- }));
- }
- }
- }
-
- if (config.defaultOpenGraphImageWidth) {
- defaults.defaultOpenGraphImageWidth = config.defaultOpenGraphImageWidth;
- }
- if (config.defaultOpenGraphImageHeight) {
- defaults.defaultOpenGraphImageHeight = config.defaultOpenGraphImageHeight;
- }
- if (config.openGraph.images && config.openGraph.images.length) {
- tagsToRender.push.apply(tagsToRender, buildOpenGraphMediaTags('image', config.openGraph.images, {
- defaultWidth: defaults.defaultOpenGraphImageWidth,
- defaultHeight: defaults.defaultOpenGraphImageHeight
- }));
- }
-
- if (config.defaultOpenGraphVideoWidth) {
- defaults.defaultOpenGraphVideoWidth = config.defaultOpenGraphVideoWidth;
- }
- if (config.defaultOpenGraphVideoHeight) {
- defaults.defaultOpenGraphVideoHeight = config.defaultOpenGraphVideoHeight;
- }
- if (config.openGraph.videos && config.openGraph.videos.length) {
- tagsToRender.push.apply(tagsToRender, buildOpenGraphMediaTags('video', config.openGraph.videos, {
- defaultWidth: defaults.defaultOpenGraphVideoWidth,
- defaultHeight: defaults.defaultOpenGraphVideoHeight
- }));
- }
-
- if (config.openGraph.audio) {
- tagsToRender.push.apply(tagsToRender, buildOpenGraphMediaTags('audio', config.openGraph.audio));
- }
- if (config.openGraph.locale) {
- tagsToRender.push( React.createElement("meta", {
- key: "og:locale",
- property: "og:locale",
- content: config.openGraph.locale
- }));
- }
- if (config.openGraph.siteName || config.openGraph.site_name) {
- tagsToRender.push( React.createElement("meta", {
- key: "og:site_name",
- property: "og:site_name",
- content: config.openGraph.siteName || config.openGraph.site_name
- }));
- }
- }
- if (config.canonical) {
- tagsToRender.push( React.createElement("link", {
- rel: "canonical",
- href: config.canonical,
- key: "canonical"
- }));
- }
- if (config.additionalMetaTags && config.additionalMetaTags.length > 0) {
- config.additionalMetaTags.forEach(function (_ref2) {
- var _ref3, _ref4;
- var keyOverride = _ref2.keyOverride,
- tag = _objectWithoutPropertiesLoose(_ref2, _excluded$x);
- tagsToRender.push( React.createElement("meta", _extends({
- key: "meta:" + ((_ref3 = (_ref4 = keyOverride != null ? keyOverride : tag.name) != null ? _ref4 : tag.property) != null ? _ref3 : tag.httpEquiv)
- }, tag)));
- });
- }
- if ((_config$additionalLin = config.additionalLinkTags) != null && _config$additionalLin.length) {
- config.additionalLinkTags.forEach(function (tag) {
- var _tag$keyOverride;
- tagsToRender.push( React.createElement("link", _extends({
- key: "link" + ((_tag$keyOverride = tag.keyOverride) != null ? _tag$keyOverride : tag.href) + tag.rel
- }, tag)));
- });
- }
- return tagsToRender;
- };
- var WithHead = function WithHead(props) {
- return React.createElement(Head, null, buildTags(props));
- };
- var DefaultSeo = function DefaultSeo(_ref) {
- var title = _ref.title,
- titleTemplate = _ref.titleTemplate,
- defaultTitle = _ref.defaultTitle,
- themeColor = _ref.themeColor,
- _ref$dangerouslySetAl = _ref.dangerouslySetAllPagesToNoIndex,
- dangerouslySetAllPagesToNoIndex = _ref$dangerouslySetAl === void 0 ? false : _ref$dangerouslySetAl,
- _ref$dangerouslySetAl2 = _ref.dangerouslySetAllPagesToNoFollow,
- dangerouslySetAllPagesToNoFollow = _ref$dangerouslySetAl2 === void 0 ? false : _ref$dangerouslySetAl2,
- description = _ref.description,
- canonical = _ref.canonical,
- facebook = _ref.facebook,
- openGraph = _ref.openGraph,
- additionalMetaTags = _ref.additionalMetaTags,
- twitter = _ref.twitter,
- defaultOpenGraphImageWidth = _ref.defaultOpenGraphImageWidth,
- defaultOpenGraphImageHeight = _ref.defaultOpenGraphImageHeight,
- defaultOpenGraphVideoWidth = _ref.defaultOpenGraphVideoWidth,
- defaultOpenGraphVideoHeight = _ref.defaultOpenGraphVideoHeight,
- mobileAlternate = _ref.mobileAlternate,
- languageAlternates = _ref.languageAlternates,
- additionalLinkTags = _ref.additionalLinkTags,
- robotsProps = _ref.robotsProps;
- return React.createElement(WithHead, {
- title: title,
- titleTemplate: titleTemplate,
- defaultTitle: defaultTitle,
- themeColor: themeColor,
- dangerouslySetAllPagesToNoIndex: dangerouslySetAllPagesToNoIndex,
- dangerouslySetAllPagesToNoFollow: dangerouslySetAllPagesToNoFollow,
- description: description,
- canonical: canonical,
- facebook: facebook,
- openGraph: openGraph,
- additionalMetaTags: additionalMetaTags,
- twitter: twitter,
- defaultOpenGraphImageWidth: defaultOpenGraphImageWidth,
- defaultOpenGraphImageHeight: defaultOpenGraphImageHeight,
- defaultOpenGraphVideoWidth: defaultOpenGraphVideoWidth,
- defaultOpenGraphVideoHeight: defaultOpenGraphVideoHeight,
- mobileAlternate: mobileAlternate,
- languageAlternates: languageAlternates,
- additionalLinkTags: additionalLinkTags,
- robotsProps: robotsProps
- });
- };
- var NextSeo = function NextSeo(_ref) {
- var title = _ref.title,
- themeColor = _ref.themeColor,
- _ref$noindex = _ref.noindex,
- noindex = _ref$noindex === void 0 ? false : _ref$noindex,
- nofollow = _ref.nofollow,
- robotsProps = _ref.robotsProps,
- description = _ref.description,
- canonical = _ref.canonical,
- openGraph = _ref.openGraph,
- facebook = _ref.facebook,
- twitter = _ref.twitter,
- additionalMetaTags = _ref.additionalMetaTags,
- titleTemplate = _ref.titleTemplate,
- defaultTitle = _ref.defaultTitle,
- mobileAlternate = _ref.mobileAlternate,
- languageAlternates = _ref.languageAlternates,
- additionalLinkTags = _ref.additionalLinkTags,
- _ref$useAppDir = _ref.useAppDir,
- useAppDir = _ref$useAppDir === void 0 ? false : _ref$useAppDir;
- return React.createElement(React.Fragment, null, useAppDir ? buildTags({
- title: title,
- themeColor: themeColor,
- noindex: noindex,
- nofollow: nofollow,
- robotsProps: robotsProps,
- description: description,
- canonical: canonical,
- facebook: facebook,
- openGraph: openGraph,
- additionalMetaTags: additionalMetaTags,
- twitter: twitter,
- titleTemplate: titleTemplate,
- defaultTitle: defaultTitle,
- mobileAlternate: mobileAlternate,
- languageAlternates: languageAlternates,
- additionalLinkTags: additionalLinkTags
- }) : React.createElement(WithHead, {
- title: title,
- themeColor: themeColor,
- noindex: noindex,
- nofollow: nofollow,
- robotsProps: robotsProps,
- description: description,
- canonical: canonical,
- facebook: facebook,
- openGraph: openGraph,
- additionalMetaTags: additionalMetaTags,
- twitter: twitter,
- titleTemplate: titleTemplate,
- defaultTitle: defaultTitle,
- mobileAlternate: mobileAlternate,
- languageAlternates: languageAlternates,
- additionalLinkTags: additionalLinkTags
- }));
- };
- var toJson = function toJson(type, jsonld) {
- var data = jsonld;
- if (Array.isArray(data) && data.length === 1) {
- data = _extends({}, jsonld[0]);
- }
- var jsonLdObject = Array.isArray(data) ? data.map(function (item) {
- return formatObjectForSchema(type, item);
- }) : formatObjectForSchema(type, data);
- return {
- __html: JSON.stringify(jsonLdObject, safeJsonLdReplacer)
- };
- };
- var formatObjectForSchema = function formatObjectForSchema(type, jsonld) {
- var _jsonld$id = jsonld.id,
- id = _jsonld$id === void 0 ? undefined : _jsonld$id;
- var updated = _extends({}, id ? {
- '@id': jsonld.id
- } : {}, jsonld);
- delete updated.id;
- return _extends({
- '@context': 'https://schema.org',
- '@type': type
- }, updated);
- };
- var ESCAPE_ENTITIES = Object.freeze({
- '&': '&',
- '<': '<',
- '>': '>',
- '"': '"',
- "'": '''
- });
- var ESCAPE_REGEX = new RegExp("[" + Object.keys(ESCAPE_ENTITIES).join('') + "]", 'g');
- var ESCAPE_REPLACER = function ESCAPE_REPLACER(t) {
- return ESCAPE_ENTITIES[t];
- };
- var safeJsonLdReplacer = function () {
-
-
- return function (_, value) {
- switch (typeof value) {
- case 'object':
-
- if (value === null) {
- return undefined;
- }
- return value;
-
- case 'number':
- case 'boolean':
- case 'bigint':
- return value;
-
- case 'string':
- return value.replace(ESCAPE_REGEX, ESCAPE_REPLACER);
- default:
- {
-
- return undefined;
- }
- }
- };
- }();
- var _excluded$w = ["type", "keyOverride", "scriptKey", "scriptId", "dataArray", "useAppDir"];
- function JsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Thing' : _ref$type,
- keyOverride = _ref.keyOverride,
- scriptKey = _ref.scriptKey,
- _ref$scriptId = _ref.scriptId,
- scriptId = _ref$scriptId === void 0 ? undefined : _ref$scriptId,
- dataArray = _ref.dataArray,
- _ref$useAppDir = _ref.useAppDir,
- useAppDir = _ref$useAppDir === void 0 ? false : _ref$useAppDir,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$w);
- var JsonLdScript = function JsonLdScript() {
- return React.createElement("script", {
- type: "application/ld+json",
- id: scriptId,
- "data-testid": scriptId,
- dangerouslySetInnerHTML: toJson(type, dataArray === undefined ? _extends({}, rest) : dataArray),
- key: "jsonld-" + scriptKey + (keyOverride ? "-" + keyOverride : '')
- });
- };
- if (useAppDir) {
- return React.createElement(JsonLdScript, null);
- }
- return React.createElement(Head, null, JsonLdScript());
- }
- function generateAuthorInfo(author) {
- if (typeof author === 'string') {
- return {
- '@type': 'Person',
- name: author
- };
- } else if (!!author.name) {
- var _author$type;
- return {
- '@type': (_author$type = author == null ? void 0 : author.type) != null ? _author$type : 'Person',
- name: author.name,
- url: author == null ? void 0 : author.url
- };
- }
- return;
- }
- function setAuthor(author) {
- if (Array.isArray(author)) {
- return author.map(function (item) {
- return generateAuthorInfo(item);
- }).filter(function (item) {
- return !!item;
- });
- } else if (author) {
- return generateAuthorInfo(author);
- }
- return;
- }
- function setImage(image) {
- if (image) {
- return {
- '@type': 'ImageObject',
- url: image
- };
- }
- return undefined;
- }
- function setPublisher(publisherName, publisherLogo) {
- if (!publisherName) {
- return undefined;
- }
- return {
- '@type': 'Organization',
- name: publisherName,
- logo: setImage(publisherLogo)
- };
- }
- function setReviewRating(rating) {
- if (rating) {
- return _extends({}, rating, {
- '@type': 'Rating'
- });
- }
- return undefined;
- }
- var _excluded$v = ["reviewRating", "author", "publisher"];
- function setReviews(reviews) {
- function mapReview(_ref) {
- var reviewRating = _ref.reviewRating,
- author = _ref.author,
- publisher = _ref.publisher,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$v);
- return _extends({}, rest, {
- '@type': 'Review'
- }, author && {
- author: setAuthor(author)
- }, reviewRating && {
- reviewRating: setReviewRating(reviewRating)
- }, publisher && {
- publisher: setPublisher(publisher.name)
- });
- }
- if (Array.isArray(reviews)) {
- return reviews.map(mapReview);
- } else if (reviews) {
- return mapReview(reviews);
- }
- return undefined;
- }
- function setNutrition(calories) {
- if (calories) {
- return {
- '@type': 'NutritionInformation',
- calories: calories + " calories"
- };
- }
- return undefined;
- }
- function setAggregateRating(aggregateRating) {
- if (aggregateRating) {
- return {
- '@type': 'AggregateRating',
- ratingCount: aggregateRating.ratingCount,
- reviewCount: aggregateRating.reviewCount,
- bestRating: aggregateRating.bestRating,
- ratingValue: aggregateRating.ratingValue
- };
- }
- return undefined;
- }
- function setClip(clips) {
- function mapClip(clip) {
- return _extends({}, clip, {
- '@type': 'Clip'
- });
- }
- if (Array.isArray(clips)) {
- return clips.map(mapClip);
- } else if (clips) {
- return mapClip(clips);
- }
- return undefined;
- }
- function setInteractionStatistic(watchCount) {
- if (watchCount) {
- return {
- '@type': 'InteractionCounter',
- interactionType: 'https://schema.org/WatchAction',
- userInteractionCount: watchCount
- };
- }
- return undefined;
- }
- function setBroadcastEvent(publication) {
- function mapBroadcastEvent(publication) {
- return _extends({}, publication, {
- '@type': 'BroadcastEvent'
- });
- }
- if (publication) {
- if (Array.isArray(publication)) {
- return publication.map(mapBroadcastEvent);
- }
- return mapBroadcastEvent(publication);
- }
- return undefined;
- }
- var _excluded$u = ["thumbnailUrls", "hasPart", "watchCount", "publication"];
- function setVideo(video, setContext) {
- if (setContext === void 0) {
- setContext = false;
- }
- function mapVideo(_ref, context) {
- var thumbnailUrls = _ref.thumbnailUrls,
- hasPart = _ref.hasPart,
- watchCount = _ref.watchCount,
- publication = _ref.publication,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$u);
- return _extends({}, rest, {
- '@type': 'VideoObject'
- }, context && {
- '@context': 'https://schema.org'
- }, {
- thumbnailUrl: thumbnailUrls,
- hasPart: setClip(hasPart),
- interactionStatistic: setInteractionStatistic(watchCount),
- publication: setBroadcastEvent(publication)
- });
- }
- if (video) {
- return mapVideo(video, setContext);
- }
- return undefined;
- }
- function setInstruction(instruction) {
- if (instruction) {
- return _extends({}, instruction, {
- '@type': 'HowToStep'
- });
- }
- return undefined;
- }
- var _excluded$t = ["type", "keyOverride", "ofType", "data"],
- _excluded2$1 = ["authorName", "images", "yields", "category", "calories", "aggregateRating", "video", "ingredients", "instructions", "cuisine"];
- function CarouselJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Carousel' : _ref$type,
- keyOverride = _ref.keyOverride,
- ofType = _ref.ofType,
- data = _ref.data,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$t);
- function generateList(data, ofType) {
- switch (ofType) {
- case 'default':
- return data.map(function (item, index) {
- return {
- '@type': 'ListItem',
- position: "" + (index + 1),
- url: item.url
- };
- });
- case 'course':
- return data.map(function (item, index) {
- return {
- '@type': 'ListItem',
- position: "" + (index + 1),
- item: {
- '@context': 'https://schema.org',
- '@type': 'Course',
- url: item.url,
- name: item.courseName,
- description: item.description,
- provider: {
- '@type': 'Organization',
- name: item.providerName,
- sameAs: item.providerUrl
- }
- }
- };
- });
- case 'movie':
- return data.map(function (item, index) {
- return {
- '@type': 'ListItem',
- position: "" + (index + 1),
- item: {
- '@context': 'https://schema.org',
- '@type': 'Movie',
- name: item.name,
- url: item.url,
- image: item.image,
- dateCreated: item.dateCreated,
- director: item.director ? Array.isArray(item.director) ? item.director.map(function (director) {
- return {
- '@type': 'Person',
- name: director.name
- };
- }) : {
- '@type': 'Person',
- name: item.director.name
- } : undefined,
- review: setReviews(item.review)
- }
- };
- });
- case 'recipe':
- return data.map(function (_ref2, index) {
- var authorName = _ref2.authorName,
- images = _ref2.images,
- yields = _ref2.yields,
- category = _ref2.category,
- calories = _ref2.calories,
- aggregateRating = _ref2.aggregateRating,
- video = _ref2.video,
- ingredients = _ref2.ingredients,
- instructions = _ref2.instructions,
- cuisine = _ref2.cuisine,
- rest = _objectWithoutPropertiesLoose(_ref2, _excluded2$1);
- return {
- '@type': 'ListItem',
- position: "" + (index + 1),
- item: _extends({
- '@context': 'https://schema.org',
- '@type': 'Recipe'
- }, rest, {
- author: setAuthor(authorName),
- image: images,
- recipeYield: yields,
- recipeCategory: category,
- recipeCuisine: cuisine,
- nutrition: setNutrition(calories),
- aggregateRating: setAggregateRating(aggregateRating),
- video: setVideo(video),
- recipeIngredient: ingredients,
- recipeInstructions: instructions.map(setInstruction)
- })
- };
- });
- }
- }
- var jsonLdData = _extends({
- '@type': 'ItemList',
- itemListElement: generateList(data, ofType)
- }, rest);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, jsonLdData, {
- scriptKey: "Carousel"
- }));
- }
- var _excluded$s = ["type", "keyOverride", "url", "title", "images", "section", "dateCreated", "datePublished", "dateModified", "authorName", "authorType", "publisherName", "publisherLogo", "body", "isAccessibleForFree"];
- function NewsArticleJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'NewsArticle' : _ref$type,
- keyOverride = _ref.keyOverride,
- url = _ref.url,
- title = _ref.title,
- images = _ref.images,
- section = _ref.section,
- dateCreated = _ref.dateCreated,
- datePublished = _ref.datePublished,
- dateModified = _ref.dateModified,
- authorName = _ref.authorName,
- publisherName = _ref.publisherName,
- publisherLogo = _ref.publisherLogo,
- body = _ref.body,
- isAccessibleForFree = _ref.isAccessibleForFree,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$s);
- var data = _extends({}, rest, {
- mainEntityOfPage: {
- '@type': 'WebPage',
- '@id': url
- },
- headline: title,
- image: images,
- articleSection: section,
- dateCreated: dateCreated || datePublished,
- datePublished: datePublished,
- dateModified: dateModified || datePublished,
- author: setAuthor(authorName),
- publisher: setPublisher(publisherName, publisherLogo),
- articleBody: body,
- isAccessibleForFree: isAccessibleForFree
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "NewsArticle"
- }));
- }
- var _excluded$r = ["type", "keyOverride", "baseSalary", "hiringOrganization", "applicantLocationRequirements", "experienceRequirements", "jobLocation"];
- function JobPostingJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'JobPosting' : _ref$type,
- keyOverride = _ref.keyOverride,
- baseSalary = _ref.baseSalary,
- hiringOrganization = _ref.hiringOrganization,
- applicantLocationRequirements = _ref.applicantLocationRequirements,
- experienceRequirements = _ref.experienceRequirements,
- jobLocation = _ref.jobLocation,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$r);
- function setBaseSalary(baseSalary) {
- if (baseSalary) {
- return {
- '@type': 'MonetaryAmount',
- currency: baseSalary.currency,
- value: _extends({
- '@type': 'QuantitativeValue',
- unitText: baseSalary.unitText
- }, Array.isArray(baseSalary.value) ? {
- minValue: baseSalary.value[0],
- maxValue: baseSalary.value[1]
- } : {
- value: baseSalary.value
- })
- };
- }
- return undefined;
- }
- function setHiringOrganization(org) {
- return {
- '@type': 'Organization',
- name: org.name,
- sameAs: org.sameAs,
- logo: org.logo
- };
- }
- function setJobLocation(location) {
- if (location) {
- return {
- '@type': 'Place',
- address: {
- '@type': 'PostalAddress',
- addressCountry: location.addressCountry,
- addressLocality: location.addressLocality,
- addressRegion: location.addressRegion,
- postalCode: location.postalCode,
- streetAddress: location.streetAddress
- }
- };
- }
- return undefined;
- }
- function setApplicantLocationRequirements(requirements) {
- if (requirements) {
- return {
- '@type': 'Country',
- name: requirements
- };
- }
- return undefined;
- }
- function setOccupationalExperienceRequirements(requirements) {
- if (requirements) {
- return {
- '@type': requirements['@type'] ? requirements['@type'] : 'OccupationalExperienceRequirements',
- monthsOfExperience: requirements.minimumMonthsOfExperience
- };
- }
- return undefined;
- }
- function setEducationalOccupationalCredential(requirements) {
- if (requirements) {
- return {
- '@type': requirements['@type'] ? requirements['@type'] : 'EducationalOccupationalCredential',
- credentialCategory: requirements.credentialCategory
- };
- }
- return undefined;
- }
- var data = _extends({}, rest, {
- baseSalary: setBaseSalary(baseSalary),
- hiringOrganization: setHiringOrganization(hiringOrganization),
- jobLocation: setJobLocation(jobLocation),
- applicantLocationRequirements: setApplicantLocationRequirements(applicantLocationRequirements),
- experienceRequirements: setOccupationalExperienceRequirements(experienceRequirements == null ? void 0 : experienceRequirements.occupational),
- educationRequirements: setEducationalOccupationalCredential(experienceRequirements == null ? void 0 : experienceRequirements.educational),
- experienceInPlaceOfEducation: experienceRequirements == null ? void 0 : experienceRequirements.experienceInPlaceOfEducation
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "JobPosting"
- }));
- }
- function setAddress(address) {
- if (!address) return undefined;
- if (!Array.isArray(address)) return toPostalAddress(address);
-
- if (address.length === 1) return toPostalAddress(address[0]);
-
- return address.map(toPostalAddress);
- }
- function toPostalAddress(address) {
- if (typeof address === 'string') return address;
- return _extends({
- '@type': 'PostalAddress'
- }, address);
- }
- function setGeo(geo) {
- if (geo) {
- return _extends({}, geo, {
- '@type': 'GeoCoordinates'
- });
- }
- return undefined;
- }
- function setAction(action) {
- if (action) {
- return {
- '@type': action.actionType,
- name: action.actionName,
- target: action.target
- };
- }
- return undefined;
- }
- function setGeoCircle(geoCircle) {
- if (geoCircle) {
- return {
- '@type': 'GeoCircle',
- geoMidpoint: {
- '@type': 'GeoCoordinates',
- latitude: geoCircle.geoMidpoint.latitude,
- longitude: geoCircle.geoMidpoint.longitude
- },
- geoRadius: geoCircle.geoRadius
- };
- }
- return undefined;
- }
- function setOffer(offer) {
- function setPriceSpecification(priceSpecification) {
- if (priceSpecification) {
- return {
- '@type': priceSpecification.type,
- priceCurrency: priceSpecification.priceCurrency,
- price: priceSpecification.price
- };
- }
- return undefined;
- }
- function setItemOffered(itemOffered) {
- if (itemOffered) {
- return _extends({}, itemOffered, {
- '@type': 'Service'
- });
- }
- return undefined;
- }
- if (offer) {
- return _extends({}, offer, {
- '@type': 'Offer',
- priceSpecification: setPriceSpecification(offer.priceSpecification),
- itemOffered: setItemOffered(offer.itemOffered)
- });
- }
- return undefined;
- }
- function setOpeningHours(openingHours) {
- if (openingHours) {
- return _extends({}, openingHours, {
- '@type': 'OpeningHoursSpecification'
- });
- }
- return undefined;
- }
- var _excluded$q = ["type", "keyOverride", "address", "geo", "rating", "review", "action", "areaServed", "makesOffer", "openingHours", "images"];
- function LocalBusinessJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'LocalBusiness' : _ref$type,
- keyOverride = _ref.keyOverride,
- address = _ref.address,
- geo = _ref.geo,
- rating = _ref.rating,
- review = _ref.review,
- action = _ref.action,
- areaServed = _ref.areaServed,
- makesOffer = _ref.makesOffer,
- openingHours = _ref.openingHours,
- images = _ref.images,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$q);
- var data = _extends({}, rest, {
- image: images,
- address: setAddress(address),
- geo: setGeo(geo),
- aggregateRating: setAggregateRating(rating),
- review: setReviews(review),
- potentialAction: setAction(action),
- areaServed: areaServed && areaServed.map(setGeoCircle),
- makesOffer: makesOffer == null ? void 0 : makesOffer.map(setOffer),
- openingHoursSpecification: Array.isArray(openingHours) ? openingHours.map(setOpeningHours) : setOpeningHours(openingHours)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "LocalBusiness"
- }));
- }
- var _excluded$p = ["type", "keyOverride", "mainEntity"],
- _excluded2 = ["upvoteCount"];
- function QAPageJsonLd(_ref) {
- var _mainEntity$author, _mainEntity$acceptedA, _mainEntity$acceptedA2;
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'QAPage' : _ref$type,
- keyOverride = _ref.keyOverride,
- mainEntity = _ref.mainEntity,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$p);
- var data = _extends({}, rest, {
- mainEntity: _extends({}, mainEntity, {
- '@type': 'Question',
- author: setAuthor((_mainEntity$author = mainEntity.author) == null ? void 0 : _mainEntity$author.name)
- }, mainEntity.acceptedAnswer && {
- acceptedAnswer: _extends({}, mainEntity.acceptedAnswer, {
- '@type': 'Answer',
- author: setAuthor((_mainEntity$acceptedA = mainEntity.acceptedAnswer) == null ? void 0 : (_mainEntity$acceptedA2 = _mainEntity$acceptedA.author) == null ? void 0 : _mainEntity$acceptedA2.name)
- })
- }, mainEntity.suggestedAnswer && {
- suggestedAnswer: mainEntity.suggestedAnswer.map(function (_ref2) {
- var _rest$author;
- var upvoteCount = _ref2.upvoteCount,
- rest = _objectWithoutPropertiesLoose(_ref2, _excluded2);
- return _extends({}, rest, {
- '@type': 'Answer',
- upvoteCount: upvoteCount || 0,
- author: setAuthor((_rest$author = rest.author) == null ? void 0 : _rest$author.name)
- });
- })
- })
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "QAPage"
- }));
- }
- function setItemListElements(items) {
- if (items && items.length) {
- return items.map(function (item) {
- return {
- '@type': 'ListItem',
- position: item.position,
- item: {
- '@id': item.item,
- name: item.name
- }
- };
- });
- }
- return undefined;
- }
- var _excluded$o = ["type", "keyOverride", "breadcrumb"];
- function ProfilePageJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'ProfilePage' : _ref$type,
- keyOverride = _ref.keyOverride,
- breadcrumb = _ref.breadcrumb,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$o);
- var data = _extends({}, rest, {
- breadcrumb: Array.isArray(breadcrumb) ? {
- '@type': 'BreadcrumbList',
- itemListElement: setItemListElements(breadcrumb)
- } : breadcrumb
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "ProfilePage"
- }));
- }
- var _excluded$n = ["type", "keyOverride", "potentialActions"];
- function SiteLinksSearchBoxJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'WebSite' : _ref$type,
- keyOverride = _ref.keyOverride,
- potentialActions = _ref.potentialActions,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$n);
- function setPotentialAction(action) {
- if (action) {
- var target = action.target,
- queryInput = action.queryInput;
- return {
- '@type': 'SearchAction',
- target: target + "={" + queryInput + "}",
- 'query-input': "required name=" + queryInput
- };
- }
- return undefined;
- }
- var data = _extends({}, rest, {
- potentialAction: potentialActions.map(setPotentialAction)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "jsonld-siteLinksSearchBox"
- }));
- }
- var _excluded$m = ["type", "keyOverride", "authorName", "images", "yields", "category", "cuisine", "calories", "aggregateRating", "video", "ingredients", "instructions"];
- function RecipeJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Recipe' : _ref$type,
- keyOverride = _ref.keyOverride,
- authorName = _ref.authorName,
- images = _ref.images,
- yields = _ref.yields,
- category = _ref.category,
- cuisine = _ref.cuisine,
- calories = _ref.calories,
- aggregateRating = _ref.aggregateRating,
- video = _ref.video,
- ingredients = _ref.ingredients,
- instructions = _ref.instructions,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$m);
- var data = _extends({}, rest, {
- author: setAuthor(authorName),
- image: images,
- recipeYield: yields,
- recipeCategory: category,
- recipeCuisine: cuisine,
- nutrition: setNutrition(calories),
- aggregateRating: setAggregateRating(aggregateRating),
- video: setVideo(video),
- recipeIngredient: ingredients,
- recipeInstructions: instructions ? instructions.map(setInstruction) : undefined
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "recipe"
- }));
- }
- function setLocation(location) {
- if (!location) {
- return undefined;
- }
- if (typeof location === 'string') {
- return location;
- }
- if ('url' in location) {
- return setVirtualLocation(location);
- } else {
- return setPlace(location);
- }
- }
- function setVirtualLocation(location) {
- return _extends({}, location, {
- '@type': 'VirtualLocation'
- });
- }
- function setPlace(location) {
- return _extends({}, location, {
- address: setAddress(location.address),
- '@type': 'Place'
- });
- }
- var _excluded$l = ["type"];
- function setPerformer(performer) {
- if (performer) {
- var type = performer.type,
- restPerformer = _objectWithoutPropertiesLoose(performer, _excluded$l);
- return _extends({}, restPerformer, {
- '@type': type || 'PerformingGroup'
- });
- }
- return undefined;
- }
- var _excluded$k = ["seller"];
- function setOffers(offers) {
- function mapOffer(_ref) {
- var seller = _ref.seller,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$k);
- return _extends({}, rest, {
- '@type': 'Offer'
- }, seller && {
- seller: {
- '@type': 'Organization',
- name: seller.name
- }
- });
- }
- if (Array.isArray(offers)) {
- return offers.map(mapOffer);
- } else if (offers) {
- return mapOffer(offers);
- }
- return undefined;
- }
- function setAggregateOffer(aggregateOffer) {
- if (aggregateOffer) {
- return {
- '@type': 'AggregateOffer',
- priceCurrency: aggregateOffer.priceCurrency,
- highPrice: aggregateOffer.highPrice,
- lowPrice: aggregateOffer.lowPrice,
- offerCount: aggregateOffer.offerCount,
- offers: setOffers(aggregateOffer.offers)
- };
- }
- return undefined;
- }
- var _excluded$j = ["type"];
- function setOrganizer(organizer) {
- if (organizer) {
- var type = organizer.type,
- restOrganizer = _objectWithoutPropertiesLoose(organizer, _excluded$j);
- return _extends({}, restOrganizer, {
- '@type': type || 'Person'
- });
- }
- return undefined;
- }
- var _excluded$i = ["type", "keyOverride", "location", "images", "offers", "aggregateOffer", "performers", "organizer", "eventStatus", "eventAttendanceMode"];
- function EventJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Event' : _ref$type,
- keyOverride = _ref.keyOverride,
- location = _ref.location,
- images = _ref.images,
- offers = _ref.offers,
- aggregateOffer = _ref.aggregateOffer,
- performers = _ref.performers,
- organizer = _ref.organizer,
- eventStatus = _ref.eventStatus,
- eventAttendanceMode = _ref.eventAttendanceMode,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$i);
- var data = _extends({}, rest, {
- location: setLocation(location),
- image: images,
- offers: offers ? setOffers(offers) : setAggregateOffer(aggregateOffer),
- performer: Array.isArray(performers) ? performers.map(setPerformer) : setPerformer(performers),
- organizer: Array.isArray(organizer) ? organizer.map(setOrganizer) : setOrganizer(organizer),
- eventStatus: eventStatus ? "https://schema.org/" + eventStatus : undefined,
- eventAttendanceMode: eventAttendanceMode ? "https://schema.org/" + eventAttendanceMode : undefined
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "Event"
- }));
- }
- function setContactPoint(contactPoint) {
- if (contactPoint) {
- return _extends({}, contactPoint, {
- '@type': 'ContactPoint'
- });
- }
- return undefined;
- }
- var _excluded$h = ["type", "keyOverride", "contactPoint"];
- function CorporateContactJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Organization' : _ref$type,
- keyOverride = _ref.keyOverride,
- contactPoint = _ref.contactPoint,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$h);
- var data = _extends({}, rest, {
- contactPoint: contactPoint.map(setContactPoint)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "CorporateContact"
- }));
- }
- function setCreativeWork(creativeWork) {
- if (creativeWork) {
- return _extends({}, creativeWork, {
- '@type': 'CreativeWork'
- });
- }
- return undefined;
- }
- var _excluded$g = ["type", "keyOverride", "hasPart"];
- function CollectionPageJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'CollectionPage' : _ref$type,
- keyOverride = _ref.keyOverride,
- hasPart = _ref.hasPart,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$g);
- var data = _extends({}, rest, {
- hasPart: hasPart.map(setCreativeWork)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "CollectionPage"
- }));
- }
- function setManufacturer(manufacturer) {
- if (manufacturer && (manufacturer.manufacturerName || manufacturer.manufacturerLogo)) {
- return {
- '@type': 'Organization',
- name: manufacturer.manufacturerName,
- logo: setImage(manufacturer.manufacturerLogo)
- };
- }
- return undefined;
- }
- function setBrand(brand) {
- if (brand) {
- return {
- '@type': 'Brand',
- name: brand
- };
- }
- return undefined;
- }
- var _excluded$f = ["type", "keyOverride", "images", "brand", "reviews", "aggregateRating", "manufacturerLogo", "manufacturerName", "offers", "aggregateOffer", "productName"];
- function ProductJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Product' : _ref$type,
- keyOverride = _ref.keyOverride,
- images = _ref.images,
- brand = _ref.brand,
- reviews = _ref.reviews,
- aggregateRating = _ref.aggregateRating,
- manufacturerLogo = _ref.manufacturerLogo,
- manufacturerName = _ref.manufacturerName,
- offers = _ref.offers,
- aggregateOffer = _ref.aggregateOffer,
- productName = _ref.productName,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$f);
- var data = _extends({}, rest, {
- image: images,
- brand: setBrand(brand),
- review: setReviews(reviews),
- aggregateRating: setAggregateRating(aggregateRating),
- manufacturer: setManufacturer({
- manufacturerLogo: manufacturerLogo,
- manufacturerName: manufacturerName
- }),
- offers: offers ? setOffers(offers) : setAggregateOffer(aggregateOffer),
- name: productName
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "Product"
- }));
- }
- var _excluded$e = ["type", "keyOverride", "priceCurrency", "price", "aggregateRating", "review"];
- function SoftwareAppJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'SoftwareApplication' : _ref$type,
- keyOverride = _ref.keyOverride,
- priceCurrency = _ref.priceCurrency,
- price = _ref.price,
- aggregateRating = _ref.aggregateRating,
- review = _ref.review,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$e);
- var data = _extends({}, rest, {
- offers: {
- '@type': 'Offer',
- price: price,
- priceCurrency: priceCurrency
- },
- aggregateRating: setAggregateRating(aggregateRating),
- review: setReviews(review)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "SoftwareApp"
- }));
- }
- var _excluded$d = ["type", "keyOverride"];
- function VideoJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Video' : _ref$type,
- keyOverride = _ref.keyOverride,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$d);
- var data = setVideo(rest, true);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "Video"
- }));
- }
- function setProducer(producer) {
- if (producer) {
- return {
- '@type': 'Organization',
- sameAs: producer.url,
- name: producer.name
- };
- }
- return undefined;
- }
- function setProvider(provider) {
- if (provider) {
- return {
- '@type': provider.type || 'Organization',
- name: provider.name,
- sameAs: provider.url
- };
- }
- return undefined;
- }
- var _excluded$c = ["type", "keyOverride", "aggregateRating", "trailer", "reviews", "image", "authorName", "provider", "producerName", "producerUrl", "offers", "operatingSystemName", "platformName", "translatorName", "languageName", "genreName", "publisherName"];
- function VideoGameJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'VideoGame' : _ref$type,
- keyOverride = _ref.keyOverride,
- aggregateRating = _ref.aggregateRating,
- trailer = _ref.trailer,
- reviews = _ref.reviews,
- image = _ref.image,
- authorName = _ref.authorName,
- provider = _ref.provider,
- producerName = _ref.producerName,
- producerUrl = _ref.producerUrl,
- offers = _ref.offers,
- operatingSystemName = _ref.operatingSystemName,
- platformName = _ref.platformName,
- translatorName = _ref.translatorName,
- languageName = _ref.languageName,
- genreName = _ref.genreName,
- publisherName = _ref.publisherName,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$c);
- var data = _extends({}, rest, {
- aggregateRating: setAggregateRating(aggregateRating),
- trailer: setVideo(trailer),
- review: setReviews(reviews),
- image: setImage(image),
- author: setAuthor(authorName),
- provider: setProvider(provider),
- producer: setProducer({
- name: producerName,
- url: producerUrl
- }),
- offers: setOffers(offers),
- operatingSystem: operatingSystemName,
- gamePlatform: platformName,
- translator: translatorName,
- inLanguage: languageName,
- genre: genreName,
- publisher: publisherName
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "VideoGame"
- }));
- }
- function setContactPoints(contactPoint) {
- if (contactPoint && contactPoint.length) {
- return contactPoint.map(function (contactPoint) {
- return _extends({
- '@type': 'ContactPoint'
- }, contactPoint);
- });
- }
- return undefined;
- }
- var _excluded$b = ["type", "keyOverride", "address", "contactPoints", "contactPoint"];
- function OrganizationJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Organization' : _ref$type,
- keyOverride = _ref.keyOverride,
- address = _ref.address,
- contactPoints = _ref.contactPoints,
- contactPoint = _ref.contactPoint,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$b);
- var data = _extends({}, rest, {
- address: setAddress(address),
- contactPoint: setContactPoints(contactPoint || contactPoints)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "organization"
- }));
- }
- function setQuestions(questions) {
- if (questions && questions.length) {
- return questions.map(function (question) {
- return {
- '@type': 'Question',
- name: question.questionName,
- acceptedAnswer: {
- '@type': 'Answer',
- text: question.acceptedAnswerText
- }
- };
- });
- }
- return undefined;
- }
- var _excluded$a = ["type", "keyOverride", "mainEntity"];
- function FAQPageJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'FAQPage' : _ref$type,
- keyOverride = _ref.keyOverride,
- mainEntity = _ref.mainEntity,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$a);
- var data = _extends({}, rest, {
- mainEntity: setQuestions(mainEntity)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "faq-page"
- }));
- }
- var _excluded$9 = ["type", "keyOverride"];
- function LogoJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Organization' : _ref$type,
- keyOverride = _ref.keyOverride,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$9);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, rest, {
- scriptKey: "Logo"
- }));
- }
- var _excluded$8 = ["type", "keyOverride"];
- function DatasetJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Dataset' : _ref$type,
- keyOverride = _ref.keyOverride,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$8);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, rest, {
- scriptKey: "dataset"
- }));
- }
- var _excluded$7 = ["type", "keyOverride", "courseName", "provider"];
- function CourseJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Course' : _ref$type,
- keyOverride = _ref.keyOverride,
- courseName = _ref.courseName,
- provider = _ref.provider,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$7);
- var data = _extends({
- name: courseName
- }, rest, {
- provider: setProvider(provider)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "course"
- }));
- }
- var _excluded$6 = ["type", "keyOverride", "itemListElements"];
- function BreadCrumbJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'BreadcrumbList' : _ref$type,
- keyOverride = _ref.keyOverride,
- itemListElements = _ref.itemListElements,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$6);
- var data = _extends({}, rest, {
- itemListElement: setItemListElements(itemListElements)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "breadcrumb"
- }));
- }
- var _excluded$5 = ["type", "id", "keyOverride", "aggregateRating"];
- function BrandJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Brand' : _ref$type,
- id = _ref.id,
- keyOverride = _ref.keyOverride,
- aggregateRating = _ref.aggregateRating,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$5);
- var data = _extends({
- aggregateRating: setAggregateRating(aggregateRating),
- '@id': id
- }, rest);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "brand"
- }));
- }
- var _excluded$4 = ["type", "keyOverride", "url", "title", "images", "datePublished", "dateModified", "authorName", "publisherName", "publisherLogo", "description", "isAccessibleForFree"];
- function ArticleJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'Article' : _ref$type,
- keyOverride = _ref.keyOverride,
- url = _ref.url,
- title = _ref.title,
- images = _ref.images,
- datePublished = _ref.datePublished,
- dateModified = _ref.dateModified,
- authorName = _ref.authorName,
- _ref$publisherName = _ref.publisherName,
- publisherName = _ref$publisherName === void 0 ? undefined : _ref$publisherName,
- _ref$publisherLogo = _ref.publisherLogo,
- publisherLogo = _ref$publisherLogo === void 0 ? undefined : _ref$publisherLogo,
- description = _ref.description,
- isAccessibleForFree = _ref.isAccessibleForFree,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$4);
- var data = _extends({
- datePublished: datePublished,
- description: description,
- mainEntityOfPage: {
- '@type': 'WebPage',
- '@id': url
- },
- headline: title,
- image: images,
- dateModified: dateModified || datePublished,
- author: setAuthor(authorName),
- publisher: setPublisher(publisherName, publisherLogo),
- isAccessibleForFree: isAccessibleForFree
- }, rest);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "article"
- }));
- }
- function setReviewedBy(reviewedBy) {
- if (reviewedBy) {
- return _extends({
- '@type': (reviewedBy == null ? void 0 : reviewedBy.type) || 'Organization'
- }, reviewedBy);
- }
- return undefined;
- }
- var _excluded$3 = ["keyOverride", "reviewedBy"];
- function WebPageJsonLd(_ref) {
- var keyOverride = _ref.keyOverride,
- reviewedBy = _ref.reviewedBy,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$3);
- var data = _extends({}, rest, {
- reviewedBy: setReviewedBy(reviewedBy)
- });
- return React.createElement(JsonLd, _extends({
- keyOverride: keyOverride
- }, data, {
- type: "WebPage",
- scriptKey: "WebPage"
- }));
- }
- var _excluded$2 = ["type", "keyOverride"];
- function SocialProfileJsonLd(_ref) {
- var type = _ref.type,
- keyOverride = _ref.keyOverride,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$2);
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, rest, {
- scriptKey: "social"
- }));
- }
- function setCost(cost) {
- if (cost) {
- return _extends({}, cost, {
- '@type': 'MonetaryAmount'
- });
- }
- return undefined;
- }
- function setSupply(supply) {
- if (supply) {
- return supply.map(function (supplyItem) {
- return {
- '@type': 'HowToSupply',
- name: supplyItem
- };
- });
- }
- return undefined;
- }
- function setTool(tool) {
- if (tool) {
- return tool.map(function (toolItem) {
- return {
- '@type': 'HowToTool',
- name: toolItem
- };
- });
- }
- return undefined;
- }
- function setStep(step) {
- if (step) {
- return step.map(function (stepElement) {
- var itemListElement = stepElement.itemListElement,
- image = stepElement.image;
- var currentListElements = itemListElement == null ? void 0 : itemListElement.map(function (_ref) {
- var type = _ref.type,
- text = _ref.text;
- return {
- '@type': type,
- text: text
- };
- });
- return _extends({}, stepElement, {
- '@type': 'HowToStep',
- itemListElement: currentListElements,
- image: setImage(image)
- });
- });
- }
- return undefined;
- }
- var _excluded$1 = ["type", "keyOverride", "image", "estimatedCost", "supply", "tool", "step"];
- function howToJsonLd(_ref) {
- var _ref$type = _ref.type,
- type = _ref$type === void 0 ? 'HowTo' : _ref$type,
- keyOverride = _ref.keyOverride,
- image = _ref.image,
- estimatedCost = _ref.estimatedCost,
- supply = _ref.supply,
- tool = _ref.tool,
- step = _ref.step,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded$1);
- var data = _extends({}, rest, {
- image: setImage(image),
- estimatedCost: setCost(estimatedCost),
- supply: setSupply(supply),
- tool: setTool(tool),
- step: setStep(step)
- });
- return React.createElement(JsonLd, _extends({
- type: type,
- keyOverride: keyOverride
- }, data, {
- scriptKey: "howTo"
- }));
- }
- var _excluded = ["keyOverride", "images"];
- function ImageJsonLd(_ref) {
- var keyOverride = _ref.keyOverride,
- images = _ref.images,
- rest = _objectWithoutPropertiesLoose(_ref, _excluded);
- return React.createElement(JsonLd, _extends({}, rest, {
- type: "ImageObject",
- keyOverride: keyOverride,
- dataArray: images,
- scriptKey: "image"
- }));
- }
- export { ArticleJsonLd, BrandJsonLd, BreadCrumbJsonLd as BreadcrumbJsonLd, CarouselJsonLd, CollectionPageJsonLd, CorporateContactJsonLd, CourseJsonLd, DatasetJsonLd, DefaultSeo, EventJsonLd, FAQPageJsonLd, howToJsonLd as HowToJsonLd, ImageJsonLd, JobPostingJsonLd, LocalBusinessJsonLd, LogoJsonLd, NewsArticleJsonLd, NextSeo, OrganizationJsonLd, ProductJsonLd, ProfilePageJsonLd, QAPageJsonLd, RecipeJsonLd, SiteLinksSearchBoxJsonLd, SocialProfileJsonLd, SoftwareAppJsonLd, VideoGameJsonLd, VideoJsonLd, WebPageJsonLd };
|