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.
Files changed (185) hide show
  1. package/build/cjs/const/analysis.js +4 -40
  2. package/build/cjs/const/analysis.js.map +1 -1
  3. package/build/cjs/index.js.map +1 -1
  4. package/build/cjs/languageProcessing/AbstractResearcher.js +1 -3
  5. package/build/cjs/languageProcessing/AbstractResearcher.js.map +1 -1
  6. package/build/cjs/languageProcessing/helpers/image/getImagesInTree.js +2 -4
  7. package/build/cjs/languageProcessing/helpers/image/getImagesInTree.js.map +1 -1
  8. package/build/cjs/languageProcessing/researches/checkRelatedKeywords.js +1 -0
  9. package/build/cjs/languageProcessing/researches/checkRelatedKeywords.js.map +1 -1
  10. package/build/cjs/languageProcessing/researches/getKeywordDensity.js.map +1 -1
  11. package/build/cjs/languageProcessing/researches/imageCount.js +1 -2
  12. package/build/cjs/languageProcessing/researches/imageCount.js.map +1 -1
  13. package/build/cjs/scoring/assessments/assessment.js +6 -5
  14. package/build/cjs/scoring/assessments/assessment.js.map +1 -1
  15. package/build/cjs/scoring/assessments/index.js +8 -12
  16. package/build/cjs/scoring/assessments/index.js.map +1 -1
  17. package/build/cjs/scoring/assessments/readability/ParagraphTooLongAssessment.js +17 -18
  18. package/build/cjs/scoring/assessments/readability/ParagraphTooLongAssessment.js.map +1 -1
  19. package/build/cjs/scoring/assessments/readability/RelatedKeywordsAssessment.js +25 -11
  20. package/build/cjs/scoring/assessments/readability/RelatedKeywordsAssessment.js.map +1 -1
  21. package/build/cjs/scoring/assessments/readability/SentenceBeginningsAssessment.js +1 -1
  22. package/build/cjs/scoring/assessments/readability/SentenceBeginningsAssessment.js.map +1 -1
  23. package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js +10 -11
  24. package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
  25. package/build/cjs/scoring/assessments/readability/TransitionWordsAssessment.js +1 -1
  26. package/build/cjs/scoring/assessments/readability/TransitionWordsAssessment.js.map +1 -1
  27. package/build/cjs/scoring/assessments/seo/FAQsAssessment.js +52 -7
  28. package/build/cjs/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
  29. package/build/cjs/scoring/assessments/seo/ImageCountAssessment.js +2 -2
  30. package/build/cjs/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
  31. package/build/cjs/scoring/assessments/seo/ImagesInContentAssessment.js +97 -0
  32. package/build/cjs/scoring/assessments/seo/ImagesInContentAssessment.js.map +1 -0
  33. package/build/cjs/scoring/assessments/seo/InternalLinksAssessment.js +5 -3
  34. package/build/cjs/scoring/assessments/seo/InternalLinksAssessment.js.map +1 -1
  35. package/build/cjs/scoring/assessments/seo/IntroductionKeywordAssessment.js +4 -2
  36. package/build/cjs/scoring/assessments/seo/IntroductionKeywordAssessment.js.map +1 -1
  37. package/build/cjs/scoring/assessments/seo/KeyphraseAssessment.js +4 -4
  38. package/build/cjs/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
  39. package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js +5 -3
  40. package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
  41. package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js +5 -3
  42. package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
  43. package/build/cjs/scoring/assessments/seo/KeywordFAQsAssessment.js +3 -3
  44. package/build/cjs/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
  45. package/build/cjs/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js +5 -3
  46. package/build/cjs/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js.map +1 -1
  47. package/build/cjs/scoring/assessments/seo/MetaDescriptionLengthAssessment.js +6 -3
  48. package/build/cjs/scoring/assessments/seo/MetaDescriptionLengthAssessment.js.map +1 -1
  49. package/build/cjs/scoring/assessments/seo/MetaTitleKeywordAssessment.js +2 -2
  50. package/build/cjs/scoring/assessments/seo/MetaTitleKeywordAssessment.js.map +1 -1
  51. package/build/cjs/scoring/assessments/seo/NumberInMetaTitleAssessment.js +2 -2
  52. package/build/cjs/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
  53. package/build/cjs/scoring/assessments/seo/OutboundLinksAssessment.js +5 -3
  54. package/build/cjs/scoring/assessments/seo/OutboundLinksAssessment.js.map +1 -1
  55. package/build/cjs/scoring/assessments/seo/PageTitleWidthAssessment.js +5 -3
  56. package/build/cjs/scoring/assessments/seo/PageTitleWidthAssessment.js.map +1 -1
  57. package/build/cjs/scoring/assessments/seo/SchemaAssessment.js +2 -16
  58. package/build/cjs/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
  59. package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js +3 -3
  60. package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
  61. package/build/cjs/scoring/assessments/seo/SingleTitleAssessment.js +5 -3
  62. package/build/cjs/scoring/assessments/seo/SingleTitleAssessment.js.map +1 -1
  63. package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +5 -3
  64. package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
  65. package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js +3 -2
  66. package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
  67. package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js +17 -52
  68. package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
  69. package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js +4 -3
  70. package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
  71. package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js +4 -2
  72. package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
  73. package/build/cjs/scoring/assessors/assessor.js +1 -0
  74. package/build/cjs/scoring/assessors/assessor.js.map +1 -1
  75. package/build/cjs/scoring/assessors/avadaAssessor.js +3 -1
  76. package/build/cjs/scoring/assessors/avadaAssessor.js.map +1 -1
  77. package/build/cjs/scoring/assessors/contentAssessor.js +1 -1
  78. package/build/cjs/scoring/assessors/contentAssessor.js.map +1 -1
  79. package/build/cjs/scoring/assessors/index.js +14 -0
  80. package/build/cjs/scoring/assessors/index.js.map +1 -1
  81. package/build/cjs/scoring/assessors/seoAssessor.js +4 -5
  82. package/build/cjs/scoring/assessors/seoAssessor.js.map +1 -1
  83. package/build/cjs/values/Paper.js +2 -10
  84. package/build/cjs/values/Paper.js.map +1 -1
  85. package/build/esm/const/analysis.js +3 -39
  86. package/build/esm/const/analysis.js.map +1 -1
  87. package/build/esm/index.js.map +1 -1
  88. package/build/esm/languageProcessing/AbstractResearcher.js +1 -3
  89. package/build/esm/languageProcessing/AbstractResearcher.js.map +1 -1
  90. package/build/esm/languageProcessing/helpers/image/getImagesInTree.js +2 -4
  91. package/build/esm/languageProcessing/helpers/image/getImagesInTree.js.map +1 -1
  92. package/build/esm/languageProcessing/researches/checkRelatedKeywords.js +1 -0
  93. package/build/esm/languageProcessing/researches/checkRelatedKeywords.js.map +1 -1
  94. package/build/esm/languageProcessing/researches/getKeywordDensity.js.map +1 -1
  95. package/build/esm/languageProcessing/researches/imageCount.js +1 -2
  96. package/build/esm/languageProcessing/researches/imageCount.js.map +1 -1
  97. package/build/esm/scoring/assessments/assessment.js +7 -6
  98. package/build/esm/scoring/assessments/assessment.js.map +1 -1
  99. package/build/esm/scoring/assessments/index.js +8 -12
  100. package/build/esm/scoring/assessments/index.js.map +1 -1
  101. package/build/esm/scoring/assessments/readability/ParagraphTooLongAssessment.js +18 -19
  102. package/build/esm/scoring/assessments/readability/ParagraphTooLongAssessment.js.map +1 -1
  103. package/build/esm/scoring/assessments/readability/RelatedKeywordsAssessment.js +26 -12
  104. package/build/esm/scoring/assessments/readability/RelatedKeywordsAssessment.js.map +1 -1
  105. package/build/esm/scoring/assessments/readability/SentenceBeginningsAssessment.js +2 -2
  106. package/build/esm/scoring/assessments/readability/SentenceBeginningsAssessment.js.map +1 -1
  107. package/build/esm/scoring/assessments/readability/SentenceLengthInTextAssessment.js +11 -12
  108. package/build/esm/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
  109. package/build/esm/scoring/assessments/readability/TransitionWordsAssessment.js +2 -2
  110. package/build/esm/scoring/assessments/readability/TransitionWordsAssessment.js.map +1 -1
  111. package/build/esm/scoring/assessments/seo/FAQsAssessment.js +53 -8
  112. package/build/esm/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
  113. package/build/esm/scoring/assessments/seo/ImageCountAssessment.js +3 -3
  114. package/build/esm/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
  115. package/build/esm/scoring/assessments/seo/ImagesInContentAssessment.js +90 -0
  116. package/build/esm/scoring/assessments/seo/ImagesInContentAssessment.js.map +1 -0
  117. package/build/esm/scoring/assessments/seo/InternalLinksAssessment.js +6 -4
  118. package/build/esm/scoring/assessments/seo/InternalLinksAssessment.js.map +1 -1
  119. package/build/esm/scoring/assessments/seo/IntroductionKeywordAssessment.js +5 -3
  120. package/build/esm/scoring/assessments/seo/IntroductionKeywordAssessment.js.map +1 -1
  121. package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js +5 -5
  122. package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
  123. package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js +6 -4
  124. package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
  125. package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js +6 -4
  126. package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
  127. package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js +4 -4
  128. package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
  129. package/build/esm/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js +6 -4
  130. package/build/esm/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js.map +1 -1
  131. package/build/esm/scoring/assessments/seo/MetaDescriptionLengthAssessment.js +7 -4
  132. package/build/esm/scoring/assessments/seo/MetaDescriptionLengthAssessment.js.map +1 -1
  133. package/build/esm/scoring/assessments/seo/MetaTitleKeywordAssessment.js +3 -3
  134. package/build/esm/scoring/assessments/seo/MetaTitleKeywordAssessment.js.map +1 -1
  135. package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js +3 -3
  136. package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
  137. package/build/esm/scoring/assessments/seo/OutboundLinksAssessment.js +6 -4
  138. package/build/esm/scoring/assessments/seo/OutboundLinksAssessment.js.map +1 -1
  139. package/build/esm/scoring/assessments/seo/PageTitleWidthAssessment.js +6 -4
  140. package/build/esm/scoring/assessments/seo/PageTitleWidthAssessment.js.map +1 -1
  141. package/build/esm/scoring/assessments/seo/SchemaAssessment.js +3 -17
  142. package/build/esm/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
  143. package/build/esm/scoring/assessments/seo/SingleH1Assessment.js +4 -4
  144. package/build/esm/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
  145. package/build/esm/scoring/assessments/seo/SingleTitleAssessment.js +6 -4
  146. package/build/esm/scoring/assessments/seo/SingleTitleAssessment.js.map +1 -1
  147. package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +6 -4
  148. package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
  149. package/build/esm/scoring/assessments/seo/TextImagesAssessment.js +4 -3
  150. package/build/esm/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
  151. package/build/esm/scoring/assessments/seo/TextLengthAssessment.js +18 -54
  152. package/build/esm/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
  153. package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js +5 -4
  154. package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
  155. package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js +5 -3
  156. package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
  157. package/build/esm/scoring/assessors/assessor.js +1 -0
  158. package/build/esm/scoring/assessors/assessor.js.map +1 -1
  159. package/build/esm/scoring/assessors/avadaAssessor.js +4 -2
  160. package/build/esm/scoring/assessors/avadaAssessor.js.map +1 -1
  161. package/build/esm/scoring/assessors/contentAssessor.js +1 -1
  162. package/build/esm/scoring/assessors/contentAssessor.js.map +1 -1
  163. package/build/esm/scoring/assessors/index.js +2 -0
  164. package/build/esm/scoring/assessors/index.js.map +1 -1
  165. package/build/esm/scoring/assessors/seoAssessor.js +4 -5
  166. package/build/esm/scoring/assessors/seoAssessor.js.map +1 -1
  167. package/build/esm/values/Paper.js +2 -10
  168. package/build/esm/values/Paper.js.map +1 -1
  169. package/package.json +5 -3
  170. package/build/cjs/languageProcessing/researches/charactersInUrl.js +0 -26
  171. package/build/cjs/languageProcessing/researches/charactersInUrl.js.map +0 -1
  172. package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js +0 -83
  173. package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +0 -1
  174. package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js +0 -93
  175. package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js.map +0 -1
  176. package/build/cjs/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js +0 -103
  177. package/build/cjs/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js.map +0 -1
  178. package/build/esm/languageProcessing/researches/charactersInUrl.js +0 -21
  179. package/build/esm/languageProcessing/researches/charactersInUrl.js.map +0 -1
  180. package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js +0 -76
  181. package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +0 -1
  182. package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js +0 -87
  183. package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js.map +0 -1
  184. package/build/esm/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js +0 -96
  185. 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":[]}