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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InvalidCharactersInUrl.js","names":["merge","Assessment","AssessmentResult","CHARACTERS_URL","URLS_POINTS","enhanceResearcherForChinese","InvalidCharactersInUrl","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","enhancedResearcher","getSlug","getKeyword","_charactersInUrl","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","isInvalidCharacters","getScore"],"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":["merge","Assessment","AssessmentResult","CHARACTERS_URL","URLS_POINTS","enhanceResearcherForChinese","InvalidCharactersInUrl","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","enhancedResearcher","getSlug","getKeyword","_charactersInUrl","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","isInvalidCharacters","getScore"],"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,SAAQA,KAAK,QAAO,QAAQ;AAE5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,cAAc,EAAEC,WAAW;AACnC,SAAQC,2BAA2B;;AAEnC;AACA;AACA;AACA,MAAMC,sBAAsB,SAASL,UAAU,CAAC;EAC9C;AACF;AACA;AACA;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEP,cAAc;MAClBQ,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,GAAGjB,cAAc;IAChC,IAAI,CAACkB,OAAO,GAAGrB,KAAK,CAACS,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B;IACA,MAAMC,kBAAkB,GAAGpB,2BAA2B,CACpDmB,UAAU,EACVD,KAAK,CAACG,OAAO,CAAC,CAAC,EACfH,KAAK,CAACI,UAAU,CAAC,CAAC,EAClB,IAAI,CAAC;IACP,CAAC;IAED,IAAI,CAACC,gBAAgB,GAAGH,kBAAkB,CAACI,WAAW,CAAC,iBAAiB,CAAC;IACzE,MAAMC,gBAAgB,GAAG,IAAI5B,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMU,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAAC,CAAC;IAE/CF,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEO,YAAYA,CAACd,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;EACEQ,eAAeA,CAAA,EAAG;IAChB,MAAMI,MAAM,GAAG,IAAI,EAAER,gBAAgB,EAAEU,mBAAmB,GAAG,KAAK,GAAG,MAAM;IAC3E,MAAMJ,KAAK,GAAG,IAAI,CAACK,QAAQ,CAACnC,WAAW,EAAGgC,MAAM,CAAC;IAEjD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAEA,eAAe9B,sBAAsB","ignoreList":[]}
|
|
@@ -72,8 +72,12 @@ class KeyphraseAssessment extends Assessment {
|
|
|
72
72
|
*/
|
|
73
73
|
calculateResult(paper) {
|
|
74
74
|
const status = (() => {
|
|
75
|
+
let status = 'bad';
|
|
75
76
|
const hasKeyphrase = paper.hasKeyword();
|
|
76
|
-
|
|
77
|
+
if (hasKeyphrase) {
|
|
78
|
+
status = 'good';
|
|
79
|
+
}
|
|
80
|
+
return status;
|
|
77
81
|
})();
|
|
78
82
|
const score = this.getScore(KEYWORD_POINTS, status);
|
|
79
83
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeyphraseAssessment.js","names":["merge","Assessment","AssessmentResult","KEYPHRASE_ID","KEYWORD_POINTS","KeyphraseAssessment","constructor","config","defaultConfig","id","docUrl","ctaType","fixPosition","priority","title","content","improve","bad","good","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","hasKeyphrase","hasKeyword","getScore"],"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":["merge","Assessment","AssessmentResult","KEYPHRASE_ID","KEYWORD_POINTS","KeyphraseAssessment","constructor","config","defaultConfig","id","docUrl","ctaType","fixPosition","priority","title","content","improve","bad","good","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","hasKeyphrase","hasKeyword","getScore"],"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,SAAQA,KAAK,QAAO,QAAQ;AAE5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,YAAY,EAAEC,cAAc;;AAEpC;AACA;AACA;AACA,MAAMC,mBAAmB,SAASJ,UAAU,CAAC;EAC3C;AACF;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,YAAY;MAChBO,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,GAAGhB,YAAY;IAC9B,IAAI,CAACiB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAItB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMK,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACJ,KAAK,CAAC;IAEpDE,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEO,YAAYA,CAACT,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;EACEG,eAAeA,CAACJ,KAAK,EAAE;IACrB,MAAMQ,MAAM,GAAG,CAAC,MAAM;MACpB,IAAIA,MAAM,GAAG,KAAK;MAClB,MAAME,YAAY,GAAGV,KAAK,CAACW,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,CAAC9B,cAAc,EAAE0B,MAAM,CAAC;IAEnD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAEA,eAAezB,mBAAmB","ignoreList":[]}
|
|
@@ -61,8 +61,8 @@ class KeyphraseLengthAssessment extends Assessment {
|
|
|
61
61
|
* @returns {Object} Object with score and text.
|
|
62
62
|
*/
|
|
63
63
|
calculateResult(paper) {
|
|
64
|
-
const keywordLength = countWords(paper.getKeyword());
|
|
65
64
|
let status = 'bad';
|
|
65
|
+
const keywordLength = countWords(paper.getKeyword());
|
|
66
66
|
if (keywordLength <= 4) {
|
|
67
67
|
status = 'good';
|
|
68
68
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeyphraseLengthAssessment.js","names":["merge","Assessment","AssessmentResult","countWords","KEYPHRASE_LENGTH_ID","MAIN_CONTENT_POINTS","KeyphraseLengthAssessment","constructor","config","defaultConfig","id","ctaType","priority","docUrl","fixPosition","title","content","improve","bad","good","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","keywordLength","getKeyword","getScore","isApplicable"],"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":["merge","Assessment","AssessmentResult","countWords","KEYPHRASE_LENGTH_ID","MAIN_CONTENT_POINTS","KeyphraseLengthAssessment","constructor","config","defaultConfig","id","ctaType","priority","docUrl","fixPosition","title","content","improve","bad","good","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","keywordLength","getKeyword","getScore","isApplicable"],"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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,UAAU;AAClB,SAAQC,mBAAmB,EAAEC,mBAAmB;;AAEhD;AACA;AACA;AACA,MAAMC,yBAAyB,SAASL,UAAU,CAAC;EACjD;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,EAAE;IAClB,KAAK,CAAC,CAAC;IAEP,IAAI,CAACC,aAAa,GAAG;MACnBC,EAAE,EAAEN,mBAAmB;MACvBO,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,GAAGhB,mBAAmB;IACrC,IAAI,CAACiB,OAAO,GAAGrB,KAAK,CAAC,IAAI,CAACS,aAAa,EAAED,MAAM,CAAC;EAClD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIvB,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMK,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACJ,KAAK,CAAC;IAEpDE,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IAEnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACJ,KAAK,EAAE;IACrB,IAAIQ,MAAM,GAAG,KAAK;IAClB,MAAMC,aAAa,GAAG7B,UAAU,CAACoB,KAAK,CAACU,UAAU,CAAC,CAAC,CAAC;IAEpD,IAAID,aAAa,IAAI,CAAC,EAAE;MACtBD,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACK,QAAQ,CAAC7B,mBAAmB,EAAE0B,MAAM,CAAC;IAExD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,YAAYA,CAACZ,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAEA,eAAejB,yBAAyB","ignoreList":[]}
|
|
@@ -63,9 +63,9 @@ class KeyphraseDensityAssessment extends Assessment {
|
|
|
63
63
|
* @returns {{title: string, score: number, status: string}}
|
|
64
64
|
*/
|
|
65
65
|
calculateResult() {
|
|
66
|
+
let status = 'bad';
|
|
66
67
|
const density = this._keyphraseDensity;
|
|
67
68
|
const roundedDensity = parseFloat(density.toFixed(2));
|
|
68
|
-
let status = 'bad';
|
|
69
69
|
if (roundedDensity >= 1 && roundedDensity <= 1.5) {
|
|
70
70
|
status = 'good';
|
|
71
71
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeywordDensityAssessment.js","names":["merge","Assessment","AssessmentResult","keyphraseLengthFactor","KEYPHRASE_DENSITY_ID","MAIN_CONTENT_POINTS","KeyphraseDensityAssessment","constructor","config","defaultConfig","id","fixPosition","docUrl","ctaType","priority","title","content","good","bad","improve","identifier","_config","getResult","paper","researcher","_keyphraseCount","getResearch","keyphraseLength","_keyphraseDensity","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","setTitle","density","roundedDensity","parseFloat","toFixed","getScore","isApplicable"],"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":["merge","Assessment","AssessmentResult","keyphraseLengthFactor","KEYPHRASE_DENSITY_ID","MAIN_CONTENT_POINTS","KeyphraseDensityAssessment","constructor","config","defaultConfig","id","fixPosition","docUrl","ctaType","priority","title","content","good","bad","improve","identifier","_config","getResult","paper","researcher","_keyphraseCount","getResearch","keyphraseLength","_keyphraseDensity","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","setTitle","density","roundedDensity","parseFloat","toFixed","getScore","isApplicable"],"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":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AAEvB,OAAOC,qBAAqB;AAC5B,SAAQC,oBAAoB,EAAEC,mBAAmB;;AAEjD;AACA;AACA;AACA,MAAMC,0BAA0B,SAASL,UAAU,CAAC;EAClD;AACF;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,oBAAoB;MACxBO,WAAW,EAAE,kBAAkB;MAC/BC,MAAM,EACJ,kGAAkG;MACpGC,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,sBAAsB;MAC7BC,OAAO,EAAE;QACPC,IAAI,EAAE,iDAAiD;QACvDC,GAAG,EAAE,sCAAsC;QAC3CC,OAAO,EAAE;MACX;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGhB,oBAAoB;IACtC,IAAI,CAACiB,OAAO,GAAGrB,KAAK,CAACS,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAE7B,IAAI,CAACC,eAAe,GAAGD,UAAU,CAACE,WAAW,CAAC,mBAAmB,CAAC;IAClE,MAAMC,eAAe,GAAG,IAAI,CAACF,eAAe,CAACE,eAAe;IAE5D,IAAI,CAACC,iBAAiB,GAAGJ,UAAU,CAACE,WAAW,CAAC,qBAAqB,CAAC;IACtE,IAAI,CAACE,iBAAiB,GAAG,IAAI,CAACA,iBAAiB,GAAGzB,qBAAqB,CAACwB,eAAe,CAAC;IAExF,MAAME,gBAAgB,GAAG,IAAI3B,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMS,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACR,KAAK,CAAC;IAEpDM,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnDN,gBAAgB,CAACO,QAAQ,CAACN,gBAAgB,CAACf,KAAK,CAAC;IACjD,OAAOc,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;EACEE,eAAeA,CAAA,EAAG;IAChB,IAAII,MAAM,GAAG,KAAK;IAClB,MAAME,OAAO,GAAG,IAAI,CAACT,iBAAiB;IACtC,MAAMU,cAAc,GAAGC,UAAU,CAACF,OAAO,CAACG,OAAO,CAAC,CAAC,CAAC,CAAC;IACrD,IAAIF,cAAc,IAAI,CAAC,IAAIA,cAAc,IAAI,GAAG,EAAE;MAChDH,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACQ,QAAQ,CAACpC,mBAAmB,EAAE8B,MAAM,CAAC;IACxD,IAAI,CAACd,OAAO,GAAGrB,KAAK,CAAC,IAAI,CAACqB,OAAO,EAAE;MACjCiB;IACF,CAAC,CAAC;IACF,OAAO;MACLA,cAAc;MACdL,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEO,YAAYA,CAACnB,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;AACF;AAEA,eAAelB,0BAA0B","ignoreList":[]}
|
|
@@ -61,10 +61,13 @@ export default class KeywordFAQsAssessment extends Assessment {
|
|
|
61
61
|
* @returns {Object} The calculated result.
|
|
62
62
|
*/
|
|
63
63
|
calculateResult(paper) {
|
|
64
|
+
let status = 'bad';
|
|
64
65
|
const faqs = paper.getFAQs()?.questions || [];
|
|
65
66
|
const keyword = paper.getKeyword();
|
|
66
67
|
const hasKeywords = this.checkKeywordsInFAQs(faqs, [keyword]);
|
|
67
|
-
|
|
68
|
+
if (hasKeywords) {
|
|
69
|
+
status = 'good';
|
|
70
|
+
}
|
|
68
71
|
const score = this.getScore(FAQS_POINTS, status);
|
|
69
72
|
return {
|
|
70
73
|
status,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"KeywordFAQsAssessment.js","names":["merge","Assessment","AssessmentResult","FAQS_POINTS","KEYWORD_FAQs_ASSESSMENT_ID","KeywordFAQsAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","setScore","score","setStatus","status","faqs","getFAQs","questions","keyword","getKeyword","hasKeywords","checkKeywordsInFAQs","getScore","keywords","some","faq","question","toLowerCase","answer","keywordLower","includes","isApplicable"],"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":["merge","Assessment","AssessmentResult","FAQS_POINTS","KEYWORD_FAQs_ASSESSMENT_ID","KeywordFAQsAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","setScore","score","setStatus","status","faqs","getFAQs","questions","keyword","getKeyword","hasKeywords","checkKeywordsInFAQs","getScore","keywords","some","faq","question","toLowerCase","answer","keywordLower","includes","isApplicable"],"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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,WAAW,EAAEC,0BAA0B;;AAE/C;AACA;AACA;AACA,eAAe,MAAMC,qBAAqB,SAASJ,UAAU,CAAC;EAC5D;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,0BAA0B;MAC9BM,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,GAAGf,0BAA0B;IAC5C,IAAI,CAACgB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACH,KAAK,CAAC;IAEpD,MAAMI,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IACrEM,gBAAgB,CAACC,QAAQ,CAACH,gBAAgB,CAACI,KAAK,CAAC;IACjDF,gBAAgB,CAACG,SAAS,CAACL,gBAAgB,CAACM,MAAM,CAAC;IAEnD,OAAOJ,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB,IAAIQ,MAAM,GAAG,KAAK;IAClB,MAAMC,IAAI,GAAGT,KAAK,CAACU,OAAO,CAAC,CAAC,EAAEC,SAAS,IAAI,EAAE;IAC7C,MAAMC,OAAO,GAAGZ,KAAK,CAACa,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,CAACnC,WAAW,EAAE2B,MAAM,CAAC;IAEhD,OAAO;MACLA,MAAM;MACNF;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;EACES,mBAAmBA,CAACN,IAAI,EAAEQ,QAAQ,EAAE;IAClC,OAAOR,IAAI,CAACS,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,CAACN,OAAO,IAAI;QAC9B,MAAMW,YAAY,GAAGX,OAAO,CAACS,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,CAACzB,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberInMetaTitleAssessment.js","names":["merge","Assessment","AssessmentResult","META_TAG_POINTS","NUMBER_TITLE_ID","NumberInMetaTitleAssessment","constructor","config","defaultConfig","id","ctaType","status","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","getTitle","test","getScore","isApplicable"],"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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe,EAAEC,eAAe;;AAExC;AACA;AACA;AACA,eAAe,MAAMC,2BAA2B,SAASJ,UAAU,CAAC;EAClE;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,eAAe;MACnBM,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,GAAGhB,eAAe;IACjC,IAAI,CAACiB,OAAO,GAAGrB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEe,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIvB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErE,MAAMK,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACJ,KAAK,CAAC;IAEpDE,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACf,MAAM,CAAC;IAEnD,OAAOc,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACJ,KAAK,EAAE;IACrB,MAAMR,KAAK,GAAGQ,KAAK,CAACQ,QAAQ,CAAC,CAAC;IAE9B,IAAIpB,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"NumberInMetaTitleAssessment.js","names":["merge","Assessment","AssessmentResult","META_TAG_POINTS","NUMBER_TITLE_ID","NumberInMetaTitleAssessment","constructor","config","defaultConfig","id","ctaType","status","docUrl","priority","fixPosition","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","getTitle","test","getScore","isApplicable"],"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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe,EAAEC,eAAe;;AAExC;AACA;AACA;AACA,eAAe,MAAMC,2BAA2B,SAASJ,UAAU,CAAC;EAClE;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,eAAe;MACnBM,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,GAAGhB,eAAe;IACjC,IAAI,CAACiB,OAAO,GAAGrB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEe,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIvB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErE,MAAMK,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACJ,KAAK,CAAC;IAEpDE,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACf,MAAM,CAAC;IAEnD,OAAOc,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACJ,KAAK,EAAE;IACrB,MAAMR,KAAK,GAAGQ,KAAK,CAACQ,QAAQ,CAAC,CAAC;IAE9B,IAAIpB,MAAM,GAAG,KAAK;IAClB,IAAI,CAAC,IAAI,CAACqB,IAAI,CAACjB,KAAK,CAAC,EAAE;MACrBJ,MAAM,GAAG,KAAK;IAChB;IAEA,IAAI,CAACI,KAAK,IAAI,IAAI,CAACiB,IAAI,CAACjB,KAAK,CAAC,EAAE;MAC9BJ,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMkB,KAAK,GAAG,IAAI,CAACI,QAAQ,CAAC9B,eAAe,EAAEQ,MAAM,CAAC;IAEpD,OAAO;MACLkB,KAAK;MACLlB;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEuB,YAAYA,CAACX,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF","ignoreList":[]}
|
|
@@ -38,7 +38,7 @@ export default class SchemaAssessment extends Assessment {
|
|
|
38
38
|
* @returns {{score: number, status: string}}
|
|
39
39
|
*/
|
|
40
40
|
calculateResult(paper) {
|
|
41
|
-
let status = '';
|
|
41
|
+
let status = 'bad';
|
|
42
42
|
const url = paper.getSlug();
|
|
43
43
|
if (url.includes('product')) {
|
|
44
44
|
this._config = merge(this._config, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SchemaAssessment.js","names":["merge","AssessmentResult","Assessment","SCHEMA_ID","TECHNICAL_SEO_POINTS","SchemaAssessment","constructor","config","defaultConfig","id","priority","docUrl","ctaType","title","content","good","improve","bad","identifier","_config","calculateResult","paper","status","url","getSlug","includes","type","hasProductSchema","hasArticleSchema","score","getScore","getResult","researcher","calculatedResult","assessmentResult","setScore","setStatus","isApplicable"],"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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,gBAAgB;AACvB,OAAOC,UAAU;AACjB,SAAQC,SAAS,EAAEC,oBAAoB;;AAEvC;AACA;AACA;AACA,eAAe,MAAMC,gBAAgB,SAASH,UAAU,CAAC;EACvD;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,SAAS;MACbO,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,GAAGf,SAAS;IAC3B,IAAI,CAACgB,OAAO,GAAGnB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;EACEa,eAAeA,CAACC,KAAK,EAAE;IACrB,IAAIC,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"SchemaAssessment.js","names":["merge","AssessmentResult","Assessment","SCHEMA_ID","TECHNICAL_SEO_POINTS","SchemaAssessment","constructor","config","defaultConfig","id","priority","docUrl","ctaType","title","content","good","improve","bad","identifier","_config","calculateResult","paper","status","url","getSlug","includes","type","hasProductSchema","hasArticleSchema","score","getScore","getResult","researcher","calculatedResult","assessmentResult","setScore","setStatus","isApplicable"],"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":[]}
|
|
@@ -65,7 +65,7 @@ class SingleH1Assessment extends Assessment {
|
|
|
65
65
|
calculateResult(paper) {
|
|
66
66
|
const htmlString = paper.getText();
|
|
67
67
|
const desHasH1Tag = htmlString.includes('<h1>');
|
|
68
|
-
let status = '';
|
|
68
|
+
let status = 'bad';
|
|
69
69
|
if (this._h1Count === 1) {
|
|
70
70
|
status = 'good';
|
|
71
71
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SingleH1Assessment.js","names":["isUndefined","merge","Assessment","AssessmentResult","SINGLE_H1_ID","TECHNICAL_SEO_POINTS","SingleH1Assessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","_h1Count","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","htmlString","getText","desHasH1Tag","includes","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SingleH1Assessment.js"],"sourcesContent":["import {isUndefined, merge} from 'lodash';\nimport Assessment from '../assessment.js';\nimport AssessmentResult from '../../../values/AssessmentResult.js';\nimport {SINGLE_H1_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the body of the text contains more than 1 H1s in the body.\n * This assessment doesn't penalize H1 that is not in the very beginning of the body.\n */\nclass SingleH1Assessment 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: SINGLE_H1_ID,\n docUrl: 'https://help.seoon.io/seo/seo-checklist',\n fixPosition: 'description',\n ctaType: 'contactUs',\n priority: 'high',\n title: 'H1 tag',\n content: {\n good: 'H1 tag is optimized.',\n improve: 'You should use only one H1 tag',\n bad: 'Missing H1 tag. Add one H1 to clearly define your page`s topic.'\n }\n };\n\n this.identifier = SINGLE_H1_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 this._h1Count = researcher.getResearch('h1s');\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n if (!isUndefined(calculatedResult)) {\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n }\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const htmlString = paper.getText();\n const desHasH1Tag = htmlString.includes('<h1>');\n\n let status = '';\n if (this._h1Count === 1) {\n status = 'good';\n }\n\n if (this._h1Count === 0 && !desHasH1Tag) {\n status = 'good';\n }\n\n if (this._h1Count > 1) {\n status = 'bad';\n }\n\n const score = this.getScore(TECHNICAL_SEO_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 SingleH1Assessment;\n"],"mappings":"AAAA,SAAQA,WAAW,EAAEC,KAAK,QAAO,QAAQ;AACzC,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,YAAY,EAAEC,oBAAoB;;AAE1C;AACA;AACA;AACA;AACA,MAAMC,kBAAkB,SAASJ,UAAU,CAAC;EAC1C;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,YAAY;MAChBO,MAAM,EAAE,yCAAyC;MACjDC,WAAW,EAAE,aAAa;MAC1BC,OAAO,EAAE,WAAW;MACpBC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,sBAAsB;QAC5BC,OAAO,EAAE,gCAAgC;QACzCC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGhB,YAAY;IAC9B,IAAI,CAACiB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,IAAI,CAACC,QAAQ,GAAGD,UAAU,CAACE,WAAW,CAAC,KAAK,CAAC;IAC7C,MAAMC,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpD,IAAI,CAACvB,WAAW,CAAC4B,gBAAgB,CAAC,EAAE;MAClCD,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;MACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACrD;IAEA,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACN,KAAK,EAAE;IACrB,MAAMW,UAAU,GAAGX,KAAK,CAACY,OAAO,CAAC,CAAC;IAClC,MAAMC,WAAW,GAAGF,UAAU,CAACG,QAAQ,CAAC,MAAM,CAAC;IAE/C,IAAIJ,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"SingleH1Assessment.js","names":["isUndefined","merge","Assessment","AssessmentResult","SINGLE_H1_ID","TECHNICAL_SEO_POINTS","SingleH1Assessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","_h1Count","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","htmlString","getText","desHasH1Tag","includes","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SingleH1Assessment.js"],"sourcesContent":["import {isUndefined, merge} from 'lodash';\nimport Assessment from '../assessment.js';\nimport AssessmentResult from '../../../values/AssessmentResult.js';\nimport {SINGLE_H1_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the body of the text contains more than 1 H1s in the body.\n * This assessment doesn't penalize H1 that is not in the very beginning of the body.\n */\nclass SingleH1Assessment 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: SINGLE_H1_ID,\n docUrl: 'https://help.seoon.io/seo/seo-checklist',\n fixPosition: 'description',\n ctaType: 'contactUs',\n priority: 'high',\n title: 'H1 tag',\n content: {\n good: 'H1 tag is optimized.',\n improve: 'You should use only one H1 tag',\n bad: 'Missing H1 tag. Add one H1 to clearly define your page`s topic.'\n }\n };\n\n this.identifier = SINGLE_H1_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 this._h1Count = researcher.getResearch('h1s');\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n if (!isUndefined(calculatedResult)) {\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n }\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const htmlString = paper.getText();\n const desHasH1Tag = htmlString.includes('<h1>');\n\n let status = 'bad';\n if (this._h1Count === 1) {\n status = 'good';\n }\n\n if (this._h1Count === 0 && !desHasH1Tag) {\n status = 'good';\n }\n\n if (this._h1Count > 1) {\n status = 'bad';\n }\n\n const score = this.getScore(TECHNICAL_SEO_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 SingleH1Assessment;\n"],"mappings":"AAAA,SAAQA,WAAW,EAAEC,KAAK,QAAO,QAAQ;AACzC,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,YAAY,EAAEC,oBAAoB;;AAE1C;AACA;AACA;AACA;AACA,MAAMC,kBAAkB,SAASJ,UAAU,CAAC;EAC1C;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,YAAY;MAChBO,MAAM,EAAE,yCAAyC;MACjDC,WAAW,EAAE,aAAa;MAC1BC,OAAO,EAAE,WAAW;MACpBC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,sBAAsB;QAC5BC,OAAO,EAAE,gCAAgC;QACzCC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGhB,YAAY;IAC9B,IAAI,CAACiB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,IAAI,CAACC,QAAQ,GAAGD,UAAU,CAACE,WAAW,CAAC,KAAK,CAAC;IAC7C,MAAMC,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpD,IAAI,CAACvB,WAAW,CAAC4B,gBAAgB,CAAC,EAAE;MAClCD,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;MACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACrD;IAEA,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACN,KAAK,EAAE;IACrB,MAAMW,UAAU,GAAGX,KAAK,CAACY,OAAO,CAAC,CAAC;IAClC,MAAMC,WAAW,GAAGF,UAAU,CAACG,QAAQ,CAAC,MAAM,CAAC;IAE/C,IAAIJ,MAAM,GAAG,KAAK;IAClB,IAAI,IAAI,CAACR,QAAQ,KAAK,CAAC,EAAE;MACvBQ,MAAM,GAAG,MAAM;IACjB;IAEA,IAAI,IAAI,CAACR,QAAQ,KAAK,CAAC,IAAI,CAACW,WAAW,EAAE;MACvCH,MAAM,GAAG,MAAM;IACjB;IAEA,IAAI,IAAI,CAACR,QAAQ,GAAG,CAAC,EAAE;MACrBQ,MAAM,GAAG,KAAK;IAChB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACO,QAAQ,CAACjC,oBAAoB,EAAE4B,MAAM,CAAC;IAEzD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,YAAYA,CAAChB,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAEA,eAAejB,kBAAkB","ignoreList":[]}
|
|
@@ -63,9 +63,8 @@ export default class SubHeadingsKeywordAssessment extends Assessment {
|
|
|
63
63
|
if (this._subHeadings.matches > 0) {
|
|
64
64
|
status = 'good';
|
|
65
65
|
}
|
|
66
|
-
const score = this.getScore(MAIN_CONTENT_POINTS, status);
|
|
67
66
|
return {
|
|
68
|
-
score,
|
|
67
|
+
score: this.getScore(MAIN_CONTENT_POINTS, status) || 0,
|
|
69
68
|
status
|
|
70
69
|
};
|
|
71
70
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SubHeadingsKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","MAIN_CONTENT_POINTS","SUBHEADINGS_KEYWORD_ID","SubHeadingsKeywordAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","bad","improve","identifier","_config","getResult","paper","researcher","_subHeadings","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","matches","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SubHeadingsKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {MAIN_CONTENT_POINTS, SUBHEADINGS_KEYWORD_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks if the keyword is present in one of the subheadings.\n */\nexport default class SubHeadingsKeywordAssessment 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: SUBHEADINGS_KEYWORD_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-subheading',\n priority: 'medium',\n fixPosition: 'subheading',\n title: 'Keyword in Subheading',\n content: {\n good: 'Keywords are included in subheadings.',\n bad:\n 'Keyword not found in any subheadings. Include it in at least one subheading (H2, H3, etc.).',\n improve: ''\n }\n };\n\n this.identifier = SUBHEADINGS_KEYWORD_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\n this._subHeadings = researcher.getResearch('matchKeywordInSubheadings');\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\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n let status = 'bad';\n if (this._subHeadings.matches > 0) {\n status = 'good';\n }\n\n
|
|
1
|
+
{"version":3,"file":"SubHeadingsKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","MAIN_CONTENT_POINTS","SUBHEADINGS_KEYWORD_ID","SubHeadingsKeywordAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","bad","improve","identifier","_config","getResult","paper","researcher","_subHeadings","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","matches","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SubHeadingsKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {MAIN_CONTENT_POINTS, SUBHEADINGS_KEYWORD_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks if the keyword is present in one of the subheadings.\n */\nexport default class SubHeadingsKeywordAssessment 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: SUBHEADINGS_KEYWORD_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-subheading',\n priority: 'medium',\n fixPosition: 'subheading',\n title: 'Keyword in Subheading',\n content: {\n good: 'Keywords are included in subheadings.',\n bad:\n 'Keyword not found in any subheadings. Include it in at least one subheading (H2, H3, etc.).',\n improve: ''\n }\n };\n\n this.identifier = SUBHEADINGS_KEYWORD_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\n this._subHeadings = researcher.getResearch('matchKeywordInSubheadings');\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\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n let status = 'bad';\n if (this._subHeadings.matches > 0) {\n status = 'good';\n }\n\n\n return {\n score: this.getScore(MAIN_CONTENT_POINTS, status) || 0,\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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,mBAAmB,EAAEC,sBAAsB;;AAEnD;AACA;AACA;AACA,eAAe,MAAMC,4BAA4B,SAASJ,UAAU,CAAC;EACnE;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,sBAAsB;MAC1BM,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,mGAAmG;MACrGC,QAAQ,EAAE,QAAQ;MAClBC,WAAW,EAAE,YAAY;MACzBC,KAAK,EAAE,uBAAuB;MAC9BC,OAAO,EAAE;QACPC,IAAI,EAAE,uCAAuC;QAC7CC,GAAG,EACD,6FAA6F;QAC/FC,OAAO,EAAE;MACX;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,sBAAsB;IACxC,IAAI,CAACgB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAE7B,IAAI,CAACC,YAAY,GAAGD,UAAU,CAACE,WAAW,CAAC,2BAA2B,CAAC;IAEvE,MAAMC,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpDI,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IAEnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;EACEE,eAAeA,CAAA,EAAG;IAChB,IAAII,MAAM,GAAG,KAAK;IAClB,IAAI,IAAI,CAACR,YAAY,CAACS,OAAO,GAAG,CAAC,EAAE;MACjCD,MAAM,GAAG,MAAM;IACjB;IAGA,OAAO;MACLF,KAAK,EAAG,IAAI,CAACI,QAAQ,CAAC/B,mBAAmB,EAAE6B,MAAM,CAAC,IAAI,CAAC;MACvDA;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEG,YAAYA,CAACb,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF","ignoreList":[]}
|
|
@@ -61,15 +61,12 @@ export default class TextImagesAssessment extends Assessment {
|
|
|
61
61
|
*/
|
|
62
62
|
calculateResult() {
|
|
63
63
|
const imagesNoAlt = this.altTagsProperties.noAlt;
|
|
64
|
-
let status = '';
|
|
64
|
+
let status = 'good';
|
|
65
65
|
if (imagesNoAlt === this.imageCount || imagesNoAlt > 0) {
|
|
66
66
|
status = 'bad';
|
|
67
|
-
} else {
|
|
68
|
-
status = 'good';
|
|
69
67
|
}
|
|
70
|
-
const score = this.getScore(TECHNICAL_SEO_POINTS, status);
|
|
71
68
|
return {
|
|
72
|
-
score,
|
|
69
|
+
score: this.getScore(TECHNICAL_SEO_POINTS, status) || 0,
|
|
73
70
|
status
|
|
74
71
|
};
|
|
75
72
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TextImagesAssessment.js","names":["merge","Assessment","AssessmentResult","TECHNICAL_SEO_POINTS","TEXT_IMAGES_ID","TextImagesAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","fixPosition","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","assessmentResult","altTagsProperties","getResearch","imageCount","calculatedResult","calculateResult","setScore","score","setStatus","status","imagesNoAlt","noAlt","getScore","fix","shop","data","console","log","body","altText","name","parser","DOMParser","doc","parseFromString","imgTags","querySelectorAll","forEach","img","hasAttribute","getAttribute","setAttribute","innerHTML","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/TextImagesAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {TECHNICAL_SEO_POINTS, TEXT_IMAGES_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 TextImagesAssessment 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: TEXT_IMAGES_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#alt-text',\n fixPosition: 'description',\n priority: 'high',\n title: 'Alt text',\n content: {\n good: 'All images have descriptive and relevant alt text.',\n improve: '',\n bad: 'Missing alt text. Add descriptive alt text for accessibility and SEO.'\n }\n };\n\n this.identifier = TEXT_IMAGES_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 this.altTagsProperties = researcher.getResearch('altTagCount');\n this.imageCount = researcher.getResearch('imageCount');\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 * @returns {{score: number, status: string}}\n */\n calculateResult() {\n const imagesNoAlt = this.altTagsProperties.noAlt;\n\n let status = '';\n if (imagesNoAlt === this.imageCount || imagesNoAlt > 0) {\n status = 'bad';\n }
|
|
1
|
+
{"version":3,"file":"TextImagesAssessment.js","names":["merge","Assessment","AssessmentResult","TECHNICAL_SEO_POINTS","TEXT_IMAGES_ID","TextImagesAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","fixPosition","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","assessmentResult","altTagsProperties","getResearch","imageCount","calculatedResult","calculateResult","setScore","score","setStatus","status","imagesNoAlt","noAlt","getScore","fix","shop","data","console","log","body","altText","name","parser","DOMParser","doc","parseFromString","imgTags","querySelectorAll","forEach","img","hasAttribute","getAttribute","setAttribute","innerHTML","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/TextImagesAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {TECHNICAL_SEO_POINTS, TEXT_IMAGES_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 TextImagesAssessment 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: TEXT_IMAGES_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#alt-text',\n fixPosition: 'description',\n priority: 'high',\n title: 'Alt text',\n content: {\n good: 'All images have descriptive and relevant alt text.',\n improve: '',\n bad: 'Missing alt text. Add descriptive alt text for accessibility and SEO.'\n }\n };\n\n this.identifier = TEXT_IMAGES_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 this.altTagsProperties = researcher.getResearch('altTagCount');\n this.imageCount = researcher.getResearch('imageCount');\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 * @returns {{score: number, status: string}}\n */\n calculateResult() {\n const imagesNoAlt = this.altTagsProperties.noAlt;\n\n let status = 'good';\n if (imagesNoAlt === this.imageCount || imagesNoAlt > 0) {\n status = 'bad';\n }\n\n return {\n score: this.getScore(TECHNICAL_SEO_POINTS, status) || 0,\n status\n };\n }\n\n /**\n *\n * @param shop\n * @param data\n * @returns {string}\n */\n fix({shop, data}) {\n if (!shop) {\n console.log('Shop is missing');\n return data.body || '';\n }\n\n if (!data.body) {\n console.log('body is missing');\n return '';\n }\n\n const altText = shop?.name || 'Shop' + ' | ' + data?.title || 'Title';\n\n const parser = new DOMParser();\n const doc = parser.parseFromString(data.body, 'text/html');\n\n const imgTags = doc.querySelectorAll('img');\n\n imgTags.forEach(img => {\n if (!img.hasAttribute('alt') || img.getAttribute('alt') === '') {\n img.setAttribute('alt', altText);\n }\n });\n\n return doc.body.innerHTML;\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param researcher\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TextLengthAssessment.js","names":["merge","Assessment","AssessmentResult","wordCountInText","MAIN_CONTENT_POINTS","TEXT_LENGTH_ID","TextLengthAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","bad","identifier","_config","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","setScore","score","setStatus","status","pageType","getPageType","count","wordCount","rules","product","min","max","badMessage","collection","article","page","rule","type","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/TextLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport wordCountInText from '@axyseo/languageProcessing/researches/wordCountInText';\nimport {MAIN_CONTENT_POINTS, TEXT_LENGTH_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks the length of the text and gives feedback accordingly.\n */\n class TextLengthAssessment 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: TEXT_LENGTH_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#text-length',\n priority: 'high',\n fixPosition: 'description',\n title: 'Content length ',\n content: {\n good: 'Content length on target',\n bad:\n 'Write 300 to 500 words. Cover features, specs, sizing, use, and care. '\n }\n };\n\n this.identifier = TEXT_LENGTH_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\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const pageType = paper.getPageType();\n const { count: wordCount } = wordCountInText(paper);\n const rules = {\n product: {\n min: 300,\n max: 500,\n badMessage:\n 'Write 300 to 500 words. Cover features, specs, sizing, use, and care.',\n },\n collection: {\n min: 150,\n max: 300,\n badMessage:\n 'Write 150 to 300 words. Present the range and give quick buying guidance.'\n },\n article: {\n min: 600,\n max: 1000,\n badMessage:\n 'Write 600 to 1000 words. Explain the topic with clear sections and examples.'\n },\n page: {\n min: 600,\n max: 1000,\n badMessage:\n 'Write 600 to 1000 words. Provide clear, well-structured info for the page’s purpose.'\n }\n };\n\n let status = 'good';\n const rule = rules[pageType];\n\n if (rule && (wordCount < rule.min || wordCount > rule.max)) {\n status = 'bad';\n this._config = merge(this._config, {\n content: {\n good: 'Content length on target',\n bad: rule.badMessage\n },\n type: pageType\n });\n }\n\n return {\n score: this.getScore(MAIN_CONTENT_POINTS, status),\n status\n };\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\nexport default TextLengthAssessment;\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,OAAOC,eAAe;AACtB,SAAQC,mBAAmB,EAAEC,cAAc;;AAE3C;AACA;AACA;AACC,MAAMC,oBAAoB,SAASL,UAAU,CAAC;EAC7C;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,cAAc;MAClBM,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,yFAAyF;MAC3FC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,aAAa;MAC1BC,KAAK,EAAE,iBAAiB;MACxBC,OAAO,EAAE;QACPC,IAAI,EAAE,0BAA0B;QAChCC,GAAG,EACD;MACJ;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGd,cAAc;IAChC,IAAI,CAACe,OAAO,GAAGpB,KAAK,CAACS,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEa,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACH,KAAK,CAAC;IACpD,MAAMI,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACY;IAAO,CAAC,CAAC;IACrEM,gBAAgB,CAACC,QAAQ,CAACH,gBAAgB,CAACI,KAAK,CAAC;IACjDF,gBAAgB,CAACG,SAAS,CAACL,gBAAgB,CAACM,MAAM,CAAC;IAEnD,OAAOJ,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB,MAAMS,QAAQ,GAAGT,KAAK,CAACU,WAAW,CAAC,CAAC;IACpC,MAAM;MAAEC,KAAK,EAAEC;IAAU,CAAC,GAAG/B,eAAe,CAACmB,KAAK,CAAC;IACnD,MAAMa,KAAK,GAAG;MACZC,OAAO,EAAE;QACPC,GAAG,EAAE,GAAG;QACRC,GAAG,EAAE,GAAG;QACRC,UAAU,EACR;MACJ,CAAC;MACDC,UAAU,EAAE;QACVH,GAAG,EAAE,GAAG;QACRC,GAAG,EAAE,GAAG;QACRC,UAAU,EACR;MACJ,CAAC;MACDE,OAAO,EAAE;QACPJ,GAAG,EAAE,GAAG;QACRC,GAAG,EAAE,IAAI;QACTC,UAAU,EACR;MACJ,CAAC;MACDG,IAAI,EAAE;QACJL,GAAG,EAAE,GAAG;QACRC,GAAG,EAAE,IAAI;QACTC,UAAU,EACR;MACJ;IACF,CAAC;IAED,IAAIT,MAAM,GAAG,MAAM;IACnB,MAAMa,IAAI,GAAGR,KAAK,CAACJ,QAAQ,CAAC;IAE5B,IAAIY,IAAI,KAAKT,SAAS,GAAGS,IAAI,CAACN,GAAG,IAAIH,SAAS,GAAGS,IAAI,CAACL,GAAG,CAAC,EAAE;MAC1DR,MAAM,GAAG,KAAK;MACd,IAAI,CAACV,OAAO,GAAGpB,KAAK,CAAC,IAAI,CAACoB,OAAO,EAAE;QACjCJ,OAAO,EAAE;UACPC,IAAI,EAAE,0BAA0B;UAChCC,GAAG,EAAEyB,IAAI,CAACJ;QACZ,CAAC;QACDK,IAAI,EAAEb;MACR,CAAC,CAAC;IACJ;IAEA,OAAO;MACLH,KAAK,EAAE,IAAI,CAACiB,QAAQ,CAACzC,mBAAmB,EAAE0B,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"TextLengthAssessment.js","names":["merge","Assessment","AssessmentResult","wordCountInText","MAIN_CONTENT_POINTS","TEXT_LENGTH_ID","TextLengthAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","bad","identifier","_config","getResult","paper","researcher","calculatedResult","calculateResult","assessmentResult","setScore","score","setStatus","status","pageType","getPageType","count","wordCount","rules","product","min","max","badMessage","collection","article","page","rule","type","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/TextLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport wordCountInText from '@axyseo/languageProcessing/researches/wordCountInText';\nimport {MAIN_CONTENT_POINTS, TEXT_LENGTH_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks the length of the text and gives feedback accordingly.\n */\n class TextLengthAssessment 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: TEXT_LENGTH_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#text-length',\n priority: 'high',\n fixPosition: 'description',\n title: 'Content length ',\n content: {\n good: 'Content length on target',\n bad:\n 'Write 300 to 500 words. Cover features, specs, sizing, use, and care. '\n }\n };\n\n this.identifier = TEXT_LENGTH_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\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const pageType = paper.getPageType();\n const { count: wordCount } = wordCountInText(paper);\n const rules = {\n product: {\n min: 300,\n max: 500,\n badMessage:\n 'Write 300 to 500 words. Cover features, specs, sizing, use, and care.',\n },\n collection: {\n min: 150,\n max: 300,\n badMessage:\n 'Write 150 to 300 words. Present the range and give quick buying guidance.'\n },\n article: {\n min: 600,\n max: 1000,\n badMessage:\n 'Write 600 to 1000 words. Explain the topic with clear sections and examples.'\n },\n page: {\n min: 600,\n max: 1000,\n badMessage:\n 'Write 600 to 1000 words. Provide clear, well-structured info for the page’s purpose.'\n }\n };\n\n let status = 'good';\n const rule = rules[pageType];\n\n if (rule && (wordCount < rule.min || wordCount > rule.max)) {\n status = 'bad';\n this._config = merge(this._config, {\n content: {\n good: 'Content length on target',\n bad: rule.badMessage\n },\n type: pageType\n });\n }\n\n return {\n score: this.getScore(MAIN_CONTENT_POINTS, status) || 0,\n status\n };\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\nexport default TextLengthAssessment;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -78,9 +78,8 @@ class SlugKeywordAssessment extends Assessment {
|
|
|
78
78
|
const status = (() => {
|
|
79
79
|
return this._keywordInSlug.percentWordMatches >= 50 ? 'good' : 'bad';
|
|
80
80
|
})();
|
|
81
|
-
const score = this.getScore(URLS_POINTS, status);
|
|
82
81
|
return {
|
|
83
|
-
score,
|
|
82
|
+
score: this.getScore(URLS_POINTS, status) || 0,
|
|
84
83
|
status
|
|
85
84
|
};
|
|
86
85
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UrlKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","SLUG_KEYWORD_ID","URLS_POINTS","enhanceResearcherForChinese","SlugKeywordAssessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","enhancedResearcher","getSlug","getKeyword","_keywordInSlug","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","percentWordMatches","getScore"],"sources":["../../../../../src/scoring/assessments/seo/UrlKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {SLUG_KEYWORD_ID, 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 SlugKeywordAssessment 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: SLUG_KEYWORD_ID,\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: 'Keyword in URL',\n content: {\n good: 'Keyword is included in URL.',\n improve: '',\n bad: 'Missing keyword in URL. Include it for relevance and better SEO.'\n }\n };\n\n this.identifier = SLUG_KEYWORD_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 // 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._keywordInSlug = enhancedResearcher.getResearch('keywordCountInSlug');\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 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 = (() => {\n return this._keywordInSlug.percentWordMatches >= 50 ? 'good' : 'bad';\n })();\n\n
|
|
1
|
+
{"version":3,"file":"UrlKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","SLUG_KEYWORD_ID","URLS_POINTS","enhanceResearcherForChinese","SlugKeywordAssessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","enhancedResearcher","getSlug","getKeyword","_keywordInSlug","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","percentWordMatches","getScore"],"sources":["../../../../../src/scoring/assessments/seo/UrlKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {SLUG_KEYWORD_ID, 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 SlugKeywordAssessment 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: SLUG_KEYWORD_ID,\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: 'Keyword in URL',\n content: {\n good: 'Keyword is included in URL.',\n improve: '',\n bad: 'Missing keyword in URL. Include it for relevance and better SEO.'\n }\n };\n\n this.identifier = SLUG_KEYWORD_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 // 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._keywordInSlug = enhancedResearcher.getResearch('keywordCountInSlug');\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 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 = (() => {\n return this._keywordInSlug.percentWordMatches >= 50 ? 'good' : 'bad';\n })();\n\n return {\n score: this.getScore(URLS_POINTS, status) || 0,\n status\n };\n }\n}\n\nexport default SlugKeywordAssessment;\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAE5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe,EAAEC,WAAW;AACpC,SAAQC,2BAA2B;;AAEnC;AACA;AACA;AACA,MAAMC,qBAAqB,SAASL,UAAU,CAAC;EAC7C;AACF;AACA;AACA;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEP,eAAe;MACnBQ,MAAM,EACJ,4FAA4F;MAC9FC,WAAW,EAAE,YAAY;MACzBC,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE,QAAQ;MAClBC,KAAK,EAAE,gBAAgB;MACvBC,OAAO,EAAE;QACPC,IAAI,EAAE,6BAA6B;QACnCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGjB,eAAe;IACjC,IAAI,CAACkB,OAAO,GAAGrB,KAAK,CAACS,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B;IACA,MAAMC,kBAAkB,GAAGpB,2BAA2B,CACpDmB,UAAU,EACVD,KAAK,CAACG,OAAO,CAAC,CAAC,EACfH,KAAK,CAACI,UAAU,CAAC,CAAC,EAClB,IAAI,CAAC;IACP,CAAC;IAED,IAAI,CAACC,cAAc,GAAGH,kBAAkB,CAACI,WAAW,CAAC,oBAAoB,CAAC;IAE1E,MAAMC,gBAAgB,GAAG,IAAI5B,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMU,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAAC,CAAC;IAE/CF,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEO,YAAYA,CAACd,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;EACEQ,eAAeA,CAAA,EAAG;IAChB,MAAMI,MAAM,GAAG,CAAC,MAAM;MACpB,OAAO,IAAI,CAACR,cAAc,CAACU,kBAAkB,IAAI,EAAE,GAAG,MAAM,GAAG,KAAK;IACtE,CAAC,EAAE,CAAC;IAEJ,OAAO;MACLJ,KAAK,EAAE,IAAI,CAACK,QAAQ,CAACnC,WAAW,EAAEgC,MAAM,CAAC,IAAI,CAAC;MAC9CA;IACF,CAAC;EACH;AACF;AAEA,eAAe9B,qBAAqB","ignoreList":[]}
|
|
@@ -44,9 +44,8 @@ export default class UrlLengthAssessment extends Assessment {
|
|
|
44
44
|
if (length < 75) {
|
|
45
45
|
status = 'good';
|
|
46
46
|
}
|
|
47
|
-
const score = this.getScore(URLS_POINTS, status);
|
|
48
47
|
return {
|
|
49
|
-
score,
|
|
48
|
+
score: this.getScore(URLS_POINTS, status) || 0,
|
|
50
49
|
status
|
|
51
50
|
};
|
|
52
51
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UrlLengthAssessment.js","names":["merge","AssessmentResult","Assessment","URL_LENGTH_ID","URLS_POINTS","UrlLengthAssessment","constructor","config","defaultConfig","id","priority","docUrl","fixPosition","ctaType","title","content","good","improve","bad","identifier","_config","calculateResult","paper","status","length","getDomain","getSlug","score","getScore","getResult","researcher","calculatedResult","assessmentResult","setScore","setStatus","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/UrlLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {URL_LENGTH_ID, URLS_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks whether there are three or more consecutive sentences beginning with the same word.\n */\nexport default class UrlLengthAssessment 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: URL_LENGTH_ID,\n priority: 'high',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#url-length',\n fixPosition: 'url handle',\n ctaType: 'fix',\n title: 'URL length',\n content: {\n good: 'URL length is optimized, less than 75 characters.',\n improve: '',\n bad: 'Keep it less than 75 characters for better readability and SEO.'\n }\n };\n\n this.identifier = URL_LENGTH_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 length = paper.getDomain().length + paper.getSlug().length;\n if (length < 75) {\n status = 'good';\n }\n\n
|
|
1
|
+
{"version":3,"file":"UrlLengthAssessment.js","names":["merge","AssessmentResult","Assessment","URL_LENGTH_ID","URLS_POINTS","UrlLengthAssessment","constructor","config","defaultConfig","id","priority","docUrl","fixPosition","ctaType","title","content","good","improve","bad","identifier","_config","calculateResult","paper","status","length","getDomain","getSlug","score","getScore","getResult","researcher","calculatedResult","assessmentResult","setScore","setStatus","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/UrlLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {URL_LENGTH_ID, URLS_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks whether there are three or more consecutive sentences beginning with the same word.\n */\nexport default class UrlLengthAssessment 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: URL_LENGTH_ID,\n priority: 'high',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#url-length',\n fixPosition: 'url handle',\n ctaType: 'fix',\n title: 'URL length',\n content: {\n good: 'URL length is optimized, less than 75 characters.',\n improve: '',\n bad: 'Keep it less than 75 characters for better readability and SEO.'\n }\n };\n\n this.identifier = URL_LENGTH_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 length = paper.getDomain().length + paper.getSlug().length;\n if (length < 75) {\n status = 'good';\n }\n\n return {\n score: this.getScore(URLS_POINTS, status) || 0,\n status\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @param i18n\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 *\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,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,gBAAgB;AACvB,OAAOC,UAAU;AACjB,SAAQC,aAAa,EAAEC,WAAW;;AAElC;AACA;AACA;AACA,eAAe,MAAMC,mBAAmB,SAASH,UAAU,CAAC;EAC1D;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,aAAa;MACjBO,QAAQ,EAAE,MAAM;MAChBC,MAAM,EACJ,wFAAwF;MAC1FC,WAAW,EAAE,YAAY;MACzBC,OAAO,EAAE,KAAK;MACdC,KAAK,EAAE,YAAY;MACnBC,OAAO,EAAE;QACPC,IAAI,EAAE,mDAAmD;QACzDC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGhB,aAAa;IAC/B,IAAI,CAACiB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;EACEc,eAAeA,CAACC,KAAK,EAAE;IACrB,IAAIC,MAAM,GAAG,KAAK;IAClB,MAAMC,MAAM,GAAGF,KAAK,CAACG,SAAS,CAAC,CAAC,CAACD,MAAM,GAAGF,KAAK,CAACI,OAAO,CAAC,CAAC,CAACF,MAAM;IAChE,IAAIA,MAAM,GAAG,EAAE,EAAE;MACfD,MAAM,GAAG,MAAM;IACjB;IAEA,OAAO;MACLI,KAAK,EAAE,IAAI,CAACC,QAAQ,CAACxB,WAAW,EAAEmB,MAAM,CAAC,IAAI,CAAC;MAC9CA;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,SAASA,CAAC;IAACP,KAAK;IAAEQ;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACV,eAAe,CAACC,KAAK,CAAC;IACpD,MAAMU,gBAAgB,GAAG,IAAI/B,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErEY,gBAAgB,CAACC,QAAQ,CAACF,gBAAgB,CAACJ,KAAK,CAAC;IACjDK,gBAAgB,CAACE,SAAS,CAACH,gBAAgB,CAACR,MAAM,CAAC;IAEnD,OAAOS,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEG,YAAYA,CAACb,KAAK,EAAEQ,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;AACF","ignoreList":[]}
|
|
@@ -47,6 +47,7 @@ export default class AvadaAssessor {
|
|
|
47
47
|
this.seoAssessor.assess(paper, i18n);
|
|
48
48
|
this.contentAssessor.assess(paper, i18n);
|
|
49
49
|
let assessments = [...this.seoAssessor.results, ...this.contentAssessor.results];
|
|
50
|
+
console.log('assessments', assessments);
|
|
50
51
|
assessments = assessments.map(assessment => ({
|
|
51
52
|
...assessment.config,
|
|
52
53
|
status: assessment.status,
|
|
@@ -54,7 +55,6 @@ export default class AvadaAssessor {
|
|
|
54
55
|
data: assessment.data,
|
|
55
56
|
title: assessment.title || assessment.config.title
|
|
56
57
|
}));
|
|
57
|
-
console.log('assessments', assessments);
|
|
58
58
|
this.assessments = assessments;
|
|
59
59
|
}
|
|
60
60
|
assessBackEnd(paper) {
|
|
@@ -90,7 +90,7 @@ export default class AvadaAssessor {
|
|
|
90
90
|
getScore() {
|
|
91
91
|
let point = 0;
|
|
92
92
|
this.assessments.forEach(assessment => {
|
|
93
|
-
point += assessment.score;
|
|
93
|
+
point += assessment.score || 0;
|
|
94
94
|
});
|
|
95
95
|
return Math.round(point);
|
|
96
96
|
}
|