axyseo 2.1.22 → 2025.1.0
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/const/analysis.js +4 -40
- package/build/cjs/const/analysis.js.map +1 -1
- package/build/cjs/index.js.map +1 -1
- package/build/cjs/languageProcessing/AbstractResearcher.js +1 -3
- package/build/cjs/languageProcessing/AbstractResearcher.js.map +1 -1
- package/build/cjs/languageProcessing/helpers/image/getImagesInTree.js +2 -4
- package/build/cjs/languageProcessing/helpers/image/getImagesInTree.js.map +1 -1
- package/build/cjs/languageProcessing/researches/checkRelatedKeywords.js +1 -0
- package/build/cjs/languageProcessing/researches/checkRelatedKeywords.js.map +1 -1
- package/build/cjs/languageProcessing/researches/getKeywordDensity.js.map +1 -1
- package/build/cjs/languageProcessing/researches/imageCount.js +1 -2
- package/build/cjs/languageProcessing/researches/imageCount.js.map +1 -1
- package/build/cjs/scoring/assessments/assessment.js +6 -5
- package/build/cjs/scoring/assessments/assessment.js.map +1 -1
- package/build/cjs/scoring/assessments/index.js +8 -12
- package/build/cjs/scoring/assessments/index.js.map +1 -1
- package/build/cjs/scoring/assessments/readability/ParagraphTooLongAssessment.js +17 -18
- package/build/cjs/scoring/assessments/readability/ParagraphTooLongAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/readability/RelatedKeywordsAssessment.js +25 -11
- package/build/cjs/scoring/assessments/readability/RelatedKeywordsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/readability/SentenceBeginningsAssessment.js +1 -1
- package/build/cjs/scoring/assessments/readability/SentenceBeginningsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js +10 -11
- package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/readability/TransitionWordsAssessment.js +1 -1
- package/build/cjs/scoring/assessments/readability/TransitionWordsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/FAQsAssessment.js +52 -7
- package/build/cjs/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/ImageCountAssessment.js +2 -2
- package/build/cjs/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/ImagesInContentAssessment.js +97 -0
- package/build/cjs/scoring/assessments/seo/ImagesInContentAssessment.js.map +1 -0
- package/build/cjs/scoring/assessments/seo/InternalLinksAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/InternalLinksAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/IntroductionKeywordAssessment.js +4 -2
- package/build/cjs/scoring/assessments/seo/IntroductionKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeyphraseAssessment.js +4 -4
- package/build/cjs/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/KeywordFAQsAssessment.js +3 -3
- package/build/cjs/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/MetaDescriptionLengthAssessment.js +6 -3
- package/build/cjs/scoring/assessments/seo/MetaDescriptionLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/MetaTitleKeywordAssessment.js +2 -2
- package/build/cjs/scoring/assessments/seo/MetaTitleKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/NumberInMetaTitleAssessment.js +2 -2
- package/build/cjs/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/OutboundLinksAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/OutboundLinksAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/PageTitleWidthAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/PageTitleWidthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SchemaAssessment.js +2 -16
- package/build/cjs/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js +3 -3
- package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SingleTitleAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/SingleTitleAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +5 -3
- package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js +3 -2
- package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js +17 -52
- package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js +4 -3
- package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
- package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js +4 -2
- package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
- package/build/cjs/scoring/assessors/assessor.js +1 -0
- package/build/cjs/scoring/assessors/assessor.js.map +1 -1
- package/build/cjs/scoring/assessors/avadaAssessor.js +3 -1
- package/build/cjs/scoring/assessors/avadaAssessor.js.map +1 -1
- package/build/cjs/scoring/assessors/contentAssessor.js +1 -1
- package/build/cjs/scoring/assessors/contentAssessor.js.map +1 -1
- package/build/cjs/scoring/assessors/index.js +14 -0
- package/build/cjs/scoring/assessors/index.js.map +1 -1
- package/build/cjs/scoring/assessors/seoAssessor.js +4 -5
- package/build/cjs/scoring/assessors/seoAssessor.js.map +1 -1
- package/build/cjs/values/Paper.js +2 -10
- package/build/cjs/values/Paper.js.map +1 -1
- package/build/esm/const/analysis.js +3 -39
- package/build/esm/const/analysis.js.map +1 -1
- package/build/esm/index.js.map +1 -1
- package/build/esm/languageProcessing/AbstractResearcher.js +1 -3
- package/build/esm/languageProcessing/AbstractResearcher.js.map +1 -1
- package/build/esm/languageProcessing/helpers/image/getImagesInTree.js +2 -4
- package/build/esm/languageProcessing/helpers/image/getImagesInTree.js.map +1 -1
- package/build/esm/languageProcessing/researches/checkRelatedKeywords.js +1 -0
- package/build/esm/languageProcessing/researches/checkRelatedKeywords.js.map +1 -1
- package/build/esm/languageProcessing/researches/getKeywordDensity.js.map +1 -1
- package/build/esm/languageProcessing/researches/imageCount.js +1 -2
- package/build/esm/languageProcessing/researches/imageCount.js.map +1 -1
- package/build/esm/scoring/assessments/assessment.js +7 -6
- package/build/esm/scoring/assessments/assessment.js.map +1 -1
- package/build/esm/scoring/assessments/index.js +8 -12
- package/build/esm/scoring/assessments/index.js.map +1 -1
- package/build/esm/scoring/assessments/readability/ParagraphTooLongAssessment.js +18 -19
- package/build/esm/scoring/assessments/readability/ParagraphTooLongAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/readability/RelatedKeywordsAssessment.js +26 -12
- package/build/esm/scoring/assessments/readability/RelatedKeywordsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/readability/SentenceBeginningsAssessment.js +2 -2
- package/build/esm/scoring/assessments/readability/SentenceBeginningsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/readability/SentenceLengthInTextAssessment.js +11 -12
- package/build/esm/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/readability/TransitionWordsAssessment.js +2 -2
- package/build/esm/scoring/assessments/readability/TransitionWordsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/FAQsAssessment.js +53 -8
- package/build/esm/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/ImageCountAssessment.js +3 -3
- package/build/esm/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/ImagesInContentAssessment.js +90 -0
- package/build/esm/scoring/assessments/seo/ImagesInContentAssessment.js.map +1 -0
- package/build/esm/scoring/assessments/seo/InternalLinksAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/InternalLinksAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/IntroductionKeywordAssessment.js +5 -3
- package/build/esm/scoring/assessments/seo/IntroductionKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js +5 -5
- package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js +4 -4
- package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/MetaDescriptionLengthAssessment.js +7 -4
- package/build/esm/scoring/assessments/seo/MetaDescriptionLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/MetaTitleKeywordAssessment.js +3 -3
- package/build/esm/scoring/assessments/seo/MetaTitleKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js +3 -3
- package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/OutboundLinksAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/OutboundLinksAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/PageTitleWidthAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/PageTitleWidthAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SchemaAssessment.js +3 -17
- package/build/esm/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SingleH1Assessment.js +4 -4
- package/build/esm/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SingleTitleAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/SingleTitleAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +6 -4
- package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/TextImagesAssessment.js +4 -3
- package/build/esm/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/TextLengthAssessment.js +18 -54
- package/build/esm/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js +5 -4
- package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
- package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js +5 -3
- package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
- package/build/esm/scoring/assessors/assessor.js +1 -0
- package/build/esm/scoring/assessors/assessor.js.map +1 -1
- package/build/esm/scoring/assessors/avadaAssessor.js +4 -2
- package/build/esm/scoring/assessors/avadaAssessor.js.map +1 -1
- package/build/esm/scoring/assessors/contentAssessor.js +1 -1
- package/build/esm/scoring/assessors/contentAssessor.js.map +1 -1
- package/build/esm/scoring/assessors/index.js +2 -0
- package/build/esm/scoring/assessors/index.js.map +1 -1
- package/build/esm/scoring/assessors/seoAssessor.js +4 -5
- package/build/esm/scoring/assessors/seoAssessor.js.map +1 -1
- package/build/esm/values/Paper.js +2 -10
- package/build/esm/values/Paper.js.map +1 -1
- package/package.json +5 -3
- package/build/cjs/languageProcessing/researches/charactersInUrl.js +0 -26
- package/build/cjs/languageProcessing/researches/charactersInUrl.js.map +0 -1
- package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js +0 -83
- package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +0 -1
- package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js +0 -93
- package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js.map +0 -1
- package/build/cjs/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js +0 -103
- package/build/cjs/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js.map +0 -1
- package/build/esm/languageProcessing/researches/charactersInUrl.js +0 -21
- package/build/esm/languageProcessing/researches/charactersInUrl.js.map +0 -1
- package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js +0 -76
- package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +0 -1
- package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js +0 -87
- package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js.map +0 -1
- package/build/esm/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js +0 -96
- package/build/esm/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js.map +0 -1
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _lodash = require("lodash");
|
|
8
|
-
var _AssessmentResult = _interopRequireDefault(require("../../../values/AssessmentResult"));
|
|
9
|
-
var _assessment = _interopRequireDefault(require("../assessment"));
|
|
10
|
-
var _analysis = require("../../../const/analysis");
|
|
11
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
|
-
/**
|
|
13
|
-
* Represents the assessment that checks whether there are enough transition words in the text.
|
|
14
|
-
*/
|
|
15
|
-
class RelatedKeywordsDensityAssessment extends _assessment.default {
|
|
16
|
-
/**
|
|
17
|
-
* Sets the identifier and the config.
|
|
18
|
-
*
|
|
19
|
-
* @param {object} config The configuration to use.
|
|
20
|
-
*
|
|
21
|
-
* @returns {void}
|
|
22
|
-
*/
|
|
23
|
-
constructor(config = {}) {
|
|
24
|
-
super();
|
|
25
|
-
const defaultConfig = {
|
|
26
|
-
id: _analysis.RELATED_KEYWORDS_DENSITY_ID,
|
|
27
|
-
fixPosition: 'description',
|
|
28
|
-
ctaType: 'fix',
|
|
29
|
-
docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#related-keywords',
|
|
30
|
-
priority: 'high',
|
|
31
|
-
title: 'Related keywords density',
|
|
32
|
-
content: {
|
|
33
|
-
good: 'Related keywords density optimized',
|
|
34
|
-
bad: 'Use each secondary keyword from 0.5% to 1%. Place where it reads naturally.',
|
|
35
|
-
improve: ''
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
this.identifier = _analysis.RELATED_KEYWORDS_DENSITY_ID;
|
|
39
|
-
this._config = (0, _lodash.merge)(defaultConfig, config);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
*
|
|
44
|
-
* @param data
|
|
45
|
-
* @param relatedKeywords
|
|
46
|
-
* @param hasDescription
|
|
47
|
-
* @returns {{score: number, status: string, words}}
|
|
48
|
-
*/
|
|
49
|
-
calculateResult(data, relatedKeywords, hasDescription) {
|
|
50
|
-
const {
|
|
51
|
-
words
|
|
52
|
-
} = relatedKeywords;
|
|
53
|
-
let status = 'good';
|
|
54
|
-
const totalWords = Object.values(words).filter(word => word.percentage === 0);
|
|
55
|
-
if (!hasDescription || (0, _lodash.isEmpty)(words) || totalWords.length > 0) {
|
|
56
|
-
status = 'bad';
|
|
57
|
-
}
|
|
58
|
-
const score = this.getScore(_analysis.MAIN_CONTENT_POINTS, status);
|
|
59
|
-
return {
|
|
60
|
-
score,
|
|
61
|
-
status,
|
|
62
|
-
words
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
*
|
|
68
|
-
* @param paper
|
|
69
|
-
* @param researcher
|
|
70
|
-
* @returns {AssessmentResult}
|
|
71
|
-
*/
|
|
72
|
-
getResult({
|
|
73
|
-
paper,
|
|
74
|
-
researcher
|
|
75
|
-
}) {
|
|
76
|
-
const relatedKeywords = researcher.getResearch('checkRelatedKeywords');
|
|
77
|
-
const data = paper.getData();
|
|
78
|
-
const hasDescription = paper.hasDescription();
|
|
79
|
-
const result = this.calculateResult(data, relatedKeywords, hasDescription);
|
|
80
|
-
const assessmentResult = new _AssessmentResult.default({
|
|
81
|
-
config: this._config
|
|
82
|
-
});
|
|
83
|
-
assessmentResult.setScore(result.score);
|
|
84
|
-
assessmentResult.setStatus(result.status);
|
|
85
|
-
assessmentResult.setData(result.words);
|
|
86
|
-
return assessmentResult;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* Checks if the transition words assessment is applicable to the paper. Language-specific length requirements and methods of counting text length
|
|
91
|
-
* may apply (e.g. for Japanese, the text should be counted in characters instead of words, which also makes the minimum required length higher).
|
|
92
|
-
*
|
|
93
|
-
* @param {Paper} paper The paper to check.
|
|
94
|
-
* @param {Researcher} researcher The researcher object.
|
|
95
|
-
*
|
|
96
|
-
* @returns {boolean} Returns true if the language is available, the paper is not empty and the text is longer than the minimum required length.
|
|
97
|
-
*/
|
|
98
|
-
isApplicable(paper, researcher) {
|
|
99
|
-
return true;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
exports.default = RelatedKeywordsDensityAssessment;
|
|
103
|
-
//# sourceMappingURL=RelatedKeywordsDensityAssessment.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RelatedKeywordsDensityAssessment.js","names":["_lodash","require","_AssessmentResult","_interopRequireDefault","_assessment","_analysis","e","__esModule","default","RelatedKeywordsDensityAssessment","Assessment","constructor","config","defaultConfig","id","RELATED_KEYWORDS_DENSITY_ID","fixPosition","ctaType","docUrl","priority","title","content","good","bad","improve","identifier","_config","merge","calculateResult","data","relatedKeywords","hasDescription","words","status","totalWords","Object","values","filter","word","percentage","isEmpty","length","score","getScore","MAIN_CONTENT_POINTS","getResult","paper","researcher","getResearch","getData","result","assessmentResult","AssessmentResult","setScore","setStatus","setData","isApplicable","exports"],"sources":["../../../../../src/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js"],"sourcesContent":["import {isEmpty, merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {MAIN_CONTENT_POINTS, RELATED_KEYWORDS_DENSITY_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks whether there are enough transition words in the text.\n */\nexport default class RelatedKeywordsDensityAssessment 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: RELATED_KEYWORDS_DENSITY_ID,\n fixPosition: 'description',\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#related-keywords',\n priority: 'high',\n title: 'Related keywords density',\n content: {\n good: 'Related keywords density optimized',\n bad:\n 'Use each secondary keyword from 0.5% to 1%. Place where it reads naturally.',\n improve: ''\n }\n };\n\n this.identifier = RELATED_KEYWORDS_DENSITY_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n *\n * @param data\n * @param relatedKeywords\n * @param hasDescription\n * @returns {{score: number, status: string, words}}\n */\n calculateResult(data, relatedKeywords, hasDescription) {\n const {words} = relatedKeywords;\n let status = 'good';\n\n const totalWords = Object.values(words).filter(word => word.percentage === 0);\n if(!hasDescription || isEmpty(words) || totalWords.length > 0){\n status = 'bad';\n }\n const score = this.getScore(MAIN_CONTENT_POINTS, status);\n\n return {\n score,\n status,\n words\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @returns {AssessmentResult}\n */\n getResult({paper, researcher}) {\n const relatedKeywords = researcher.getResearch('checkRelatedKeywords');\n const data = paper.getData();\n const hasDescription = paper.hasDescription();\n const result = this.calculateResult(data, relatedKeywords, hasDescription);\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(result.score);\n assessmentResult.setStatus(result.status);\n assessmentResult.setData(result.words);\n\n return assessmentResult;\n }\n\n /**\n * Checks if the transition words assessment is applicable to the paper. Language-specific length requirements and methods of counting text length\n * may apply (e.g. for Japanese, the text should be counted in characters instead of words, which also makes the minimum required length higher).\n *\n * @param {Paper} paper The paper to check.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} Returns true if the language is available, the paper is not empty and the text is longer than the minimum required length.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,WAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,SAAA,GAAAJ,OAAA;AAAwF,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAExF;AACA;AACA;AACe,MAAMG,gCAAgC,SAASC,mBAAU,CAAC;EACvE;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEC,qCAA2B;MAC/BC,WAAW,EAAE,aAAa;MAC1BC,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,8FAA8F;MAChGC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,0BAA0B;MACjCC,OAAO,EAAE;QACPC,IAAI,EAAE,oCAAoC;QAC1CC,GAAG,EACD,6EAA6E;QAC/EC,OAAO,EAAE;MACX;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGV,qCAA2B;IAC7C,IAAI,CAACW,OAAO,GAAG,IAAAC,aAAK,EAACd,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEgB,eAAeA,CAACC,IAAI,EAAEC,eAAe,EAAEC,cAAc,EAAE;IACrD,MAAM;MAACC;IAAK,CAAC,GAAGF,eAAe;IAC/B,IAAIG,MAAM,GAAG,MAAM;IAEnB,MAAMC,UAAU,GAAGC,MAAM,CAACC,MAAM,CAACJ,KAAK,CAAC,CAACK,MAAM,CAACC,IAAI,IAAIA,IAAI,CAACC,UAAU,KAAK,CAAC,CAAC;IAC7E,IAAG,CAACR,cAAc,IAAI,IAAAS,eAAO,EAACR,KAAK,CAAC,IAAIE,UAAU,CAACO,MAAM,GAAG,CAAC,EAAC;MAC5DR,MAAM,GAAG,KAAK;IAChB;IACA,MAAMS,KAAK,GAAG,IAAI,CAACC,QAAQ,CAACC,6BAAmB,EAAEX,MAAM,CAAC;IAExD,OAAO;MACLS,KAAK;MACLT,MAAM;MACND;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEa,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMjB,eAAe,GAAGiB,UAAU,CAACC,WAAW,CAAC,sBAAsB,CAAC;IACtE,MAAMnB,IAAI,GAAGiB,KAAK,CAACG,OAAO,CAAC,CAAC;IAC5B,MAAMlB,cAAc,GAAGe,KAAK,CAACf,cAAc,CAAC,CAAC;IAC7C,MAAMmB,MAAM,GAAG,IAAI,CAACtB,eAAe,CAACC,IAAI,EAAEC,eAAe,EAAEC,cAAc,CAAC;IAC1E,MAAMoB,gBAAgB,GAAG,IAAIC,yBAAgB,CAAC;MAACxC,MAAM,EAAE,IAAI,CAACc;IAAO,CAAC,CAAC;IAErEyB,gBAAgB,CAACE,QAAQ,CAACH,MAAM,CAACR,KAAK,CAAC;IACvCS,gBAAgB,CAACG,SAAS,CAACJ,MAAM,CAACjB,MAAM,CAAC;IACzCkB,gBAAgB,CAACI,OAAO,CAACL,MAAM,CAAClB,KAAK,CAAC;IAEtC,OAAOmB,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEK,YAAYA,CAACV,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;AACF;AAACU,OAAA,CAAAjD,OAAA,GAAAC,gCAAA","ignoreList":[]}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
/** @module researches/charactersInUrl */
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Checks if the URL contains invalid characters (characters not in a-z or 0-9).
|
|
5
|
-
*
|
|
6
|
-
* @param {Paper} paper the Paper object to use in this count.
|
|
7
|
-
*
|
|
8
|
-
* @returns {{isInvalidCharacters: boolean}} Object indicating if the URL contains invalid characters.
|
|
9
|
-
*/
|
|
10
|
-
function charactersInUrl(paper) {
|
|
11
|
-
const slug = paper.getSlug() || '';
|
|
12
|
-
const newSlug = new URL(slug).pathname.split('/').pop();
|
|
13
|
-
// Check if slug contains any characters that are NOT in a-z or 0-9
|
|
14
|
-
// Regex matches any character that is NOT lowercase letter (a-z) or digit (0-9)
|
|
15
|
-
const hasInvalidCharacters = /[^a-z0-9-]/.test(newSlug);
|
|
16
|
-
return {
|
|
17
|
-
isInvalidCharacters: hasInvalidCharacters
|
|
18
|
-
};
|
|
19
|
-
}
|
|
20
|
-
export { charactersInUrl };
|
|
21
|
-
//# sourceMappingURL=charactersInUrl.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"charactersInUrl.js","names":["charactersInUrl","paper","slug","getSlug","newSlug","URL","pathname","split","pop","hasInvalidCharacters","test","isInvalidCharacters"],"sources":["../../../../src/languageProcessing/researches/charactersInUrl.js"],"sourcesContent":["/** @module researches/charactersInUrl */\n\n/**\n * Checks if the URL contains invalid characters (characters not in a-z or 0-9).\n *\n * @param {Paper} paper the Paper object to use in this count.\n *\n * @returns {{isInvalidCharacters: boolean}} Object indicating if the URL contains invalid characters.\n */\nfunction charactersInUrl(paper) {\n const slug = paper.getSlug() || '';\n const newSlug = new URL(slug).pathname.split('/').pop();\n // Check if slug contains any characters that are NOT in a-z or 0-9\n // Regex matches any character that is NOT lowercase letter (a-z) or digit (0-9)\n const hasInvalidCharacters = /[^a-z0-9-]/.test(newSlug);\n return {\n isInvalidCharacters: hasInvalidCharacters\n };\n}\n\nexport {charactersInUrl};\n"],"mappings":"AAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAASA,eAAeA,CAACC,KAAK,EAAE;EAC9B,MAAMC,IAAI,GAAGD,KAAK,CAACE,OAAO,CAAC,CAAC,IAAI,EAAE;EAClC,MAAMC,OAAO,GAAG,IAAIC,GAAG,CAACH,IAAI,CAAC,CAACI,QAAQ,CAACC,KAAK,CAAC,GAAG,CAAC,CAACC,GAAG,CAAC,CAAC;EACvD;EACA;EACA,MAAMC,oBAAoB,GAAG,YAAY,CAACC,IAAI,CAACN,OAAO,CAAC;EACvD,OAAO;IACLO,mBAAmB,EAAEF;EACvB,CAAC;AACH;AAEA,SAAQT,eAAe","ignoreList":[]}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import { merge } from 'lodash';
|
|
2
|
-
import Assessment from "../assessment";
|
|
3
|
-
import AssessmentResult from "../../../values/AssessmentResult";
|
|
4
|
-
import { FAQS_POINTS, FAQs_STRUCTURE_DATA_ID } from "../../../const/analysis";
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Represents an assessment that checks FAQs content and structure for SGE optimization.
|
|
8
|
-
*/
|
|
9
|
-
export default class FAQsStructureDataAssessment extends Assessment {
|
|
10
|
-
/**
|
|
11
|
-
* Sets the identifier and the config.
|
|
12
|
-
*
|
|
13
|
-
* @param {Object} [config] The configuration to use.
|
|
14
|
-
*
|
|
15
|
-
* @returns {void}
|
|
16
|
-
*/
|
|
17
|
-
constructor(config = {}) {
|
|
18
|
-
super();
|
|
19
|
-
const defaultConfig = {
|
|
20
|
-
id: FAQs_STRUCTURE_DATA_ID,
|
|
21
|
-
ctaType: 'fix',
|
|
22
|
-
docUrl: 'https://blog.google/products/search/generative-ai-search/',
|
|
23
|
-
priority: 'high',
|
|
24
|
-
fixPosition: 'faqs',
|
|
25
|
-
title: 'FAQs structured data',
|
|
26
|
-
content: {
|
|
27
|
-
good: 'FAQ structured data added',
|
|
28
|
-
improve: '',
|
|
29
|
-
bad: 'Add FAQs structured data for Google rich results eligibility.'
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
this.identifier = FAQs_STRUCTURE_DATA_ID;
|
|
33
|
-
this._config = merge(defaultConfig, config);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* Executes the Assessment and returns a result.
|
|
38
|
-
*
|
|
39
|
-
* @param {Paper} paper The Paper object to assess.
|
|
40
|
-
* @param {Researcher} researcher The Researcher object containing all available researches.
|
|
41
|
-
*
|
|
42
|
-
* @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.
|
|
43
|
-
*/
|
|
44
|
-
getResult({
|
|
45
|
-
paper,
|
|
46
|
-
researcher
|
|
47
|
-
}) {
|
|
48
|
-
const calculatedResult = this.calculateResult(paper);
|
|
49
|
-
const assessmentResult = new AssessmentResult({
|
|
50
|
-
config: this._config
|
|
51
|
-
});
|
|
52
|
-
assessmentResult.setScore(calculatedResult.score);
|
|
53
|
-
assessmentResult.setStatus(calculatedResult.status);
|
|
54
|
-
return assessmentResult;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
*
|
|
59
|
-
* @param paper
|
|
60
|
-
* @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}
|
|
61
|
-
*/
|
|
62
|
-
calculateResult(paper) {
|
|
63
|
-
// Check FAQ structure and content
|
|
64
|
-
const hasSchema = paper.hasFAQsSchema();
|
|
65
|
-
const status = hasSchema ? 'good' : 'bad';
|
|
66
|
-
const score = this.getScore(FAQS_POINTS, status);
|
|
67
|
-
return {
|
|
68
|
-
score,
|
|
69
|
-
status
|
|
70
|
-
};
|
|
71
|
-
}
|
|
72
|
-
isApplicable(paper) {
|
|
73
|
-
return true;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
//# sourceMappingURL=FAQsStructureDataAssessment.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"FAQsStructureDataAssessment.js","names":["merge","Assessment","AssessmentResult","FAQS_POINTS","FAQs_STRUCTURE_DATA_ID","FAQsStructureDataAssessment","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","hasSchema","hasFAQsSchema","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/FAQsStructureDataAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {FAQS_POINTS, FAQs_STRUCTURE_DATA_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks FAQs content and structure for SGE optimization.\n */\nexport default class FAQsStructureDataAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: FAQs_STRUCTURE_DATA_ID,\n ctaType: 'fix',\n docUrl: 'https://blog.google/products/search/generative-ai-search/',\n priority: 'high',\n fixPosition: 'faqs',\n title: 'FAQs structured data',\n content: {\n good: 'FAQ structured data added',\n improve: '',\n bad: 'Add FAQs structured data for Google rich results eligibility.',\n }\n };\n\n this.identifier = FAQs_STRUCTURE_DATA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string, data: {hasSchema: ((function(): *)|boolean), hasProperStructure: boolean, hasMinimumFAQs: boolean}}|{score: number, status: string, data: {hasFAQs: boolean}}}\n */\n calculateResult(paper) {\n // Check FAQ structure and content\n const hasSchema = paper.hasFAQsSchema();\n const status = hasSchema ? 'good' : 'bad';\n const score = this.getScore(FAQS_POINTS, status);\n return {\n score,\n status\n };\n }\n\n\n\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,sBAAsB;;AAE3C;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,sBAAsB;MAC1BM,OAAO,EAAE,KAAK;MACdC,MAAM,EAAE,2DAA2D;MACnEC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,MAAM;MACnBC,KAAK,EAAE,sBAAsB;MAC7BC,OAAO,EAAE;QACPC,IAAI,EAAE,2BAA2B;QACjCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,sBAAsB;IACxC,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;IACpD,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;IACnD,OAAOJ,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB;IACA,MAAMS,SAAS,GAAGT,KAAK,CAACU,aAAa,CAAC,CAAC;IACvC,MAAMF,MAAM,GAAGC,SAAS,GAAG,MAAM,GAAG,KAAK;IAC1C,MAAMH,KAAK,GAAG,IAAI,CAACK,QAAQ,CAAC9B,WAAW,EAAE2B,MAAM,CAAC;IAC/C,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;EAKAI,YAAYA,CAACZ,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF","ignoreList":[]}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
import { merge } from 'lodash';
|
|
2
|
-
import Assessment from "../assessment";
|
|
3
|
-
import AssessmentResult from "../../../values/AssessmentResult";
|
|
4
|
-
import { CHARACTERS_URL, URLS_POINTS } from "../../../const/analysis";
|
|
5
|
-
import { enhanceResearcherForChinese } from "../../../languageProcessing/helpers/language/chineseHelperFactory";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.
|
|
9
|
-
*/
|
|
10
|
-
class InvalidCharactersInUrl extends Assessment {
|
|
11
|
-
/**
|
|
12
|
-
* Sets the identifier and the config.
|
|
13
|
-
*
|
|
14
|
-
* @param {Object} config The configuration to use.
|
|
15
|
-
* @returns {void}
|
|
16
|
-
*/
|
|
17
|
-
constructor(config = {}) {
|
|
18
|
-
super();
|
|
19
|
-
const defaultConfig = {
|
|
20
|
-
id: CHARACTERS_URL,
|
|
21
|
-
docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-url',
|
|
22
|
-
fixPosition: 'url handle',
|
|
23
|
-
ctaType: 'fix',
|
|
24
|
-
priority: 'medium',
|
|
25
|
-
title: 'Invalid characters in URL',
|
|
26
|
-
content: {
|
|
27
|
-
good: 'URL characters valid',
|
|
28
|
-
improve: '',
|
|
29
|
-
bad: 'Use only lowercase letters, numbers, and hyphens.'
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
this.identifier = CHARACTERS_URL;
|
|
33
|
-
this._config = merge(defaultConfig, config);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* Executes the Assessment and returns a result.
|
|
38
|
-
*
|
|
39
|
-
* @param {Paper} paper The Paper object to assess.
|
|
40
|
-
* @param {Researcher} researcher The Researcher object containing all available researches.
|
|
41
|
-
*
|
|
42
|
-
* @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.
|
|
43
|
-
*/
|
|
44
|
-
getResult({
|
|
45
|
-
paper,
|
|
46
|
-
researcher
|
|
47
|
-
}) {
|
|
48
|
-
// Enhance researcher for Chinese if needed - specifically for URL context
|
|
49
|
-
const enhancedResearcher = enhanceResearcherForChinese(researcher, paper.getSlug(), paper.getKeyword(), true // isUrlContext = true for enhanced Chinese URL matching
|
|
50
|
-
);
|
|
51
|
-
this._charactersInUrl = enhancedResearcher.getResearch('charactersInUrl');
|
|
52
|
-
const assessmentResult = new AssessmentResult({
|
|
53
|
-
config: this._config
|
|
54
|
-
});
|
|
55
|
-
const calculatedResult = this.calculateResult();
|
|
56
|
-
assessmentResult.setScore(calculatedResult.score);
|
|
57
|
-
assessmentResult.setStatus(calculatedResult.status);
|
|
58
|
-
return assessmentResult;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Checks whether the paper has a keyword and a slug.
|
|
63
|
-
*
|
|
64
|
-
* @param {Paper} paper The paper to use for the assessment.
|
|
65
|
-
* @param {Researcher} researcher The researcher object.
|
|
66
|
-
*
|
|
67
|
-
* @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.
|
|
68
|
-
*/
|
|
69
|
-
isApplicable(paper, researcher) {
|
|
70
|
-
return true;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
*
|
|
75
|
-
* @returns {{score: number, status: (string)}}
|
|
76
|
-
*/
|
|
77
|
-
calculateResult() {
|
|
78
|
-
const status = this._charactersInUrl.isInvalidCharacters ? 'bad' : 'good';
|
|
79
|
-
const score = this.getScore(URLS_POINTS, status);
|
|
80
|
-
return {
|
|
81
|
-
score,
|
|
82
|
-
status
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
export default InvalidCharactersInUrl;
|
|
87
|
-
//# sourceMappingURL=InvalidCharactersInUrl.js.map
|
|
@@ -1 +0,0 @@
|
|
|
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,CAACR,gBAAgB,CAACU,mBAAmB,GAAG,KAAK,GAAG,MAAM;IACzE,MAAMJ,KAAK,GAAG,IAAI,CAACK,QAAQ,CAACnC,WAAW,EAAGgC,MAAM,CAAC;IAEjD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAEA,eAAe9B,sBAAsB","ignoreList":[]}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { isEmpty, merge } from 'lodash';
|
|
2
|
-
import AssessmentResult from "../../../values/AssessmentResult";
|
|
3
|
-
import Assessment from "../assessment";
|
|
4
|
-
import { MAIN_CONTENT_POINTS, RELATED_KEYWORDS_DENSITY_ID } from "../../../const/analysis";
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Represents the assessment that checks whether there are enough transition words in the text.
|
|
8
|
-
*/
|
|
9
|
-
export default class RelatedKeywordsDensityAssessment extends Assessment {
|
|
10
|
-
/**
|
|
11
|
-
* Sets the identifier and the config.
|
|
12
|
-
*
|
|
13
|
-
* @param {object} config The configuration to use.
|
|
14
|
-
*
|
|
15
|
-
* @returns {void}
|
|
16
|
-
*/
|
|
17
|
-
constructor(config = {}) {
|
|
18
|
-
super();
|
|
19
|
-
const defaultConfig = {
|
|
20
|
-
id: RELATED_KEYWORDS_DENSITY_ID,
|
|
21
|
-
fixPosition: 'description',
|
|
22
|
-
ctaType: 'fix',
|
|
23
|
-
docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#related-keywords',
|
|
24
|
-
priority: 'high',
|
|
25
|
-
title: 'Related keywords density',
|
|
26
|
-
content: {
|
|
27
|
-
good: 'Related keywords density optimized',
|
|
28
|
-
bad: 'Use each secondary keyword from 0.5% to 1%. Place where it reads naturally.',
|
|
29
|
-
improve: ''
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
this.identifier = RELATED_KEYWORDS_DENSITY_ID;
|
|
33
|
-
this._config = merge(defaultConfig, config);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
*
|
|
38
|
-
* @param data
|
|
39
|
-
* @param relatedKeywords
|
|
40
|
-
* @param hasDescription
|
|
41
|
-
* @returns {{score: number, status: string, words}}
|
|
42
|
-
*/
|
|
43
|
-
calculateResult(data, relatedKeywords, hasDescription) {
|
|
44
|
-
const {
|
|
45
|
-
words
|
|
46
|
-
} = relatedKeywords;
|
|
47
|
-
let status = 'good';
|
|
48
|
-
const totalWords = Object.values(words).filter(word => word.percentage === 0);
|
|
49
|
-
if (!hasDescription || isEmpty(words) || totalWords.length > 0) {
|
|
50
|
-
status = 'bad';
|
|
51
|
-
}
|
|
52
|
-
const score = this.getScore(MAIN_CONTENT_POINTS, status);
|
|
53
|
-
return {
|
|
54
|
-
score,
|
|
55
|
-
status,
|
|
56
|
-
words
|
|
57
|
-
};
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
*
|
|
62
|
-
* @param paper
|
|
63
|
-
* @param researcher
|
|
64
|
-
* @returns {AssessmentResult}
|
|
65
|
-
*/
|
|
66
|
-
getResult({
|
|
67
|
-
paper,
|
|
68
|
-
researcher
|
|
69
|
-
}) {
|
|
70
|
-
const relatedKeywords = researcher.getResearch('checkRelatedKeywords');
|
|
71
|
-
const data = paper.getData();
|
|
72
|
-
const hasDescription = paper.hasDescription();
|
|
73
|
-
const result = this.calculateResult(data, relatedKeywords, hasDescription);
|
|
74
|
-
const assessmentResult = new AssessmentResult({
|
|
75
|
-
config: this._config
|
|
76
|
-
});
|
|
77
|
-
assessmentResult.setScore(result.score);
|
|
78
|
-
assessmentResult.setStatus(result.status);
|
|
79
|
-
assessmentResult.setData(result.words);
|
|
80
|
-
return assessmentResult;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/**
|
|
84
|
-
* Checks if the transition words assessment is applicable to the paper. Language-specific length requirements and methods of counting text length
|
|
85
|
-
* may apply (e.g. for Japanese, the text should be counted in characters instead of words, which also makes the minimum required length higher).
|
|
86
|
-
*
|
|
87
|
-
* @param {Paper} paper The paper to check.
|
|
88
|
-
* @param {Researcher} researcher The researcher object.
|
|
89
|
-
*
|
|
90
|
-
* @returns {boolean} Returns true if the language is available, the paper is not empty and the text is longer than the minimum required length.
|
|
91
|
-
*/
|
|
92
|
-
isApplicable(paper, researcher) {
|
|
93
|
-
return true;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
//# sourceMappingURL=RelatedKeywordsDensityAssessment.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RelatedKeywordsDensityAssessment.js","names":["isEmpty","merge","AssessmentResult","Assessment","MAIN_CONTENT_POINTS","RELATED_KEYWORDS_DENSITY_ID","RelatedKeywordsDensityAssessment","constructor","config","defaultConfig","id","fixPosition","ctaType","docUrl","priority","title","content","good","bad","improve","identifier","_config","calculateResult","data","relatedKeywords","hasDescription","words","status","totalWords","Object","values","filter","word","percentage","length","score","getScore","getResult","paper","researcher","getResearch","getData","result","assessmentResult","setScore","setStatus","setData","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js"],"sourcesContent":["import {isEmpty, merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {MAIN_CONTENT_POINTS, RELATED_KEYWORDS_DENSITY_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks whether there are enough transition words in the text.\n */\nexport default class RelatedKeywordsDensityAssessment 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: RELATED_KEYWORDS_DENSITY_ID,\n fixPosition: 'description',\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#related-keywords',\n priority: 'high',\n title: 'Related keywords density',\n content: {\n good: 'Related keywords density optimized',\n bad:\n 'Use each secondary keyword from 0.5% to 1%. Place where it reads naturally.',\n improve: ''\n }\n };\n\n this.identifier = RELATED_KEYWORDS_DENSITY_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n *\n * @param data\n * @param relatedKeywords\n * @param hasDescription\n * @returns {{score: number, status: string, words}}\n */\n calculateResult(data, relatedKeywords, hasDescription) {\n const {words} = relatedKeywords;\n let status = 'good';\n\n const totalWords = Object.values(words).filter(word => word.percentage === 0);\n if(!hasDescription || isEmpty(words) || totalWords.length > 0){\n status = 'bad';\n }\n const score = this.getScore(MAIN_CONTENT_POINTS, status);\n\n return {\n score,\n status,\n words\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @returns {AssessmentResult}\n */\n getResult({paper, researcher}) {\n const relatedKeywords = researcher.getResearch('checkRelatedKeywords');\n const data = paper.getData();\n const hasDescription = paper.hasDescription();\n const result = this.calculateResult(data, relatedKeywords, hasDescription);\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(result.score);\n assessmentResult.setStatus(result.status);\n assessmentResult.setData(result.words);\n\n return assessmentResult;\n }\n\n /**\n * Checks if the transition words assessment is applicable to the paper. Language-specific length requirements and methods of counting text length\n * may apply (e.g. for Japanese, the text should be counted in characters instead of words, which also makes the minimum required length higher).\n *\n * @param {Paper} paper The paper to check.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} Returns true if the language is available, the paper is not empty and the text is longer than the minimum required length.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n}\n"],"mappings":"AAAA,SAAQA,OAAO,EAAEC,KAAK,QAAO,QAAQ;AACrC,OAAOC,gBAAgB;AACvB,OAAOC,UAAU;AACjB,SAAQC,mBAAmB,EAAEC,2BAA2B;;AAExD;AACA;AACA;AACA,eAAe,MAAMC,gCAAgC,SAASH,UAAU,CAAC;EACvE;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,2BAA2B;MAC/BM,WAAW,EAAE,aAAa;MAC1BC,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,8FAA8F;MAChGC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,0BAA0B;MACjCC,OAAO,EAAE;QACPC,IAAI,EAAE,oCAAoC;QAC1CC,GAAG,EACD,6EAA6E;QAC/EC,OAAO,EAAE;MACX;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,2BAA2B;IAC7C,IAAI,CAACgB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,eAAeA,CAACC,IAAI,EAAEC,eAAe,EAAEC,cAAc,EAAE;IACrD,MAAM;MAACC;IAAK,CAAC,GAAGF,eAAe;IAC/B,IAAIG,MAAM,GAAG,MAAM;IAEnB,MAAMC,UAAU,GAAGC,MAAM,CAACC,MAAM,CAACJ,KAAK,CAAC,CAACK,MAAM,CAACC,IAAI,IAAIA,IAAI,CAACC,UAAU,KAAK,CAAC,CAAC;IAC7E,IAAG,CAACR,cAAc,IAAIzB,OAAO,CAAC0B,KAAK,CAAC,IAAIE,UAAU,CAACM,MAAM,GAAG,CAAC,EAAC;MAC5DP,MAAM,GAAG,KAAK;IAChB;IACA,MAAMQ,KAAK,GAAG,IAAI,CAACC,QAAQ,CAAChC,mBAAmB,EAAEuB,MAAM,CAAC;IAExD,OAAO;MACLQ,KAAK;MACLR,MAAM;MACND;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEW,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMf,eAAe,GAAGe,UAAU,CAACC,WAAW,CAAC,sBAAsB,CAAC;IACtE,MAAMjB,IAAI,GAAGe,KAAK,CAACG,OAAO,CAAC,CAAC;IAC5B,MAAMhB,cAAc,GAAGa,KAAK,CAACb,cAAc,CAAC,CAAC;IAC7C,MAAMiB,MAAM,GAAG,IAAI,CAACpB,eAAe,CAACC,IAAI,EAAEC,eAAe,EAAEC,cAAc,CAAC;IAC1E,MAAMkB,gBAAgB,GAAG,IAAIzC,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErEsB,gBAAgB,CAACC,QAAQ,CAACF,MAAM,CAACP,KAAK,CAAC;IACvCQ,gBAAgB,CAACE,SAAS,CAACH,MAAM,CAACf,MAAM,CAAC;IACzCgB,gBAAgB,CAACG,OAAO,CAACJ,MAAM,CAAChB,KAAK,CAAC;IAEtC,OAAOiB,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEI,YAAYA,CAACT,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;AACF","ignoreList":[]}
|