axyseo 2.1.56 → 2.1.58
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/languageProcessing/researches/getLinkStatistics.js +2 -1
- package/build/cjs/languageProcessing/researches/getLinkStatistics.js.map +1 -1
- package/build/cjs/scoring/assessors/avadaAssessor.js +7 -1
- package/build/cjs/scoring/assessors/avadaAssessor.js.map +1 -1
- package/build/cjs/values/Paper.js +12 -1
- package/build/cjs/values/Paper.js.map +1 -1
- package/build/esm/languageProcessing/researches/getLinkStatistics.js +2 -1
- package/build/esm/languageProcessing/researches/getLinkStatistics.js.map +1 -1
- package/build/esm/scoring/assessors/avadaAssessor.js +7 -1
- package/build/esm/scoring/assessors/avadaAssessor.js.map +1 -1
- package/build/esm/values/Paper.js +12 -1
- package/build/esm/values/Paper.js.map +1 -1
- package/package.json +1 -1
|
@@ -26,7 +26,8 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
|
|
|
26
26
|
* otherNofollow: other links with a nofollow attribute.
|
|
27
27
|
*/
|
|
28
28
|
function _default(paper) {
|
|
29
|
-
const
|
|
29
|
+
const text = paper.getPageType() === 'collection' ? paper.getText() + ' ' + paper.getAfterListContent() : paper.getText();
|
|
30
|
+
const anchors = (0, _getAnchorsFromText.default)(text);
|
|
30
31
|
/*
|
|
31
32
|
* We get the site's URL (e.g., https://yoast.com) or domain (e.g., yoast.com) from the paper.
|
|
32
33
|
* In case of WordPress, the variable is a URL. In case of Shopify, it is a domain.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getLinkStatistics.js","names":["_checkNofollow","_interopRequireDefault","require","_getAnchorsFromText","_getLinkType","e","__esModule","default","_default","paper","
|
|
1
|
+
{"version":3,"file":"getLinkStatistics.js","names":["_checkNofollow","_interopRequireDefault","require","_getAnchorsFromText","_getLinkType","e","__esModule","default","_default","paper","text","getPageType","getText","getAfterListContent","anchors","getAnchors","siteUrlOrDomain","getPermalink","linkCount","total","length","internalTotal","internalDofollow","internalNofollow","externalTotal","externalDofollow","externalNofollow","otherTotal","otherDofollow","otherNofollow","i","currentAnchor","linkType","getLinkType","linkFollow","checkNofollow"],"sources":["../../../../src/languageProcessing/researches/getLinkStatistics.js"],"sourcesContent":["import checkNofollow from \"../helpers/link/checkNofollow.js\";\nimport getAnchors from \"../helpers/link/getAnchorsFromText.js\";\nimport getLinkType from \"../helpers/link/getLinkType.js\";\n\n/**\n * Counts the links found in the text.\n *\n * @param {Paper} paper The paper object containing text, keyword and url.\n *\n * @returns {object} The object containing all linktypes.\n * total: the total number of links found.\n * internalTotal: the total number of links that are internal.\n * internalDofollow: the internal links without a nofollow attribute.\n * internalNofollow: the internal links with a nofollow attribute.\n * externalTotal: the total number of links that are external.\n * externalDofollow: the external links without a nofollow attribute.\n * externalNofollow: the internal links with a dofollow attribute.\n * otherTotal: all links that are not HTTP or HTTPS.\n * otherDofollow: other links without a nofollow attribute.\n * otherNofollow: other links with a nofollow attribute.\n */\nexport default function( paper ) {\n\tconst text = paper.getPageType() === 'collection'\n\t\t? paper.getText() + ' ' + paper.getAfterListContent()\n\t\t: paper.getText();\n\tconst anchors = getAnchors( text );\n\t/*\n\t * We get the site's URL (e.g., https://yoast.com) or domain (e.g., yoast.com) from the paper.\n\t * In case of WordPress, the variable is a URL. In case of Shopify, it is a domain.\n\t */\n\tconst siteUrlOrDomain = paper.getPermalink();\n\n\tconst linkCount = {\n\t\ttotal: anchors.length,\n\t\tinternalTotal: 0,\n\t\tinternalDofollow: 0,\n\t\tinternalNofollow: 0,\n\t\texternalTotal: 0,\n\t\texternalDofollow: 0,\n\t\texternalNofollow: 0,\n\t\totherTotal: 0,\n\t\totherDofollow: 0,\n\t\totherNofollow: 0,\n\t};\n\n\tfor ( let i = 0; i < anchors.length; i++ ) {\n\t\tconst currentAnchor = anchors[ i ];\n\n\t\tconst linkType = getLinkType( currentAnchor, siteUrlOrDomain );\n\t\tconst linkFollow = checkNofollow( currentAnchor );\n\n\t\tlinkCount[ linkType + \"Total\" ]++;\n\t\tlinkCount[ linkType + linkFollow ]++;\n\t}\n\n\treturn linkCount;\n}\n"],"mappings":";;;;;;AAAA,IAAAA,cAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,mBAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,YAAA,GAAAH,sBAAA,CAAAC,OAAA;AAAyD,SAAAD,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACe,SAAAG,SAAUC,KAAK,EAAG;EAChC,MAAMC,IAAI,GAAGD,KAAK,CAACE,WAAW,CAAC,CAAC,KAAK,YAAY,GAC9CF,KAAK,CAACG,OAAO,CAAC,CAAC,GAAG,GAAG,GAAGH,KAAK,CAACI,mBAAmB,CAAC,CAAC,GACnDJ,KAAK,CAACG,OAAO,CAAC,CAAC;EAClB,MAAME,OAAO,GAAG,IAAAC,2BAAU,EAAEL,IAAK,CAAC;EAClC;AACD;AACA;AACA;EACC,MAAMM,eAAe,GAAGP,KAAK,CAACQ,YAAY,CAAC,CAAC;EAE5C,MAAMC,SAAS,GAAG;IACjBC,KAAK,EAAEL,OAAO,CAACM,MAAM;IACrBC,aAAa,EAAE,CAAC;IAChBC,gBAAgB,EAAE,CAAC;IACnBC,gBAAgB,EAAE,CAAC;IACnBC,aAAa,EAAE,CAAC;IAChBC,gBAAgB,EAAE,CAAC;IACnBC,gBAAgB,EAAE,CAAC;IACnBC,UAAU,EAAE,CAAC;IACbC,aAAa,EAAE,CAAC;IAChBC,aAAa,EAAE;EAChB,CAAC;EAED,KAAM,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGhB,OAAO,CAACM,MAAM,EAAEU,CAAC,EAAE,EAAG;IAC1C,MAAMC,aAAa,GAAGjB,OAAO,CAAEgB,CAAC,CAAE;IAElC,MAAME,QAAQ,GAAG,IAAAC,oBAAW,EAAEF,aAAa,EAAEf,eAAgB,CAAC;IAC9D,MAAMkB,UAAU,GAAG,IAAAC,sBAAa,EAAEJ,aAAc,CAAC;IAEjDb,SAAS,CAAEc,QAAQ,GAAG,OAAO,CAAE,EAAE;IACjCd,SAAS,CAAEc,QAAQ,GAAGE,UAAU,CAAE,EAAE;EACrC;EAEA,OAAOhB,SAAS;AACjB","ignoreList":[]}
|
|
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.default = void 0;
|
|
7
7
|
var _index = require("./index");
|
|
8
8
|
var _helpers = require("../helpers");
|
|
9
|
+
var _analysis = require("../../const/analysis");
|
|
9
10
|
/**
|
|
10
11
|
* The AvadaAssessor class is used for the general SEO analysis.
|
|
11
12
|
*/
|
|
@@ -93,10 +94,15 @@ class AvadaAssessor {
|
|
|
93
94
|
}
|
|
94
95
|
getScore() {
|
|
95
96
|
let point = 0;
|
|
97
|
+
let maxPoint = 0;
|
|
96
98
|
this.assessments.forEach(assessment => {
|
|
99
|
+
const weight = _analysis.idPointsMap[assessment.id];
|
|
100
|
+
if (weight === undefined) return;
|
|
101
|
+
maxPoint += weight;
|
|
97
102
|
point += assessment.score || 0;
|
|
98
103
|
});
|
|
99
|
-
|
|
104
|
+
if (!maxPoint) return 0;
|
|
105
|
+
return Math.round(point / maxPoint * 100);
|
|
100
106
|
}
|
|
101
107
|
}
|
|
102
108
|
exports.default = AvadaAssessor;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"avadaAssessor.js","names":["_index","require","_helpers","AvadaAssessor","constructor","researcher","config","seoAssessor","SEOAssessor","contentAssessor","ContentAssessor","assess","paper","i18n","assessments","results","map","assessment","status","score","data","title","assessBackEnd","getResult","groupBy","getScore","groupAssessmentsByCategory","groupAssessmentsByStatus","point","forEach","Math","round","exports","default"],"sources":["../../../../src/scoring/assessors/avadaAssessor.js"],"sourcesContent":["import {ContentAssessor, SEOAssessor} from '@axyseo/scoring/assessors/index';\nimport {groupAssessmentsByCategory, groupAssessmentsByStatus} from '../helpers';\n\n/**\n * The AvadaAssessor class is used for the general SEO analysis.\n */\nexport default class AvadaAssessor {\n /**\n * Creates a new AvadaAssessor instance.\n * @param {Researcher} researcher The researcher to use.\n * @param {Object} [config] The assessor config.\n * @param {Object} [config.textParagraphTooLong]\n * @param {Object} [config.textSentenceLength]\n * @param {Object} [config.textTransitionWords]\n * @param {Object} [config.sentenceBeginnings]\n * @param {Object} [config.relatedKeywords]\n * @param {Object} [config.titleKeyword]\n * @param {Object} [config.textImages]\n * @param {Object} [config.numberTitle]\n * @param {Object} [config.introductionKeyword]\n * @param {Object} [config.keyphraseLength]\n * @param {Object} [config.metaDescriptionKeyword]\n * @param {Object} [config.metaDescriptionLength]\n * @param {Object} [config.subheadingsKeyword]\n * @param {Object} [config.externalLinks]\n * @param {Object} [config.keyphraseDensity]\n * @param {Object} [config.media]\n * @param {Object} [config.urlLength]\n * @param {Object} [config.textLength]\n * @param {Object} [config.singleTitle]\n * @param {Object} [config.keyphrase]\n * @param {Object} [config.internalLinks]\n * @param {Object} [config.titleWidth]\n * @param {Object} [config.slugKeyword]\n * @param {Object} [config.singleH1]\n * @param {Object} [config.schema]\n */\n constructor(researcher, config = {}) {\n const seoAssessor = new SEOAssessor(researcher, config);\n const contentAssessor = new ContentAssessor(researcher, config);\n this.seoAssessor = seoAssessor;\n this.contentAssessor = contentAssessor;\n this.researcher = researcher;\n this.config = config;\n }\n\n assess(paper, i18n = null) {\n this.seoAssessor.assess(paper, i18n);\n this.contentAssessor.assess(paper, i18n);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n assessBackEnd(paper) {\n this.seoAssessor.assess(paper);\n this.contentAssessor.assess(paper);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n getResult(groupBy = 'category', getScore = true) {\n let assessments = [];\n switch (groupBy) {\n case 'category':\n assessments = groupAssessmentsByCategory(this.assessments);\n break;\n case 'status':\n assessments = groupAssessmentsByStatus(this.assessments);\n break;\n }\n\n return {\n assessments,\n ...(getScore ? {score: this.getScore()} : {})\n };\n }\n\n getScore() {\n let point = 0;\n this.assessments.forEach(assessment => {\n point += assessment.score || 0;\n });\n return Math.round(
|
|
1
|
+
{"version":3,"file":"avadaAssessor.js","names":["_index","require","_helpers","_analysis","AvadaAssessor","constructor","researcher","config","seoAssessor","SEOAssessor","contentAssessor","ContentAssessor","assess","paper","i18n","assessments","results","map","assessment","status","score","data","title","assessBackEnd","getResult","groupBy","getScore","groupAssessmentsByCategory","groupAssessmentsByStatus","point","maxPoint","forEach","weight","idPointsMap","id","undefined","Math","round","exports","default"],"sources":["../../../../src/scoring/assessors/avadaAssessor.js"],"sourcesContent":["import {ContentAssessor, SEOAssessor} from '@axyseo/scoring/assessors/index';\nimport {groupAssessmentsByCategory, groupAssessmentsByStatus} from '../helpers';\nimport {idPointsMap} from '@axyseo/const/analysis';\n\n/**\n * The AvadaAssessor class is used for the general SEO analysis.\n */\nexport default class AvadaAssessor {\n /**\n * Creates a new AvadaAssessor instance.\n * @param {Researcher} researcher The researcher to use.\n * @param {Object} [config] The assessor config.\n * @param {Object} [config.textParagraphTooLong]\n * @param {Object} [config.textSentenceLength]\n * @param {Object} [config.textTransitionWords]\n * @param {Object} [config.sentenceBeginnings]\n * @param {Object} [config.relatedKeywords]\n * @param {Object} [config.titleKeyword]\n * @param {Object} [config.textImages]\n * @param {Object} [config.numberTitle]\n * @param {Object} [config.introductionKeyword]\n * @param {Object} [config.keyphraseLength]\n * @param {Object} [config.metaDescriptionKeyword]\n * @param {Object} [config.metaDescriptionLength]\n * @param {Object} [config.subheadingsKeyword]\n * @param {Object} [config.externalLinks]\n * @param {Object} [config.keyphraseDensity]\n * @param {Object} [config.media]\n * @param {Object} [config.urlLength]\n * @param {Object} [config.textLength]\n * @param {Object} [config.singleTitle]\n * @param {Object} [config.keyphrase]\n * @param {Object} [config.internalLinks]\n * @param {Object} [config.titleWidth]\n * @param {Object} [config.slugKeyword]\n * @param {Object} [config.singleH1]\n * @param {Object} [config.schema]\n */\n constructor(researcher, config = {}) {\n const seoAssessor = new SEOAssessor(researcher, config);\n const contentAssessor = new ContentAssessor(researcher, config);\n this.seoAssessor = seoAssessor;\n this.contentAssessor = contentAssessor;\n this.researcher = researcher;\n this.config = config;\n }\n\n assess(paper, i18n = null) {\n this.seoAssessor.assess(paper, i18n);\n this.contentAssessor.assess(paper, i18n);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n assessBackEnd(paper) {\n this.seoAssessor.assess(paper);\n this.contentAssessor.assess(paper);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n getResult(groupBy = 'category', getScore = true) {\n let assessments = [];\n switch (groupBy) {\n case 'category':\n assessments = groupAssessmentsByCategory(this.assessments);\n break;\n case 'status':\n assessments = groupAssessmentsByStatus(this.assessments);\n break;\n }\n\n return {\n assessments,\n ...(getScore ? {score: this.getScore()} : {})\n };\n }\n\n getScore() {\n let point = 0;\n let maxPoint = 0;\n this.assessments.forEach(assessment => {\n const weight = idPointsMap[assessment.id];\n if (weight === undefined) return;\n maxPoint += weight;\n point += assessment.score || 0;\n });\n if (!maxPoint) return 0;\n return Math.round(point / maxPoint * 100);\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -31,7 +31,8 @@ const defaultAttributes = {
|
|
|
31
31
|
writingDirection: 'LTR',
|
|
32
32
|
wpBlocks: [],
|
|
33
33
|
isFrontPage: false,
|
|
34
|
-
pageType: ''
|
|
34
|
+
pageType: '',
|
|
35
|
+
afterListContent: ''
|
|
35
36
|
};
|
|
36
37
|
|
|
37
38
|
/**
|
|
@@ -64,6 +65,7 @@ class Paper {
|
|
|
64
65
|
* @param {string} [attributes.textTitle] The title of the text.
|
|
65
66
|
* @param {string} [attributes.writingDirection=LTR] The writing direction of the paper. Defaults to left to right (LTR).
|
|
66
67
|
* @param {boolean} [attributes.isFrontPage=false] Whether the current page is the front page of the site. Defaults to false.
|
|
68
|
+
* @param {string} [attributes.afterListContent] HTML content displayed after the product list on collection pages.
|
|
67
69
|
*/
|
|
68
70
|
constructor(text, attributes) {
|
|
69
71
|
this._text = (0, _helpers.cleanHTML)(text || '');
|
|
@@ -353,6 +355,15 @@ class Paper {
|
|
|
353
355
|
getPageType() {
|
|
354
356
|
return this._attributes?.pageType || '';
|
|
355
357
|
}
|
|
358
|
+
|
|
359
|
+
/**
|
|
360
|
+
* Returns the HTML content displayed after the product list on collection pages.
|
|
361
|
+
* @returns {string} The after-list HTML, or '' if not set.
|
|
362
|
+
*/
|
|
363
|
+
getAfterListContent() {
|
|
364
|
+
return this._attributes?.afterListContent || '';
|
|
365
|
+
}
|
|
366
|
+
|
|
356
367
|
/**
|
|
357
368
|
*
|
|
358
369
|
* @returns {Object[String]|*[String]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Paper.js","names":["_lodash","require","_helpers","_checkRelatedKeywords","defaultAttributes","keyword","synonyms","description","title","titleWidth","titleCount","h1Count","slug","domain","locale","permalink","date","customData","textTitle","writingDirection","wpBlocks","isFrontPage","pageType","Paper","constructor","text","attributes","_text","cleanHTML","_tree","defaults","hasOwnProperty","url","onlyLetters","replace","isEmpty","_attributes","hasKeyword","getKeyword","getAttributes","hasSynonyms","getSynonyms","getRelatedKeywords","data","getData","related_keywords","map","hasH1Count","isNull","getH1Count","hasTitleCount","getTitleCount","hasText","getText","getDomain","setTree","tree","getTree","hasDescription","body_html","descriptionHtml","getDescription","hasTitle","getTitle","hasTitleWidth","getTitleWidth","hasSlug","hasShopSettings","shopSettings","getSlug","hasProductSchema","hasFAQsSchema","hasFAQs","getFAQs","length","hasArticleSchema","hasData","isObject","hasRelatedKeywords","relatedKeywords","Array","isArray","getIgnoredAssessments","ignoredAssessments","getPageType","getSkippedAssessments","skippedAssessments","getShopSettings","hasUrl","console","warn","getUrl","hasLocale","getLocale","getWritingDirection","hasPermalink","getPermalink","hasDate","getDate","faqs","hasCustomData","getCustomData","hasTextTitle","isNil","getTextTitle","serialize","_parseClass","equals","paper","isEqual","parse","serialized","exports","default"],"sources":["../../../src/values/Paper.js"],"sourcesContent":["import {defaults, isEmpty, isEqual, isNil, isNull, isObject} from 'lodash';\nimport {cleanHTML} from '@axyseo/helpers';\nimport {transformRelatedKeyword} from '@axyseo/languageProcessing/researches/checkRelatedKeywords';\n\n/**\n * Default attributes to be used by the Paper if they are left undefined.\n * @type {{keyword: string, synonyms: string, description: string, title: string, titleWidth: number,\n * \t\t slug: string, locale: string, permalink: string, date: string, customData: object, textTitle: string,\n * \t\t writingDirection: \"LTR\", isFrontPage: boolean }}\n */\nconst defaultAttributes = {\n keyword: '',\n synonyms: '',\n description: '',\n title: '',\n titleWidth: 0,\n titleCount: null,\n h1Count: null,\n slug: '',\n domain: '',\n locale: 'en_US',\n permalink: '',\n date: '',\n customData: {},\n textTitle: '',\n writingDirection: 'LTR',\n wpBlocks: [],\n isFrontPage: false,\n pageType: '',\n};\n\n/**\n * Represents an object where the analysis data is stored.\n */\nexport default class Paper {\n /**\n * Constructs the Paper object and sets its attributes.\n *\n * @param {string} text The text to use in the analysis.\n * @param {object} [attributes] The object containing all attributes.\n * @param {string} [attributes.keyword] The main keyword or keyphrase of the text.\n * @param {string} [attributes.synonyms] The synonyms of the main keyword or keyphrase. It should be separated by commas if multiple synonyms are added.\n * @param {string} [attributes.description] The SEO meta description.\n * @param {string} [attributes.title] The SEO title.\n * @param {string} [attributes.domain] The shop domain.\n * @param {number|null} [attributes.titleCount=null] The title tag count value.\n * @param {number|null} [attributes.h1Count=null] The h1 tag count value.\n * @param {number} [attributes.titleWidth=0] The width of the title in pixels.\n * @param {string} [attributes.slug] The slug.\n * @param {string} [attributes.locale=en_US] The locale.\n * @param {string} [attributes.permalink] The full URL for any given post, page, or other pieces of content on a site.\n * @param {string} [attributes.date] The date.\n * @param {Object[]} [attributes.wpBlocks] The array of texts, encoded in WordPress block editor blocks.\n * @param {Object[]} [attributes.ignoredAssessments] The array of texts, show which assessments should be ignored.\n * @param {Object[]} [attributes.skippedAssessments] The array of texts, show which assessments should be skipped (those assessments will have good result).\n * @param {Object} [attributes.data] Given data.\n * @param {Object} [attributes.customData] Custom data.\n * @param {Object} [attributes.shopSettings] Shop's settings.\n * @param {string} [attributes.textTitle] The title of the text.\n * @param {string} [attributes.writingDirection=LTR] The writing direction of the paper. Defaults to left to right (LTR).\n * @param {boolean} [attributes.isFrontPage=false] Whether the current page is the front page of the site. Defaults to false.\n */\n constructor(text, attributes) {\n this._text = cleanHTML(text || '');\n\n this._tree = null;\n\n attributes = attributes || {};\n defaults(attributes, defaultAttributes);\n\n if (attributes.locale === '') {\n attributes.locale = defaultAttributes.locale;\n }\n\n if (attributes.hasOwnProperty('url')) {\n attributes.slug = attributes.url || attributes.slug;\n }\n\n const onlyLetters = attributes.keyword.replace(\n /[‘’“”\"'.?!:;,¿¡«»&*@#±^%|~`[\\](){}⟨⟩<>/\\\\–\\-\\u2014\\u00d7\\u002b\\s]/g,\n ''\n );\n\n if (isEmpty(onlyLetters)) {\n attributes.keyword = defaultAttributes.keyword;\n }\n\n this._attributes = attributes;\n }\n\n /**\n * Checks whether a keyword is available.\n * @returns {boolean} Returns true if the Paper has a keyword.\n */\n hasKeyword() {\n return this._attributes.keyword !== '';\n }\n\n /**\n * Returns the associated keyword or an empty string if no keyword is available.\n * @returns {string} Returns Keyword\n */\n getKeyword() {\n return this._attributes.keyword;\n }\n\n /**\n *\n * @returns {*|{keyword?: string, synonyms?: string, description?: string, title?: string, titleCount?: (number|null), h1Count?: (number|null), titleWidth?: number, slug?: string, locale?: string, permalink?: string, date?: string, wpBlocks?: Object[], customData?: Object, textTitle?: string, writingDirection?: string, isFrontPage?: boolean}|{}|{}}\n */\n getAttributes() {\n return this._attributes;\n }\n\n /**\n * Checks whether synonyms are available.\n * @returns {boolean} Returns true if the Paper has synonyms.\n */\n hasSynonyms() {\n return this._attributes.synonyms !== '';\n }\n\n /**\n * Returns the associated synonyms or an empty string if no synonyms is available.\n * @returns {string} Returns synonyms.\n */\n getSynonyms() {\n return this._attributes.synonyms;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getRelatedKeywords() {\n const data = this.getData();\n return (data?.related_keywords || []).map(keyword => keyword.text);\n }\n\n /**\n * Checks whether the h1 count value is available.\n * @returns {boolean} Returns true if the paper has a h1 count value.\n */\n hasH1Count() {\n return !isNull(this._attributes.h1Count);\n }\n\n /**\n * Returns the h1 tag count value.\n * @returns {number | null}\n */\n getH1Count() {\n return this._attributes.h1Count;\n }\n\n /**\n * Checks whether the title count value is available.\n * @returns {boolean} Returns true if the paper has a title count.\n */\n hasTitleCount() {\n return !isNull(this._attributes.titleCount);\n }\n\n /**\n * Returns the title count value.\n * @returns {number | null}\n */\n getTitleCount() {\n return this._attributes.titleCount;\n }\n\n /**\n * Checks whether the text is available.\n * @returns {boolean} Returns true if the paper has a text.\n */\n hasText() {\n return this._text !== '';\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getText() {\n return this._text;\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getDomain() {\n return this._attributes.domain;\n }\n\n /**\n * Sets the tree.\n *\n * @param {Node} tree The tree to set.\n *\n * @returns {void}\n */\n setTree(tree) {\n this._tree = tree;\n }\n\n /**\n * Returns the tree.\n *\n * @returns {Node} The tree.\n */\n getTree() {\n return this._tree;\n }\n\n /**\n * Checks whether a description is available.\n * @returns {boolean} Returns true if the paper has a description.\n */\n hasDescription() {\n return this._attributes?.data?.body_html !== '' || this._attributes?.data?.descriptionHtml !== '';\n }\n\n /**\n * Returns the description or an empty string if no description is available.\n * @returns {string} Returns the description.\n */\n getDescription() {\n return this._attributes.description;\n }\n\n /**\n * Checks whether an SEO title is available\n * @returns {boolean} Returns true if the Paper has an SEO title.\n */\n hasTitle() {\n return this._attributes.title !== '';\n }\n\n /**\n * Returns the SEO title, or an empty string if no title is available.\n * @returns {string} Returns the SEO title.\n */\n getTitle() {\n return this._attributes.title;\n }\n\n /**\n * Checks whether an SEO title width in pixels is available.\n * @returns {boolean} Returns true if the Paper's SEO title is wider than 0 pixels.\n */\n hasTitleWidth() {\n return this._attributes.titleWidth !== 0;\n }\n\n /**\n * Gets the SEO title width in pixels, or an empty string of no title width in pixels is available.\n * @returns {number} Returns the SEO title width in pixels.\n */\n getTitleWidth() {\n return this._attributes.titleWidth;\n }\n\n /**\n * Checks whether a slug is available.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasSlug() {\n return this._attributes.slug !== '';\n }\n\n /**\n * Checks whether a shop settings is available.\n * @returns {boolean} Returns true if the Paper has a shop settings.\n */\n hasShopSettings() {\n return !isEmpty(this._attributes?.shopSettings || {});\n }\n\n /**\n * Gets the paper's slug, or an empty string if no slug is available.\n * @returns {string} Returns the slug.\n */\n getSlug() {\n return this._attributes.slug;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasProductSchema() {\n return this._attributes?.hasProductSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasFAQsSchema() {\n return this._attributes?.hasFAQsSchema || false;\n }\n\n /**\n *\n * @returns {boolean}\n */\n hasFAQs() {\n return 'faqs' in this.getData() && this.getFAQs().length > 0;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasArticleSchema() {\n return this._attributes?.hasArticleSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasData() {\n const data = this._attributes?.data;\n return isObject(data) && !isEmpty(data);\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasRelatedKeywords() {\n const relatedKeywords = this._attributes?.data?.related_keywords || [];\n return Array.isArray(relatedKeywords) && relatedKeywords.length > 0;\n }\n\n /**\n *\n * @returns {Object|{}}\n */\n getData() {\n return this._attributes?.data || {};\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getIgnoredAssessments() {\n return this._attributes?.ignoredAssessments || [];\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getPageType() {\n return this._attributes?.pageType || '';\n }\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getSkippedAssessments() {\n return this._attributes?.skippedAssessments || [];\n }\n\n /**\n *\n * @returns {*|{}}\n */\n getShopSettings() {\n return this._attributes?.shopSettings || {};\n }\n\n /**\n * Checks if currently edited page is a front page.\n * @returns {boolean} Returns true if the current page is a front page.\n */\n isFrontPage() {\n return this._attributes.isFrontPage;\n }\n\n /**\n * Checks whether an url is available\n * @deprecated Since version 1.19.1. Use hasSlug instead.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasUrl() {\n console.warn('This function is deprecated, use hasSlug instead');\n return this.hasSlug();\n }\n\n /**\n * Returns the url, or an empty string if no url is available.\n * @deprecated Since version 1.19.1. Use getSlug instead.\n * @returns {string} Returns the url\n */\n getUrl() {\n console.warn('This function is deprecated, use getSlug instead');\n return this.getSlug();\n }\n\n /**\n * Checks whether a locale is available.\n * @returns {boolean} Returns true if the paper has a locale.\n */\n hasLocale() {\n return this._attributes.locale !== '';\n }\n\n /**\n * Returns the locale or an empty string if no locale is available\n * @returns {string} Returns the locale.\n */\n getLocale() {\n return this._attributes.locale;\n }\n\n /**\n * Gets the information of the writing direction of the paper.\n * It returns \"LTR\" (left to right) if this attribute is not provided.\n *\n * @returns {string} Returns the information of the writing direction of the paper.\n */\n getWritingDirection() {\n return this._attributes.writingDirection;\n }\n\n /**\n * Checks whether a permalink is available.\n * @returns {boolean} Returns true if the Paper has a permalink.\n */\n hasPermalink() {\n return this._attributes.permalink !== '';\n }\n\n /**\n * Returns the permalink, or an empty string if no permalink is available.\n * @returns {string} Returns the permalink.\n */\n getPermalink() {\n return this._attributes.permalink;\n }\n\n /**\n * Checks whether a date is available.\n * @returns {boolean} Returns true if the Paper has a date.\n */\n hasDate() {\n return this._attributes.date !== '';\n }\n\n /**\n * Returns the date, or an empty string if no date is available.\n * @returns {string} Returns the date.\n */\n getDate() {\n return this._attributes.date;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getFAQs() {\n return this.getData()?.faqs || {};\n }\n\n\n /**\n * Checks whether custom data is available.\n * @returns {boolean} Returns true if the Paper has custom data.\n */\n hasCustomData() {\n return !isEmpty(this._attributes.customData);\n }\n\n /**\n * Returns the custom data, or an empty object if no data is available.\n * @returns {Object} Returns the custom data.\n */\n getCustomData() {\n return this._attributes.customData;\n }\n\n /**\n * Checks whether a text title is available.\n * @returns {boolean} Returns true if the Paper has a text title.\n */\n hasTextTitle() {\n return this._attributes.textTitle !== '' && !isNil(this._attributes.textTitle);\n }\n\n /**\n * Returns the text title, or an empty string if no data is available.\n * @returns {string} Returns the text title.\n */\n getTextTitle() {\n return this._attributes.textTitle;\n }\n\n /**\n * Serializes the Paper instance to an object.\n *\n * @returns {Object} The serialized Paper.\n */\n serialize() {\n return {\n _parseClass: 'Paper',\n text: this._text,\n ...this._attributes\n };\n }\n\n /**\n * Checks whether the given paper has the same properties as this instance.\n *\n * @param {Paper} paper The paper to compare to.\n *\n * @returns {boolean} Whether the given paper is identical or not.\n */\n equals(paper) {\n return this._text === paper.getText() && isEqual(this._attributes, paper._attributes);\n }\n\n /**\n * Parses the object to a Paper.\n *\n * @param {Object|Paper} serialized The serialized object or Paper instance.\n *\n * @returns {Paper} The parsed Paper.\n */\n static parse(serialized) {\n // For ease of use, check if it is not already a Paper instance.\n if (serialized instanceof Paper) {\n return serialized;\n }\n\n // _parseClass is taken here, so it doesn't end up in the attributes.\n // eslint-disable-next-line no-unused-vars\n const {text, _parseClass, ...attributes} = serialized;\n\n return new Paper(text, attributes);\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AACA,IAAAE,qBAAA,GAAAF,OAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMG,iBAAiB,GAAG;EACxBC,OAAO,EAAE,EAAE;EACXC,QAAQ,EAAE,EAAE;EACZC,WAAW,EAAE,EAAE;EACfC,KAAK,EAAE,EAAE;EACTC,UAAU,EAAE,CAAC;EACbC,UAAU,EAAE,IAAI;EAChBC,OAAO,EAAE,IAAI;EACbC,IAAI,EAAE,EAAE;EACRC,MAAM,EAAE,EAAE;EACVC,MAAM,EAAE,OAAO;EACfC,SAAS,EAAE,EAAE;EACbC,IAAI,EAAE,EAAE;EACRC,UAAU,EAAE,CAAC,CAAC;EACdC,SAAS,EAAE,EAAE;EACbC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE,EAAE;EACZC,WAAW,EAAE,KAAK;EAClBC,QAAQ,EAAE;AACZ,CAAC;;AAED;AACA;AACA;AACe,MAAMC,KAAK,CAAC;EACzB;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,IAAI,EAAEC,UAAU,EAAE;IAC5B,IAAI,CAACC,KAAK,GAAG,IAAAC,kBAAS,EAACH,IAAI,IAAI,EAAE,CAAC;IAElC,IAAI,CAACI,KAAK,GAAG,IAAI;IAEjBH,UAAU,GAAGA,UAAU,IAAI,CAAC,CAAC;IAC7B,IAAAI,gBAAQ,EAACJ,UAAU,EAAEtB,iBAAiB,CAAC;IAEvC,IAAIsB,UAAU,CAACZ,MAAM,KAAK,EAAE,EAAE;MAC5BY,UAAU,CAACZ,MAAM,GAAGV,iBAAiB,CAACU,MAAM;IAC9C;IAEA,IAAIY,UAAU,CAACK,cAAc,CAAC,KAAK,CAAC,EAAE;MACpCL,UAAU,CAACd,IAAI,GAAGc,UAAU,CAACM,GAAG,IAAIN,UAAU,CAACd,IAAI;IACrD;IAEA,MAAMqB,WAAW,GAAGP,UAAU,CAACrB,OAAO,CAAC6B,OAAO,CAC5C,oEAAoE,EACpE,EACF,CAAC;IAED,IAAI,IAAAC,eAAO,EAACF,WAAW,CAAC,EAAE;MACxBP,UAAU,CAACrB,OAAO,GAAGD,iBAAiB,CAACC,OAAO;IAChD;IAEA,IAAI,CAAC+B,WAAW,GAAGV,UAAU;EAC/B;;EAEA;AACF;AACA;AACA;EACEW,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACD,WAAW,CAAC/B,OAAO,KAAK,EAAE;EACxC;;EAEA;AACF;AACA;AACA;EACEiC,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACF,WAAW,CAAC/B,OAAO;EACjC;;EAEA;AACF;AACA;AACA;EACEkC,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACH,WAAW;EACzB;;EAEA;AACF;AACA;AACA;EACEI,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACJ,WAAW,CAAC9B,QAAQ,KAAK,EAAE;EACzC;;EAEA;AACF;AACA;AACA;EACEmC,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACL,WAAW,CAAC9B,QAAQ;EAClC;;EAEA;AACF;AACA;AACA;EACEoC,kBAAkBA,CAAA,EAAG;IACnB,MAAMC,IAAI,GAAG,IAAI,CAACC,OAAO,CAAC,CAAC;IAC3B,OAAO,CAACD,IAAI,EAAEE,gBAAgB,IAAI,EAAE,EAAEC,GAAG,CAACzC,OAAO,IAAIA,OAAO,CAACoB,IAAI,CAAC;EACpE;;EAEA;AACF;AACA;AACA;EACEsB,UAAUA,CAAA,EAAG;IACX,OAAO,CAAC,IAAAC,cAAM,EAAC,IAAI,CAACZ,WAAW,CAACzB,OAAO,CAAC;EAC1C;;EAEA;AACF;AACA;AACA;EACEsC,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACb,WAAW,CAACzB,OAAO;EACjC;;EAEA;AACF;AACA;AACA;EACEuC,aAAaA,CAAA,EAAG;IACd,OAAO,CAAC,IAAAF,cAAM,EAAC,IAAI,CAACZ,WAAW,CAAC1B,UAAU,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;EACEyC,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACf,WAAW,CAAC1B,UAAU;EACpC;;EAEA;AACF;AACA;AACA;EACE0C,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACzB,KAAK,KAAK,EAAE;EAC1B;;EAEA;AACF;AACA;AACA;EACE0B,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC1B,KAAK;EACnB;;EAEA;AACF;AACA;AACA;EACE2B,SAASA,CAAA,EAAG;IACV,OAAO,IAAI,CAAClB,WAAW,CAACvB,MAAM;EAChC;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE0C,OAAOA,CAACC,IAAI,EAAE;IACZ,IAAI,CAAC3B,KAAK,GAAG2B,IAAI;EACnB;;EAEA;AACF;AACA;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC5B,KAAK;EACnB;;EAEA;AACF;AACA;AACA;EACE6B,cAAcA,CAAA,EAAG;IACf,OAAO,IAAI,CAACtB,WAAW,EAAEO,IAAI,EAAEgB,SAAS,KAAK,EAAE,IAAI,IAAI,CAACvB,WAAW,EAAEO,IAAI,EAAEiB,eAAe,KAAK,EAAE;EACnG;;EAEA;AACF;AACA;AACA;EACEC,cAAcA,CAAA,EAAG;IACf,OAAO,IAAI,CAACzB,WAAW,CAAC7B,WAAW;EACrC;;EAEA;AACF;AACA;AACA;EACEuD,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC1B,WAAW,CAAC5B,KAAK,KAAK,EAAE;EACtC;;EAEA;AACF;AACA;AACA;EACEuD,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC3B,WAAW,CAAC5B,KAAK;EAC/B;;EAEA;AACF;AACA;AACA;EACEwD,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC5B,WAAW,CAAC3B,UAAU,KAAK,CAAC;EAC1C;;EAEA;AACF;AACA;AACA;EACEwD,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC7B,WAAW,CAAC3B,UAAU;EACpC;;EAEA;AACF;AACA;AACA;EACEyD,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC9B,WAAW,CAACxB,IAAI,KAAK,EAAE;EACrC;;EAEA;AACF;AACA;AACA;EACEuD,eAAeA,CAAA,EAAG;IAChB,OAAO,CAAC,IAAAhC,eAAO,EAAC,IAAI,CAACC,WAAW,EAAEgC,YAAY,IAAI,CAAC,CAAC,CAAC;EACvD;;EAEA;AACF;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACjC,WAAW,CAACxB,IAAI;EAC9B;;EAEA;AACF;AACA;AACA;EACE0D,gBAAgBA,CAAA,EAAG;IACjB,OAAO,IAAI,CAAClC,WAAW,EAAEkC,gBAAgB,IAAI,KAAK;EACpD;;EAEA;AACF;AACA;AACA;EACEC,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACnC,WAAW,EAAEmC,aAAa,IAAI,KAAK;EACjD;;EAEA;AACF;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,OAAO,MAAM,IAAI,IAAI,CAAC5B,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC6B,OAAO,CAAC,CAAC,CAACC,MAAM,GAAG,CAAC;EAC9D;;EAEA;AACF;AACA;AACA;EACEC,gBAAgBA,CAAA,EAAG;IACjB,OAAO,IAAI,CAACvC,WAAW,EAAEuC,gBAAgB,IAAI,KAAK;EACpD;;EAEA;AACF;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,MAAMjC,IAAI,GAAG,IAAI,CAACP,WAAW,EAAEO,IAAI;IACnC,OAAO,IAAAkC,gBAAQ,EAAClC,IAAI,CAAC,IAAI,CAAC,IAAAR,eAAO,EAACQ,IAAI,CAAC;EACzC;;EAEA;AACF;AACA;AACA;EACEmC,kBAAkBA,CAAA,EAAG;IACnB,MAAMC,eAAe,GAAG,IAAI,CAAC3C,WAAW,EAAEO,IAAI,EAAEE,gBAAgB,IAAI,EAAE;IACtE,OAAOmC,KAAK,CAACC,OAAO,CAACF,eAAe,CAAC,IAAIA,eAAe,CAACL,MAAM,GAAG,CAAC;EACrE;;EAEA;AACF;AACA;AACA;EACE9B,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACR,WAAW,EAAEO,IAAI,IAAI,CAAC,CAAC;EACrC;;EAEA;AACF;AACA;AACA;EACEuC,qBAAqBA,CAAA,EAAG;IACtB,OAAO,IAAI,CAAC9C,WAAW,EAAE+C,kBAAkB,IAAI,EAAE;EACnD;;EAEA;AACF;AACA;AACA;EACEC,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAChD,WAAW,EAAEd,QAAQ,IAAI,EAAE;EACzC;EACA;AACF;AACA;AACA;EACE+D,qBAAqBA,CAAA,EAAG;IACtB,OAAO,IAAI,CAACjD,WAAW,EAAEkD,kBAAkB,IAAI,EAAE;EACnD;;EAEA;AACF;AACA;AACA;EACEC,eAAeA,CAAA,EAAG;IAChB,OAAO,IAAI,CAACnD,WAAW,EAAEgC,YAAY,IAAI,CAAC,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;EACE/C,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACe,WAAW,CAACf,WAAW;EACrC;;EAEA;AACF;AACA;AACA;AACA;EACEmE,MAAMA,CAAA,EAAG;IACPC,OAAO,CAACC,IAAI,CAAC,kDAAkD,CAAC;IAChE,OAAO,IAAI,CAACxB,OAAO,CAAC,CAAC;EACvB;;EAEA;AACF;AACA;AACA;AACA;EACEyB,MAAMA,CAAA,EAAG;IACPF,OAAO,CAACC,IAAI,CAAC,kDAAkD,CAAC;IAChE,OAAO,IAAI,CAACrB,OAAO,CAAC,CAAC;EACvB;;EAEA;AACF;AACA;AACA;EACEuB,SAASA,CAAA,EAAG;IACV,OAAO,IAAI,CAACxD,WAAW,CAACtB,MAAM,KAAK,EAAE;EACvC;;EAEA;AACF;AACA;AACA;EACE+E,SAASA,CAAA,EAAG;IACV,OAAO,IAAI,CAACzD,WAAW,CAACtB,MAAM;EAChC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEgF,mBAAmBA,CAAA,EAAG;IACpB,OAAO,IAAI,CAAC1D,WAAW,CAACjB,gBAAgB;EAC1C;;EAEA;AACF;AACA;AACA;EACE4E,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAAC3D,WAAW,CAACrB,SAAS,KAAK,EAAE;EAC1C;;EAEA;AACF;AACA;AACA;EACEiF,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAAC5D,WAAW,CAACrB,SAAS;EACnC;;EAEA;AACF;AACA;AACA;EACEkF,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC7D,WAAW,CAACpB,IAAI,KAAK,EAAE;EACrC;;EAEA;AACF;AACA;AACA;EACEkF,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC9D,WAAW,CAACpB,IAAI;EAC9B;;EAEA;AACF;AACA;AACA;EACEyD,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC7B,OAAO,CAAC,CAAC,EAAEuD,IAAI,IAAI,CAAC,CAAC;EACnC;;EAGA;AACF;AACA;AACA;EACEC,aAAaA,CAAA,EAAG;IACd,OAAO,CAAC,IAAAjE,eAAO,EAAC,IAAI,CAACC,WAAW,CAACnB,UAAU,CAAC;EAC9C;;EAEA;AACF;AACA;AACA;EACEoF,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACjE,WAAW,CAACnB,UAAU;EACpC;;EAEA;AACF;AACA;AACA;EACEqF,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAAClE,WAAW,CAAClB,SAAS,KAAK,EAAE,IAAI,CAAC,IAAAqF,aAAK,EAAC,IAAI,CAACnE,WAAW,CAAClB,SAAS,CAAC;EAChF;;EAEA;AACF;AACA;AACA;EACEsF,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAACpE,WAAW,CAAClB,SAAS;EACnC;;EAEA;AACF;AACA;AACA;AACA;EACEuF,SAASA,CAAA,EAAG;IACV,OAAO;MACLC,WAAW,EAAE,OAAO;MACpBjF,IAAI,EAAE,IAAI,CAACE,KAAK;MAChB,GAAG,IAAI,CAACS;IACV,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEuE,MAAMA,CAACC,KAAK,EAAE;IACZ,OAAO,IAAI,CAACjF,KAAK,KAAKiF,KAAK,CAACvD,OAAO,CAAC,CAAC,IAAI,IAAAwD,eAAO,EAAC,IAAI,CAACzE,WAAW,EAAEwE,KAAK,CAACxE,WAAW,CAAC;EACvF;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,OAAO0E,KAAKA,CAACC,UAAU,EAAE;IACvB;IACA,IAAIA,UAAU,YAAYxF,KAAK,EAAE;MAC/B,OAAOwF,UAAU;IACnB;;IAEA;IACA;IACA,MAAM;MAACtF,IAAI;MAAEiF,WAAW;MAAE,GAAGhF;IAAU,CAAC,GAAGqF,UAAU;IAErD,OAAO,IAAIxF,KAAK,CAACE,IAAI,EAAEC,UAAU,CAAC;EACpC;AACF;AAACsF,OAAA,CAAAC,OAAA,GAAA1F,KAAA","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Paper.js","names":["_lodash","require","_helpers","_checkRelatedKeywords","defaultAttributes","keyword","synonyms","description","title","titleWidth","titleCount","h1Count","slug","domain","locale","permalink","date","customData","textTitle","writingDirection","wpBlocks","isFrontPage","pageType","afterListContent","Paper","constructor","text","attributes","_text","cleanHTML","_tree","defaults","hasOwnProperty","url","onlyLetters","replace","isEmpty","_attributes","hasKeyword","getKeyword","getAttributes","hasSynonyms","getSynonyms","getRelatedKeywords","data","getData","related_keywords","map","hasH1Count","isNull","getH1Count","hasTitleCount","getTitleCount","hasText","getText","getDomain","setTree","tree","getTree","hasDescription","body_html","descriptionHtml","getDescription","hasTitle","getTitle","hasTitleWidth","getTitleWidth","hasSlug","hasShopSettings","shopSettings","getSlug","hasProductSchema","hasFAQsSchema","hasFAQs","getFAQs","length","hasArticleSchema","hasData","isObject","hasRelatedKeywords","relatedKeywords","Array","isArray","getIgnoredAssessments","ignoredAssessments","getPageType","getAfterListContent","getSkippedAssessments","skippedAssessments","getShopSettings","hasUrl","console","warn","getUrl","hasLocale","getLocale","getWritingDirection","hasPermalink","getPermalink","hasDate","getDate","faqs","hasCustomData","getCustomData","hasTextTitle","isNil","getTextTitle","serialize","_parseClass","equals","paper","isEqual","parse","serialized","exports","default"],"sources":["../../../src/values/Paper.js"],"sourcesContent":["import {defaults, isEmpty, isEqual, isNil, isNull, isObject} from 'lodash';\nimport {cleanHTML} from '@axyseo/helpers';\nimport {transformRelatedKeyword} from '@axyseo/languageProcessing/researches/checkRelatedKeywords';\n\n/**\n * Default attributes to be used by the Paper if they are left undefined.\n * @type {{keyword: string, synonyms: string, description: string, title: string, titleWidth: number,\n * \t\t slug: string, locale: string, permalink: string, date: string, customData: object, textTitle: string,\n * \t\t writingDirection: \"LTR\", isFrontPage: boolean }}\n */\nconst defaultAttributes = {\n keyword: '',\n synonyms: '',\n description: '',\n title: '',\n titleWidth: 0,\n titleCount: null,\n h1Count: null,\n slug: '',\n domain: '',\n locale: 'en_US',\n permalink: '',\n date: '',\n customData: {},\n textTitle: '',\n writingDirection: 'LTR',\n wpBlocks: [],\n isFrontPage: false,\n pageType: '',\n afterListContent: '',\n};\n\n/**\n * Represents an object where the analysis data is stored.\n */\nexport default class Paper {\n /**\n * Constructs the Paper object and sets its attributes.\n *\n * @param {string} text The text to use in the analysis.\n * @param {object} [attributes] The object containing all attributes.\n * @param {string} [attributes.keyword] The main keyword or keyphrase of the text.\n * @param {string} [attributes.synonyms] The synonyms of the main keyword or keyphrase. It should be separated by commas if multiple synonyms are added.\n * @param {string} [attributes.description] The SEO meta description.\n * @param {string} [attributes.title] The SEO title.\n * @param {string} [attributes.domain] The shop domain.\n * @param {number|null} [attributes.titleCount=null] The title tag count value.\n * @param {number|null} [attributes.h1Count=null] The h1 tag count value.\n * @param {number} [attributes.titleWidth=0] The width of the title in pixels.\n * @param {string} [attributes.slug] The slug.\n * @param {string} [attributes.locale=en_US] The locale.\n * @param {string} [attributes.permalink] The full URL for any given post, page, or other pieces of content on a site.\n * @param {string} [attributes.date] The date.\n * @param {Object[]} [attributes.wpBlocks] The array of texts, encoded in WordPress block editor blocks.\n * @param {Object[]} [attributes.ignoredAssessments] The array of texts, show which assessments should be ignored.\n * @param {Object[]} [attributes.skippedAssessments] The array of texts, show which assessments should be skipped (those assessments will have good result).\n * @param {Object} [attributes.data] Given data.\n * @param {Object} [attributes.customData] Custom data.\n * @param {Object} [attributes.shopSettings] Shop's settings.\n * @param {string} [attributes.textTitle] The title of the text.\n * @param {string} [attributes.writingDirection=LTR] The writing direction of the paper. Defaults to left to right (LTR).\n * @param {boolean} [attributes.isFrontPage=false] Whether the current page is the front page of the site. Defaults to false.\n * @param {string} [attributes.afterListContent] HTML content displayed after the product list on collection pages.\n */\n constructor(text, attributes) {\n this._text = cleanHTML(text || '');\n\n this._tree = null;\n\n attributes = attributes || {};\n defaults(attributes, defaultAttributes);\n\n if (attributes.locale === '') {\n attributes.locale = defaultAttributes.locale;\n }\n\n if (attributes.hasOwnProperty('url')) {\n attributes.slug = attributes.url || attributes.slug;\n }\n\n const onlyLetters = attributes.keyword.replace(\n /[‘’“”\"'.?!:;,¿¡«»&*@#±^%|~`[\\](){}⟨⟩<>/\\\\–\\-\\u2014\\u00d7\\u002b\\s]/g,\n ''\n );\n\n if (isEmpty(onlyLetters)) {\n attributes.keyword = defaultAttributes.keyword;\n }\n\n this._attributes = attributes;\n }\n\n /**\n * Checks whether a keyword is available.\n * @returns {boolean} Returns true if the Paper has a keyword.\n */\n hasKeyword() {\n return this._attributes.keyword !== '';\n }\n\n /**\n * Returns the associated keyword or an empty string if no keyword is available.\n * @returns {string} Returns Keyword\n */\n getKeyword() {\n return this._attributes.keyword;\n }\n\n /**\n *\n * @returns {*|{keyword?: string, synonyms?: string, description?: string, title?: string, titleCount?: (number|null), h1Count?: (number|null), titleWidth?: number, slug?: string, locale?: string, permalink?: string, date?: string, wpBlocks?: Object[], customData?: Object, textTitle?: string, writingDirection?: string, isFrontPage?: boolean}|{}|{}}\n */\n getAttributes() {\n return this._attributes;\n }\n\n /**\n * Checks whether synonyms are available.\n * @returns {boolean} Returns true if the Paper has synonyms.\n */\n hasSynonyms() {\n return this._attributes.synonyms !== '';\n }\n\n /**\n * Returns the associated synonyms or an empty string if no synonyms is available.\n * @returns {string} Returns synonyms.\n */\n getSynonyms() {\n return this._attributes.synonyms;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getRelatedKeywords() {\n const data = this.getData();\n return (data?.related_keywords || []).map(keyword => keyword.text);\n }\n\n /**\n * Checks whether the h1 count value is available.\n * @returns {boolean} Returns true if the paper has a h1 count value.\n */\n hasH1Count() {\n return !isNull(this._attributes.h1Count);\n }\n\n /**\n * Returns the h1 tag count value.\n * @returns {number | null}\n */\n getH1Count() {\n return this._attributes.h1Count;\n }\n\n /**\n * Checks whether the title count value is available.\n * @returns {boolean} Returns true if the paper has a title count.\n */\n hasTitleCount() {\n return !isNull(this._attributes.titleCount);\n }\n\n /**\n * Returns the title count value.\n * @returns {number | null}\n */\n getTitleCount() {\n return this._attributes.titleCount;\n }\n\n /**\n * Checks whether the text is available.\n * @returns {boolean} Returns true if the paper has a text.\n */\n hasText() {\n return this._text !== '';\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getText() {\n return this._text;\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getDomain() {\n return this._attributes.domain;\n }\n\n /**\n * Sets the tree.\n *\n * @param {Node} tree The tree to set.\n *\n * @returns {void}\n */\n setTree(tree) {\n this._tree = tree;\n }\n\n /**\n * Returns the tree.\n *\n * @returns {Node} The tree.\n */\n getTree() {\n return this._tree;\n }\n\n /**\n * Checks whether a description is available.\n * @returns {boolean} Returns true if the paper has a description.\n */\n hasDescription() {\n return this._attributes?.data?.body_html !== '' || this._attributes?.data?.descriptionHtml !== '';\n }\n\n /**\n * Returns the description or an empty string if no description is available.\n * @returns {string} Returns the description.\n */\n getDescription() {\n return this._attributes.description;\n }\n\n /**\n * Checks whether an SEO title is available\n * @returns {boolean} Returns true if the Paper has an SEO title.\n */\n hasTitle() {\n return this._attributes.title !== '';\n }\n\n /**\n * Returns the SEO title, or an empty string if no title is available.\n * @returns {string} Returns the SEO title.\n */\n getTitle() {\n return this._attributes.title;\n }\n\n /**\n * Checks whether an SEO title width in pixels is available.\n * @returns {boolean} Returns true if the Paper's SEO title is wider than 0 pixels.\n */\n hasTitleWidth() {\n return this._attributes.titleWidth !== 0;\n }\n\n /**\n * Gets the SEO title width in pixels, or an empty string of no title width in pixels is available.\n * @returns {number} Returns the SEO title width in pixels.\n */\n getTitleWidth() {\n return this._attributes.titleWidth;\n }\n\n /**\n * Checks whether a slug is available.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasSlug() {\n return this._attributes.slug !== '';\n }\n\n /**\n * Checks whether a shop settings is available.\n * @returns {boolean} Returns true if the Paper has a shop settings.\n */\n hasShopSettings() {\n return !isEmpty(this._attributes?.shopSettings || {});\n }\n\n /**\n * Gets the paper's slug, or an empty string if no slug is available.\n * @returns {string} Returns the slug.\n */\n getSlug() {\n return this._attributes.slug;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasProductSchema() {\n return this._attributes?.hasProductSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasFAQsSchema() {\n return this._attributes?.hasFAQsSchema || false;\n }\n\n /**\n *\n * @returns {boolean}\n */\n hasFAQs() {\n return 'faqs' in this.getData() && this.getFAQs().length > 0;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasArticleSchema() {\n return this._attributes?.hasArticleSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasData() {\n const data = this._attributes?.data;\n return isObject(data) && !isEmpty(data);\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasRelatedKeywords() {\n const relatedKeywords = this._attributes?.data?.related_keywords || [];\n return Array.isArray(relatedKeywords) && relatedKeywords.length > 0;\n }\n\n /**\n *\n * @returns {Object|{}}\n */\n getData() {\n return this._attributes?.data || {};\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getIgnoredAssessments() {\n return this._attributes?.ignoredAssessments || [];\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getPageType() {\n return this._attributes?.pageType || '';\n }\n\n /**\n * Returns the HTML content displayed after the product list on collection pages.\n * @returns {string} The after-list HTML, or '' if not set.\n */\n getAfterListContent() {\n return this._attributes?.afterListContent || '';\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getSkippedAssessments() {\n return this._attributes?.skippedAssessments || [];\n }\n\n /**\n *\n * @returns {*|{}}\n */\n getShopSettings() {\n return this._attributes?.shopSettings || {};\n }\n\n /**\n * Checks if currently edited page is a front page.\n * @returns {boolean} Returns true if the current page is a front page.\n */\n isFrontPage() {\n return this._attributes.isFrontPage;\n }\n\n /**\n * Checks whether an url is available\n * @deprecated Since version 1.19.1. Use hasSlug instead.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasUrl() {\n console.warn('This function is deprecated, use hasSlug instead');\n return this.hasSlug();\n }\n\n /**\n * Returns the url, or an empty string if no url is available.\n * @deprecated Since version 1.19.1. Use getSlug instead.\n * @returns {string} Returns the url\n */\n getUrl() {\n console.warn('This function is deprecated, use getSlug instead');\n return this.getSlug();\n }\n\n /**\n * Checks whether a locale is available.\n * @returns {boolean} Returns true if the paper has a locale.\n */\n hasLocale() {\n return this._attributes.locale !== '';\n }\n\n /**\n * Returns the locale or an empty string if no locale is available\n * @returns {string} Returns the locale.\n */\n getLocale() {\n return this._attributes.locale;\n }\n\n /**\n * Gets the information of the writing direction of the paper.\n * It returns \"LTR\" (left to right) if this attribute is not provided.\n *\n * @returns {string} Returns the information of the writing direction of the paper.\n */\n getWritingDirection() {\n return this._attributes.writingDirection;\n }\n\n /**\n * Checks whether a permalink is available.\n * @returns {boolean} Returns true if the Paper has a permalink.\n */\n hasPermalink() {\n return this._attributes.permalink !== '';\n }\n\n /**\n * Returns the permalink, or an empty string if no permalink is available.\n * @returns {string} Returns the permalink.\n */\n getPermalink() {\n return this._attributes.permalink;\n }\n\n /**\n * Checks whether a date is available.\n * @returns {boolean} Returns true if the Paper has a date.\n */\n hasDate() {\n return this._attributes.date !== '';\n }\n\n /**\n * Returns the date, or an empty string if no date is available.\n * @returns {string} Returns the date.\n */\n getDate() {\n return this._attributes.date;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getFAQs() {\n return this.getData()?.faqs || {};\n }\n\n\n /**\n * Checks whether custom data is available.\n * @returns {boolean} Returns true if the Paper has custom data.\n */\n hasCustomData() {\n return !isEmpty(this._attributes.customData);\n }\n\n /**\n * Returns the custom data, or an empty object if no data is available.\n * @returns {Object} Returns the custom data.\n */\n getCustomData() {\n return this._attributes.customData;\n }\n\n /**\n * Checks whether a text title is available.\n * @returns {boolean} Returns true if the Paper has a text title.\n */\n hasTextTitle() {\n return this._attributes.textTitle !== '' && !isNil(this._attributes.textTitle);\n }\n\n /**\n * Returns the text title, or an empty string if no data is available.\n * @returns {string} Returns the text title.\n */\n getTextTitle() {\n return this._attributes.textTitle;\n }\n\n /**\n * Serializes the Paper instance to an object.\n *\n * @returns {Object} The serialized Paper.\n */\n serialize() {\n return {\n _parseClass: 'Paper',\n text: this._text,\n ...this._attributes\n };\n }\n\n /**\n * Checks whether the given paper has the same properties as this instance.\n *\n * @param {Paper} paper The paper to compare to.\n *\n * @returns {boolean} Whether the given paper is identical or not.\n */\n equals(paper) {\n return this._text === paper.getText() && isEqual(this._attributes, paper._attributes);\n }\n\n /**\n * Parses the object to a Paper.\n *\n * @param {Object|Paper} serialized The serialized object or Paper instance.\n *\n * @returns {Paper} The parsed Paper.\n */\n static parse(serialized) {\n // For ease of use, check if it is not already a Paper instance.\n if (serialized instanceof Paper) {\n return serialized;\n }\n\n // _parseClass is taken here, so it doesn't end up in the attributes.\n // eslint-disable-next-line no-unused-vars\n const {text, _parseClass, ...attributes} = serialized;\n\n return new Paper(text, attributes);\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -20,7 +20,8 @@ import getLinkType from "../helpers/link/getLinkType.js";
|
|
|
20
20
|
* otherNofollow: other links with a nofollow attribute.
|
|
21
21
|
*/
|
|
22
22
|
export default function (paper) {
|
|
23
|
-
const
|
|
23
|
+
const text = paper.getPageType() === 'collection' ? paper.getText() + ' ' + paper.getAfterListContent() : paper.getText();
|
|
24
|
+
const anchors = getAnchors(text);
|
|
24
25
|
/*
|
|
25
26
|
* We get the site's URL (e.g., https://yoast.com) or domain (e.g., yoast.com) from the paper.
|
|
26
27
|
* In case of WordPress, the variable is a URL. In case of Shopify, it is a domain.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getLinkStatistics.js","names":["checkNofollow","getAnchors","getLinkType","paper","
|
|
1
|
+
{"version":3,"file":"getLinkStatistics.js","names":["checkNofollow","getAnchors","getLinkType","paper","text","getPageType","getText","getAfterListContent","anchors","siteUrlOrDomain","getPermalink","linkCount","total","length","internalTotal","internalDofollow","internalNofollow","externalTotal","externalDofollow","externalNofollow","otherTotal","otherDofollow","otherNofollow","i","currentAnchor","linkType","linkFollow"],"sources":["../../../../src/languageProcessing/researches/getLinkStatistics.js"],"sourcesContent":["import checkNofollow from \"../helpers/link/checkNofollow.js\";\nimport getAnchors from \"../helpers/link/getAnchorsFromText.js\";\nimport getLinkType from \"../helpers/link/getLinkType.js\";\n\n/**\n * Counts the links found in the text.\n *\n * @param {Paper} paper The paper object containing text, keyword and url.\n *\n * @returns {object} The object containing all linktypes.\n * total: the total number of links found.\n * internalTotal: the total number of links that are internal.\n * internalDofollow: the internal links without a nofollow attribute.\n * internalNofollow: the internal links with a nofollow attribute.\n * externalTotal: the total number of links that are external.\n * externalDofollow: the external links without a nofollow attribute.\n * externalNofollow: the internal links with a dofollow attribute.\n * otherTotal: all links that are not HTTP or HTTPS.\n * otherDofollow: other links without a nofollow attribute.\n * otherNofollow: other links with a nofollow attribute.\n */\nexport default function( paper ) {\n\tconst text = paper.getPageType() === 'collection'\n\t\t? paper.getText() + ' ' + paper.getAfterListContent()\n\t\t: paper.getText();\n\tconst anchors = getAnchors( text );\n\t/*\n\t * We get the site's URL (e.g., https://yoast.com) or domain (e.g., yoast.com) from the paper.\n\t * In case of WordPress, the variable is a URL. In case of Shopify, it is a domain.\n\t */\n\tconst siteUrlOrDomain = paper.getPermalink();\n\n\tconst linkCount = {\n\t\ttotal: anchors.length,\n\t\tinternalTotal: 0,\n\t\tinternalDofollow: 0,\n\t\tinternalNofollow: 0,\n\t\texternalTotal: 0,\n\t\texternalDofollow: 0,\n\t\texternalNofollow: 0,\n\t\totherTotal: 0,\n\t\totherDofollow: 0,\n\t\totherNofollow: 0,\n\t};\n\n\tfor ( let i = 0; i < anchors.length; i++ ) {\n\t\tconst currentAnchor = anchors[ i ];\n\n\t\tconst linkType = getLinkType( currentAnchor, siteUrlOrDomain );\n\t\tconst linkFollow = checkNofollow( currentAnchor );\n\n\t\tlinkCount[ linkType + \"Total\" ]++;\n\t\tlinkCount[ linkType + linkFollow ]++;\n\t}\n\n\treturn linkCount;\n}\n"],"mappings":"AAAA,OAAOA,aAAa;AACpB,OAAOC,UAAU;AACjB,OAAOC,WAAW;;AAElB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,UAAUC,KAAK,EAAG;EAChC,MAAMC,IAAI,GAAGD,KAAK,CAACE,WAAW,CAAC,CAAC,KAAK,YAAY,GAC9CF,KAAK,CAACG,OAAO,CAAC,CAAC,GAAG,GAAG,GAAGH,KAAK,CAACI,mBAAmB,CAAC,CAAC,GACnDJ,KAAK,CAACG,OAAO,CAAC,CAAC;EAClB,MAAME,OAAO,GAAGP,UAAU,CAAEG,IAAK,CAAC;EAClC;AACD;AACA;AACA;EACC,MAAMK,eAAe,GAAGN,KAAK,CAACO,YAAY,CAAC,CAAC;EAE5C,MAAMC,SAAS,GAAG;IACjBC,KAAK,EAAEJ,OAAO,CAACK,MAAM;IACrBC,aAAa,EAAE,CAAC;IAChBC,gBAAgB,EAAE,CAAC;IACnBC,gBAAgB,EAAE,CAAC;IACnBC,aAAa,EAAE,CAAC;IAChBC,gBAAgB,EAAE,CAAC;IACnBC,gBAAgB,EAAE,CAAC;IACnBC,UAAU,EAAE,CAAC;IACbC,aAAa,EAAE,CAAC;IAChBC,aAAa,EAAE;EAChB,CAAC;EAED,KAAM,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGf,OAAO,CAACK,MAAM,EAAEU,CAAC,EAAE,EAAG;IAC1C,MAAMC,aAAa,GAAGhB,OAAO,CAAEe,CAAC,CAAE;IAElC,MAAME,QAAQ,GAAGvB,WAAW,CAAEsB,aAAa,EAAEf,eAAgB,CAAC;IAC9D,MAAMiB,UAAU,GAAG1B,aAAa,CAAEwB,aAAc,CAAC;IAEjDb,SAAS,CAAEc,QAAQ,GAAG,OAAO,CAAE,EAAE;IACjCd,SAAS,CAAEc,QAAQ,GAAGC,UAAU,CAAE,EAAE;EACrC;EAEA,OAAOf,SAAS;AACjB","ignoreList":[]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ContentAssessor, SEOAssessor } from "./index";
|
|
2
2
|
import { groupAssessmentsByCategory, groupAssessmentsByStatus } from "../helpers";
|
|
3
|
+
import { idPointsMap } from "../../const/analysis";
|
|
3
4
|
|
|
4
5
|
/**
|
|
5
6
|
* The AvadaAssessor class is used for the general SEO analysis.
|
|
@@ -88,10 +89,15 @@ export default class AvadaAssessor {
|
|
|
88
89
|
}
|
|
89
90
|
getScore() {
|
|
90
91
|
let point = 0;
|
|
92
|
+
let maxPoint = 0;
|
|
91
93
|
this.assessments.forEach(assessment => {
|
|
94
|
+
const weight = idPointsMap[assessment.id];
|
|
95
|
+
if (weight === undefined) return;
|
|
96
|
+
maxPoint += weight;
|
|
92
97
|
point += assessment.score || 0;
|
|
93
98
|
});
|
|
94
|
-
|
|
99
|
+
if (!maxPoint) return 0;
|
|
100
|
+
return Math.round(point / maxPoint * 100);
|
|
95
101
|
}
|
|
96
102
|
}
|
|
97
103
|
//# sourceMappingURL=avadaAssessor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"avadaAssessor.js","names":["ContentAssessor","SEOAssessor","groupAssessmentsByCategory","groupAssessmentsByStatus","AvadaAssessor","constructor","researcher","config","seoAssessor","contentAssessor","assess","paper","i18n","assessments","results","map","assessment","status","score","data","title","assessBackEnd","getResult","groupBy","getScore","point","forEach","Math","round"],"sources":["../../../../src/scoring/assessors/avadaAssessor.js"],"sourcesContent":["import {ContentAssessor, SEOAssessor} from '@axyseo/scoring/assessors/index';\nimport {groupAssessmentsByCategory, groupAssessmentsByStatus} from '../helpers';\n\n/**\n * The AvadaAssessor class is used for the general SEO analysis.\n */\nexport default class AvadaAssessor {\n /**\n * Creates a new AvadaAssessor instance.\n * @param {Researcher} researcher The researcher to use.\n * @param {Object} [config] The assessor config.\n * @param {Object} [config.textParagraphTooLong]\n * @param {Object} [config.textSentenceLength]\n * @param {Object} [config.textTransitionWords]\n * @param {Object} [config.sentenceBeginnings]\n * @param {Object} [config.relatedKeywords]\n * @param {Object} [config.titleKeyword]\n * @param {Object} [config.textImages]\n * @param {Object} [config.numberTitle]\n * @param {Object} [config.introductionKeyword]\n * @param {Object} [config.keyphraseLength]\n * @param {Object} [config.metaDescriptionKeyword]\n * @param {Object} [config.metaDescriptionLength]\n * @param {Object} [config.subheadingsKeyword]\n * @param {Object} [config.externalLinks]\n * @param {Object} [config.keyphraseDensity]\n * @param {Object} [config.media]\n * @param {Object} [config.urlLength]\n * @param {Object} [config.textLength]\n * @param {Object} [config.singleTitle]\n * @param {Object} [config.keyphrase]\n * @param {Object} [config.internalLinks]\n * @param {Object} [config.titleWidth]\n * @param {Object} [config.slugKeyword]\n * @param {Object} [config.singleH1]\n * @param {Object} [config.schema]\n */\n constructor(researcher, config = {}) {\n const seoAssessor = new SEOAssessor(researcher, config);\n const contentAssessor = new ContentAssessor(researcher, config);\n this.seoAssessor = seoAssessor;\n this.contentAssessor = contentAssessor;\n this.researcher = researcher;\n this.config = config;\n }\n\n assess(paper, i18n = null) {\n this.seoAssessor.assess(paper, i18n);\n this.contentAssessor.assess(paper, i18n);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n assessBackEnd(paper) {\n this.seoAssessor.assess(paper);\n this.contentAssessor.assess(paper);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n getResult(groupBy = 'category', getScore = true) {\n let assessments = [];\n switch (groupBy) {\n case 'category':\n assessments = groupAssessmentsByCategory(this.assessments);\n break;\n case 'status':\n assessments = groupAssessmentsByStatus(this.assessments);\n break;\n }\n\n return {\n assessments,\n ...(getScore ? {score: this.getScore()} : {})\n };\n }\n\n getScore() {\n let point = 0;\n this.assessments.forEach(assessment => {\n point += assessment.score || 0;\n });\n return Math.round(
|
|
1
|
+
{"version":3,"file":"avadaAssessor.js","names":["ContentAssessor","SEOAssessor","groupAssessmentsByCategory","groupAssessmentsByStatus","idPointsMap","AvadaAssessor","constructor","researcher","config","seoAssessor","contentAssessor","assess","paper","i18n","assessments","results","map","assessment","status","score","data","title","assessBackEnd","getResult","groupBy","getScore","point","maxPoint","forEach","weight","id","undefined","Math","round"],"sources":["../../../../src/scoring/assessors/avadaAssessor.js"],"sourcesContent":["import {ContentAssessor, SEOAssessor} from '@axyseo/scoring/assessors/index';\nimport {groupAssessmentsByCategory, groupAssessmentsByStatus} from '../helpers';\nimport {idPointsMap} from '@axyseo/const/analysis';\n\n/**\n * The AvadaAssessor class is used for the general SEO analysis.\n */\nexport default class AvadaAssessor {\n /**\n * Creates a new AvadaAssessor instance.\n * @param {Researcher} researcher The researcher to use.\n * @param {Object} [config] The assessor config.\n * @param {Object} [config.textParagraphTooLong]\n * @param {Object} [config.textSentenceLength]\n * @param {Object} [config.textTransitionWords]\n * @param {Object} [config.sentenceBeginnings]\n * @param {Object} [config.relatedKeywords]\n * @param {Object} [config.titleKeyword]\n * @param {Object} [config.textImages]\n * @param {Object} [config.numberTitle]\n * @param {Object} [config.introductionKeyword]\n * @param {Object} [config.keyphraseLength]\n * @param {Object} [config.metaDescriptionKeyword]\n * @param {Object} [config.metaDescriptionLength]\n * @param {Object} [config.subheadingsKeyword]\n * @param {Object} [config.externalLinks]\n * @param {Object} [config.keyphraseDensity]\n * @param {Object} [config.media]\n * @param {Object} [config.urlLength]\n * @param {Object} [config.textLength]\n * @param {Object} [config.singleTitle]\n * @param {Object} [config.keyphrase]\n * @param {Object} [config.internalLinks]\n * @param {Object} [config.titleWidth]\n * @param {Object} [config.slugKeyword]\n * @param {Object} [config.singleH1]\n * @param {Object} [config.schema]\n */\n constructor(researcher, config = {}) {\n const seoAssessor = new SEOAssessor(researcher, config);\n const contentAssessor = new ContentAssessor(researcher, config);\n this.seoAssessor = seoAssessor;\n this.contentAssessor = contentAssessor;\n this.researcher = researcher;\n this.config = config;\n }\n\n assess(paper, i18n = null) {\n this.seoAssessor.assess(paper, i18n);\n this.contentAssessor.assess(paper, i18n);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n assessBackEnd(paper) {\n this.seoAssessor.assess(paper);\n this.contentAssessor.assess(paper);\n let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];\n assessments = assessments.map(assessment => ({\n ...assessment.config,\n status: assessment.status,\n score: assessment.score,\n data: assessment.data,\n title: assessment.title || assessment.config.title\n }));\n this.assessments = assessments;\n }\n\n getResult(groupBy = 'category', getScore = true) {\n let assessments = [];\n switch (groupBy) {\n case 'category':\n assessments = groupAssessmentsByCategory(this.assessments);\n break;\n case 'status':\n assessments = groupAssessmentsByStatus(this.assessments);\n break;\n }\n\n return {\n assessments,\n ...(getScore ? {score: this.getScore()} : {})\n };\n }\n\n getScore() {\n let point = 0;\n let maxPoint = 0;\n this.assessments.forEach(assessment => {\n const weight = idPointsMap[assessment.id];\n if (weight === undefined) return;\n maxPoint += weight;\n point += assessment.score || 0;\n });\n if (!maxPoint) return 0;\n return Math.round(point / maxPoint * 100);\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -26,7 +26,8 @@ const defaultAttributes = {
|
|
|
26
26
|
writingDirection: 'LTR',
|
|
27
27
|
wpBlocks: [],
|
|
28
28
|
isFrontPage: false,
|
|
29
|
-
pageType: ''
|
|
29
|
+
pageType: '',
|
|
30
|
+
afterListContent: ''
|
|
30
31
|
};
|
|
31
32
|
|
|
32
33
|
/**
|
|
@@ -59,6 +60,7 @@ export default class Paper {
|
|
|
59
60
|
* @param {string} [attributes.textTitle] The title of the text.
|
|
60
61
|
* @param {string} [attributes.writingDirection=LTR] The writing direction of the paper. Defaults to left to right (LTR).
|
|
61
62
|
* @param {boolean} [attributes.isFrontPage=false] Whether the current page is the front page of the site. Defaults to false.
|
|
63
|
+
* @param {string} [attributes.afterListContent] HTML content displayed after the product list on collection pages.
|
|
62
64
|
*/
|
|
63
65
|
constructor(text, attributes) {
|
|
64
66
|
this._text = cleanHTML(text || '');
|
|
@@ -348,6 +350,15 @@ export default class Paper {
|
|
|
348
350
|
getPageType() {
|
|
349
351
|
return this._attributes?.pageType || '';
|
|
350
352
|
}
|
|
353
|
+
|
|
354
|
+
/**
|
|
355
|
+
* Returns the HTML content displayed after the product list on collection pages.
|
|
356
|
+
* @returns {string} The after-list HTML, or '' if not set.
|
|
357
|
+
*/
|
|
358
|
+
getAfterListContent() {
|
|
359
|
+
return this._attributes?.afterListContent || '';
|
|
360
|
+
}
|
|
361
|
+
|
|
351
362
|
/**
|
|
352
363
|
*
|
|
353
364
|
* @returns {Object[String]|*[String]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Paper.js","names":["defaults","isEmpty","isEqual","isNil","isNull","isObject","cleanHTML","transformRelatedKeyword","defaultAttributes","keyword","synonyms","description","title","titleWidth","titleCount","h1Count","slug","domain","locale","permalink","date","customData","textTitle","writingDirection","wpBlocks","isFrontPage","pageType","Paper","constructor","text","attributes","_text","_tree","hasOwnProperty","url","onlyLetters","replace","_attributes","hasKeyword","getKeyword","getAttributes","hasSynonyms","getSynonyms","getRelatedKeywords","data","getData","related_keywords","map","hasH1Count","getH1Count","hasTitleCount","getTitleCount","hasText","getText","getDomain","setTree","tree","getTree","hasDescription","body_html","descriptionHtml","getDescription","hasTitle","getTitle","hasTitleWidth","getTitleWidth","hasSlug","hasShopSettings","shopSettings","getSlug","hasProductSchema","hasFAQsSchema","hasFAQs","getFAQs","length","hasArticleSchema","hasData","hasRelatedKeywords","relatedKeywords","Array","isArray","getIgnoredAssessments","ignoredAssessments","getPageType","getSkippedAssessments","skippedAssessments","getShopSettings","hasUrl","console","warn","getUrl","hasLocale","getLocale","getWritingDirection","hasPermalink","getPermalink","hasDate","getDate","faqs","hasCustomData","getCustomData","hasTextTitle","getTextTitle","serialize","_parseClass","equals","paper","parse","serialized"],"sources":["../../../src/values/Paper.js"],"sourcesContent":["import {defaults, isEmpty, isEqual, isNil, isNull, isObject} from 'lodash';\nimport {cleanHTML} from '@axyseo/helpers';\nimport {transformRelatedKeyword} from '@axyseo/languageProcessing/researches/checkRelatedKeywords';\n\n/**\n * Default attributes to be used by the Paper if they are left undefined.\n * @type {{keyword: string, synonyms: string, description: string, title: string, titleWidth: number,\n * \t\t slug: string, locale: string, permalink: string, date: string, customData: object, textTitle: string,\n * \t\t writingDirection: \"LTR\", isFrontPage: boolean }}\n */\nconst defaultAttributes = {\n keyword: '',\n synonyms: '',\n description: '',\n title: '',\n titleWidth: 0,\n titleCount: null,\n h1Count: null,\n slug: '',\n domain: '',\n locale: 'en_US',\n permalink: '',\n date: '',\n customData: {},\n textTitle: '',\n writingDirection: 'LTR',\n wpBlocks: [],\n isFrontPage: false,\n pageType: '',\n};\n\n/**\n * Represents an object where the analysis data is stored.\n */\nexport default class Paper {\n /**\n * Constructs the Paper object and sets its attributes.\n *\n * @param {string} text The text to use in the analysis.\n * @param {object} [attributes] The object containing all attributes.\n * @param {string} [attributes.keyword] The main keyword or keyphrase of the text.\n * @param {string} [attributes.synonyms] The synonyms of the main keyword or keyphrase. It should be separated by commas if multiple synonyms are added.\n * @param {string} [attributes.description] The SEO meta description.\n * @param {string} [attributes.title] The SEO title.\n * @param {string} [attributes.domain] The shop domain.\n * @param {number|null} [attributes.titleCount=null] The title tag count value.\n * @param {number|null} [attributes.h1Count=null] The h1 tag count value.\n * @param {number} [attributes.titleWidth=0] The width of the title in pixels.\n * @param {string} [attributes.slug] The slug.\n * @param {string} [attributes.locale=en_US] The locale.\n * @param {string} [attributes.permalink] The full URL for any given post, page, or other pieces of content on a site.\n * @param {string} [attributes.date] The date.\n * @param {Object[]} [attributes.wpBlocks] The array of texts, encoded in WordPress block editor blocks.\n * @param {Object[]} [attributes.ignoredAssessments] The array of texts, show which assessments should be ignored.\n * @param {Object[]} [attributes.skippedAssessments] The array of texts, show which assessments should be skipped (those assessments will have good result).\n * @param {Object} [attributes.data] Given data.\n * @param {Object} [attributes.customData] Custom data.\n * @param {Object} [attributes.shopSettings] Shop's settings.\n * @param {string} [attributes.textTitle] The title of the text.\n * @param {string} [attributes.writingDirection=LTR] The writing direction of the paper. Defaults to left to right (LTR).\n * @param {boolean} [attributes.isFrontPage=false] Whether the current page is the front page of the site. Defaults to false.\n */\n constructor(text, attributes) {\n this._text = cleanHTML(text || '');\n\n this._tree = null;\n\n attributes = attributes || {};\n defaults(attributes, defaultAttributes);\n\n if (attributes.locale === '') {\n attributes.locale = defaultAttributes.locale;\n }\n\n if (attributes.hasOwnProperty('url')) {\n attributes.slug = attributes.url || attributes.slug;\n }\n\n const onlyLetters = attributes.keyword.replace(\n /[‘’“”\"'.?!:;,¿¡«»&*@#±^%|~`[\\](){}⟨⟩<>/\\\\–\\-\\u2014\\u00d7\\u002b\\s]/g,\n ''\n );\n\n if (isEmpty(onlyLetters)) {\n attributes.keyword = defaultAttributes.keyword;\n }\n\n this._attributes = attributes;\n }\n\n /**\n * Checks whether a keyword is available.\n * @returns {boolean} Returns true if the Paper has a keyword.\n */\n hasKeyword() {\n return this._attributes.keyword !== '';\n }\n\n /**\n * Returns the associated keyword or an empty string if no keyword is available.\n * @returns {string} Returns Keyword\n */\n getKeyword() {\n return this._attributes.keyword;\n }\n\n /**\n *\n * @returns {*|{keyword?: string, synonyms?: string, description?: string, title?: string, titleCount?: (number|null), h1Count?: (number|null), titleWidth?: number, slug?: string, locale?: string, permalink?: string, date?: string, wpBlocks?: Object[], customData?: Object, textTitle?: string, writingDirection?: string, isFrontPage?: boolean}|{}|{}}\n */\n getAttributes() {\n return this._attributes;\n }\n\n /**\n * Checks whether synonyms are available.\n * @returns {boolean} Returns true if the Paper has synonyms.\n */\n hasSynonyms() {\n return this._attributes.synonyms !== '';\n }\n\n /**\n * Returns the associated synonyms or an empty string if no synonyms is available.\n * @returns {string} Returns synonyms.\n */\n getSynonyms() {\n return this._attributes.synonyms;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getRelatedKeywords() {\n const data = this.getData();\n return (data?.related_keywords || []).map(keyword => keyword.text);\n }\n\n /**\n * Checks whether the h1 count value is available.\n * @returns {boolean} Returns true if the paper has a h1 count value.\n */\n hasH1Count() {\n return !isNull(this._attributes.h1Count);\n }\n\n /**\n * Returns the h1 tag count value.\n * @returns {number | null}\n */\n getH1Count() {\n return this._attributes.h1Count;\n }\n\n /**\n * Checks whether the title count value is available.\n * @returns {boolean} Returns true if the paper has a title count.\n */\n hasTitleCount() {\n return !isNull(this._attributes.titleCount);\n }\n\n /**\n * Returns the title count value.\n * @returns {number | null}\n */\n getTitleCount() {\n return this._attributes.titleCount;\n }\n\n /**\n * Checks whether the text is available.\n * @returns {boolean} Returns true if the paper has a text.\n */\n hasText() {\n return this._text !== '';\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getText() {\n return this._text;\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getDomain() {\n return this._attributes.domain;\n }\n\n /**\n * Sets the tree.\n *\n * @param {Node} tree The tree to set.\n *\n * @returns {void}\n */\n setTree(tree) {\n this._tree = tree;\n }\n\n /**\n * Returns the tree.\n *\n * @returns {Node} The tree.\n */\n getTree() {\n return this._tree;\n }\n\n /**\n * Checks whether a description is available.\n * @returns {boolean} Returns true if the paper has a description.\n */\n hasDescription() {\n return this._attributes?.data?.body_html !== '' || this._attributes?.data?.descriptionHtml !== '';\n }\n\n /**\n * Returns the description or an empty string if no description is available.\n * @returns {string} Returns the description.\n */\n getDescription() {\n return this._attributes.description;\n }\n\n /**\n * Checks whether an SEO title is available\n * @returns {boolean} Returns true if the Paper has an SEO title.\n */\n hasTitle() {\n return this._attributes.title !== '';\n }\n\n /**\n * Returns the SEO title, or an empty string if no title is available.\n * @returns {string} Returns the SEO title.\n */\n getTitle() {\n return this._attributes.title;\n }\n\n /**\n * Checks whether an SEO title width in pixels is available.\n * @returns {boolean} Returns true if the Paper's SEO title is wider than 0 pixels.\n */\n hasTitleWidth() {\n return this._attributes.titleWidth !== 0;\n }\n\n /**\n * Gets the SEO title width in pixels, or an empty string of no title width in pixels is available.\n * @returns {number} Returns the SEO title width in pixels.\n */\n getTitleWidth() {\n return this._attributes.titleWidth;\n }\n\n /**\n * Checks whether a slug is available.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasSlug() {\n return this._attributes.slug !== '';\n }\n\n /**\n * Checks whether a shop settings is available.\n * @returns {boolean} Returns true if the Paper has a shop settings.\n */\n hasShopSettings() {\n return !isEmpty(this._attributes?.shopSettings || {});\n }\n\n /**\n * Gets the paper's slug, or an empty string if no slug is available.\n * @returns {string} Returns the slug.\n */\n getSlug() {\n return this._attributes.slug;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasProductSchema() {\n return this._attributes?.hasProductSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasFAQsSchema() {\n return this._attributes?.hasFAQsSchema || false;\n }\n\n /**\n *\n * @returns {boolean}\n */\n hasFAQs() {\n return 'faqs' in this.getData() && this.getFAQs().length > 0;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasArticleSchema() {\n return this._attributes?.hasArticleSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasData() {\n const data = this._attributes?.data;\n return isObject(data) && !isEmpty(data);\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasRelatedKeywords() {\n const relatedKeywords = this._attributes?.data?.related_keywords || [];\n return Array.isArray(relatedKeywords) && relatedKeywords.length > 0;\n }\n\n /**\n *\n * @returns {Object|{}}\n */\n getData() {\n return this._attributes?.data || {};\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getIgnoredAssessments() {\n return this._attributes?.ignoredAssessments || [];\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getPageType() {\n return this._attributes?.pageType || '';\n }\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getSkippedAssessments() {\n return this._attributes?.skippedAssessments || [];\n }\n\n /**\n *\n * @returns {*|{}}\n */\n getShopSettings() {\n return this._attributes?.shopSettings || {};\n }\n\n /**\n * Checks if currently edited page is a front page.\n * @returns {boolean} Returns true if the current page is a front page.\n */\n isFrontPage() {\n return this._attributes.isFrontPage;\n }\n\n /**\n * Checks whether an url is available\n * @deprecated Since version 1.19.1. Use hasSlug instead.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasUrl() {\n console.warn('This function is deprecated, use hasSlug instead');\n return this.hasSlug();\n }\n\n /**\n * Returns the url, or an empty string if no url is available.\n * @deprecated Since version 1.19.1. Use getSlug instead.\n * @returns {string} Returns the url\n */\n getUrl() {\n console.warn('This function is deprecated, use getSlug instead');\n return this.getSlug();\n }\n\n /**\n * Checks whether a locale is available.\n * @returns {boolean} Returns true if the paper has a locale.\n */\n hasLocale() {\n return this._attributes.locale !== '';\n }\n\n /**\n * Returns the locale or an empty string if no locale is available\n * @returns {string} Returns the locale.\n */\n getLocale() {\n return this._attributes.locale;\n }\n\n /**\n * Gets the information of the writing direction of the paper.\n * It returns \"LTR\" (left to right) if this attribute is not provided.\n *\n * @returns {string} Returns the information of the writing direction of the paper.\n */\n getWritingDirection() {\n return this._attributes.writingDirection;\n }\n\n /**\n * Checks whether a permalink is available.\n * @returns {boolean} Returns true if the Paper has a permalink.\n */\n hasPermalink() {\n return this._attributes.permalink !== '';\n }\n\n /**\n * Returns the permalink, or an empty string if no permalink is available.\n * @returns {string} Returns the permalink.\n */\n getPermalink() {\n return this._attributes.permalink;\n }\n\n /**\n * Checks whether a date is available.\n * @returns {boolean} Returns true if the Paper has a date.\n */\n hasDate() {\n return this._attributes.date !== '';\n }\n\n /**\n * Returns the date, or an empty string if no date is available.\n * @returns {string} Returns the date.\n */\n getDate() {\n return this._attributes.date;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getFAQs() {\n return this.getData()?.faqs || {};\n }\n\n\n /**\n * Checks whether custom data is available.\n * @returns {boolean} Returns true if the Paper has custom data.\n */\n hasCustomData() {\n return !isEmpty(this._attributes.customData);\n }\n\n /**\n * Returns the custom data, or an empty object if no data is available.\n * @returns {Object} Returns the custom data.\n */\n getCustomData() {\n return this._attributes.customData;\n }\n\n /**\n * Checks whether a text title is available.\n * @returns {boolean} Returns true if the Paper has a text title.\n */\n hasTextTitle() {\n return this._attributes.textTitle !== '' && !isNil(this._attributes.textTitle);\n }\n\n /**\n * Returns the text title, or an empty string if no data is available.\n * @returns {string} Returns the text title.\n */\n getTextTitle() {\n return this._attributes.textTitle;\n }\n\n /**\n * Serializes the Paper instance to an object.\n *\n * @returns {Object} The serialized Paper.\n */\n serialize() {\n return {\n _parseClass: 'Paper',\n text: this._text,\n ...this._attributes\n };\n }\n\n /**\n * Checks whether the given paper has the same properties as this instance.\n *\n * @param {Paper} paper The paper to compare to.\n *\n * @returns {boolean} Whether the given paper is identical or not.\n */\n equals(paper) {\n return this._text === paper.getText() && isEqual(this._attributes, paper._attributes);\n }\n\n /**\n * Parses the object to a Paper.\n *\n * @param {Object|Paper} serialized The serialized object or Paper instance.\n *\n * @returns {Paper} The parsed Paper.\n */\n static parse(serialized) {\n // For ease of use, check if it is not already a Paper instance.\n if (serialized instanceof Paper) {\n return serialized;\n }\n\n // _parseClass is taken here, so it doesn't end up in the attributes.\n // eslint-disable-next-line no-unused-vars\n const {text, _parseClass, ...attributes} = serialized;\n\n return new Paper(text, attributes);\n }\n}\n"],"mappings":"AAAA,SAAQA,QAAQ,EAAEC,OAAO,EAAEC,OAAO,EAAEC,KAAK,EAAEC,MAAM,EAAEC,QAAQ,QAAO,QAAQ;AAC1E,SAAQC,SAAS;AACjB,SAAQC,uBAAuB;;AAE/B;AACA;AACA;AACA;AACA;AACA;AACA,MAAMC,iBAAiB,GAAG;EACxBC,OAAO,EAAE,EAAE;EACXC,QAAQ,EAAE,EAAE;EACZC,WAAW,EAAE,EAAE;EACfC,KAAK,EAAE,EAAE;EACTC,UAAU,EAAE,CAAC;EACbC,UAAU,EAAE,IAAI;EAChBC,OAAO,EAAE,IAAI;EACbC,IAAI,EAAE,EAAE;EACRC,MAAM,EAAE,EAAE;EACVC,MAAM,EAAE,OAAO;EACfC,SAAS,EAAE,EAAE;EACbC,IAAI,EAAE,EAAE;EACRC,UAAU,EAAE,CAAC,CAAC;EACdC,SAAS,EAAE,EAAE;EACbC,gBAAgB,EAAE,KAAK;EACvBC,QAAQ,EAAE,EAAE;EACZC,WAAW,EAAE,KAAK;EAClBC,QAAQ,EAAE;AACZ,CAAC;;AAED;AACA;AACA;AACA,eAAe,MAAMC,KAAK,CAAC;EACzB;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,IAAI,EAAEC,UAAU,EAAE;IAC5B,IAAI,CAACC,KAAK,GAAGzB,SAAS,CAACuB,IAAI,IAAI,EAAE,CAAC;IAElC,IAAI,CAACG,KAAK,GAAG,IAAI;IAEjBF,UAAU,GAAGA,UAAU,IAAI,CAAC,CAAC;IAC7B9B,QAAQ,CAAC8B,UAAU,EAAEtB,iBAAiB,CAAC;IAEvC,IAAIsB,UAAU,CAACZ,MAAM,KAAK,EAAE,EAAE;MAC5BY,UAAU,CAACZ,MAAM,GAAGV,iBAAiB,CAACU,MAAM;IAC9C;IAEA,IAAIY,UAAU,CAACG,cAAc,CAAC,KAAK,CAAC,EAAE;MACpCH,UAAU,CAACd,IAAI,GAAGc,UAAU,CAACI,GAAG,IAAIJ,UAAU,CAACd,IAAI;IACrD;IAEA,MAAMmB,WAAW,GAAGL,UAAU,CAACrB,OAAO,CAAC2B,OAAO,CAC5C,oEAAoE,EACpE,EACF,CAAC;IAED,IAAInC,OAAO,CAACkC,WAAW,CAAC,EAAE;MACxBL,UAAU,CAACrB,OAAO,GAAGD,iBAAiB,CAACC,OAAO;IAChD;IAEA,IAAI,CAAC4B,WAAW,GAAGP,UAAU;EAC/B;;EAEA;AACF;AACA;AACA;EACEQ,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACD,WAAW,CAAC5B,OAAO,KAAK,EAAE;EACxC;;EAEA;AACF;AACA;AACA;EACE8B,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACF,WAAW,CAAC5B,OAAO;EACjC;;EAEA;AACF;AACA;AACA;EACE+B,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACH,WAAW;EACzB;;EAEA;AACF;AACA;AACA;EACEI,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACJ,WAAW,CAAC3B,QAAQ,KAAK,EAAE;EACzC;;EAEA;AACF;AACA;AACA;EACEgC,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACL,WAAW,CAAC3B,QAAQ;EAClC;;EAEA;AACF;AACA;AACA;EACEiC,kBAAkBA,CAAA,EAAG;IACnB,MAAMC,IAAI,GAAG,IAAI,CAACC,OAAO,CAAC,CAAC;IAC3B,OAAO,CAACD,IAAI,EAAEE,gBAAgB,IAAI,EAAE,EAAEC,GAAG,CAACtC,OAAO,IAAIA,OAAO,CAACoB,IAAI,CAAC;EACpE;;EAEA;AACF;AACA;AACA;EACEmB,UAAUA,CAAA,EAAG;IACX,OAAO,CAAC5C,MAAM,CAAC,IAAI,CAACiC,WAAW,CAACtB,OAAO,CAAC;EAC1C;;EAEA;AACF;AACA;AACA;EACEkC,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACZ,WAAW,CAACtB,OAAO;EACjC;;EAEA;AACF;AACA;AACA;EACEmC,aAAaA,CAAA,EAAG;IACd,OAAO,CAAC9C,MAAM,CAAC,IAAI,CAACiC,WAAW,CAACvB,UAAU,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;EACEqC,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAACd,WAAW,CAACvB,UAAU;EACpC;;EAEA;AACF;AACA;AACA;EACEsC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACrB,KAAK,KAAK,EAAE;EAC1B;;EAEA;AACF;AACA;AACA;EACEsB,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACtB,KAAK;EACnB;;EAEA;AACF;AACA;AACA;EACEuB,SAASA,CAAA,EAAG;IACV,OAAO,IAAI,CAACjB,WAAW,CAACpB,MAAM;EAChC;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEsC,OAAOA,CAACC,IAAI,EAAE;IACZ,IAAI,CAACxB,KAAK,GAAGwB,IAAI;EACnB;;EAEA;AACF;AACA;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACzB,KAAK;EACnB;;EAEA;AACF;AACA;AACA;EACE0B,cAAcA,CAAA,EAAG;IACf,OAAO,IAAI,CAACrB,WAAW,EAAEO,IAAI,EAAEe,SAAS,KAAK,EAAE,IAAI,IAAI,CAACtB,WAAW,EAAEO,IAAI,EAAEgB,eAAe,KAAK,EAAE;EACnG;;EAEA;AACF;AACA;AACA;EACEC,cAAcA,CAAA,EAAG;IACf,OAAO,IAAI,CAACxB,WAAW,CAAC1B,WAAW;EACrC;;EAEA;AACF;AACA;AACA;EACEmD,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAACzB,WAAW,CAACzB,KAAK,KAAK,EAAE;EACtC;;EAEA;AACF;AACA;AACA;EACEmD,QAAQA,CAAA,EAAG;IACT,OAAO,IAAI,CAAC1B,WAAW,CAACzB,KAAK;EAC/B;;EAEA;AACF;AACA;AACA;EACEoD,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC3B,WAAW,CAACxB,UAAU,KAAK,CAAC;EAC1C;;EAEA;AACF;AACA;AACA;EACEoD,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC5B,WAAW,CAACxB,UAAU;EACpC;;EAEA;AACF;AACA;AACA;EACEqD,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC7B,WAAW,CAACrB,IAAI,KAAK,EAAE;EACrC;;EAEA;AACF;AACA;AACA;EACEmD,eAAeA,CAAA,EAAG;IAChB,OAAO,CAAClE,OAAO,CAAC,IAAI,CAACoC,WAAW,EAAE+B,YAAY,IAAI,CAAC,CAAC,CAAC;EACvD;;EAEA;AACF;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAChC,WAAW,CAACrB,IAAI;EAC9B;;EAEA;AACF;AACA;AACA;EACEsD,gBAAgBA,CAAA,EAAG;IACjB,OAAO,IAAI,CAACjC,WAAW,EAAEiC,gBAAgB,IAAI,KAAK;EACpD;;EAEA;AACF;AACA;AACA;EACEC,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAClC,WAAW,EAAEkC,aAAa,IAAI,KAAK;EACjD;;EAEA;AACF;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,OAAO,MAAM,IAAI,IAAI,CAAC3B,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC4B,OAAO,CAAC,CAAC,CAACC,MAAM,GAAG,CAAC;EAC9D;;EAEA;AACF;AACA;AACA;EACEC,gBAAgBA,CAAA,EAAG;IACjB,OAAO,IAAI,CAACtC,WAAW,EAAEsC,gBAAgB,IAAI,KAAK;EACpD;;EAEA;AACF;AACA;AACA;EACEC,OAAOA,CAAA,EAAG;IACR,MAAMhC,IAAI,GAAG,IAAI,CAACP,WAAW,EAAEO,IAAI;IACnC,OAAOvC,QAAQ,CAACuC,IAAI,CAAC,IAAI,CAAC3C,OAAO,CAAC2C,IAAI,CAAC;EACzC;;EAEA;AACF;AACA;AACA;EACEiC,kBAAkBA,CAAA,EAAG;IACnB,MAAMC,eAAe,GAAG,IAAI,CAACzC,WAAW,EAAEO,IAAI,EAAEE,gBAAgB,IAAI,EAAE;IACtE,OAAOiC,KAAK,CAACC,OAAO,CAACF,eAAe,CAAC,IAAIA,eAAe,CAACJ,MAAM,GAAG,CAAC;EACrE;;EAEA;AACF;AACA;AACA;EACE7B,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAACR,WAAW,EAAEO,IAAI,IAAI,CAAC,CAAC;EACrC;;EAEA;AACF;AACA;AACA;EACEqC,qBAAqBA,CAAA,EAAG;IACtB,OAAO,IAAI,CAAC5C,WAAW,EAAE6C,kBAAkB,IAAI,EAAE;EACnD;;EAEA;AACF;AACA;AACA;EACEC,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAC9C,WAAW,EAAEX,QAAQ,IAAI,EAAE;EACzC;EACA;AACF;AACA;AACA;EACE0D,qBAAqBA,CAAA,EAAG;IACtB,OAAO,IAAI,CAAC/C,WAAW,EAAEgD,kBAAkB,IAAI,EAAE;EACnD;;EAEA;AACF;AACA;AACA;EACEC,eAAeA,CAAA,EAAG;IAChB,OAAO,IAAI,CAACjD,WAAW,EAAE+B,YAAY,IAAI,CAAC,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;EACE3C,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACY,WAAW,CAACZ,WAAW;EACrC;;EAEA;AACF;AACA;AACA;AACA;EACE8D,MAAMA,CAAA,EAAG;IACPC,OAAO,CAACC,IAAI,CAAC,kDAAkD,CAAC;IAChE,OAAO,IAAI,CAACvB,OAAO,CAAC,CAAC;EACvB;;EAEA;AACF;AACA;AACA;AACA;EACEwB,MAAMA,CAAA,EAAG;IACPF,OAAO,CAACC,IAAI,CAAC,kDAAkD,CAAC;IAChE,OAAO,IAAI,CAACpB,OAAO,CAAC,CAAC;EACvB;;EAEA;AACF;AACA;AACA;EACEsB,SAASA,CAAA,EAAG;IACV,OAAO,IAAI,CAACtD,WAAW,CAACnB,MAAM,KAAK,EAAE;EACvC;;EAEA;AACF;AACA;AACA;EACE0E,SAASA,CAAA,EAAG;IACV,OAAO,IAAI,CAACvD,WAAW,CAACnB,MAAM;EAChC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE2E,mBAAmBA,CAAA,EAAG;IACpB,OAAO,IAAI,CAACxD,WAAW,CAACd,gBAAgB;EAC1C;;EAEA;AACF;AACA;AACA;EACEuE,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAACzD,WAAW,CAAClB,SAAS,KAAK,EAAE;EAC1C;;EAEA;AACF;AACA;AACA;EACE4E,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAAC1D,WAAW,CAAClB,SAAS;EACnC;;EAEA;AACF;AACA;AACA;EACE6E,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC3D,WAAW,CAACjB,IAAI,KAAK,EAAE;EACrC;;EAEA;AACF;AACA;AACA;EACE6E,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC5D,WAAW,CAACjB,IAAI;EAC9B;;EAEA;AACF;AACA;AACA;EACEqD,OAAOA,CAAA,EAAG;IACR,OAAO,IAAI,CAAC5B,OAAO,CAAC,CAAC,EAAEqD,IAAI,IAAI,CAAC,CAAC;EACnC;;EAGA;AACF;AACA;AACA;EACEC,aAAaA,CAAA,EAAG;IACd,OAAO,CAAClG,OAAO,CAAC,IAAI,CAACoC,WAAW,CAAChB,UAAU,CAAC;EAC9C;;EAEA;AACF;AACA;AACA;EACE+E,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC/D,WAAW,CAAChB,UAAU;EACpC;;EAEA;AACF;AACA;AACA;EACEgF,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAAChE,WAAW,CAACf,SAAS,KAAK,EAAE,IAAI,CAACnB,KAAK,CAAC,IAAI,CAACkC,WAAW,CAACf,SAAS,CAAC;EAChF;;EAEA;AACF;AACA;AACA;EACEgF,YAAYA,CAAA,EAAG;IACb,OAAO,IAAI,CAACjE,WAAW,CAACf,SAAS;EACnC;;EAEA;AACF;AACA;AACA;AACA;EACEiF,SAASA,CAAA,EAAG;IACV,OAAO;MACLC,WAAW,EAAE,OAAO;MACpB3E,IAAI,EAAE,IAAI,CAACE,KAAK;MAChB,GAAG,IAAI,CAACM;IACV,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEoE,MAAMA,CAACC,KAAK,EAAE;IACZ,OAAO,IAAI,CAAC3E,KAAK,KAAK2E,KAAK,CAACrD,OAAO,CAAC,CAAC,IAAInD,OAAO,CAAC,IAAI,CAACmC,WAAW,EAAEqE,KAAK,CAACrE,WAAW,CAAC;EACvF;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,OAAOsE,KAAKA,CAACC,UAAU,EAAE;IACvB;IACA,IAAIA,UAAU,YAAYjF,KAAK,EAAE;MAC/B,OAAOiF,UAAU;IACnB;;IAEA;IACA;IACA,MAAM;MAAC/E,IAAI;MAAE2E,WAAW;MAAE,GAAG1E;IAAU,CAAC,GAAG8E,UAAU;IAErD,OAAO,IAAIjF,KAAK,CAACE,IAAI,EAAEC,UAAU,CAAC;EACpC;AACF","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Paper.js","names":["defaults","isEmpty","isEqual","isNil","isNull","isObject","cleanHTML","transformRelatedKeyword","defaultAttributes","keyword","synonyms","description","title","titleWidth","titleCount","h1Count","slug","domain","locale","permalink","date","customData","textTitle","writingDirection","wpBlocks","isFrontPage","pageType","afterListContent","Paper","constructor","text","attributes","_text","_tree","hasOwnProperty","url","onlyLetters","replace","_attributes","hasKeyword","getKeyword","getAttributes","hasSynonyms","getSynonyms","getRelatedKeywords","data","getData","related_keywords","map","hasH1Count","getH1Count","hasTitleCount","getTitleCount","hasText","getText","getDomain","setTree","tree","getTree","hasDescription","body_html","descriptionHtml","getDescription","hasTitle","getTitle","hasTitleWidth","getTitleWidth","hasSlug","hasShopSettings","shopSettings","getSlug","hasProductSchema","hasFAQsSchema","hasFAQs","getFAQs","length","hasArticleSchema","hasData","hasRelatedKeywords","relatedKeywords","Array","isArray","getIgnoredAssessments","ignoredAssessments","getPageType","getAfterListContent","getSkippedAssessments","skippedAssessments","getShopSettings","hasUrl","console","warn","getUrl","hasLocale","getLocale","getWritingDirection","hasPermalink","getPermalink","hasDate","getDate","faqs","hasCustomData","getCustomData","hasTextTitle","getTextTitle","serialize","_parseClass","equals","paper","parse","serialized"],"sources":["../../../src/values/Paper.js"],"sourcesContent":["import {defaults, isEmpty, isEqual, isNil, isNull, isObject} from 'lodash';\nimport {cleanHTML} from '@axyseo/helpers';\nimport {transformRelatedKeyword} from '@axyseo/languageProcessing/researches/checkRelatedKeywords';\n\n/**\n * Default attributes to be used by the Paper if they are left undefined.\n * @type {{keyword: string, synonyms: string, description: string, title: string, titleWidth: number,\n * \t\t slug: string, locale: string, permalink: string, date: string, customData: object, textTitle: string,\n * \t\t writingDirection: \"LTR\", isFrontPage: boolean }}\n */\nconst defaultAttributes = {\n keyword: '',\n synonyms: '',\n description: '',\n title: '',\n titleWidth: 0,\n titleCount: null,\n h1Count: null,\n slug: '',\n domain: '',\n locale: 'en_US',\n permalink: '',\n date: '',\n customData: {},\n textTitle: '',\n writingDirection: 'LTR',\n wpBlocks: [],\n isFrontPage: false,\n pageType: '',\n afterListContent: '',\n};\n\n/**\n * Represents an object where the analysis data is stored.\n */\nexport default class Paper {\n /**\n * Constructs the Paper object and sets its attributes.\n *\n * @param {string} text The text to use in the analysis.\n * @param {object} [attributes] The object containing all attributes.\n * @param {string} [attributes.keyword] The main keyword or keyphrase of the text.\n * @param {string} [attributes.synonyms] The synonyms of the main keyword or keyphrase. It should be separated by commas if multiple synonyms are added.\n * @param {string} [attributes.description] The SEO meta description.\n * @param {string} [attributes.title] The SEO title.\n * @param {string} [attributes.domain] The shop domain.\n * @param {number|null} [attributes.titleCount=null] The title tag count value.\n * @param {number|null} [attributes.h1Count=null] The h1 tag count value.\n * @param {number} [attributes.titleWidth=0] The width of the title in pixels.\n * @param {string} [attributes.slug] The slug.\n * @param {string} [attributes.locale=en_US] The locale.\n * @param {string} [attributes.permalink] The full URL for any given post, page, or other pieces of content on a site.\n * @param {string} [attributes.date] The date.\n * @param {Object[]} [attributes.wpBlocks] The array of texts, encoded in WordPress block editor blocks.\n * @param {Object[]} [attributes.ignoredAssessments] The array of texts, show which assessments should be ignored.\n * @param {Object[]} [attributes.skippedAssessments] The array of texts, show which assessments should be skipped (those assessments will have good result).\n * @param {Object} [attributes.data] Given data.\n * @param {Object} [attributes.customData] Custom data.\n * @param {Object} [attributes.shopSettings] Shop's settings.\n * @param {string} [attributes.textTitle] The title of the text.\n * @param {string} [attributes.writingDirection=LTR] The writing direction of the paper. Defaults to left to right (LTR).\n * @param {boolean} [attributes.isFrontPage=false] Whether the current page is the front page of the site. Defaults to false.\n * @param {string} [attributes.afterListContent] HTML content displayed after the product list on collection pages.\n */\n constructor(text, attributes) {\n this._text = cleanHTML(text || '');\n\n this._tree = null;\n\n attributes = attributes || {};\n defaults(attributes, defaultAttributes);\n\n if (attributes.locale === '') {\n attributes.locale = defaultAttributes.locale;\n }\n\n if (attributes.hasOwnProperty('url')) {\n attributes.slug = attributes.url || attributes.slug;\n }\n\n const onlyLetters = attributes.keyword.replace(\n /[‘’“”\"'.?!:;,¿¡«»&*@#±^%|~`[\\](){}⟨⟩<>/\\\\–\\-\\u2014\\u00d7\\u002b\\s]/g,\n ''\n );\n\n if (isEmpty(onlyLetters)) {\n attributes.keyword = defaultAttributes.keyword;\n }\n\n this._attributes = attributes;\n }\n\n /**\n * Checks whether a keyword is available.\n * @returns {boolean} Returns true if the Paper has a keyword.\n */\n hasKeyword() {\n return this._attributes.keyword !== '';\n }\n\n /**\n * Returns the associated keyword or an empty string if no keyword is available.\n * @returns {string} Returns Keyword\n */\n getKeyword() {\n return this._attributes.keyword;\n }\n\n /**\n *\n * @returns {*|{keyword?: string, synonyms?: string, description?: string, title?: string, titleCount?: (number|null), h1Count?: (number|null), titleWidth?: number, slug?: string, locale?: string, permalink?: string, date?: string, wpBlocks?: Object[], customData?: Object, textTitle?: string, writingDirection?: string, isFrontPage?: boolean}|{}|{}}\n */\n getAttributes() {\n return this._attributes;\n }\n\n /**\n * Checks whether synonyms are available.\n * @returns {boolean} Returns true if the Paper has synonyms.\n */\n hasSynonyms() {\n return this._attributes.synonyms !== '';\n }\n\n /**\n * Returns the associated synonyms or an empty string if no synonyms is available.\n * @returns {string} Returns synonyms.\n */\n getSynonyms() {\n return this._attributes.synonyms;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getRelatedKeywords() {\n const data = this.getData();\n return (data?.related_keywords || []).map(keyword => keyword.text);\n }\n\n /**\n * Checks whether the h1 count value is available.\n * @returns {boolean} Returns true if the paper has a h1 count value.\n */\n hasH1Count() {\n return !isNull(this._attributes.h1Count);\n }\n\n /**\n * Returns the h1 tag count value.\n * @returns {number | null}\n */\n getH1Count() {\n return this._attributes.h1Count;\n }\n\n /**\n * Checks whether the title count value is available.\n * @returns {boolean} Returns true if the paper has a title count.\n */\n hasTitleCount() {\n return !isNull(this._attributes.titleCount);\n }\n\n /**\n * Returns the title count value.\n * @returns {number | null}\n */\n getTitleCount() {\n return this._attributes.titleCount;\n }\n\n /**\n * Checks whether the text is available.\n * @returns {boolean} Returns true if the paper has a text.\n */\n hasText() {\n return this._text !== '';\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getText() {\n return this._text;\n }\n\n /**\n * Returns the associated text or an empty string if no text is available.\n * @returns {string} Returns the text.\n */\n getDomain() {\n return this._attributes.domain;\n }\n\n /**\n * Sets the tree.\n *\n * @param {Node} tree The tree to set.\n *\n * @returns {void}\n */\n setTree(tree) {\n this._tree = tree;\n }\n\n /**\n * Returns the tree.\n *\n * @returns {Node} The tree.\n */\n getTree() {\n return this._tree;\n }\n\n /**\n * Checks whether a description is available.\n * @returns {boolean} Returns true if the paper has a description.\n */\n hasDescription() {\n return this._attributes?.data?.body_html !== '' || this._attributes?.data?.descriptionHtml !== '';\n }\n\n /**\n * Returns the description or an empty string if no description is available.\n * @returns {string} Returns the description.\n */\n getDescription() {\n return this._attributes.description;\n }\n\n /**\n * Checks whether an SEO title is available\n * @returns {boolean} Returns true if the Paper has an SEO title.\n */\n hasTitle() {\n return this._attributes.title !== '';\n }\n\n /**\n * Returns the SEO title, or an empty string if no title is available.\n * @returns {string} Returns the SEO title.\n */\n getTitle() {\n return this._attributes.title;\n }\n\n /**\n * Checks whether an SEO title width in pixels is available.\n * @returns {boolean} Returns true if the Paper's SEO title is wider than 0 pixels.\n */\n hasTitleWidth() {\n return this._attributes.titleWidth !== 0;\n }\n\n /**\n * Gets the SEO title width in pixels, or an empty string of no title width in pixels is available.\n * @returns {number} Returns the SEO title width in pixels.\n */\n getTitleWidth() {\n return this._attributes.titleWidth;\n }\n\n /**\n * Checks whether a slug is available.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasSlug() {\n return this._attributes.slug !== '';\n }\n\n /**\n * Checks whether a shop settings is available.\n * @returns {boolean} Returns true if the Paper has a shop settings.\n */\n hasShopSettings() {\n return !isEmpty(this._attributes?.shopSettings || {});\n }\n\n /**\n * Gets the paper's slug, or an empty string if no slug is available.\n * @returns {string} Returns the slug.\n */\n getSlug() {\n return this._attributes.slug;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasProductSchema() {\n return this._attributes?.hasProductSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasFAQsSchema() {\n return this._attributes?.hasFAQsSchema || false;\n }\n\n /**\n *\n * @returns {boolean}\n */\n hasFAQs() {\n return 'faqs' in this.getData() && this.getFAQs().length > 0;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasArticleSchema() {\n return this._attributes?.hasArticleSchema || false;\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasData() {\n const data = this._attributes?.data;\n return isObject(data) && !isEmpty(data);\n }\n\n /**\n *\n * @returns {(function(): *)|boolean}\n */\n hasRelatedKeywords() {\n const relatedKeywords = this._attributes?.data?.related_keywords || [];\n return Array.isArray(relatedKeywords) && relatedKeywords.length > 0;\n }\n\n /**\n *\n * @returns {Object|{}}\n */\n getData() {\n return this._attributes?.data || {};\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getIgnoredAssessments() {\n return this._attributes?.ignoredAssessments || [];\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getPageType() {\n return this._attributes?.pageType || '';\n }\n\n /**\n * Returns the HTML content displayed after the product list on collection pages.\n * @returns {string} The after-list HTML, or '' if not set.\n */\n getAfterListContent() {\n return this._attributes?.afterListContent || '';\n }\n\n /**\n *\n * @returns {Object[String]|*[String]}\n */\n getSkippedAssessments() {\n return this._attributes?.skippedAssessments || [];\n }\n\n /**\n *\n * @returns {*|{}}\n */\n getShopSettings() {\n return this._attributes?.shopSettings || {};\n }\n\n /**\n * Checks if currently edited page is a front page.\n * @returns {boolean} Returns true if the current page is a front page.\n */\n isFrontPage() {\n return this._attributes.isFrontPage;\n }\n\n /**\n * Checks whether an url is available\n * @deprecated Since version 1.19.1. Use hasSlug instead.\n * @returns {boolean} Returns true if the Paper has a slug.\n */\n hasUrl() {\n console.warn('This function is deprecated, use hasSlug instead');\n return this.hasSlug();\n }\n\n /**\n * Returns the url, or an empty string if no url is available.\n * @deprecated Since version 1.19.1. Use getSlug instead.\n * @returns {string} Returns the url\n */\n getUrl() {\n console.warn('This function is deprecated, use getSlug instead');\n return this.getSlug();\n }\n\n /**\n * Checks whether a locale is available.\n * @returns {boolean} Returns true if the paper has a locale.\n */\n hasLocale() {\n return this._attributes.locale !== '';\n }\n\n /**\n * Returns the locale or an empty string if no locale is available\n * @returns {string} Returns the locale.\n */\n getLocale() {\n return this._attributes.locale;\n }\n\n /**\n * Gets the information of the writing direction of the paper.\n * It returns \"LTR\" (left to right) if this attribute is not provided.\n *\n * @returns {string} Returns the information of the writing direction of the paper.\n */\n getWritingDirection() {\n return this._attributes.writingDirection;\n }\n\n /**\n * Checks whether a permalink is available.\n * @returns {boolean} Returns true if the Paper has a permalink.\n */\n hasPermalink() {\n return this._attributes.permalink !== '';\n }\n\n /**\n * Returns the permalink, or an empty string if no permalink is available.\n * @returns {string} Returns the permalink.\n */\n getPermalink() {\n return this._attributes.permalink;\n }\n\n /**\n * Checks whether a date is available.\n * @returns {boolean} Returns true if the Paper has a date.\n */\n hasDate() {\n return this._attributes.date !== '';\n }\n\n /**\n * Returns the date, or an empty string if no date is available.\n * @returns {string} Returns the date.\n */\n getDate() {\n return this._attributes.date;\n }\n\n /**\n *\n * @returns {*|*[]}\n */\n getFAQs() {\n return this.getData()?.faqs || {};\n }\n\n\n /**\n * Checks whether custom data is available.\n * @returns {boolean} Returns true if the Paper has custom data.\n */\n hasCustomData() {\n return !isEmpty(this._attributes.customData);\n }\n\n /**\n * Returns the custom data, or an empty object if no data is available.\n * @returns {Object} Returns the custom data.\n */\n getCustomData() {\n return this._attributes.customData;\n }\n\n /**\n * Checks whether a text title is available.\n * @returns {boolean} Returns true if the Paper has a text title.\n */\n hasTextTitle() {\n return this._attributes.textTitle !== '' && !isNil(this._attributes.textTitle);\n }\n\n /**\n * Returns the text title, or an empty string if no data is available.\n * @returns {string} Returns the text title.\n */\n getTextTitle() {\n return this._attributes.textTitle;\n }\n\n /**\n * Serializes the Paper instance to an object.\n *\n * @returns {Object} The serialized Paper.\n */\n serialize() {\n return {\n _parseClass: 'Paper',\n text: this._text,\n ...this._attributes\n };\n }\n\n /**\n * Checks whether the given paper has the same properties as this instance.\n *\n * @param {Paper} paper The paper to compare to.\n *\n * @returns {boolean} Whether the given paper is identical or not.\n */\n equals(paper) {\n return this._text === paper.getText() && isEqual(this._attributes, paper._attributes);\n }\n\n /**\n * Parses the object to a Paper.\n *\n * @param {Object|Paper} serialized The serialized object or Paper instance.\n *\n * @returns {Paper} The parsed Paper.\n */\n static parse(serialized) {\n // For ease of use, check if it is not already a Paper instance.\n if (serialized instanceof Paper) {\n return serialized;\n }\n\n // _parseClass is taken here, so it doesn't end up in the attributes.\n // eslint-disable-next-line no-unused-vars\n const {text, _parseClass, ...attributes} = serialized;\n\n return new Paper(text, attributes);\n }\n}\n"],"mappings":"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","ignoreList":[]}
|