axyseo 2.1.33 → 2.1.35
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/scoring/assessments/assessment.js +3 -2
- package/build/cjs/scoring/assessments/assessment.js.map +1 -1
- package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js +1 -2
- package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/FAQsAssessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js +5 -4
- package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/ImageCountAssessment.js +1 -3
- package/build/cjs/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js +1 -1
- package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeyphraseAssessment.js +5 -1
- package/build/cjs/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeywordFAQsAssessment.js +4 -1
- package/build/cjs/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/NumberInMetaTitleAssessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SchemaAssessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +1 -2
- package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js +2 -5
- package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js +1 -1
- package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js +1 -2
- package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js +1 -2
- package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessors/avadaAssessor.js +2 -2
- package/build/cjs/scoring/assessors/avadaAssessor.js.map +1 -1
- package/build/esm/scoring/assessments/assessment.js +3 -2
- package/build/esm/scoring/assessments/assessment.js.map +1 -1
- package/build/esm/scoring/assessments/readability/SentenceLengthInTextAssessment.js +1 -2
- package/build/esm/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/FAQsAssessment.js +1 -1
- package/build/esm/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js +5 -4
- package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/ImageCountAssessment.js +1 -3
- package/build/esm/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js +1 -1
- package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js +5 -1
- package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js +1 -1
- package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js +1 -1
- package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js +4 -1
- package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js +1 -1
- package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SchemaAssessment.js +1 -1
- package/build/esm/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SingleH1Assessment.js +1 -1
- package/build/esm/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +1 -2
- package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/TextImagesAssessment.js +2 -5
- package/build/esm/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/TextLengthAssessment.js +1 -1
- package/build/esm/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js +1 -2
- package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js +1 -2
- package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessors/avadaAssessor.js +2 -2
- package/build/esm/scoring/assessors/avadaAssessor.js.map +1 -1
- package/package.json +1 -1
|
@@ -65,8 +65,9 @@ class Assessment {
|
|
|
65
65
|
* @param status
|
|
66
66
|
* @returns {number}
|
|
67
67
|
*/
|
|
68
|
-
getScore(points, status) {
|
|
69
|
-
|
|
68
|
+
getScore(points, status = 'good') {
|
|
69
|
+
const newStatus = status === 'bad' ? 'bad' : 'bad';
|
|
70
|
+
return points * _analysis.statusRate[newStatus];
|
|
70
71
|
}
|
|
71
72
|
}
|
|
72
73
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assessment.js","names":["_languageProcessing","require","_helpers","_analysis","Assessment","getResult","paper","researcher","i18n","isApplicable","hasEnoughContentForAssessment","contentNeededForAssessment","text","getText","removeHtmlBlocks","filterShortcodesFromHTML","_attributes","shortcodes","sanitizeString","length","checkCanSkip","getScore","points","status","statusRate","_default","exports","default"],"sources":["../../../../src/scoring/assessments/assessment.js"],"sourcesContent":["/* eslint-disable no-unused-vars */\nimport {sanitizeString} from '../../languageProcessing';\nimport {filterShortcodesFromHTML, removeHtmlBlocks} from '../../languageProcessing/helpers';\nimport {statusRate} from '../../const/analysis';\n\n/**\n * The base class for an Assessment.\n */\nclass Assessment {\n /**\n * Executes the assessment and return its result.\n *\n * @param {Paper} paper The paper to run this assessment on.\n * @param {Researcher} researcher The researcher used for the assessment.\n * @param i18n\n * @returns {AssessmentResult} The result of the assessment.\n */\n getResult({paper, researcher, i18n}) {\n throw 'The method getResult is not implemented';\n }\n\n /**\n * Checks whether the assessment is applicable.\n *\n * @param {Paper} paper The paper to run this assessment on.\n * @param {Researcher} researcher The researcher used for the assessment.\n *\n * @returns {boolean} Whether the assessment is applicable, defaults to `true`.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n * Tests whether a `Paper` has enough content for assessments to be displayed.\n *\n * @param {Paper} paper The paper to run this assessment on.\n * @param {number} contentNeededForAssessment The minimum length in characters a text must have for assessments to be displayed.\n *\n * @returns {boolean} `true` if the text is of the required length, `false` otherwise.\n */\n hasEnoughContentForAssessment(paper, contentNeededForAssessment = 50) {\n let text = paper.getText();\n text = removeHtmlBlocks(text);\n text = filterShortcodesFromHTML(text, paper._attributes && paper._attributes.shortcodes);\n\n return sanitizeString(text).length >= contentNeededForAssessment;\n }\n\n checkCanSkip(paper) {\n return !this.hasEnoughContentForAssessment;\n }\n\n /**\n *\n * @param points\n * @param status\n * @returns {number}\n */\n getScore(points, status) {\n return points * statusRate[
|
|
1
|
+
{"version":3,"file":"assessment.js","names":["_languageProcessing","require","_helpers","_analysis","Assessment","getResult","paper","researcher","i18n","isApplicable","hasEnoughContentForAssessment","contentNeededForAssessment","text","getText","removeHtmlBlocks","filterShortcodesFromHTML","_attributes","shortcodes","sanitizeString","length","checkCanSkip","getScore","points","status","newStatus","statusRate","_default","exports","default"],"sources":["../../../../src/scoring/assessments/assessment.js"],"sourcesContent":["/* eslint-disable no-unused-vars */\nimport {sanitizeString} from '../../languageProcessing';\nimport {filterShortcodesFromHTML, removeHtmlBlocks} from '../../languageProcessing/helpers';\nimport {statusRate} from '../../const/analysis';\n\n/**\n * The base class for an Assessment.\n */\nclass Assessment {\n /**\n * Executes the assessment and return its result.\n *\n * @param {Paper} paper The paper to run this assessment on.\n * @param {Researcher} researcher The researcher used for the assessment.\n * @param i18n\n * @returns {AssessmentResult} The result of the assessment.\n */\n getResult({paper, researcher, i18n}) {\n throw 'The method getResult is not implemented';\n }\n\n /**\n * Checks whether the assessment is applicable.\n *\n * @param {Paper} paper The paper to run this assessment on.\n * @param {Researcher} researcher The researcher used for the assessment.\n *\n * @returns {boolean} Whether the assessment is applicable, defaults to `true`.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n * Tests whether a `Paper` has enough content for assessments to be displayed.\n *\n * @param {Paper} paper The paper to run this assessment on.\n * @param {number} contentNeededForAssessment The minimum length in characters a text must have for assessments to be displayed.\n *\n * @returns {boolean} `true` if the text is of the required length, `false` otherwise.\n */\n hasEnoughContentForAssessment(paper, contentNeededForAssessment = 50) {\n let text = paper.getText();\n text = removeHtmlBlocks(text);\n text = filterShortcodesFromHTML(text, paper._attributes && paper._attributes.shortcodes);\n\n return sanitizeString(text).length >= contentNeededForAssessment;\n }\n\n checkCanSkip(paper) {\n return !this.hasEnoughContentForAssessment;\n }\n\n /**\n *\n * @param points\n * @param status\n * @returns {number}\n */\n getScore(points, status = 'good') {\n const newStatus = status === 'bad' ? 'bad' : 'bad';\n return points * statusRate[newStatus]\n\n }\n}\n\n/* eslint-enable no-unused-vars */\n\nexport default Assessment;\n"],"mappings":";;;;;;AACA,IAAAA,mBAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAF,OAAA;AAHA;;AAKA;AACA;AACA;AACA,MAAMG,UAAU,CAAC;EACf;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,SAASA,CAAC;IAACC,KAAK;IAAEC,UAAU;IAAEC;EAAI,CAAC,EAAE;IACnC,MAAM,yCAAyC;EACjD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,YAAYA,CAACH,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEG,6BAA6BA,CAACJ,KAAK,EAAEK,0BAA0B,GAAG,EAAE,EAAE;IACpE,IAAIC,IAAI,GAAGN,KAAK,CAACO,OAAO,CAAC,CAAC;IAC1BD,IAAI,GAAG,IAAAE,yBAAgB,EAACF,IAAI,CAAC;IAC7BA,IAAI,GAAG,IAAAG,iCAAwB,EAACH,IAAI,EAAEN,KAAK,CAACU,WAAW,IAAIV,KAAK,CAACU,WAAW,CAACC,UAAU,CAAC;IAExF,OAAO,IAAAC,kCAAc,EAACN,IAAI,CAAC,CAACO,MAAM,IAAIR,0BAA0B;EAClE;EAEAS,YAAYA,CAACd,KAAK,EAAE;IAClB,OAAO,CAAC,IAAI,CAACI,6BAA6B;EAC5C;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEW,QAAQA,CAACC,MAAM,EAAEC,MAAM,GAAG,MAAM,EAAE;IAChC,MAAMC,SAAS,GAAGD,MAAM,KAAK,KAAK,GAAG,KAAK,GAAG,KAAK;IAClD,OAAOD,MAAM,GAAGG,oBAAU,CAACD,SAAS,CAAC;EAEvC;AACF;;AAEA;AAAA,IAAAE,QAAA,GAAAC,OAAA,CAAAC,OAAA,GAEexB,UAAU","ignoreList":[]}
|
|
@@ -123,9 +123,8 @@ class SentenceLengthInTextAssessment extends _assessment.default {
|
|
|
123
123
|
if (percentage && hasDescription && percentage <= this._config.recommendedLength) {
|
|
124
124
|
status = 'good';
|
|
125
125
|
}
|
|
126
|
-
const score = this.getScore(_analysis.MAIN_CONTENT_POINTS, status);
|
|
127
126
|
return {
|
|
128
|
-
score,
|
|
127
|
+
score: parseInt(this.getScore(_analysis.MAIN_CONTENT_POINTS, status)) || 0,
|
|
129
128
|
status
|
|
130
129
|
};
|
|
131
130
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SentenceLengthInTextAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_checkForTooLongSentences","_formatNumber","_AssessmentResult","_analysis","e","__esModule","default","SentenceLengthInTextAssessment","Assessment","constructor","config","defaultConfig","id","TEXT_SENTENCE_LENGTH_ID","priority","docUrl","ctaType","fixPosition","recommendedLength","slightlyTooMany","farTooMany","title","content","improve","bad","good","_config","merge","identifier","getResult","paper","researcher","sentences","getResearch","hasDescription","getConfig","getLanguageSpecificConfig","percentage","calculatePercentage","result","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","isApplicable","currentConfig","languageSpecificConfig","hasOwnProperty","length","tooLongTotal","countTooLongSentences","formatNumber","getScore","MAIN_CONTENT_POINTS","getTooLongSentences","_default","exports"],"sources":["../../../../../src/scoring/assessments/readability/SentenceLengthInTextAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport getTooLongSentences from '../../helpers/assessments/checkForTooLongSentences';\nimport formatNumber from '../../../helpers/formatNumber';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {MAIN_CONTENT_POINTS, TEXT_SENTENCE_LENGTH_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that will calculate the length of sentences in the text.\n */\nclass SentenceLengthInTextAssessment extends Assessment {\n /**\n\t * Sets the identifier and the config.\n\t *\n\t * @param {object} config\t\t\tThe scoring configuration that should be used.\n\n\t * @returns {void}\n\t */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: TEXT_SENTENCE_LENGTH_ID,\n priority: 'high',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#sentence-length',\n ctaType: 'fix',\n fixPosition: 'sentenceLength',\n recommendedLength: 20,\n slightlyTooMany: 25,\n farTooMany: 30,\n title: 'Text Sentence Length',\n content: {\n improve: '',\n bad:\n 'Sentence too long. Keep sentence length less than 20 words to improve readability and flow.',\n good: 'Sentence length is optimized for readability, less than 20 words.'\n }\n };\n\n this._config = merge(defaultConfig, config);\n this.identifier = TEXT_SENTENCE_LENGTH_ID;\n }\n\n /**\n * Scores the percentage of sentences including more than the recommended number of words.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling research.\n *\n * @returns {AssessmentResult} The Assessment result.\n */\n getResult({paper, researcher}) {\n const sentences = researcher.getResearch('countSentencesFromText');\n const hasDescription = paper.hasDescription();\n if (researcher.getConfig('sentenceLength')) {\n this._config = this.getLanguageSpecificConfig(researcher);\n }\n const percentage = this.calculatePercentage(sentences);\n\n const result = this.calculateResult(percentage, hasDescription);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(result.score);\n assessmentResult.setStatus(result.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n\n /**\n * Check if there is language-specific config, and if so, overwrite the current config with it.\n *\n * @param {Researcher} researcher The researcher to use.\n *\n * @returns {Object} The config that should be used.\n */\n getLanguageSpecificConfig(researcher) {\n const currentConfig = this._config;\n const languageSpecificConfig = researcher.getConfig('sentenceLength');\n\n if (languageSpecificConfig.hasOwnProperty('recommendedLength')) {\n currentConfig.recommendedLength = languageSpecificConfig.recommendedLength;\n }\n\n return currentConfig;\n }\n\n /**\n * Calculates the percentage of sentences that are too long.\n *\n * @param {Array} sentences The sentences to calculate the percentage for.\n * @returns {number} The calculates percentage of too long sentences.\n */\n calculatePercentage(sentences) {\n let percentage = 0;\n\n if (sentences.length !== 0) {\n const tooLongTotal = this.countTooLongSentences(sentences);\n percentage = formatNumber((tooLongTotal / sentences.length) * 100);\n }\n\n return percentage;\n }\n\n /**\n *\n * @param percentage\n * @param hasDescription\n * @returns {{score: number, status: string}}\n */\n calculateResult(percentage, hasDescription) {\n let status = 'bad';\n if (percentage && hasDescription && percentage <= this._config.recommendedLength) {\n status = 'good';\n }\n
|
|
1
|
+
{"version":3,"file":"SentenceLengthInTextAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_checkForTooLongSentences","_formatNumber","_AssessmentResult","_analysis","e","__esModule","default","SentenceLengthInTextAssessment","Assessment","constructor","config","defaultConfig","id","TEXT_SENTENCE_LENGTH_ID","priority","docUrl","ctaType","fixPosition","recommendedLength","slightlyTooMany","farTooMany","title","content","improve","bad","good","_config","merge","identifier","getResult","paper","researcher","sentences","getResearch","hasDescription","getConfig","getLanguageSpecificConfig","percentage","calculatePercentage","result","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","isApplicable","currentConfig","languageSpecificConfig","hasOwnProperty","length","tooLongTotal","countTooLongSentences","formatNumber","parseInt","getScore","MAIN_CONTENT_POINTS","getTooLongSentences","_default","exports"],"sources":["../../../../../src/scoring/assessments/readability/SentenceLengthInTextAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport getTooLongSentences from '../../helpers/assessments/checkForTooLongSentences';\nimport formatNumber from '../../../helpers/formatNumber';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {MAIN_CONTENT_POINTS, TEXT_SENTENCE_LENGTH_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that will calculate the length of sentences in the text.\n */\nclass SentenceLengthInTextAssessment extends Assessment {\n /**\n\t * Sets the identifier and the config.\n\t *\n\t * @param {object} config\t\t\tThe scoring configuration that should be used.\n\n\t * @returns {void}\n\t */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: TEXT_SENTENCE_LENGTH_ID,\n priority: 'high',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#sentence-length',\n ctaType: 'fix',\n fixPosition: 'sentenceLength',\n recommendedLength: 20,\n slightlyTooMany: 25,\n farTooMany: 30,\n title: 'Text Sentence Length',\n content: {\n improve: '',\n bad:\n 'Sentence too long. Keep sentence length less than 20 words to improve readability and flow.',\n good: 'Sentence length is optimized for readability, less than 20 words.'\n }\n };\n\n this._config = merge(defaultConfig, config);\n this.identifier = TEXT_SENTENCE_LENGTH_ID;\n }\n\n /**\n * Scores the percentage of sentences including more than the recommended number of words.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling research.\n *\n * @returns {AssessmentResult} The Assessment result.\n */\n getResult({paper, researcher}) {\n const sentences = researcher.getResearch('countSentencesFromText');\n const hasDescription = paper.hasDescription();\n if (researcher.getConfig('sentenceLength')) {\n this._config = this.getLanguageSpecificConfig(researcher);\n }\n const percentage = this.calculatePercentage(sentences);\n\n const result = this.calculateResult(percentage, hasDescription);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(result.score);\n assessmentResult.setStatus(result.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n\n /**\n * Check if there is language-specific config, and if so, overwrite the current config with it.\n *\n * @param {Researcher} researcher The researcher to use.\n *\n * @returns {Object} The config that should be used.\n */\n getLanguageSpecificConfig(researcher) {\n const currentConfig = this._config;\n const languageSpecificConfig = researcher.getConfig('sentenceLength');\n\n if (languageSpecificConfig.hasOwnProperty('recommendedLength')) {\n currentConfig.recommendedLength = languageSpecificConfig.recommendedLength;\n }\n\n return currentConfig;\n }\n\n /**\n * Calculates the percentage of sentences that are too long.\n *\n * @param {Array} sentences The sentences to calculate the percentage for.\n * @returns {number} The calculates percentage of too long sentences.\n */\n calculatePercentage(sentences) {\n let percentage = 0;\n\n if (sentences.length !== 0) {\n const tooLongTotal = this.countTooLongSentences(sentences);\n percentage = formatNumber((tooLongTotal / sentences.length) * 100);\n }\n\n return percentage;\n }\n\n /**\n *\n * @param percentage\n * @param hasDescription\n * @returns {{score: number, status: string}}\n */\n calculateResult(percentage, hasDescription) {\n let status = 'bad';\n if (percentage && hasDescription && percentage <= this._config.recommendedLength) {\n status = 'good';\n }\n return {\n score: parseInt(this.getScore(MAIN_CONTENT_POINTS, status)) || 0,\n status\n };\n }\n\n /**\n * Gets the sentences that are qualified as being too long.\n *\n * @param {array} sentences The sentences to filter through.\n * @returns {array} Array with all the sentences considered to be too long.\n */\n getTooLongSentences(sentences) {\n return getTooLongSentences(sentences, this._config.recommendedLength);\n }\n\n /**\n * Get the total amount of sentences that are qualified as being too long.\n *\n * @param {Array} sentences The sentences to filter through.\n * @returns {Number} The amount of sentences that are considered too long.\n */\n countTooLongSentences(sentences) {\n return this.getTooLongSentences(sentences).length;\n }\n}\n\nexport default SentenceLengthInTextAssessment;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -71,8 +71,8 @@ class FAQsAssessment extends _assessment.default {
|
|
|
71
71
|
* @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}
|
|
72
72
|
*/
|
|
73
73
|
calculateResult(paper) {
|
|
74
|
-
const faqs = paper.getFAQs()?.questions || [];
|
|
75
74
|
let status = 'bad';
|
|
75
|
+
const faqs = paper.getFAQs()?.questions || [];
|
|
76
76
|
let score = 0;
|
|
77
77
|
if (!faqs || faqs.length === 0) {
|
|
78
78
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FAQsAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","FAQsAssessment","Assessment","constructor","config","defaultConfig","id","FAQs_ASSESSMENT_ID","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","details","hasProperStructure","hasMinimumFAQs","identifier","_config","merge","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","setData","data","faqs","getFAQs","questions","length","hasFAQs","isEnableFaqs","checkMinimumFAQs","getScore","FAQS_POINTS","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/FAQsAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQs_ASSESSMENT_ID, FAQS_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks FAQs content and structure for SGE optimization.\n */\nexport default class FAQsAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: FAQs_ASSESSMENT_ID,\n ctaType: 'fix',\n docUrl: 'https://blog.google/products/search/generative-ai-search/',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'FAQs Optimization',\n content: {\n good: 'FAQs are well-structured and optimized for Google SGE.',\n improve: '',\n bad: 'FAQs need significant improvement to meet Google SGE standards.',\n details: {\n hasProperStructure: 'Empty questions or answers',\n hasMinimumFAQs: 'Less than 3 FAQs'\n }\n }\n };\n\n this.identifier = FAQs_ASSESSMENT_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n assessmentResult.setData(calculatedResult.data);\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}\n */\n calculateResult(paper) {\n const faqs = paper.getFAQs()?.questions || [];\n let
|
|
1
|
+
{"version":3,"file":"FAQsAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","FAQsAssessment","Assessment","constructor","config","defaultConfig","id","FAQs_ASSESSMENT_ID","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","details","hasProperStructure","hasMinimumFAQs","identifier","_config","merge","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","setData","data","faqs","getFAQs","questions","length","hasFAQs","isEnableFaqs","checkMinimumFAQs","getScore","FAQS_POINTS","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/FAQsAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQs_ASSESSMENT_ID, FAQS_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks FAQs content and structure for SGE optimization.\n */\nexport default class FAQsAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: FAQs_ASSESSMENT_ID,\n ctaType: 'fix',\n docUrl: 'https://blog.google/products/search/generative-ai-search/',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'FAQs Optimization',\n content: {\n good: 'FAQs are well-structured and optimized for Google SGE.',\n improve: '',\n bad: 'FAQs need significant improvement to meet Google SGE standards.',\n details: {\n hasProperStructure: 'Empty questions or answers',\n hasMinimumFAQs: 'Less than 3 FAQs'\n }\n }\n };\n\n this.identifier = FAQs_ASSESSMENT_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n assessmentResult.setData(calculatedResult.data);\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}\n */\n calculateResult(paper) {\n let status = 'bad';\n const faqs = paper.getFAQs()?.questions || [];\n let score = 0;\n\n if (!faqs || faqs.length === 0) {\n return {score: 0, status: 'bad', data: {hasFAQs: false}};\n }\n const isEnableFaqs = paper.getFAQs()?.status;\n const hasMinimumFAQs = this.checkMinimumFAQs(faqs);\n status = hasMinimumFAQs && isEnableFaqs ? 'good' : 'bad';\n score = this.getScore(FAQS_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n\n\n /**\n * Checks if there are at least 3 FAQs\n * @param {Array} faqs\n * @returns {boolean}\n */\n checkMinimumFAQs(faqs) {\n return faqs.length >= 3;\n }\n\n /**\n * Checks whether the paper has text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -66,12 +66,13 @@ class FAQsStructureDataAssessment extends _assessment.default {
|
|
|
66
66
|
* @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}
|
|
67
67
|
*/
|
|
68
68
|
calculateResult(paper) {
|
|
69
|
-
|
|
69
|
+
let status = 'bad';
|
|
70
70
|
const hasSchema = paper.hasFAQsSchema();
|
|
71
|
-
|
|
72
|
-
|
|
71
|
+
if (hasSchema) {
|
|
72
|
+
status = 'good';
|
|
73
|
+
}
|
|
73
74
|
return {
|
|
74
|
-
score,
|
|
75
|
+
score: this.getScore(_analysis.FAQS_POINTS, status) || 0,
|
|
75
76
|
status
|
|
76
77
|
};
|
|
77
78
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FAQsStructureDataAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","FAQsStructureDataAssessment","Assessment","constructor","config","defaultConfig","id","FAQs_STRUCTURE_DATA_ID","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","hasSchema","hasFAQsSchema","getScore","FAQS_POINTS","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/FAQsStructureDataAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, FAQs_STRUCTURE_DATA_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks FAQs content and structure for SGE optimization.\n */\nexport default class FAQsStructureDataAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: FAQs_STRUCTURE_DATA_ID,\n ctaType: 'contactUs',\n docUrl: 'https://blog.google/products/search/generative-ai-search/',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'FAQs structured data',\n content: {\n good: 'FAQ structured data added',\n improve: '',\n bad: 'Add FAQs structured data for Google rich results eligibility.',\n }\n };\n\n this.identifier = FAQs_STRUCTURE_DATA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}\n */\n calculateResult(paper) {\n
|
|
1
|
+
{"version":3,"file":"FAQsStructureDataAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","FAQsStructureDataAssessment","Assessment","constructor","config","defaultConfig","id","FAQs_STRUCTURE_DATA_ID","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","hasSchema","hasFAQsSchema","getScore","FAQS_POINTS","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/FAQsStructureDataAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, FAQs_STRUCTURE_DATA_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks FAQs content and structure for SGE optimization.\n */\nexport default class FAQsStructureDataAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: FAQs_STRUCTURE_DATA_ID,\n ctaType: 'contactUs',\n docUrl: 'https://blog.google/products/search/generative-ai-search/',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'FAQs structured data',\n content: {\n good: 'FAQ structured data added',\n improve: '',\n bad: 'Add FAQs structured data for Google rich results eligibility.',\n }\n };\n\n this.identifier = FAQs_STRUCTURE_DATA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}\n */\n calculateResult(paper) {\n let status = 'bad'\n const hasSchema = paper.hasFAQsSchema();\n if (hasSchema) {\n status = 'good';\n }\n return {\n score: this.getScore(FAQS_POINTS, status) || 0,\n status\n };\n }\n\n\n\n\n isApplicable(paper) {\n return true;\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAA2E,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAE3E;AACA;AACA;AACe,MAAMG,2BAA2B,SAASC,mBAAU,CAAC;EAClE;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,gCAAsB;MAC1BC,OAAO,EAAE,WAAW;MACpBC,MAAM,EAAE,2DAA2D;MACnEC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,MAAM;MACnBC,KAAK,EAAE,sBAAsB;MAC7BC,OAAO,EAAE;QACPC,IAAI,EAAE,2BAA2B;QACjCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGV,gCAAsB;IACxC,IAAI,CAACW,OAAO,GAAG,IAAAC,aAAK,EAACd,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEgB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACH,KAAK,CAAC;IACpD,MAAMI,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACtB,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IACrEO,gBAAgB,CAACE,QAAQ,CAACJ,gBAAgB,CAACK,KAAK,CAAC;IACjDH,gBAAgB,CAACI,SAAS,CAACN,gBAAgB,CAACO,MAAM,CAAC;IACnD,OAAOL,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB,IAAIS,MAAM,GAAG,KAAK;IAClB,MAAMC,SAAS,GAAGV,KAAK,CAACW,aAAa,CAAC,CAAC;IACvC,IAAID,SAAS,EAAE;MACbD,MAAM,GAAG,MAAM;IACjB;IACA,OAAO;MACLF,KAAK,EAAE,IAAI,CAACK,QAAQ,CAACC,qBAAW,EAAEJ,MAAM,CAAC,IAAI,CAAC;MAC9CA;IACF,CAAC;EACH;EAKAK,YAAYA,CAACd,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAACe,OAAA,CAAApC,OAAA,GAAAC,2BAAA","ignoreList":[]}
|
|
@@ -80,12 +80,10 @@ class TextImagesAssessment extends _assessment.default {
|
|
|
80
80
|
calculateResult() {
|
|
81
81
|
// If "countVideos" is on, we include videos in the assessment
|
|
82
82
|
const mediaCount = this._countVideos ? this.imageCount + this.videoCount : this.imageCount;
|
|
83
|
-
let status = '';
|
|
83
|
+
let status = 'good';
|
|
84
84
|
// No images.
|
|
85
85
|
if (mediaCount === 0) {
|
|
86
86
|
status = 'bad';
|
|
87
|
-
} else {
|
|
88
|
-
status = 'good';
|
|
89
87
|
}
|
|
90
88
|
const score = this.getScore(_analysis.FAQS_POINTS, status);
|
|
91
89
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ImageCountAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","TextImagesAssessment","Assessment","constructor","config","countVideos","defaultConfig","id","MEDIA_ID","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","_countVideos","getResult","paper","researcher","imageCount","getResearch","videoCount","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","mediaCount","getScore","FAQS_POINTS","exports"],"sources":["../../../../../src/scoring/assessments/seo/ImageCountAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, MEDIA_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks if the text has any images present, including videos in product pages.\n */\nexport default class TextImagesAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n * @param {boolean} countVideos Whether videos are also included in the assessment or not.\n *\n * @returns {void}\n */\n constructor(config = {}, countVideos = true) {\n super();\n\n const defaultConfig = {\n id: MEDIA_ID,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#images-and-videos',\n priority: 'high',\n fixPosition: 'description',\n title: 'Media',\n content: {\n good: 'Media are used effectively.',\n improve: '',\n bad: 'No media found. Add visual content to enhance engagement.'\n }\n };\n\n this.identifier = MEDIA_ID;\n this._config = merge(defaultConfig, config);\n this._countVideos = countVideos;\n }\n\n /**\n * Execute the Assessment and return a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n this.imageCount = researcher.getResearch('imageCount');\n this.videoCount = researcher.getResearch('videoCount');\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult();\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n // If \"countVideos\" is on, we include videos in the assessment\n const mediaCount = this._countVideos ? this.imageCount + this.videoCount : this.imageCount;\n\n let status = '';\n // No images.\n if (mediaCount === 0) {\n status = 'bad';\n }
|
|
1
|
+
{"version":3,"file":"ImageCountAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","TextImagesAssessment","Assessment","constructor","config","countVideos","defaultConfig","id","MEDIA_ID","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","_countVideos","getResult","paper","researcher","imageCount","getResearch","videoCount","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","mediaCount","getScore","FAQS_POINTS","exports"],"sources":["../../../../../src/scoring/assessments/seo/ImageCountAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, MEDIA_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks if the text has any images present, including videos in product pages.\n */\nexport default class TextImagesAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n * @param {boolean} countVideos Whether videos are also included in the assessment or not.\n *\n * @returns {void}\n */\n constructor(config = {}, countVideos = true) {\n super();\n\n const defaultConfig = {\n id: MEDIA_ID,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#images-and-videos',\n priority: 'high',\n fixPosition: 'description',\n title: 'Media',\n content: {\n good: 'Media are used effectively.',\n improve: '',\n bad: 'No media found. Add visual content to enhance engagement.'\n }\n };\n\n this.identifier = MEDIA_ID;\n this._config = merge(defaultConfig, config);\n this._countVideos = countVideos;\n }\n\n /**\n * Execute the Assessment and return a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n this.imageCount = researcher.getResearch('imageCount');\n this.videoCount = researcher.getResearch('videoCount');\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult();\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n // If \"countVideos\" is on, we include videos in the assessment\n const mediaCount = this._countVideos ? this.imageCount + this.videoCount : this.imageCount;\n\n let status = 'good';\n // No images.\n if (mediaCount === 0) {\n status = 'bad';\n }\n\n const score = this.getScore(FAQS_POINTS, status);\n\n return {\n score,\n status\n };\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAA6D,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAE7D;AACA;AACA;AACe,MAAMG,oBAAoB,SAASC,mBAAU,CAAC;EAC3D;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAEC,WAAW,GAAG,IAAI,EAAE;IAC3C,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,kBAAQ;MACZC,MAAM,EACJ,+FAA+F;MACjGC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,aAAa;MAC1BC,KAAK,EAAE,OAAO;MACdC,OAAO,EAAE;QACPC,IAAI,EAAE,6BAA6B;QACnCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGT,kBAAQ;IAC1B,IAAI,CAACU,OAAO,GAAG,IAAAC,aAAK,EAACb,aAAa,EAAEF,MAAM,CAAC;IAC3C,IAAI,CAACgB,YAAY,GAAGf,WAAW;EACjC;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEgB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,IAAI,CAACC,UAAU,GAAGD,UAAU,CAACE,WAAW,CAAC,YAAY,CAAC;IACtD,IAAI,CAACC,UAAU,GAAGH,UAAU,CAACE,WAAW,CAAC,YAAY,CAAC;IAEtD,MAAME,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACxB,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErE,MAAMW,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAAC,CAAC;IAE/CH,gBAAgB,CAACI,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDL,gBAAgB,CAACM,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IAEnD,OAAOP,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEQ,YAAYA,CAACb,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;EACEQ,eAAeA,CAAA,EAAG;IAChB;IACA,MAAMM,UAAU,GAAG,IAAI,CAAChB,YAAY,GAAG,IAAI,CAACI,UAAU,GAAG,IAAI,CAACE,UAAU,GAAG,IAAI,CAACF,UAAU;IAE1F,IAAIU,MAAM,GAAG,MAAM;IACnB;IACA,IAAIE,UAAU,KAAK,CAAC,EAAE;MACpBF,MAAM,GAAG,KAAK;IAChB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACK,QAAQ,CAACC,qBAAW,EAAEJ,MAAM,CAAC;IAEhD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAACK,OAAA,CAAAvC,OAAA,GAAAC,oBAAA","ignoreList":[]}
|
|
@@ -81,7 +81,7 @@ class InvalidCharactersInUrl extends _assessment.default {
|
|
|
81
81
|
* @returns {{score: number, status: (string)}}
|
|
82
82
|
*/
|
|
83
83
|
calculateResult() {
|
|
84
|
-
const status = this
|
|
84
|
+
const status = this?._charactersInUrl?.isInvalidCharacters ? 'bad' : 'good';
|
|
85
85
|
const score = this.getScore(_analysis.URLS_POINTS, status);
|
|
86
86
|
return {
|
|
87
87
|
score,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InvalidCharactersInUrl.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","_chineseHelperFactory","e","__esModule","default","InvalidCharactersInUrl","Assessment","constructor","config","defaultConfig","id","CHARACTERS_URL","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","enhancedResearcher","enhanceResearcherForChinese","getSlug","getKeyword","_charactersInUrl","getResearch","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","isInvalidCharacters","getScore","URLS_POINTS","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/InvalidCharactersInUrl.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {CHARACTERS_URL, URLS_POINTS} from '@axyseo/const/analysis';\nimport {enhanceResearcherForChinese} from '@axyseo/languageProcessing/helpers/language/chineseHelperFactory';\n\n/**\n * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.\n */\nclass InvalidCharactersInUrl extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: CHARACTERS_URL,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-url',\n fixPosition: 'url handle',\n ctaType: 'fix',\n priority: 'medium',\n title: 'Invalid characters in URL',\n content: {\n good: 'URL characters valid',\n improve: '',\n bad: 'Use only lowercase letters, numbers, and hyphens.'\n }\n };\n\n this.identifier = CHARACTERS_URL;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n // Enhance researcher for Chinese if needed - specifically for URL context\n const enhancedResearcher = enhanceResearcherForChinese(\n researcher,\n paper.getSlug(),\n paper.getKeyword(),\n true // isUrlContext = true for enhanced Chinese URL matching\n );\n\n this._charactersInUrl = enhancedResearcher.getResearch('charactersInUrl');\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult();\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n *\n * @returns {{score: number, status: (string)}}\n */\n calculateResult() {\n const status = this
|
|
1
|
+
{"version":3,"file":"InvalidCharactersInUrl.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","_chineseHelperFactory","e","__esModule","default","InvalidCharactersInUrl","Assessment","constructor","config","defaultConfig","id","CHARACTERS_URL","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","enhancedResearcher","enhanceResearcherForChinese","getSlug","getKeyword","_charactersInUrl","getResearch","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","isInvalidCharacters","getScore","URLS_POINTS","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/InvalidCharactersInUrl.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {CHARACTERS_URL, URLS_POINTS} from '@axyseo/const/analysis';\nimport {enhanceResearcherForChinese} from '@axyseo/languageProcessing/helpers/language/chineseHelperFactory';\n\n/**\n * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.\n */\nclass InvalidCharactersInUrl extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: CHARACTERS_URL,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-url',\n fixPosition: 'url handle',\n ctaType: 'fix',\n priority: 'medium',\n title: 'Invalid characters in URL',\n content: {\n good: 'URL characters valid',\n improve: '',\n bad: 'Use only lowercase letters, numbers, and hyphens.'\n }\n };\n\n this.identifier = CHARACTERS_URL;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n // Enhance researcher for Chinese if needed - specifically for URL context\n const enhancedResearcher = enhanceResearcherForChinese(\n researcher,\n paper.getSlug(),\n paper.getKeyword(),\n true // isUrlContext = true for enhanced Chinese URL matching\n );\n\n this._charactersInUrl = enhancedResearcher.getResearch('charactersInUrl');\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult();\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n *\n * @returns {{score: number, status: (string)}}\n */\n calculateResult() {\n const status = this?._charactersInUrl?.isInvalidCharacters ? 'bad' : 'good'\n const score = this.getScore(URLS_POINTS , status);\n\n return {\n score,\n status\n };\n }\n}\n\nexport default InvalidCharactersInUrl;\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAEA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AACA,IAAAK,qBAAA,GAAAL,OAAA;AAA6G,SAAAE,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAE7G;AACA;AACA;AACA,MAAMG,sBAAsB,SAASC,mBAAU,CAAC;EAC9C;AACF;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,wBAAc;MAClBC,MAAM,EACJ,4FAA4F;MAC9FC,WAAW,EAAE,YAAY;MACzBC,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE,QAAQ;MAClBC,KAAK,EAAE,2BAA2B;MAClCC,OAAO,EAAE;QACPC,IAAI,EAAE,sBAAsB;QAC5BC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGV,wBAAc;IAChC,IAAI,CAACW,OAAO,GAAG,IAAAC,aAAK,EAACd,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEgB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B;IACA,MAAMC,kBAAkB,GAAG,IAAAC,iDAA2B,EACpDF,UAAU,EACVD,KAAK,CAACI,OAAO,CAAC,CAAC,EACfJ,KAAK,CAACK,UAAU,CAAC,CAAC,EAClB,IAAI,CAAC;IACP,CAAC;IAED,IAAI,CAACC,gBAAgB,GAAGJ,kBAAkB,CAACK,WAAW,CAAC,iBAAiB,CAAC;IACzE,MAAMC,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAAC1B,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErE,MAAMa,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAAC,CAAC;IAE/CH,gBAAgB,CAACI,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDL,gBAAgB,CAACM,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnD,OAAOP,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEQ,YAAYA,CAAChB,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;EACEU,eAAeA,CAAA,EAAG;IAChB,MAAMI,MAAM,GAAG,IAAI,EAAET,gBAAgB,EAAEW,mBAAmB,GAAG,KAAK,GAAG,MAAM;IAC3E,MAAMJ,KAAK,GAAG,IAAI,CAACK,QAAQ,CAACC,qBAAW,EAAGJ,MAAM,CAAC;IAEjD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAAC,IAAAK,QAAA,GAAAC,OAAA,CAAA1C,OAAA,GAEcC,sBAAsB","ignoreList":[]}
|
|
@@ -78,8 +78,12 @@ class KeyphraseAssessment extends _assessment.default {
|
|
|
78
78
|
*/
|
|
79
79
|
calculateResult(paper) {
|
|
80
80
|
const status = (() => {
|
|
81
|
+
let status = 'bad';
|
|
81
82
|
const hasKeyphrase = paper.hasKeyword();
|
|
82
|
-
|
|
83
|
+
if (hasKeyphrase) {
|
|
84
|
+
status = 'good';
|
|
85
|
+
}
|
|
86
|
+
return status;
|
|
83
87
|
})();
|
|
84
88
|
const score = this.getScore(_analysis.KEYWORD_POINTS, status);
|
|
85
89
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeyphraseAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","KeyphraseAssessment","Assessment","constructor","config","defaultConfig","id","KEYPHRASE_ID","docUrl","ctaType","fixPosition","priority","title","content","improve","bad","good","identifier","_config","merge","getResult","paper","researcher","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","hasKeyphrase","hasKeyword","getScore","KEYWORD_POINTS","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeyphraseAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {KEYPHRASE_ID, KEYWORD_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.\n */\nclass KeyphraseAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: KEYPHRASE_ID,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#use-of-main-keyword',\n ctaType: 'fix',\n fixPosition: 'keyword search',\n priority: 'high',\n title: 'Missing main keyword',\n content: {\n improve: '',\n bad: 'Main keyword field is empty. Add a 2-5 word primary keyword.',\n good: 'Main keyword set'\n }\n };\n\n this.identifier = KEYPHRASE_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: (string)}}\n */\n calculateResult(paper) {\n const status = (() => {\n const hasKeyphrase = paper.hasKeyword();\n
|
|
1
|
+
{"version":3,"file":"KeyphraseAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","KeyphraseAssessment","Assessment","constructor","config","defaultConfig","id","KEYPHRASE_ID","docUrl","ctaType","fixPosition","priority","title","content","improve","bad","good","identifier","_config","merge","getResult","paper","researcher","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","hasKeyphrase","hasKeyword","getScore","KEYWORD_POINTS","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeyphraseAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {KEYPHRASE_ID, KEYWORD_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.\n */\nclass KeyphraseAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: KEYPHRASE_ID,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#use-of-main-keyword',\n ctaType: 'fix',\n fixPosition: 'keyword search',\n priority: 'high',\n title: 'Missing main keyword',\n content: {\n improve: '',\n bad: 'Main keyword field is empty. Add a 2-5 word primary keyword.',\n good: 'Main keyword set'\n }\n };\n\n this.identifier = KEYPHRASE_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: (string)}}\n */\n calculateResult(paper) {\n const status = (() => {\n let status = 'bad';\n const hasKeyphrase = paper.hasKeyword();\n if (hasKeyphrase) {\n status = 'good';\n }\n return status;\n })();\n\n const score = this.getScore(KEYWORD_POINTS, status);\n\n return {\n score,\n status\n };\n }\n}\n\nexport default KeyphraseAssessment;\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAEA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAAoE,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEpE;AACA;AACA;AACA,MAAMG,mBAAmB,SAASC,mBAAU,CAAC;EAC3C;AACF;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,sBAAY;MAChBC,MAAM,EACJ,iGAAiG;MACnGC,OAAO,EAAE,KAAK;MACdC,WAAW,EAAE,gBAAgB;MAC7BC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,sBAAsB;MAC7BC,OAAO,EAAE;QACPC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE,8DAA8D;QACnEC,IAAI,EAAE;MACR;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGV,sBAAY;IAC9B,IAAI,CAACW,OAAO,GAAG,IAAAC,aAAK,EAACd,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEgB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACpB,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACL,KAAK,CAAC;IAEpDE,gBAAgB,CAACI,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDL,gBAAgB,CAACM,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnD,OAAOP,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEQ,YAAYA,CAACV,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;EACEI,eAAeA,CAACL,KAAK,EAAE;IACrB,MAAMS,MAAM,GAAG,CAAC,MAAM;MACpB,IAAIA,MAAM,GAAG,KAAK;MAClB,MAAME,YAAY,GAAGX,KAAK,CAACY,UAAU,CAAC,CAAC;MACvC,IAAID,YAAY,EAAE;QAChBF,MAAM,GAAG,MAAM;MACjB;MACA,OAAOA,MAAM;IACf,CAAC,EAAE,CAAC;IAEJ,MAAMF,KAAK,GAAG,IAAI,CAACM,QAAQ,CAACC,wBAAc,EAAEL,MAAM,CAAC;IAEnD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAAC,IAAAM,QAAA,GAAAC,OAAA,CAAArC,OAAA,GAEcC,mBAAmB","ignoreList":[]}
|
|
@@ -67,8 +67,8 @@ class KeyphraseLengthAssessment extends _assessment.default {
|
|
|
67
67
|
* @returns {Object} Object with score and text.
|
|
68
68
|
*/
|
|
69
69
|
calculateResult(paper) {
|
|
70
|
-
const keywordLength = (0, _helpers.countWords)(paper.getKeyword());
|
|
71
70
|
let status = 'bad';
|
|
71
|
+
const keywordLength = (0, _helpers.countWords)(paper.getKeyword());
|
|
72
72
|
if (keywordLength <= 4) {
|
|
73
73
|
status = 'good';
|
|
74
74
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeyphraseLengthAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_helpers","_analysis","e","__esModule","default","KeyphraseLengthAssessment","Assessment","constructor","config","defaultConfig","id","KEYPHRASE_LENGTH_ID","ctaType","priority","docUrl","fixPosition","title","content","improve","bad","good","identifier","_config","merge","getResult","paper","researcher","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","keywordLength","countWords","getKeyword","getScore","MAIN_CONTENT_POINTS","isApplicable","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeyphraseLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {countWords} from '@axyseo/helpers';\nimport {KEYPHRASE_LENGTH_ID, MAIN_CONTENT_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the keyphrase has a good length.\n */\nclass KeyphraseLengthAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config) {\n super();\n\n this.defaultConfig = {\n id: KEYPHRASE_LENGTH_ID,\n ctaType: 'fix',\n priority: 'low',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-length',\n fixPosition: 'keyword search',\n title: 'Keyword length',\n content: {\n improve: '',\n bad: 'Keyword too long. Keep keyword length less than 4 words for readability.',\n good: 'Keyword length is optimized, less than 4 words.'\n }\n };\n\n this.identifier = KEYPHRASE_LENGTH_ID;\n this._config = merge(this.defaultConfig, config);\n }\n\n /**\n * Assesses the keyphrase presence and length.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling research.\n *\n * @returns {AssessmentResult} The result of this assessment.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Calculates the result based on the keyphraseLength research.\n *\n * @returns {Object} Object with score and text.\n */\n calculateResult(paper) {\n const keywordLength = countWords(paper.getKeyword());\n\n
|
|
1
|
+
{"version":3,"file":"KeyphraseLengthAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_helpers","_analysis","e","__esModule","default","KeyphraseLengthAssessment","Assessment","constructor","config","defaultConfig","id","KEYPHRASE_LENGTH_ID","ctaType","priority","docUrl","fixPosition","title","content","improve","bad","good","identifier","_config","merge","getResult","paper","researcher","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","keywordLength","countWords","getKeyword","getScore","MAIN_CONTENT_POINTS","isApplicable","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeyphraseLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {countWords} from '@axyseo/helpers';\nimport {KEYPHRASE_LENGTH_ID, MAIN_CONTENT_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the keyphrase has a good length.\n */\nclass KeyphraseLengthAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config) {\n super();\n\n this.defaultConfig = {\n id: KEYPHRASE_LENGTH_ID,\n ctaType: 'fix',\n priority: 'low',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-length',\n fixPosition: 'keyword search',\n title: 'Keyword length',\n content: {\n improve: '',\n bad: 'Keyword too long. Keep keyword length less than 4 words for readability.',\n good: 'Keyword length is optimized, less than 4 words.'\n }\n };\n\n this.identifier = KEYPHRASE_LENGTH_ID;\n this._config = merge(this.defaultConfig, config);\n }\n\n /**\n * Assesses the keyphrase presence and length.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling research.\n *\n * @returns {AssessmentResult} The result of this assessment.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Calculates the result based on the keyphraseLength research.\n *\n * @returns {Object} Object with score and text.\n */\n calculateResult(paper) {\n let status = 'bad';\n const keywordLength = countWords(paper.getKeyword());\n\n if (keywordLength <= 4) {\n status = 'good';\n }\n\n const score = this.getScore(MAIN_CONTENT_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n\nexport default KeyphraseLengthAssessment;\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AACA,IAAAK,SAAA,GAAAL,OAAA;AAAgF,SAAAE,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEhF;AACA;AACA;AACA,MAAMG,yBAAyB,SAASC,mBAAU,CAAC;EACjD;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,EAAE;IAClB,KAAK,CAAC,CAAC;IAEP,IAAI,CAACC,aAAa,GAAG;MACnBC,EAAE,EAAEC,6BAAmB;MACvBC,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE,KAAK;MACfC,MAAM,EACJ,4FAA4F;MAC9FC,WAAW,EAAE,gBAAgB;MAC7BC,KAAK,EAAE,gBAAgB;MACvBC,OAAO,EAAE;QACPC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE,0EAA0E;QAC/EC,IAAI,EAAE;MACR;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGV,6BAAmB;IACrC,IAAI,CAACW,OAAO,GAAG,IAAAC,aAAK,EAAC,IAAI,CAACd,aAAa,EAAED,MAAM,CAAC;EAClD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEgB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACpB,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACL,KAAK,CAAC;IAEpDE,gBAAgB,CAACI,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDL,gBAAgB,CAACM,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IAEnD,OAAOP,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEG,eAAeA,CAACL,KAAK,EAAE;IACrB,IAAIS,MAAM,GAAG,KAAK;IAClB,MAAMC,aAAa,GAAG,IAAAC,mBAAU,EAACX,KAAK,CAACY,UAAU,CAAC,CAAC,CAAC;IAEpD,IAAIF,aAAa,IAAI,CAAC,EAAE;MACtBD,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACM,QAAQ,CAACC,6BAAmB,EAAEL,MAAM,CAAC;IAExD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,YAAYA,CAACf,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAAC,IAAAgB,QAAA,GAAAC,OAAA,CAAAtC,OAAA,GAEcC,yBAAyB","ignoreList":[]}
|
|
@@ -69,9 +69,9 @@ class KeyphraseDensityAssessment extends _assessment.default {
|
|
|
69
69
|
* @returns {{title: string, score: number, status: string}}
|
|
70
70
|
*/
|
|
71
71
|
calculateResult() {
|
|
72
|
+
let status = 'bad';
|
|
72
73
|
const density = this._keyphraseDensity;
|
|
73
74
|
const roundedDensity = parseFloat(density.toFixed(2));
|
|
74
|
-
let status = 'bad';
|
|
75
75
|
if (roundedDensity >= 1 && roundedDensity <= 1.5) {
|
|
76
76
|
status = 'good';
|
|
77
77
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeywordDensityAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_keyphraseLengthFactor","_analysis","e","__esModule","default","KeyphraseDensityAssessment","Assessment","constructor","config","defaultConfig","id","KEYPHRASE_DENSITY_ID","fixPosition","docUrl","ctaType","priority","title","content","good","bad","improve","identifier","_config","merge","getResult","paper","researcher","_keyphraseCount","getResearch","keyphraseLength","_keyphraseDensity","keyphraseLengthFactor","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","setTitle","density","roundedDensity","parseFloat","toFixed","getScore","MAIN_CONTENT_POINTS","isApplicable","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeywordDensityAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\n\nimport keyphraseLengthFactor from '../../../scoring/helpers/assessments/keyphraseLengthFactor';\nimport {KEYPHRASE_DENSITY_ID, MAIN_CONTENT_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that will look if the keyphrase density is within the recommended range.\n */\nclass KeyphraseDensityAssessment extends Assessment {\n /**\n *\n * @param config\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: KEYPHRASE_DENSITY_ID,\n fixPosition: 'highlightKeyword',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#main-keyword-density',\n ctaType: 'fix',\n priority: 'high',\n title: 'Main keyword density',\n content: {\n good: 'Keyword density is optimized, between 1 - 1.5%.',\n bad: 'Keep keyword density from 1% - 1.5%.',\n improve: ''\n }\n };\n\n this.identifier = KEYPHRASE_DENSITY_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the keyphrase density module, based on this returns an assessment\n * result with score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n *\n * @returns {AssessmentResult} The result of the assessment.\n */\n getResult({paper, researcher}) {\n\n this._keyphraseCount = researcher.getResearch('getKeyphraseCount');\n const keyphraseLength = this._keyphraseCount.keyphraseLength;\n\n this._keyphraseDensity = researcher.getResearch('getKeyphraseDensity');\n this._keyphraseDensity = this._keyphraseDensity * keyphraseLengthFactor(keyphraseLength);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n assessmentResult.setTitle(calculatedResult.title);\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{title: string, score: number, status: string}}\n */\n calculateResult() {\n const density = this._keyphraseDensity;\n const roundedDensity = parseFloat(density.toFixed(2));\n
|
|
1
|
+
{"version":3,"file":"KeywordDensityAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_keyphraseLengthFactor","_analysis","e","__esModule","default","KeyphraseDensityAssessment","Assessment","constructor","config","defaultConfig","id","KEYPHRASE_DENSITY_ID","fixPosition","docUrl","ctaType","priority","title","content","good","bad","improve","identifier","_config","merge","getResult","paper","researcher","_keyphraseCount","getResearch","keyphraseLength","_keyphraseDensity","keyphraseLengthFactor","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","setTitle","density","roundedDensity","parseFloat","toFixed","getScore","MAIN_CONTENT_POINTS","isApplicable","_default","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeywordDensityAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\n\nimport keyphraseLengthFactor from '../../../scoring/helpers/assessments/keyphraseLengthFactor';\nimport {KEYPHRASE_DENSITY_ID, MAIN_CONTENT_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that will look if the keyphrase density is within the recommended range.\n */\nclass KeyphraseDensityAssessment extends Assessment {\n /**\n *\n * @param config\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: KEYPHRASE_DENSITY_ID,\n fixPosition: 'highlightKeyword',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#main-keyword-density',\n ctaType: 'fix',\n priority: 'high',\n title: 'Main keyword density',\n content: {\n good: 'Keyword density is optimized, between 1 - 1.5%.',\n bad: 'Keep keyword density from 1% - 1.5%.',\n improve: ''\n }\n };\n\n this.identifier = KEYPHRASE_DENSITY_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the keyphrase density module, based on this returns an assessment\n * result with score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n *\n * @returns {AssessmentResult} The result of the assessment.\n */\n getResult({paper, researcher}) {\n\n this._keyphraseCount = researcher.getResearch('getKeyphraseCount');\n const keyphraseLength = this._keyphraseCount.keyphraseLength;\n\n this._keyphraseDensity = researcher.getResearch('getKeyphraseDensity');\n this._keyphraseDensity = this._keyphraseDensity * keyphraseLengthFactor(keyphraseLength);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n assessmentResult.setTitle(calculatedResult.title);\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{title: string, score: number, status: string}}\n */\n calculateResult() {\n let status = 'bad';\n const density = this._keyphraseDensity;\n const roundedDensity = parseFloat(density.toFixed(2));\n if (roundedDensity >= 1 && roundedDensity <= 1.5) {\n status = 'good';\n }\n\n const score = this.getScore(MAIN_CONTENT_POINTS, status);\n this._config = merge(this._config, {\n roundedDensity\n });\n return {\n roundedDensity,\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text of the minimum required length and a keyphrase is set. Language-specific length requirements and methods\n * of counting text length may apply (e.g. for Japanese, the text should be counted in characters instead of words, which also makes the minimum\n * required length higher).\n *\n * @param {Paper} \t\tpaper \t\tThe paper to use for the assessment.\n * @param {Researcher} researcher The paper to use for the assessment.\n *\n * @returns {boolean} True if applicable.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n}\n\nexport default KeyphraseDensityAssessment;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -67,10 +67,13 @@ class KeywordFAQsAssessment extends _assessment.default {
|
|
|
67
67
|
* @returns {Object} The calculated result.
|
|
68
68
|
*/
|
|
69
69
|
calculateResult(paper) {
|
|
70
|
+
let status = 'bad';
|
|
70
71
|
const faqs = paper.getFAQs()?.questions || [];
|
|
71
72
|
const keyword = paper.getKeyword();
|
|
72
73
|
const hasKeywords = this.checkKeywordsInFAQs(faqs, [keyword]);
|
|
73
|
-
|
|
74
|
+
if (hasKeywords) {
|
|
75
|
+
status = 'good';
|
|
76
|
+
}
|
|
74
77
|
const score = this.getScore(_analysis.FAQS_POINTS, status);
|
|
75
78
|
return {
|
|
76
79
|
status,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeywordFAQsAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","KeywordFAQsAssessment","Assessment","constructor","config","defaultConfig","id","KEYWORD_FAQs_ASSESSMENT_ID","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","faqs","getFAQs","questions","keyword","getKeyword","hasKeywords","checkKeywordsInFAQs","getScore","FAQS_POINTS","keywords","some","faq","question","toLowerCase","answer","keywordLower","includes","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeywordFAQsAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, KEYWORD_FAQs_ASSESSMENT_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks if keywords exist in FAQs.\n */\nexport default class KeywordFAQsAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: KEYWORD_FAQs_ASSESSMENT_ID,\n ctaType: 'fix',\n docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/faqs-builder',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'Keyword in FAQs',\n content: {\n good: 'Keywords are found in FAQs.',\n improve: '',\n bad: 'No keywords found in FAQs.'\n }\n };\n\n this.identifier = KEYWORD_FAQs_ASSESSMENT_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Calculates the result of the assessment based on keyword presence in FAQs.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @returns {Object} The calculated result.\n */\n calculateResult(paper) {\n const faqs = paper.getFAQs()?.questions || [];\n const keyword = paper.getKeyword();\n const hasKeywords = this.checkKeywordsInFAQs(faqs, [keyword]);\n
|
|
1
|
+
{"version":3,"file":"KeywordFAQsAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","KeywordFAQsAssessment","Assessment","constructor","config","defaultConfig","id","KEYWORD_FAQs_ASSESSMENT_ID","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","AssessmentResult","setScore","score","setStatus","status","faqs","getFAQs","questions","keyword","getKeyword","hasKeywords","checkKeywordsInFAQs","getScore","FAQS_POINTS","keywords","some","faq","question","toLowerCase","answer","keywordLower","includes","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/KeywordFAQsAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, KEYWORD_FAQs_ASSESSMENT_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks if keywords exist in FAQs.\n */\nexport default class KeywordFAQsAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: KEYWORD_FAQs_ASSESSMENT_ID,\n ctaType: 'fix',\n docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/faqs-builder',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'Keyword in FAQs',\n content: {\n good: 'Keywords are found in FAQs.',\n improve: '',\n bad: 'No keywords found in FAQs.'\n }\n };\n\n this.identifier = KEYWORD_FAQs_ASSESSMENT_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Calculates the result of the assessment based on keyword presence in FAQs.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @returns {Object} The calculated result.\n */\n calculateResult(paper) {\n let status = 'bad'\n const faqs = paper.getFAQs()?.questions || [];\n const keyword = paper.getKeyword();\n const hasKeywords = this.checkKeywordsInFAQs(faqs, [keyword]);\n if(hasKeywords) {\n status = 'good'\n }\n const score = this.getScore(FAQS_POINTS, status);\n\n return {\n status,\n score\n };\n }\n\n /**\n * Checks if keywords exist in FAQs\n * @param {Array} faqs\n * @param {Array} keywords\n * @returns {boolean}\n */\n checkKeywordsInFAQs(faqs, keywords) {\n return faqs.some(faq => {\n const question = faq.question.toLowerCase();\n const answer = faq.answer.toLowerCase();\n return keywords.some(keyword => {\n const keywordLower = keyword.toLowerCase();\n return question.includes(keywordLower) || answer.includes(keywordLower);\n });\n });\n }\n\n /**\n * Checks whether the paper has text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAA+E,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAE/E;AACA;AACA;AACe,MAAMG,qBAAqB,SAASC,mBAAU,CAAC;EAC5D;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,oCAA0B;MAC9BC,OAAO,EAAE,KAAK;MACdC,MAAM,EAAE,gFAAgF;MACxFC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,MAAM;MACnBC,KAAK,EAAE,iBAAiB;MACxBC,OAAO,EAAE;QACPC,IAAI,EAAE,6BAA6B;QACnCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGV,oCAA0B;IAC5C,IAAI,CAACW,OAAO,GAAG,IAAAC,aAAK,EAACd,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEgB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACH,KAAK,CAAC;IAEpD,MAAMI,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACtB,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IACrEO,gBAAgB,CAACE,QAAQ,CAACJ,gBAAgB,CAACK,KAAK,CAAC;IACjDH,gBAAgB,CAACI,SAAS,CAACN,gBAAgB,CAACO,MAAM,CAAC;IAEnD,OAAOL,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB,IAAIS,MAAM,GAAG,KAAK;IAClB,MAAMC,IAAI,GAAGV,KAAK,CAACW,OAAO,CAAC,CAAC,EAAEC,SAAS,IAAI,EAAE;IAC7C,MAAMC,OAAO,GAAGb,KAAK,CAACc,UAAU,CAAC,CAAC;IAClC,MAAMC,WAAW,GAAG,IAAI,CAACC,mBAAmB,CAACN,IAAI,EAAE,CAACG,OAAO,CAAC,CAAC;IAC7D,IAAGE,WAAW,EAAE;MACdN,MAAM,GAAG,MAAM;IACjB;IACA,MAAMF,KAAK,GAAG,IAAI,CAACU,QAAQ,CAACC,qBAAW,EAAET,MAAM,CAAC;IAEhD,OAAO;MACLA,MAAM;MACNF;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;EACES,mBAAmBA,CAACN,IAAI,EAAES,QAAQ,EAAE;IAClC,OAAOT,IAAI,CAACU,IAAI,CAACC,GAAG,IAAI;MACtB,MAAMC,QAAQ,GAAGD,GAAG,CAACC,QAAQ,CAACC,WAAW,CAAC,CAAC;MAC3C,MAAMC,MAAM,GAAGH,GAAG,CAACG,MAAM,CAACD,WAAW,CAAC,CAAC;MACvC,OAAOJ,QAAQ,CAACC,IAAI,CAACP,OAAO,IAAI;QAC9B,MAAMY,YAAY,GAAGZ,OAAO,CAACU,WAAW,CAAC,CAAC;QAC1C,OAAOD,QAAQ,CAACI,QAAQ,CAACD,YAAY,CAAC,IAAID,MAAM,CAACE,QAAQ,CAACD,YAAY,CAAC;MACzE,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEE,YAAYA,CAAC3B,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAAC4B,OAAA,CAAAjD,OAAA,GAAAC,qBAAA","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberInMetaTitleAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","NumberInMetaTitleAssessment","Assessment","constructor","config","defaultConfig","id","NUMBER_TITLE_ID","ctaType","status","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","getTitle","test","getScore","META_TAG_POINTS","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/NumberInMetaTitleAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {META_TAG_POINTS, NUMBER_TITLE_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that assesses the SEO title width and gives the feedback accordingly.\n */\nexport default class NumberInMetaTitleAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: NUMBER_TITLE_ID,\n ctaType: 'fix',\n status: 'good',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#using-number-in-title',\n priority: 'high',\n fixPosition: 'meta title',\n title: 'Number in meta title',\n content: {\n good: 'Number is used effectively in the title tag.',\n improve: '',\n bad: 'No number found in title tag. Consider adding a number to make it more engaging.'\n }\n };\n\n this.identifier = NUMBER_TITLE_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, body: React.JSX.Element, status: string}}\n */\n calculateResult(paper) {\n const title = paper.getTitle();\n\n let status = '';\n if (!/\\d/.test(title)) {\n status = 'bad';\n }\n\n if (!title || /\\d/.test(title)) {\n status = 'good';\n }\n\n const score = this.getScore(META_TAG_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAAwE,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAExE;AACA;AACA;AACe,MAAMG,2BAA2B,SAASC,mBAAU,CAAC;EAClE;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,yBAAe;MACnBC,OAAO,EAAE,KAAK;MACdC,MAAM,EAAE,MAAM;MACdC,MAAM,EACJ,mGAAmG;MACrGC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,YAAY;MACzBC,KAAK,EAAE,sBAAsB;MAC7BC,OAAO,EAAE;QACPC,IAAI,EAAE,8CAA8C;QACpDC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGX,yBAAe;IACjC,IAAI,CAACY,OAAO,GAAG,IAAAC,aAAK,EAACf,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEiB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACrB,MAAM,EAAE,IAAI,CAACe;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACL,KAAK,CAAC;IAEpDE,gBAAgB,CAACI,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDL,gBAAgB,CAACM,SAAS,CAACJ,gBAAgB,CAACjB,MAAM,CAAC;IAEnD,OAAOe,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEG,eAAeA,CAACL,KAAK,EAAE;IACrB,MAAMT,KAAK,GAAGS,KAAK,CAACS,QAAQ,CAAC,CAAC;IAE9B,IAAItB,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"NumberInMetaTitleAssessment.js","names":["_lodash","require","_assessment","_interopRequireDefault","_AssessmentResult","_analysis","e","__esModule","default","NumberInMetaTitleAssessment","Assessment","constructor","config","defaultConfig","id","NUMBER_TITLE_ID","ctaType","status","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","merge","getResult","paper","researcher","assessmentResult","AssessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","getTitle","test","getScore","META_TAG_POINTS","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/NumberInMetaTitleAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {META_TAG_POINTS, NUMBER_TITLE_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that assesses the SEO title width and gives the feedback accordingly.\n */\nexport default class NumberInMetaTitleAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: NUMBER_TITLE_ID,\n ctaType: 'fix',\n status: 'good',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#using-number-in-title',\n priority: 'high',\n fixPosition: 'meta title',\n title: 'Number in meta title',\n content: {\n good: 'Number is used effectively in the title tag.',\n improve: '',\n bad: 'No number found in title tag. Consider adding a number to make it more engaging.'\n }\n };\n\n this.identifier = NUMBER_TITLE_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, body: React.JSX.Element, status: string}}\n */\n calculateResult(paper) {\n const title = paper.getTitle();\n\n let status = 'bad';\n if (!/\\d/.test(title)) {\n status = 'bad';\n }\n\n if (!title || /\\d/.test(title)) {\n status = 'good';\n }\n\n const score = this.getScore(META_TAG_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAAwE,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAExE;AACA;AACA;AACe,MAAMG,2BAA2B,SAASC,mBAAU,CAAC;EAClE;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,yBAAe;MACnBC,OAAO,EAAE,KAAK;MACdC,MAAM,EAAE,MAAM;MACdC,MAAM,EACJ,mGAAmG;MACrGC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,YAAY;MACzBC,KAAK,EAAE,sBAAsB;MAC7BC,OAAO,EAAE;QACPC,IAAI,EAAE,8CAA8C;QACpDC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGX,yBAAe;IACjC,IAAI,CAACY,OAAO,GAAG,IAAAC,aAAK,EAACf,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEiB,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACrB,MAAM,EAAE,IAAI,CAACe;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACL,KAAK,CAAC;IAEpDE,gBAAgB,CAACI,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDL,gBAAgB,CAACM,SAAS,CAACJ,gBAAgB,CAACjB,MAAM,CAAC;IAEnD,OAAOe,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEG,eAAeA,CAACL,KAAK,EAAE;IACrB,MAAMT,KAAK,GAAGS,KAAK,CAACS,QAAQ,CAAC,CAAC;IAE9B,IAAItB,MAAM,GAAG,KAAK;IAClB,IAAI,CAAC,IAAI,CAACuB,IAAI,CAACnB,KAAK,CAAC,EAAE;MACrBJ,MAAM,GAAG,KAAK;IAChB;IAEA,IAAI,CAACI,KAAK,IAAI,IAAI,CAACmB,IAAI,CAACnB,KAAK,CAAC,EAAE;MAC9BJ,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMoB,KAAK,GAAG,IAAI,CAACI,QAAQ,CAACC,yBAAe,EAAEzB,MAAM,CAAC;IAEpD,OAAO;MACLoB,KAAK;MACLpB;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE0B,YAAYA,CAACb,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAACc,OAAA,CAAApC,OAAA,GAAAC,2BAAA","ignoreList":[]}
|
|
@@ -44,7 +44,7 @@ class SchemaAssessment extends _assessment.default {
|
|
|
44
44
|
* @returns {{score: number, status: string}}
|
|
45
45
|
*/
|
|
46
46
|
calculateResult(paper) {
|
|
47
|
-
let status = '';
|
|
47
|
+
let status = 'bad';
|
|
48
48
|
const url = paper.getSlug();
|
|
49
49
|
if (url.includes('product')) {
|
|
50
50
|
this._config = (0, _lodash.merge)(this._config, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SchemaAssessment.js","names":["_lodash","require","_AssessmentResult","_interopRequireDefault","_assessment","_analysis","e","__esModule","default","SchemaAssessment","Assessment","constructor","config","defaultConfig","id","SCHEMA_ID","priority","docUrl","ctaType","title","content","good","improve","bad","identifier","_config","merge","calculateResult","paper","status","url","getSlug","includes","type","hasProductSchema","hasArticleSchema","score","getScore","TECHNICAL_SEO_POINTS","getResult","researcher","calculatedResult","assessmentResult","AssessmentResult","setScore","setStatus","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/SchemaAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {SCHEMA_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks shop has schema.\n */\nexport default class SchemaAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SCHEMA_ID,\n priority: 'high',\n docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#schema',\n ctaType: 'contactUs',\n title: 'Schema',\n content: {\n good: 'Schema markup is applied effectively.',\n improve: '',\n bad: 'No schema markup applied. Add schema to optimize visibility for search engines.'\n }\n };\n\n this.identifier = SCHEMA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n let status = '';\n const url = paper.getSlug();\n\n if (url.includes('product')) {\n this._config = merge(this._config, {\n type: \"product\",\n title: 'Missing product structured data',\n content: {\n good: 'Product structured data added',\n bad: 'Add Product structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasProductSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n if (url.includes('collection')) {\n this._config = merge(this._config, {\n type: \"collection\",\n title: 'Missing collection structured data',\n content: {\n good: 'Collection structured data added',\n bad: 'Add Collection structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasProductSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n if (url.includes('blogs')) {\n this._config = merge(this._config, {\n type: \"article\",\n title: 'Missing article structured data',\n content: {\n good: 'Article structured data added',\n bad: 'Add Article structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasArticleSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n\n const score = this.getScore(TECHNICAL_SEO_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @param config\n * @returns {AssessmentResult}\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks if the sentence beginnings assessment is applicable to the paper.\n *\n * @param {Object} paper The paper to check.\n * @param {Researcher} researcher The researcher object.\n * @returns {boolean} Returns true if the language is available and the paper is not empty.\n */\n isApplicable(paper, researcher) {\n return true\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,WAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAAuE,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEvE;AACA;AACA;AACe,MAAMG,gBAAgB,SAASC,mBAAU,CAAC;EACvD;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,mBAAS;MACbC,QAAQ,EAAE,MAAM;MAChBC,MAAM,EAAE,oFAAoF;MAC5FC,OAAO,EAAE,WAAW;MACpBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,uCAAuC;QAC7CC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGT,mBAAS;IAC3B,IAAI,CAACU,OAAO,GAAG,IAAAC,aAAK,EAACb,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;EACEe,eAAeA,CAACC,KAAK,EAAE;IACrB,IAAIC,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"SchemaAssessment.js","names":["_lodash","require","_AssessmentResult","_interopRequireDefault","_assessment","_analysis","e","__esModule","default","SchemaAssessment","Assessment","constructor","config","defaultConfig","id","SCHEMA_ID","priority","docUrl","ctaType","title","content","good","improve","bad","identifier","_config","merge","calculateResult","paper","status","url","getSlug","includes","type","hasProductSchema","hasArticleSchema","score","getScore","TECHNICAL_SEO_POINTS","getResult","researcher","calculatedResult","assessmentResult","AssessmentResult","setScore","setStatus","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/SchemaAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {SCHEMA_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks shop has schema.\n */\nexport default class SchemaAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SCHEMA_ID,\n priority: 'high',\n docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#schema',\n ctaType: 'contactUs',\n title: 'Schema',\n content: {\n good: 'Schema markup is applied effectively.',\n improve: '',\n bad: 'No schema markup applied. Add schema to optimize visibility for search engines.'\n }\n };\n\n this.identifier = SCHEMA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n let status = 'bad';\n const url = paper.getSlug();\n\n if (url.includes('product')) {\n this._config = merge(this._config, {\n type: \"product\",\n title: 'Missing product structured data',\n content: {\n good: 'Product structured data added',\n bad: 'Add Product structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasProductSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n if (url.includes('collection')) {\n this._config = merge(this._config, {\n type: \"collection\",\n title: 'Missing collection structured data',\n content: {\n good: 'Collection structured data added',\n bad: 'Add Collection structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasProductSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n if (url.includes('blogs')) {\n this._config = merge(this._config, {\n type: \"article\",\n title: 'Missing article structured data',\n content: {\n good: 'Article structured data added',\n bad: 'Add Article structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasArticleSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n\n const score = this.getScore(TECHNICAL_SEO_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @param config\n * @returns {AssessmentResult}\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks if the sentence beginnings assessment is applicable to the paper.\n *\n * @param {Object} paper The paper to check.\n * @param {Researcher} researcher The researcher object.\n * @returns {boolean} Returns true if the language is available and the paper is not empty.\n */\n isApplicable(paper, researcher) {\n return true\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -71,7 +71,7 @@ class SingleH1Assessment extends _assessment.default {
|
|
|
71
71
|
calculateResult(paper) {
|
|
72
72
|
const htmlString = paper.getText();
|
|
73
73
|
const desHasH1Tag = htmlString.includes('<h1>');
|
|
74
|
-
let status = '';
|
|
74
|
+
let status = 'bad';
|
|
75
75
|
if (this._h1Count === 1) {
|
|
76
76
|
status = 'good';
|
|
77
77
|
}
|