axyseo 2.1.13 → 2.1.19

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 (173) hide show
  1. package/build/cjs/const/analysis.js +41 -4
  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 +3 -1
  5. package/build/cjs/languageProcessing/AbstractResearcher.js.map +1 -1
  6. package/build/cjs/languageProcessing/researches/charactersInUrl.js +26 -0
  7. package/build/cjs/languageProcessing/researches/charactersInUrl.js.map +1 -0
  8. package/build/cjs/languageProcessing/researches/checkRelatedKeywords.js +0 -1
  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/scoring/assessments/assessment.js +5 -6
  12. package/build/cjs/scoring/assessments/assessment.js.map +1 -1
  13. package/build/cjs/scoring/assessments/index.js +12 -4
  14. package/build/cjs/scoring/assessments/index.js.map +1 -1
  15. package/build/cjs/scoring/assessments/readability/ParagraphTooLongAssessment.js +18 -17
  16. package/build/cjs/scoring/assessments/readability/ParagraphTooLongAssessment.js.map +1 -1
  17. package/build/cjs/scoring/assessments/readability/RelatedKeywordsAssessment.js +11 -25
  18. package/build/cjs/scoring/assessments/readability/RelatedKeywordsAssessment.js.map +1 -1
  19. package/build/cjs/scoring/assessments/readability/SentenceBeginningsAssessment.js +1 -1
  20. package/build/cjs/scoring/assessments/readability/SentenceBeginningsAssessment.js.map +1 -1
  21. package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js +9 -10
  22. package/build/cjs/scoring/assessments/readability/SentenceLengthInTextAssessment.js.map +1 -1
  23. package/build/cjs/scoring/assessments/readability/TransitionWordsAssessment.js +1 -1
  24. package/build/cjs/scoring/assessments/readability/TransitionWordsAssessment.js.map +1 -1
  25. package/build/cjs/scoring/assessments/seo/FAQsAssessment.js +7 -52
  26. package/build/cjs/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
  27. package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js +83 -0
  28. package/build/cjs/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +1 -0
  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/InternalLinksAssessment.js +3 -5
  32. package/build/cjs/scoring/assessments/seo/InternalLinksAssessment.js.map +1 -1
  33. package/build/cjs/scoring/assessments/seo/IntroductionKeywordAssessment.js +2 -4
  34. package/build/cjs/scoring/assessments/seo/IntroductionKeywordAssessment.js.map +1 -1
  35. package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js +93 -0
  36. package/build/cjs/scoring/assessments/seo/InvalidCharactersInUrl.js.map +1 -0
  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 +3 -5
  40. package/build/cjs/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
  41. package/build/cjs/scoring/assessments/seo/KeywordDensityAssessment.js +3 -5
  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 +3 -5
  46. package/build/cjs/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js.map +1 -1
  47. package/build/cjs/scoring/assessments/seo/MetaDescriptionLengthAssessment.js +3 -6
  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 +3 -5
  54. package/build/cjs/scoring/assessments/seo/OutboundLinksAssessment.js.map +1 -1
  55. package/build/cjs/scoring/assessments/seo/PageTitleWidthAssessment.js +3 -5
  56. package/build/cjs/scoring/assessments/seo/PageTitleWidthAssessment.js.map +1 -1
  57. package/build/cjs/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js +103 -0
  58. package/build/cjs/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js.map +1 -0
  59. package/build/cjs/scoring/assessments/seo/SchemaAssessment.js +16 -2
  60. package/build/cjs/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
  61. package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js +3 -4
  62. package/build/cjs/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
  63. package/build/cjs/scoring/assessments/seo/SingleTitleAssessment.js +3 -5
  64. package/build/cjs/scoring/assessments/seo/SingleTitleAssessment.js.map +1 -1
  65. package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +3 -5
  66. package/build/cjs/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
  67. package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js +2 -3
  68. package/build/cjs/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
  69. package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js +22 -7
  70. package/build/cjs/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
  71. package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js +3 -4
  72. package/build/cjs/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
  73. package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js +2 -4
  74. package/build/cjs/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
  75. package/build/cjs/scoring/assessors/assessor.js +0 -1
  76. package/build/cjs/scoring/assessors/assessor.js.map +1 -1
  77. package/build/cjs/scoring/assessors/avadaAssessor.js +1 -2
  78. package/build/cjs/scoring/assessors/avadaAssessor.js.map +1 -1
  79. package/build/cjs/scoring/assessors/contentAssessor.js +1 -1
  80. package/build/cjs/scoring/assessors/contentAssessor.js.map +1 -1
  81. package/build/cjs/scoring/assessors/index.js +0 -14
  82. package/build/cjs/scoring/assessors/index.js.map +1 -1
  83. package/build/cjs/scoring/assessors/seoAssessor.js +4 -2
  84. package/build/cjs/scoring/assessors/seoAssessor.js.map +1 -1
  85. package/build/cjs/values/Paper.js +11 -2
  86. package/build/cjs/values/Paper.js.map +1 -1
  87. package/build/esm/const/analysis.js +40 -3
  88. package/build/esm/const/analysis.js.map +1 -1
  89. package/build/esm/index.js.map +1 -1
  90. package/build/esm/languageProcessing/AbstractResearcher.js +3 -1
  91. package/build/esm/languageProcessing/AbstractResearcher.js.map +1 -1
  92. package/build/esm/languageProcessing/researches/charactersInUrl.js +21 -0
  93. package/build/esm/languageProcessing/researches/charactersInUrl.js.map +1 -0
  94. package/build/esm/languageProcessing/researches/checkRelatedKeywords.js +0 -1
  95. package/build/esm/languageProcessing/researches/checkRelatedKeywords.js.map +1 -1
  96. package/build/esm/languageProcessing/researches/getKeywordDensity.js.map +1 -1
  97. package/build/esm/scoring/assessments/assessment.js +6 -7
  98. package/build/esm/scoring/assessments/assessment.js.map +1 -1
  99. package/build/esm/scoring/assessments/index.js +12 -4
  100. package/build/esm/scoring/assessments/index.js.map +1 -1
  101. package/build/esm/scoring/assessments/readability/ParagraphTooLongAssessment.js +19 -18
  102. package/build/esm/scoring/assessments/readability/ParagraphTooLongAssessment.js.map +1 -1
  103. package/build/esm/scoring/assessments/readability/RelatedKeywordsAssessment.js +12 -26
  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 +10 -11
  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 +8 -53
  112. package/build/esm/scoring/assessments/seo/FAQsAssessment.js.map +1 -1
  113. package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js +76 -0
  114. package/build/esm/scoring/assessments/seo/FAQsStructureDataAssessment.js.map +1 -0
  115. package/build/esm/scoring/assessments/seo/ImageCountAssessment.js +3 -3
  116. package/build/esm/scoring/assessments/seo/ImageCountAssessment.js.map +1 -1
  117. package/build/esm/scoring/assessments/seo/InternalLinksAssessment.js +4 -6
  118. package/build/esm/scoring/assessments/seo/InternalLinksAssessment.js.map +1 -1
  119. package/build/esm/scoring/assessments/seo/IntroductionKeywordAssessment.js +3 -5
  120. package/build/esm/scoring/assessments/seo/IntroductionKeywordAssessment.js.map +1 -1
  121. package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js +87 -0
  122. package/build/esm/scoring/assessments/seo/InvalidCharactersInUrl.js.map +1 -0
  123. package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js +5 -5
  124. package/build/esm/scoring/assessments/seo/KeyphraseAssessment.js.map +1 -1
  125. package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js +4 -6
  126. package/build/esm/scoring/assessments/seo/KeyphraseLengthAssessment.js.map +1 -1
  127. package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js +4 -6
  128. package/build/esm/scoring/assessments/seo/KeywordDensityAssessment.js.map +1 -1
  129. package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js +4 -4
  130. package/build/esm/scoring/assessments/seo/KeywordFAQsAssessment.js.map +1 -1
  131. package/build/esm/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js +4 -6
  132. package/build/esm/scoring/assessments/seo/MetaDescriptionKeywordAssessment.js.map +1 -1
  133. package/build/esm/scoring/assessments/seo/MetaDescriptionLengthAssessment.js +4 -7
  134. package/build/esm/scoring/assessments/seo/MetaDescriptionLengthAssessment.js.map +1 -1
  135. package/build/esm/scoring/assessments/seo/MetaTitleKeywordAssessment.js +3 -3
  136. package/build/esm/scoring/assessments/seo/MetaTitleKeywordAssessment.js.map +1 -1
  137. package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js +3 -3
  138. package/build/esm/scoring/assessments/seo/NumberInMetaTitleAssessment.js.map +1 -1
  139. package/build/esm/scoring/assessments/seo/OutboundLinksAssessment.js +4 -6
  140. package/build/esm/scoring/assessments/seo/OutboundLinksAssessment.js.map +1 -1
  141. package/build/esm/scoring/assessments/seo/PageTitleWidthAssessment.js +4 -6
  142. package/build/esm/scoring/assessments/seo/PageTitleWidthAssessment.js.map +1 -1
  143. package/build/esm/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js +96 -0
  144. package/build/esm/scoring/assessments/seo/RelatedKeywordsDensityAssessment.js.map +1 -0
  145. package/build/esm/scoring/assessments/seo/SchemaAssessment.js +17 -3
  146. package/build/esm/scoring/assessments/seo/SchemaAssessment.js.map +1 -1
  147. package/build/esm/scoring/assessments/seo/SingleH1Assessment.js +4 -5
  148. package/build/esm/scoring/assessments/seo/SingleH1Assessment.js.map +1 -1
  149. package/build/esm/scoring/assessments/seo/SingleTitleAssessment.js +4 -6
  150. package/build/esm/scoring/assessments/seo/SingleTitleAssessment.js.map +1 -1
  151. package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js +4 -6
  152. package/build/esm/scoring/assessments/seo/SubHeadingsKeywordAssessment.js.map +1 -1
  153. package/build/esm/scoring/assessments/seo/TextImagesAssessment.js +3 -4
  154. package/build/esm/scoring/assessments/seo/TextImagesAssessment.js.map +1 -1
  155. package/build/esm/scoring/assessments/seo/TextLengthAssessment.js +24 -8
  156. package/build/esm/scoring/assessments/seo/TextLengthAssessment.js.map +1 -1
  157. package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js +4 -5
  158. package/build/esm/scoring/assessments/seo/UrlKeywordAssessment.js.map +1 -1
  159. package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js +3 -5
  160. package/build/esm/scoring/assessments/seo/UrlLengthAssessment.js.map +1 -1
  161. package/build/esm/scoring/assessors/assessor.js +0 -1
  162. package/build/esm/scoring/assessors/assessor.js.map +1 -1
  163. package/build/esm/scoring/assessors/avadaAssessor.js +2 -3
  164. package/build/esm/scoring/assessors/avadaAssessor.js.map +1 -1
  165. package/build/esm/scoring/assessors/contentAssessor.js +1 -1
  166. package/build/esm/scoring/assessors/contentAssessor.js.map +1 -1
  167. package/build/esm/scoring/assessors/index.js +0 -2
  168. package/build/esm/scoring/assessors/index.js.map +1 -1
  169. package/build/esm/scoring/assessors/seoAssessor.js +4 -2
  170. package/build/esm/scoring/assessors/seoAssessor.js.map +1 -1
  171. package/build/esm/values/Paper.js +11 -2
  172. package/build/esm/values/Paper.js.map +1 -1
  173. package/package.json +3 -3
@@ -0,0 +1,96 @@
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
@@ -0,0 +1 @@
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":[]}
@@ -1,7 +1,7 @@
1
1
  import { merge } from 'lodash';
2
2
  import AssessmentResult from "../../../values/AssessmentResult";
3
3
  import Assessment from "../assessment";
4
- import { SCHEMA_ID } from "../../../const/analysis";
4
+ import { SCHEMA_ID, TECHNICAL_SEO_POINTS } from "../../../const/analysis";
5
5
 
6
6
  /**
7
7
  * Represents the assessment that checks shop has schema.
@@ -41,6 +41,13 @@ export default class SchemaAssessment extends Assessment {
41
41
  let status = '';
42
42
  const url = paper.getSlug();
43
43
  if (url.includes('product') || url.includes('collection')) {
44
+ this._config = merge(this._config, {
45
+ title: 'Missing product structured data',
46
+ content: {
47
+ good: 'Product structured data added',
48
+ bad: 'Add Product structured data for Google rich results eligibility.'
49
+ }
50
+ });
44
51
  if (paper.hasProductSchema()) {
45
52
  status = 'good';
46
53
  } else {
@@ -48,13 +55,20 @@ export default class SchemaAssessment extends Assessment {
48
55
  }
49
56
  }
50
57
  if (url.includes('blogs')) {
58
+ this._config = merge(this._config, {
59
+ title: 'Missing article structured data',
60
+ content: {
61
+ good: 'Article structured data added',
62
+ bad: 'Add Article structured data for Google rich results eligibility.'
63
+ }
64
+ });
51
65
  if (paper.hasArticleSchema()) {
52
66
  status = 'good';
53
67
  } else {
54
68
  status = 'bad';
55
69
  }
56
70
  }
57
- const score = this.getScore(this._config.priority, status);
71
+ const score = this.getScore(TECHNICAL_SEO_POINTS, status);
58
72
  return {
59
73
  score,
60
74
  status
@@ -89,7 +103,7 @@ export default class SchemaAssessment extends Assessment {
89
103
  * @returns {boolean} Returns true if the language is available and the paper is not empty.
90
104
  */
91
105
  isApplicable(paper, researcher) {
92
- return paper.hasShopSettings() && paper.hasSlug();
106
+ return true;
93
107
  }
94
108
  }
95
109
  //# sourceMappingURL=SchemaAssessment.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SchemaAssessment.js","names":["merge","AssessmentResult","Assessment","SCHEMA_ID","SchemaAssessment","constructor","config","defaultConfig","id","priority","docUrl","ctaType","title","content","good","improve","bad","identifier","_config","calculateResult","paper","status","url","getSlug","includes","hasProductSchema","hasArticleSchema","score","getScore","getResult","researcher","calculatedResult","assessmentResult","setScore","setStatus","isApplicable","hasShopSettings","hasSlug"],"sources":["../../../../../src/scoring/assessments/seo/SchemaAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {SCHEMA_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks shop has schema.\n */\nexport default class SchemaAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SCHEMA_ID,\n priority: 'high',\n docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#schema',\n ctaType: 'contactUs',\n title: 'Schema',\n content: {\n good: 'Schema markup is applied effectively.',\n improve: '',\n bad: 'No schema markup applied. Add schema to optimize visibility for search engines.'\n }\n };\n\n this.identifier = SCHEMA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n let status = '';\n const url = paper.getSlug();\n\n if (url.includes('product') || url.includes('collection')) {\n if (paper.hasProductSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n if (url.includes('blogs')) {\n if (paper.hasArticleSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @param config\n * @returns {AssessmentResult}\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks if the sentence beginnings assessment is applicable to the paper.\n *\n * @param {Object} paper The paper to check.\n * @param {Researcher} researcher The researcher object.\n * @returns {boolean} Returns true if the language is available and the paper is not empty.\n */\n isApplicable(paper, researcher) {\n return paper.hasShopSettings() && paper.hasSlug();\n }\n}\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,gBAAgB;AACvB,OAAOC,UAAU;AACjB,SAAQC,SAAS;;AAEjB;AACA;AACA;AACA,eAAe,MAAMC,gBAAgB,SAASF,UAAU,CAAC;EACvD;AACF;AACA;AACA;AACA;AACA;AACA;EACEG,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,SAAS;MACbM,QAAQ,EAAE,MAAM;MAChBC,MAAM,EAAE,oFAAoF;MAC5FC,OAAO,EAAE,WAAW;MACpBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,uCAAuC;QAC7CC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGd,SAAS;IAC3B,IAAI,CAACe,OAAO,GAAGlB,KAAK,CAACO,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;EACEa,eAAeA,CAACC,KAAK,EAAE;IACrB,IAAIC,MAAM,GAAG,EAAE;IACf,MAAMC,GAAG,GAAGF,KAAK,CAACG,OAAO,CAAC,CAAC;IAE3B,IAAID,GAAG,CAACE,QAAQ,CAAC,SAAS,CAAC,IAAIF,GAAG,CAACE,QAAQ,CAAC,YAAY,CAAC,EAAE;MACzD,IAAIJ,KAAK,CAACK,gBAAgB,CAAC,CAAC,EAAE;QAC5BJ,MAAM,GAAG,MAAM;MACjB,CAAC,MAAM;QACLA,MAAM,GAAG,KAAK;MAChB;IACF;IACA,IAAIC,GAAG,CAACE,QAAQ,CAAC,OAAO,CAAC,EAAE;MACzB,IAAIJ,KAAK,CAACM,gBAAgB,CAAC,CAAC,EAAE;QAC5BL,MAAM,GAAG,MAAM;MACjB,CAAC,MAAM;QACLA,MAAM,GAAG,KAAK;MAChB;IACF;IAEA,MAAMM,KAAK,GAAG,IAAI,CAACC,QAAQ,CAAC,IAAI,CAACV,OAAO,CAACT,QAAQ,EAAEY,MAAM,CAAC;IAE1D,OAAO;MACLM,KAAK;MACLN;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEQ,SAASA,CAAC;IAACT,KAAK;IAAEU;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACZ,eAAe,CAACC,KAAK,CAAC;IACpD,MAAMY,gBAAgB,GAAG,IAAI/B,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACY;IAAO,CAAC,CAAC;IAErEc,gBAAgB,CAACC,QAAQ,CAACF,gBAAgB,CAACJ,KAAK,CAAC;IACjDK,gBAAgB,CAACE,SAAS,CAACH,gBAAgB,CAACV,MAAM,CAAC;IAEnD,OAAOW,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEG,YAAYA,CAACf,KAAK,EAAEU,UAAU,EAAE;IAC9B,OAAOV,KAAK,CAACgB,eAAe,CAAC,CAAC,IAAIhB,KAAK,CAACiB,OAAO,CAAC,CAAC;EACnD;AACF","ignoreList":[]}
1
+ {"version":3,"file":"SchemaAssessment.js","names":["merge","AssessmentResult","Assessment","SCHEMA_ID","TECHNICAL_SEO_POINTS","SchemaAssessment","constructor","config","defaultConfig","id","priority","docUrl","ctaType","title","content","good","improve","bad","identifier","_config","calculateResult","paper","status","url","getSlug","includes","hasProductSchema","hasArticleSchema","score","getScore","getResult","researcher","calculatedResult","assessmentResult","setScore","setStatus","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SchemaAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport Assessment from '../assessment';\nimport {SCHEMA_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks shop has schema.\n */\nexport default class SchemaAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SCHEMA_ID,\n priority: 'high',\n docUrl: 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#schema',\n ctaType: 'contactUs',\n title: 'Schema',\n content: {\n good: 'Schema markup is applied effectively.',\n improve: '',\n bad: 'No schema markup applied. Add schema to optimize visibility for search engines.'\n }\n };\n\n this.identifier = SCHEMA_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n let status = '';\n const url = paper.getSlug();\n\n if (url.includes('product') || url.includes('collection')) {\n this._config = merge(this._config, {\n title: 'Missing product structured data',\n content: {\n good: 'Product structured data added',\n bad: 'Add Product structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasProductSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n if (url.includes('blogs')) {\n this._config = merge(this._config, {\n title: 'Missing article structured data',\n content: {\n good: 'Article structured data added',\n bad: 'Add Article structured data for Google rich results eligibility.'\n }\n });\n if (paper.hasArticleSchema()) {\n status = 'good';\n } else {\n status = 'bad';\n }\n }\n\n const score = this.getScore(TECHNICAL_SEO_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n *\n * @param paper\n * @param researcher\n * @param config\n * @returns {AssessmentResult}\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n * Checks if the sentence beginnings assessment is applicable to the paper.\n *\n * @param {Object} paper The paper to check.\n * @param {Researcher} researcher The researcher object.\n * @returns {boolean} Returns true if the language is available and the paper is not empty.\n */\n isApplicable(paper, researcher) {\n return true\n }\n}\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,gBAAgB;AACvB,OAAOC,UAAU;AACjB,SAAQC,SAAS,EAAEC,oBAAoB;;AAEvC;AACA;AACA;AACA,eAAe,MAAMC,gBAAgB,SAASH,UAAU,CAAC;EACvD;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,SAAS;MACbO,QAAQ,EAAE,MAAM;MAChBC,MAAM,EAAE,oFAAoF;MAC5FC,OAAO,EAAE,WAAW;MACpBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,uCAAuC;QAC7CC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,SAAS;IAC3B,IAAI,CAACgB,OAAO,GAAGnB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;EACEa,eAAeA,CAACC,KAAK,EAAE;IACrB,IAAIC,MAAM,GAAG,EAAE;IACf,MAAMC,GAAG,GAAGF,KAAK,CAACG,OAAO,CAAC,CAAC;IAE3B,IAAID,GAAG,CAACE,QAAQ,CAAC,SAAS,CAAC,IAAIF,GAAG,CAACE,QAAQ,CAAC,YAAY,CAAC,EAAE;MACzD,IAAI,CAACN,OAAO,GAAGnB,KAAK,CAAC,IAAI,CAACmB,OAAO,EAAE;QACjCN,KAAK,EAAE,iCAAiC;QACxCC,OAAO,EAAE;UACPC,IAAI,EAAE,+BAA+B;UACrCE,GAAG,EAAE;QACP;MACF,CAAC,CAAC;MACF,IAAII,KAAK,CAACK,gBAAgB,CAAC,CAAC,EAAE;QAC5BJ,MAAM,GAAG,MAAM;MACjB,CAAC,MAAM;QACLA,MAAM,GAAG,KAAK;MAChB;IACF;IACA,IAAIC,GAAG,CAACE,QAAQ,CAAC,OAAO,CAAC,EAAE;MACzB,IAAI,CAACN,OAAO,GAAGnB,KAAK,CAAC,IAAI,CAACmB,OAAO,EAAE;QACjCN,KAAK,EAAE,iCAAiC;QACxCC,OAAO,EAAE;UACPC,IAAI,EAAE,+BAA+B;UACrCE,GAAG,EAAE;QACP;MACF,CAAC,CAAC;MACF,IAAII,KAAK,CAACM,gBAAgB,CAAC,CAAC,EAAE;QAC5BL,MAAM,GAAG,MAAM;MACjB,CAAC,MAAM;QACLA,MAAM,GAAG,KAAK;MAChB;IACF;IAEA,MAAMM,KAAK,GAAG,IAAI,CAACC,QAAQ,CAACzB,oBAAoB,EAAEkB,MAAM,CAAC;IAEzD,OAAO;MACLM,KAAK;MACLN;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEQ,SAASA,CAAC;IAACT,KAAK;IAAEU;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAI,CAACZ,eAAe,CAACC,KAAK,CAAC;IACpD,MAAMY,gBAAgB,GAAG,IAAIhC,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACY;IAAO,CAAC,CAAC;IAErEc,gBAAgB,CAACC,QAAQ,CAACF,gBAAgB,CAACJ,KAAK,CAAC;IACjDK,gBAAgB,CAACE,SAAS,CAACH,gBAAgB,CAACV,MAAM,CAAC;IAEnD,OAAOW,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEG,YAAYA,CAACf,KAAK,EAAEU,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;AACF","ignoreList":[]}
@@ -1,7 +1,7 @@
1
1
  import { isUndefined, merge } from 'lodash';
2
2
  import Assessment from "../assessment.js";
3
3
  import AssessmentResult from "../../../values/AssessmentResult.js";
4
- import { SINGLE_H1_ID } from "../../../const/analysis";
4
+ import { SINGLE_H1_ID, TECHNICAL_SEO_POINTS } from "../../../const/analysis";
5
5
 
6
6
  /**
7
7
  * Assessment to check whether the body of the text contains more than 1 H1s in the body.
@@ -65,7 +65,6 @@ class SingleH1Assessment extends Assessment {
65
65
  calculateResult(paper) {
66
66
  const htmlString = paper.getText();
67
67
  const desHasH1Tag = htmlString.includes('<h1>');
68
- console.log('calculateResult h1', htmlString, desHasH1Tag);
69
68
  let status = '';
70
69
  if (this._h1Count === 1) {
71
70
  status = 'good';
@@ -74,9 +73,9 @@ class SingleH1Assessment extends Assessment {
74
73
  status = 'good';
75
74
  }
76
75
  if (this._h1Count > 1) {
77
- status = 'improve';
76
+ status = 'bad';
78
77
  }
79
- const score = this.getScore(this._config.priority, status);
78
+ const score = this.getScore(TECHNICAL_SEO_POINTS, status);
80
79
  return {
81
80
  score,
82
81
  status
@@ -91,7 +90,7 @@ class SingleH1Assessment extends Assessment {
91
90
  * @returns {boolean} True when there is text.
92
91
  */
93
92
  isApplicable(paper) {
94
- return paper.hasText();
93
+ return true;
95
94
  }
96
95
  }
97
96
  export default SingleH1Assessment;
@@ -1 +1 @@
1
- {"version":3,"file":"SingleH1Assessment.js","names":["isUndefined","merge","Assessment","AssessmentResult","SINGLE_H1_ID","SingleH1Assessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","_h1Count","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","htmlString","getText","desHasH1Tag","includes","console","log","getScore","isApplicable","hasText"],"sources":["../../../../../src/scoring/assessments/seo/SingleH1Assessment.js"],"sourcesContent":["import {isUndefined, merge} from 'lodash';\nimport Assessment from '../assessment.js';\nimport AssessmentResult from '../../../values/AssessmentResult.js';\nimport {SINGLE_H1_ID} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the body of the text contains more than 1 H1s in the body.\n * This assessment doesn't penalize H1 that is not in the very beginning of the body.\n */\nclass SingleH1Assessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SINGLE_H1_ID,\n docUrl: 'https://help.seoon.io/seo/seo-checklist',\n fixPosition: 'description',\n ctaType: 'contactUs',\n priority: 'high',\n title: 'H1 tag',\n content: {\n good: 'H1 tag is optimized.',\n improve: 'You should use only one H1 tag',\n bad: 'Missing H1 tag. Add one H1 to clearly define your page`s topic.'\n }\n };\n\n this.identifier = SINGLE_H1_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n this._h1Count = researcher.getResearch('h1s');\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n if (!isUndefined(calculatedResult)) {\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n }\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const htmlString = paper.getText();\n const desHasH1Tag = htmlString.includes('<h1>');\n console.log('calculateResult h1', htmlString, desHasH1Tag);\n\n let status = '';\n if (this._h1Count === 1) {\n status = 'good';\n }\n\n if (this._h1Count === 0 && !desHasH1Tag) {\n status = 'good';\n }\n\n if (this._h1Count > 1) {\n status = 'improve';\n }\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return paper.hasText();\n }\n}\n\nexport default SingleH1Assessment;\n"],"mappings":"AAAA,SAAQA,WAAW,EAAEC,KAAK,QAAO,QAAQ;AACzC,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,YAAY;;AAEpB;AACA;AACA;AACA;AACA,MAAMC,kBAAkB,SAASH,UAAU,CAAC;EAC1C;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,YAAY;MAChBM,MAAM,EAAE,yCAAyC;MACjDC,WAAW,EAAE,aAAa;MAC1BC,OAAO,EAAE,WAAW;MACpBC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,sBAAsB;QAC5BC,OAAO,EAAE,gCAAgC;QACzCC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,YAAY;IAC9B,IAAI,CAACgB,OAAO,GAAGnB,KAAK,CAACO,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,IAAI,CAACC,QAAQ,GAAGD,UAAU,CAACE,WAAW,CAAC,KAAK,CAAC;IAC7C,MAAMC,gBAAgB,GAAG,IAAIvB,gBAAgB,CAAC;MAACI,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpD,IAAI,CAACtB,WAAW,CAAC2B,gBAAgB,CAAC,EAAE;MAClCD,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;MACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACrD;IAEA,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACN,KAAK,EAAE;IACrB,MAAMW,UAAU,GAAGX,KAAK,CAACY,OAAO,CAAC,CAAC;IAClC,MAAMC,WAAW,GAAGF,UAAU,CAACG,QAAQ,CAAC,MAAM,CAAC;IAC/CC,OAAO,CAACC,GAAG,CAAC,oBAAoB,EAAEL,UAAU,EAAEE,WAAW,CAAC;IAE1D,IAAIH,MAAM,GAAG,EAAE;IACf,IAAI,IAAI,CAACR,QAAQ,KAAK,CAAC,EAAE;MACvBQ,MAAM,GAAG,MAAM;IACjB;IAEA,IAAI,IAAI,CAACR,QAAQ,KAAK,CAAC,IAAI,CAACW,WAAW,EAAE;MACvCH,MAAM,GAAG,MAAM;IACjB;IAEA,IAAI,IAAI,CAACR,QAAQ,GAAG,CAAC,EAAE;MACrBQ,MAAM,GAAG,SAAS;IACpB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACS,QAAQ,CAAC,IAAI,CAACnB,OAAO,CAACP,QAAQ,EAAEmB,MAAM,CAAC;IAE1D,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEQ,YAAYA,CAAClB,KAAK,EAAE;IAClB,OAAOA,KAAK,CAACmB,OAAO,CAAC,CAAC;EACxB;AACF;AAEA,eAAepC,kBAAkB","ignoreList":[]}
1
+ {"version":3,"file":"SingleH1Assessment.js","names":["isUndefined","merge","Assessment","AssessmentResult","SINGLE_H1_ID","TECHNICAL_SEO_POINTS","SingleH1Assessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","_h1Count","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","htmlString","getText","desHasH1Tag","includes","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SingleH1Assessment.js"],"sourcesContent":["import {isUndefined, merge} from 'lodash';\nimport Assessment from '../assessment.js';\nimport AssessmentResult from '../../../values/AssessmentResult.js';\nimport {SINGLE_H1_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the body of the text contains more than 1 H1s in the body.\n * This assessment doesn't penalize H1 that is not in the very beginning of the body.\n */\nclass SingleH1Assessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SINGLE_H1_ID,\n docUrl: 'https://help.seoon.io/seo/seo-checklist',\n fixPosition: 'description',\n ctaType: 'contactUs',\n priority: 'high',\n title: 'H1 tag',\n content: {\n good: 'H1 tag is optimized.',\n improve: 'You should use only one H1 tag',\n bad: 'Missing H1 tag. Add one H1 to clearly define your page`s topic.'\n }\n };\n\n this.identifier = SINGLE_H1_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n this._h1Count = researcher.getResearch('h1s');\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n if (!isUndefined(calculatedResult)) {\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n }\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const htmlString = paper.getText();\n const desHasH1Tag = htmlString.includes('<h1>');\n\n let status = '';\n if (this._h1Count === 1) {\n status = 'good';\n }\n\n if (this._h1Count === 0 && !desHasH1Tag) {\n status = 'good';\n }\n\n if (this._h1Count > 1) {\n status = 'bad';\n }\n\n const score = this.getScore(TECHNICAL_SEO_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true\n }\n}\n\nexport default SingleH1Assessment;\n"],"mappings":"AAAA,SAAQA,WAAW,EAAEC,KAAK,QAAO,QAAQ;AACzC,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,YAAY,EAAEC,oBAAoB;;AAE1C;AACA;AACA;AACA;AACA,MAAMC,kBAAkB,SAASJ,UAAU,CAAC;EAC1C;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,YAAY;MAChBO,MAAM,EAAE,yCAAyC;MACjDC,WAAW,EAAE,aAAa;MAC1BC,OAAO,EAAE,WAAW;MACpBC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,QAAQ;MACfC,OAAO,EAAE;QACPC,IAAI,EAAE,sBAAsB;QAC5BC,OAAO,EAAE,gCAAgC;QACzCC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGhB,YAAY;IAC9B,IAAI,CAACiB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,IAAI,CAACC,QAAQ,GAAGD,UAAU,CAACE,WAAW,CAAC,KAAK,CAAC;IAC7C,MAAMC,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpD,IAAI,CAACvB,WAAW,CAAC4B,gBAAgB,CAAC,EAAE;MAClCD,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;MACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACrD;IAEA,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACN,KAAK,EAAE;IACrB,MAAMW,UAAU,GAAGX,KAAK,CAACY,OAAO,CAAC,CAAC;IAClC,MAAMC,WAAW,GAAGF,UAAU,CAACG,QAAQ,CAAC,MAAM,CAAC;IAE/C,IAAIJ,MAAM,GAAG,EAAE;IACf,IAAI,IAAI,CAACR,QAAQ,KAAK,CAAC,EAAE;MACvBQ,MAAM,GAAG,MAAM;IACjB;IAEA,IAAI,IAAI,CAACR,QAAQ,KAAK,CAAC,IAAI,CAACW,WAAW,EAAE;MACvCH,MAAM,GAAG,MAAM;IACjB;IAEA,IAAI,IAAI,CAACR,QAAQ,GAAG,CAAC,EAAE;MACrBQ,MAAM,GAAG,KAAK;IAChB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACO,QAAQ,CAACjC,oBAAoB,EAAE4B,MAAM,CAAC;IAEzD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,YAAYA,CAAChB,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAEA,eAAejB,kBAAkB","ignoreList":[]}
@@ -1,7 +1,7 @@
1
1
  import { isUndefined, merge } from 'lodash';
2
2
  import Assessment from "../assessment.js";
3
3
  import AssessmentResult from "../../../values/AssessmentResult.js";
4
- import { SINGLE_TITLE_ID } from "../../../const/analysis";
4
+ import { SINGLE_TITLE_ID, TECHNICAL_SEO_POINTS } from "../../../const/analysis";
5
5
 
6
6
  /**
7
7
  * Assessment to check whether the body of the text contains more than 1 H1s in the body.
@@ -62,13 +62,11 @@ class SingleTitleAssessment extends Assessment {
62
62
  */
63
63
  calculateResult(paper) {
64
64
  const count = paper.getTitleCount();
65
- let status = '';
65
+ let status = 'bad';
66
66
  if (count === 1) {
67
67
  status = 'good';
68
- } else {
69
- status = 'bad';
70
68
  }
71
- const score = this.getScore(this._config.priority, status);
69
+ const score = this.getScore(TECHNICAL_SEO_POINTS, status);
72
70
  return {
73
71
  score,
74
72
  status
@@ -83,7 +81,7 @@ class SingleTitleAssessment extends Assessment {
83
81
  * @returns {boolean} True when there is text.
84
82
  */
85
83
  isApplicable(paper) {
86
- return paper.hasTitle();
84
+ return true;
87
85
  }
88
86
  }
89
87
  export default SingleTitleAssessment;
@@ -1 +1 @@
1
- {"version":3,"file":"SingleTitleAssessment.js","names":["isUndefined","merge","Assessment","AssessmentResult","SINGLE_TITLE_ID","SingleTitleAssessment","constructor","config","defaultConfig","id","docUrl","ctaType","priority","title","content","improve","bad","good","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","count","getTitleCount","getScore","isApplicable","hasTitle"],"sources":["../../../../../src/scoring/assessments/seo/SingleTitleAssessment.js"],"sourcesContent":["import {isUndefined, merge} from 'lodash';\nimport Assessment from '../assessment.js';\nimport AssessmentResult from '../../../values/AssessmentResult.js';\nimport {SINGLE_TITLE_ID} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the body of the text contains more than 1 H1s in the body.\n * This assessment doesn't penalize H1 that is not in the very beginning of the body.\n */\nclass SingleTitleAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SINGLE_TITLE_ID,\n docUrl: 'https://help.seoon.io/seo/seo-checklist',\n ctaType: 'contactUs',\n priority: 'high',\n title: 'Duplicate title',\n content: {\n improve: '',\n bad: 'Found duplicate titles. Check your content and create unique titles.',\n good: 'No duplicate titles found.'\n }\n };\n\n this.identifier = SINGLE_TITLE_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n if (!isUndefined(calculatedResult)) {\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n }\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const count = paper.getTitleCount();\n\n let status = '';\n if (count === 1) {\n status = 'good';\n } else {\n status = 'bad';\n }\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return paper.hasTitle();\n }\n}\n\nexport default SingleTitleAssessment;\n"],"mappings":"AAAA,SAAQA,WAAW,EAAEC,KAAK,QAAO,QAAQ;AACzC,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe;;AAEvB;AACA;AACA;AACA;AACA,MAAMC,qBAAqB,SAASH,UAAU,CAAC;EAC7C;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,eAAe;MACnBM,MAAM,EAAE,yCAAyC;MACjDC,OAAO,EAAE,WAAW;MACpBC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,iBAAiB;MACxBC,OAAO,EAAE;QACPC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE,sEAAsE;QAC3EC,IAAI,EAAE;MACR;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGd,eAAe;IACjC,IAAI,CAACe,OAAO,GAAGlB,KAAK,CAACO,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEa,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIpB,gBAAgB,CAAC;MAACI,MAAM,EAAE,IAAI,CAACY;IAAO,CAAC,CAAC;IAErE,MAAMK,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACJ,KAAK,CAAC;IAEpD,IAAI,CAACrB,WAAW,CAACwB,gBAAgB,CAAC,EAAE;MAClCD,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;MACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACrD;IAEA,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACJ,KAAK,EAAE;IACrB,MAAMS,KAAK,GAAGT,KAAK,CAACU,aAAa,CAAC,CAAC;IAEnC,IAAIF,MAAM,GAAG,EAAE;IACf,IAAIC,KAAK,KAAK,CAAC,EAAE;MACfD,MAAM,GAAG,MAAM;IACjB,CAAC,MAAM;MACLA,MAAM,GAAG,KAAK;IAChB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACK,QAAQ,CAAC,IAAI,CAACb,OAAO,CAACP,QAAQ,EAAEiB,MAAM,CAAC;IAE1D,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,YAAYA,CAACZ,KAAK,EAAE;IAClB,OAAOA,KAAK,CAACa,QAAQ,CAAC,CAAC;EACzB;AACF;AAEA,eAAe7B,qBAAqB","ignoreList":[]}
1
+ {"version":3,"file":"SingleTitleAssessment.js","names":["isUndefined","merge","Assessment","AssessmentResult","SINGLE_TITLE_ID","TECHNICAL_SEO_POINTS","SingleTitleAssessment","constructor","config","defaultConfig","id","docUrl","ctaType","priority","title","content","improve","bad","good","identifier","_config","getResult","paper","researcher","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","count","getTitleCount","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SingleTitleAssessment.js"],"sourcesContent":["import {isUndefined, merge} from 'lodash';\nimport Assessment from '../assessment.js';\nimport AssessmentResult from '../../../values/AssessmentResult.js';\nimport {SINGLE_TITLE_ID, TECHNICAL_SEO_POINTS} from '@axyseo/const/analysis';\n\n/**\n * Assessment to check whether the body of the text contains more than 1 H1s in the body.\n * This assessment doesn't penalize H1 that is not in the very beginning of the body.\n */\nclass SingleTitleAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SINGLE_TITLE_ID,\n docUrl: 'https://help.seoon.io/seo/seo-checklist',\n ctaType: 'contactUs',\n priority: 'high',\n title: 'Duplicate title',\n content: {\n improve: '',\n bad: 'Found duplicate titles. Check your content and create unique titles.',\n good: 'No duplicate titles found.'\n }\n };\n\n this.identifier = SINGLE_TITLE_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n if (!isUndefined(calculatedResult)) {\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n }\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const count = paper.getTitleCount();\n\n let status = 'bad';\n if (count === 1) {\n status = 'good';\n }\n\n const score = this.getScore(TECHNICAL_SEO_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n\nexport default SingleTitleAssessment;\n"],"mappings":"AAAA,SAAQA,WAAW,EAAEC,KAAK,QAAO,QAAQ;AACzC,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe,EAAEC,oBAAoB;;AAE7C;AACA;AACA;AACA;AACA,MAAMC,qBAAqB,SAASJ,UAAU,CAAC;EAC7C;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,eAAe;MACnBO,MAAM,EAAE,yCAAyC;MACjDC,OAAO,EAAE,WAAW;MACpBC,QAAQ,EAAE,MAAM;MAChBC,KAAK,EAAE,iBAAiB;MACxBC,OAAO,EAAE;QACPC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE,sEAAsE;QAC3EC,IAAI,EAAE;MACR;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,eAAe;IACjC,IAAI,CAACgB,OAAO,GAAGnB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEa,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,MAAMC,gBAAgB,GAAG,IAAIrB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACY;IAAO,CAAC,CAAC;IAErE,MAAMK,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACJ,KAAK,CAAC;IAEpD,IAAI,CAACtB,WAAW,CAACyB,gBAAgB,CAAC,EAAE;MAClCD,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;MACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACrD;IAEA,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACEE,eAAeA,CAACJ,KAAK,EAAE;IACrB,MAAMS,KAAK,GAAGT,KAAK,CAACU,aAAa,CAAC,CAAC;IAEnC,IAAIF,MAAM,GAAG,KAAK;IAClB,IAAIC,KAAK,KAAK,CAAC,EAAE;MACfD,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACK,QAAQ,CAAC5B,oBAAoB,EAAEyB,MAAM,CAAC;IAEzD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,YAAYA,CAACZ,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF;AAEA,eAAehB,qBAAqB","ignoreList":[]}
@@ -1,7 +1,7 @@
1
1
  import { merge } from 'lodash';
2
2
  import Assessment from "../assessment";
3
3
  import AssessmentResult from "../../../values/AssessmentResult";
4
- import { SUBHEADINGS_KEYWORD_ID } from "../../../const/analysis";
4
+ import { MAIN_CONTENT_POINTS, SUBHEADINGS_KEYWORD_ID } from "../../../const/analysis";
5
5
 
6
6
  /**
7
7
  * Represents the assessment that checks if the keyword is present in one of the subheadings.
@@ -59,13 +59,11 @@ export default class SubHeadingsKeywordAssessment extends Assessment {
59
59
  * @returns {{score: number, status: string}}
60
60
  */
61
61
  calculateResult() {
62
- let status = '';
62
+ let status = 'bad';
63
63
  if (this._subHeadings.matches > 0) {
64
64
  status = 'good';
65
- } else {
66
- status = 'bad';
67
65
  }
68
- const score = this.getScore(this._config.priority, status);
66
+ const score = this.getScore(MAIN_CONTENT_POINTS, status);
69
67
  return {
70
68
  score,
71
69
  status
@@ -80,7 +78,7 @@ export default class SubHeadingsKeywordAssessment extends Assessment {
80
78
  * @returns {boolean} True when there is text.
81
79
  */
82
80
  isApplicable(paper) {
83
- return paper.hasKeyword();
81
+ return true;
84
82
  }
85
83
  }
86
84
  //# sourceMappingURL=SubHeadingsKeywordAssessment.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SubHeadingsKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","SUBHEADINGS_KEYWORD_ID","SubHeadingsKeywordAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","bad","improve","identifier","_config","getResult","paper","researcher","_subHeadings","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","matches","getScore","isApplicable","hasKeyword"],"sources":["../../../../../src/scoring/assessments/seo/SubHeadingsKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {SUBHEADINGS_KEYWORD_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks if the keyword is present in one of the subheadings.\n */\nexport default class SubHeadingsKeywordAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SUBHEADINGS_KEYWORD_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-subheading',\n priority: 'medium',\n fixPosition: 'subheading',\n title: 'Keyword in Subheading',\n content: {\n good: 'Keywords are included in subheadings.',\n bad:\n 'Keyword not found in any subheadings. Include it in at least one subheading (H2, H3, etc.).',\n improve: ''\n }\n };\n\n this.identifier = SUBHEADINGS_KEYWORD_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n this._subHeadings = researcher.getResearch('matchKeywordInSubheadings');\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n let status = '';\n if (this._subHeadings.matches > 0) {\n status = 'good';\n } else {\n status = 'bad';\n }\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return paper.hasKeyword();\n }\n}\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,sBAAsB;;AAE9B;AACA;AACA;AACA,eAAe,MAAMC,4BAA4B,SAASH,UAAU,CAAC;EACnE;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,sBAAsB;MAC1BM,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,mGAAmG;MACrGC,QAAQ,EAAE,QAAQ;MAClBC,WAAW,EAAE,YAAY;MACzBC,KAAK,EAAE,uBAAuB;MAC9BC,OAAO,EAAE;QACPC,IAAI,EAAE,uCAAuC;QAC7CC,GAAG,EACD,6FAA6F;QAC/FC,OAAO,EAAE;MACX;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,sBAAsB;IACxC,IAAI,CAACgB,OAAO,GAAGnB,KAAK,CAACO,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B,IAAI,CAACC,YAAY,GAAGD,UAAU,CAACE,WAAW,CAAC,2BAA2B,CAAC;IAEvE,MAAMC,gBAAgB,GAAG,IAAIvB,gBAAgB,CAAC;MAACI,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpDI,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IAEnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;EACEE,eAAeA,CAAA,EAAG;IAChB,IAAII,MAAM,GAAG,EAAE;IACf,IAAI,IAAI,CAACR,YAAY,CAACS,OAAO,GAAG,CAAC,EAAE;MACjCD,MAAM,GAAG,MAAM;IACjB,CAAC,MAAM;MACLA,MAAM,GAAG,KAAK;IAChB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACI,QAAQ,CAAC,IAAI,CAACd,OAAO,CAACR,QAAQ,EAAEoB,MAAM,CAAC;IAE1D,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEG,YAAYA,CAACb,KAAK,EAAE;IAClB,OAAOA,KAAK,CAACc,UAAU,CAAC,CAAC;EAC3B;AACF","ignoreList":[]}
1
+ {"version":3,"file":"SubHeadingsKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","MAIN_CONTENT_POINTS","SUBHEADINGS_KEYWORD_ID","SubHeadingsKeywordAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","priority","fixPosition","title","content","good","bad","improve","identifier","_config","getResult","paper","researcher","_subHeadings","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","matches","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/SubHeadingsKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {MAIN_CONTENT_POINTS, SUBHEADINGS_KEYWORD_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that checks if the keyword is present in one of the subheadings.\n */\nexport default class SubHeadingsKeywordAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {object} config The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SUBHEADINGS_KEYWORD_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-subheading',\n priority: 'medium',\n fixPosition: 'subheading',\n title: 'Keyword in Subheading',\n content: {\n good: 'Keywords are included in subheadings.',\n bad:\n 'Keyword not found in any subheadings. Include it in at least one subheading (H2, H3, etc.).',\n improve: ''\n }\n };\n\n this.identifier = SUBHEADINGS_KEYWORD_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n\n this._subHeadings = researcher.getResearch('matchKeywordInSubheadings');\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n let status = 'bad';\n if (this._subHeadings.matches > 0) {\n status = 'good';\n }\n\n const score = this.getScore(MAIN_CONTENT_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n *\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper) {\n return true;\n }\n}\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,mBAAmB,EAAEC,sBAAsB;;AAEnD;AACA;AACA;AACA,eAAe,MAAMC,4BAA4B,SAASJ,UAAU,CAAC;EACnE;AACF;AACA;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,sBAAsB;MAC1BM,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,mGAAmG;MACrGC,QAAQ,EAAE,QAAQ;MAClBC,WAAW,EAAE,YAAY;MACzBC,KAAK,EAAE,uBAAuB;MAC9BC,OAAO,EAAE;QACPC,IAAI,EAAE,uCAAuC;QAC7CC,GAAG,EACD,6FAA6F;QAC/FC,OAAO,EAAE;MACX;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,sBAAsB;IACxC,IAAI,CAACgB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAE7B,IAAI,CAACC,YAAY,GAAGD,UAAU,CAACE,WAAW,CAAC,2BAA2B,CAAC;IAEvE,MAAMC,gBAAgB,GAAG,IAAIxB,gBAAgB,CAAC;MAACK,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMO,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACN,KAAK,CAAC;IAEpDI,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IAEnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;EACEE,eAAeA,CAAA,EAAG;IAChB,IAAII,MAAM,GAAG,KAAK;IAClB,IAAI,IAAI,CAACR,YAAY,CAACS,OAAO,GAAG,CAAC,EAAE;MACjCD,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACI,QAAQ,CAAC/B,mBAAmB,EAAE6B,MAAM,CAAC;IAExD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEG,YAAYA,CAACb,KAAK,EAAE;IAClB,OAAO,IAAI;EACb;AACF","ignoreList":[]}
@@ -3,7 +3,7 @@ import Assessment from "../assessment";
3
3
  import AssessmentResult from "../../../values/AssessmentResult";
4
4
  import { checkMissingAlt } from "../../../helpers";
5
5
  import { ExternalIcon } from '@shopify/polaris-icons';
6
- import { TEXT_IMAGES_ID } from "../../../const/analysis";
6
+ import { TECHNICAL_SEO_POINTS, TEXT_IMAGES_ID } from "../../../const/analysis";
7
7
 
8
8
  /**
9
9
  * Represents the assessment that assesses the SEO title width and gives the feedback accordingly.
@@ -70,7 +70,7 @@ export default class TextImagesAssessment extends Assessment {
70
70
  } else {
71
71
  status = 'good';
72
72
  }
73
- const score = this.getScore(this._config.priority, status);
73
+ const score = this.getScore(TECHNICAL_SEO_POINTS, status);
74
74
  return {
75
75
  score,
76
76
  status
@@ -115,8 +115,7 @@ export default class TextImagesAssessment extends Assessment {
115
115
  * @returns {boolean} True when there is text.
116
116
  */
117
117
  isApplicable(paper, researcher) {
118
- this.imageCount = researcher.getResearch('imageCount');
119
- return paper.hasText() && this.imageCount > 0;
118
+ return true;
120
119
  }
121
120
  }
122
121
  //# sourceMappingURL=TextImagesAssessment.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextImagesAssessment.js","names":["merge","Assessment","AssessmentResult","checkMissingAlt","ExternalIcon","TEXT_IMAGES_ID","TextImagesAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","fixPosition","icon","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","assessmentResult","altTagsProperties","getResearch","imageCount","calculatedResult","calculateResult","setScore","score","setStatus","status","imagesNoAlt","noAlt","getScore","fix","shop","data","console","log","body","altText","name","parser","DOMParser","doc","parseFromString","imgTags","querySelectorAll","forEach","img","hasAttribute","getAttribute","setAttribute","innerHTML","isApplicable","hasText"],"sources":["../../../../../src/scoring/assessments/seo/TextImagesAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {checkMissingAlt} from '../../../helpers';\nimport {ExternalIcon} from '@shopify/polaris-icons';\nimport {TEXT_IMAGES_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that assesses the SEO title width and gives the feedback accordingly.\n */\nexport default class TextImagesAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: TEXT_IMAGES_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#alt-text',\n fixPosition: 'description',\n icon: ExternalIcon,\n priority: 'high',\n title: 'Alt text',\n content: {\n good: 'All images have descriptive and relevant alt text.',\n improve: '',\n bad: 'Missing alt text. Add descriptive alt text for accessibility and SEO.'\n }\n };\n\n this.identifier = TEXT_IMAGES_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n this.altTagsProperties = researcher.getResearch('altTagCount');\n this.imageCount = researcher.getResearch('imageCount');\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n const imagesNoAlt = this.altTagsProperties.noAlt;\n\n let status = '';\n if (imagesNoAlt === this.imageCount || imagesNoAlt > 0) {\n status = 'bad';\n } else {\n status = 'good';\n }\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n *\n * @param shop\n * @param data\n * @returns {string}\n */\n fix({shop, data}) {\n if (!shop) {\n console.log('Shop is missing');\n return data.body || '';\n }\n\n if (!data.body) {\n console.log('body is missing');\n return '';\n }\n\n const altText = shop?.name || 'Shop' + ' | ' + data?.title || 'Title';\n\n const parser = new DOMParser();\n const doc = parser.parseFromString(data.body, 'text/html');\n\n const imgTags = doc.querySelectorAll('img');\n\n imgTags.forEach(img => {\n if (!img.hasAttribute('alt') || img.getAttribute('alt') === '') {\n img.setAttribute('alt', altText);\n }\n });\n\n return doc.body.innerHTML;\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param researcher\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper, researcher) {\n this.imageCount = researcher.getResearch('imageCount');\n return paper.hasText() && this.imageCount > 0;\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"TextImagesAssessment.js","names":["merge","Assessment","AssessmentResult","checkMissingAlt","ExternalIcon","TECHNICAL_SEO_POINTS","TEXT_IMAGES_ID","TextImagesAssessment","constructor","config","defaultConfig","id","ctaType","docUrl","fixPosition","icon","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","assessmentResult","altTagsProperties","getResearch","imageCount","calculatedResult","calculateResult","setScore","score","setStatus","status","imagesNoAlt","noAlt","getScore","fix","shop","data","console","log","body","altText","name","parser","DOMParser","doc","parseFromString","imgTags","querySelectorAll","forEach","img","hasAttribute","getAttribute","setAttribute","innerHTML","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/TextImagesAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {checkMissingAlt} from '../../../helpers';\nimport {ExternalIcon} from '@shopify/polaris-icons';\nimport {TECHNICAL_SEO_POINTS, TEXT_IMAGES_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents the assessment that assesses the SEO title width and gives the feedback accordingly.\n */\nexport default class TextImagesAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: TEXT_IMAGES_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#alt-text',\n fixPosition: 'description',\n icon: ExternalIcon,\n priority: 'high',\n title: 'Alt text',\n content: {\n good: 'All images have descriptive and relevant alt text.',\n improve: '',\n bad: 'Missing alt text. Add descriptive alt text for accessibility and SEO.'\n }\n };\n\n this.identifier = TEXT_IMAGES_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Runs the h1 research and based on this returns an assessment result with a score.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher used for calling the research.\n * @returns {AssessmentResult} The assessment result.\n */\n getResult({paper, researcher}) {\n const assessmentResult = new AssessmentResult({config: this._config});\n this.altTagsProperties = researcher.getResearch('altTagCount');\n this.imageCount = researcher.getResearch('imageCount');\n\n const calculatedResult = this.calculateResult(paper);\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @returns {{score: number, status: string}}\n */\n calculateResult() {\n const imagesNoAlt = this.altTagsProperties.noAlt;\n\n let status = '';\n if (imagesNoAlt === this.imageCount || imagesNoAlt > 0) {\n status = 'bad';\n } else {\n status = 'good';\n }\n\n const score = this.getScore(TECHNICAL_SEO_POINTS, status);\n\n return {\n score,\n status\n };\n }\n\n /**\n *\n * @param shop\n * @param data\n * @returns {string}\n */\n fix({shop, data}) {\n if (!shop) {\n console.log('Shop is missing');\n return data.body || '';\n }\n\n if (!data.body) {\n console.log('body is missing');\n return '';\n }\n\n const altText = shop?.name || 'Shop' + ' | ' + data?.title || 'Title';\n\n const parser = new DOMParser();\n const doc = parser.parseFromString(data.body, 'text/html');\n\n const imgTags = doc.querySelectorAll('img');\n\n imgTags.forEach(img => {\n if (!img.hasAttribute('alt') || img.getAttribute('alt') === '') {\n img.setAttribute('alt', altText);\n }\n });\n\n return doc.body.innerHTML;\n }\n\n /**\n * Checks whether the paper has a text.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param researcher\n * @returns {boolean} True when there is text.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -3,12 +3,12 @@ import Assessment from "../assessment";
3
3
  import AssessmentResult from "../../../values/AssessmentResult";
4
4
  import wordCountInText from "../../../languageProcessing/researches/wordCountInText";
5
5
  import countCharacters from "../../../languageProcessing/languages/ja/helpers/countCharacters";
6
- import { TEXT_LENGTH_ID } from "../../../const/analysis";
6
+ import { MAIN_CONTENT_POINTS, TEXT_LENGTH_ID } from "../../../const/analysis";
7
7
 
8
8
  /**
9
9
  * Represents an assessment that checks the length of the text and gives feedback accordingly.
10
10
  */
11
- export default class TextLengthAssessment extends Assessment {
11
+ class TextLengthAssessment extends Assessment {
12
12
  /**
13
13
  * Sets the identifier and the config.
14
14
  *
@@ -62,23 +62,39 @@ export default class TextLengthAssessment extends Assessment {
62
62
  * @returns {{score: number, status: string}}
63
63
  */
64
64
  calculateResult(paper) {
65
+ const pageType = paper.getPageType();
65
66
  const wordCount = wordCountInText(paper).count;
66
67
  const charCount = countCharacters(paper.getText());
67
68
  let status = 'bad';
68
- if (charCount < 2500 && wordCount >= 600) {
69
- status = 'improve';
69
+ if (pageType === "product" && charCount <= 500 && wordCount >= 300) {
70
+ status = 'good';
70
71
  }
71
- if (wordCount < 600 && charCount < 2500) {
72
- status = 'bad';
72
+ if (pageType === "collection" && charCount <= 300 && wordCount >= 150) {
73
+ status = 'good';
73
74
  }
74
- if (charCount >= 2500 && wordCount >= 600) {
75
+ if (pageType === "article" && charCount <= 1000 && wordCount >= 600) {
75
76
  status = 'good';
76
77
  }
77
- const score = this.getScore(this._config.priority, status);
78
+ if (pageType === "page" && charCount <= 1000 && wordCount >= 600) {
79
+ status = 'good';
80
+ }
81
+ const score = this.getScore(MAIN_CONTENT_POINTS, status);
78
82
  return {
79
83
  score,
80
84
  status
81
85
  };
82
86
  }
87
+ /**
88
+ * Checks whether the paper has a keyword and a slug.
89
+ *
90
+ * @param {Paper} paper The paper to use for the assessment.
91
+ * @param {Researcher} researcher The researcher object.
92
+ *
93
+ * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.
94
+ */
95
+ isApplicable(paper, researcher) {
96
+ return true;
97
+ }
83
98
  }
99
+ export default TextLengthAssessment;
84
100
  //# sourceMappingURL=TextLengthAssessment.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextLengthAssessment.js","names":["merge","Assessment","AssessmentResult","wordCountInText","countCharacters","TEXT_LENGTH_ID","TextLengthAssessment","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","wordCount","count","charCount","getText","getScore"],"sources":["../../../../../src/scoring/assessments/seo/TextLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport wordCountInText from '@axyseo/languageProcessing/researches/wordCountInText';\nimport countCharacters from '@axyseo/languageProcessing/languages/ja/helpers/countCharacters';\nimport {TEXT_LENGTH_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks the length of the text and gives feedback accordingly.\n */\nexport default class TextLengthAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: TEXT_LENGTH_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#text-length',\n priority: 'high',\n fixPosition: 'description',\n title: 'Text length',\n content: {\n good: 'Text length is optimized.',\n improve:\n 'Content length is acceptable, but could be expanded to 2,500 characters for more value.',\n bad:\n 'Insufficient content. Aim for at least 600 words to provide value and rank well in search results.'\n }\n };\n\n this.identifier = TEXT_LENGTH_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const wordCount = wordCountInText(paper).count;\n const charCount = countCharacters(paper.getText());\n\n let status = 'bad';\n if (charCount < 2500 && wordCount >= 600) {\n status = 'improve';\n }\n if (wordCount < 600 && charCount < 2500) {\n status = 'bad';\n }\n if (charCount >= 2500 && wordCount >= 600) {\n status = 'good';\n }\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n}\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,OAAOC,eAAe;AACtB,OAAOC,eAAe;AACtB,SAAQC,cAAc;;AAEtB;AACA;AACA;AACA,eAAe,MAAMC,oBAAoB,SAASL,UAAU,CAAC;EAC3D;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,cAAc;MAClBM,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,yFAAyF;MAC3FC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,aAAa;MAC1BC,KAAK,EAAE,aAAa;MACpBC,OAAO,EAAE;QACPC,IAAI,EAAE,2BAA2B;QACjCC,OAAO,EACL,yFAAyF;QAC3FC,GAAG,EACD;MACJ;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,cAAc;IAChC,IAAI,CAACgB,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,MAAMC,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAACH,KAAK,CAAC;IAEpD,MAAMI,gBAAgB,GAAG,IAAIzB,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IACrEM,gBAAgB,CAACC,QAAQ,CAACH,gBAAgB,CAACI,KAAK,CAAC;IACjDF,gBAAgB,CAACG,SAAS,CAACL,gBAAgB,CAACM,MAAM,CAAC;IAEnD,OAAOJ,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB,MAAMS,SAAS,GAAG7B,eAAe,CAACoB,KAAK,CAAC,CAACU,KAAK;IAC9C,MAAMC,SAAS,GAAG9B,eAAe,CAACmB,KAAK,CAACY,OAAO,CAAC,CAAC,CAAC;IAElD,IAAIJ,MAAM,GAAG,KAAK;IAClB,IAAIG,SAAS,GAAG,IAAI,IAAIF,SAAS,IAAI,GAAG,EAAE;MACxCD,MAAM,GAAG,SAAS;IACpB;IACA,IAAIC,SAAS,GAAG,GAAG,IAAIE,SAAS,GAAG,IAAI,EAAE;MACvCH,MAAM,GAAG,KAAK;IAChB;IACA,IAAIG,SAAS,IAAI,IAAI,IAAIF,SAAS,IAAI,GAAG,EAAE;MACzCD,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACO,QAAQ,CAAC,IAAI,CAACf,OAAO,CAACR,QAAQ,EAAEkB,MAAM,CAAC;IAE1D,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF","ignoreList":[]}
1
+ {"version":3,"file":"TextLengthAssessment.js","names":["merge","Assessment","AssessmentResult","wordCountInText","countCharacters","MAIN_CONTENT_POINTS","TEXT_LENGTH_ID","TextLengthAssessment","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","pageType","getPageType","wordCount","count","charCount","getText","getScore","isApplicable"],"sources":["../../../../../src/scoring/assessments/seo/TextLengthAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport wordCountInText from '@axyseo/languageProcessing/researches/wordCountInText';\nimport countCharacters from '@axyseo/languageProcessing/languages/ja/helpers/countCharacters';\nimport {MAIN_CONTENT_POINTS, TEXT_LENGTH_ID} from '@axyseo/const/analysis';\n\n/**\n * Represents an assessment that checks the length of the text and gives feedback accordingly.\n */\n class TextLengthAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} [config] The configuration to use.\n *\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: TEXT_LENGTH_ID,\n ctaType: 'fix',\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#text-length',\n priority: 'high',\n fixPosition: 'description',\n title: 'Text length',\n content: {\n good: 'Text length is optimized.',\n improve:\n 'Content length is acceptable, but could be expanded to 2,500 characters for more value.',\n bad:\n 'Insufficient content. Aim for at least 600 words to provide value and rank well in search results.'\n }\n };\n\n this.identifier = TEXT_LENGTH_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n const calculatedResult = this.calculateResult(paper);\n const assessmentResult = new AssessmentResult({config: this._config});\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n\n return assessmentResult;\n }\n\n /**\n *\n * @param paper\n * @returns {{score: number, status: string}}\n */\n calculateResult(paper) {\n const pageType = paper.getPageType();\n const wordCount = wordCountInText(paper).count;\n const charCount = countCharacters(paper.getText());\n\n let status = 'bad';\n if (pageType === \"product\" && charCount <= 500 && wordCount >= 300) {\n status = 'good';\n }\n if (pageType === \"collection\" && charCount <= 300 && wordCount >= 150) {\n status = 'good';\n }\n if (pageType === \"article\" && charCount <= 1000 && wordCount >= 600) {\n status = 'good';\n }\n if (pageType === \"page\" && charCount <= 1000 && wordCount >= 600) {\n status = 'good';\n }\n\n const score = this.getScore(MAIN_CONTENT_POINTS, status);\n\n return {\n score,\n status\n };\n }\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n}\n\nexport default TextLengthAssessment;\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,OAAOC,eAAe;AACtB,OAAOC,eAAe;AACtB,SAAQC,mBAAmB,EAAEC,cAAc;;AAE3C;AACA;AACA;AACC,MAAMC,oBAAoB,SAASN,UAAU,CAAC;EAC7C;AACF;AACA;AACA;AACA;AACA;AACA;EACEO,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEL,cAAc;MAClBM,OAAO,EAAE,KAAK;MACdC,MAAM,EACJ,yFAAyF;MAC3FC,QAAQ,EAAE,MAAM;MAChBC,WAAW,EAAE,aAAa;MAC1BC,KAAK,EAAE,aAAa;MACpBC,OAAO,EAAE;QACPC,IAAI,EAAE,2BAA2B;QACjCC,OAAO,EACL,yFAAyF;QAC3FC,GAAG,EACD;MACJ;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGf,cAAc;IAChC,IAAI,CAACgB,OAAO,GAAGtB,KAAK,CAACU,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,IAAI1B,gBAAgB,CAAC;MAACO,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IACrEM,gBAAgB,CAACC,QAAQ,CAACH,gBAAgB,CAACI,KAAK,CAAC;IACjDF,gBAAgB,CAACG,SAAS,CAACL,gBAAgB,CAACM,MAAM,CAAC;IAEnD,OAAOJ,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;EACED,eAAeA,CAACH,KAAK,EAAE;IACrB,MAAMS,QAAQ,GAAGT,KAAK,CAACU,WAAW,CAAC,CAAC;IACpC,MAAMC,SAAS,GAAGhC,eAAe,CAACqB,KAAK,CAAC,CAACY,KAAK;IAC9C,MAAMC,SAAS,GAAGjC,eAAe,CAACoB,KAAK,CAACc,OAAO,CAAC,CAAC,CAAC;IAElD,IAAIN,MAAM,GAAG,KAAK;IAClB,IAAIC,QAAQ,KAAK,SAAS,IAAII,SAAS,IAAI,GAAG,IAAIF,SAAS,IAAI,GAAG,EAAE;MAClEH,MAAM,GAAG,MAAM;IACjB;IACA,IAAIC,QAAQ,KAAK,YAAY,IAAII,SAAS,IAAI,GAAG,IAAIF,SAAS,IAAI,GAAG,EAAE;MACrEH,MAAM,GAAG,MAAM;IACjB;IACA,IAAIC,QAAQ,KAAK,SAAS,IAAII,SAAS,IAAI,IAAI,IAAIF,SAAS,IAAI,GAAG,EAAE;MACnEH,MAAM,GAAG,MAAM;IACjB;IACA,IAAIC,QAAQ,KAAK,MAAM,IAAII,SAAS,IAAI,IAAI,IAAIF,SAAS,IAAI,GAAG,EAAE;MAChEH,MAAM,GAAG,MAAM;IACjB;IAEA,MAAMF,KAAK,GAAG,IAAI,CAACS,QAAQ,CAAClC,mBAAmB,EAAE2B,MAAM,CAAC;IAExD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;EACA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEQ,YAAYA,CAAChB,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;AACF;AAEA,eAAelB,oBAAoB","ignoreList":[]}
@@ -1,9 +1,8 @@
1
- import { Text } from '@shopify/polaris';
2
1
  import { merge } from 'lodash';
3
2
  import Assessment from "../assessment";
4
3
  import AssessmentResult from "../../../values/AssessmentResult";
5
- import { SLUG_KEYWORD_ID } from "../../../const/analysis";
6
- import { enhanceResearcherForChinese } from "../../../languageProcessing/helpers/language/chineseHelperFactory.js";
4
+ import { SLUG_KEYWORD_ID, URLS_POINTS } from "../../../const/analysis";
5
+ import { enhanceResearcherForChinese } from "../../../languageProcessing/helpers/language/chineseHelperFactory";
7
6
 
8
7
  /**
9
8
  * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.
@@ -68,7 +67,7 @@ class SlugKeywordAssessment extends Assessment {
68
67
  * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.
69
68
  */
70
69
  isApplicable(paper, researcher) {
71
- return !paper.isFrontPage() && paper.hasKeyword() && paper.hasSlug() && researcher.hasResearch('keywordCountInSlug');
70
+ return true;
72
71
  }
73
72
 
74
73
  /**
@@ -79,7 +78,7 @@ class SlugKeywordAssessment extends Assessment {
79
78
  const status = (() => {
80
79
  return this._keywordInSlug.percentWordMatches >= 50 ? 'good' : 'bad';
81
80
  })();
82
- const score = this.getScore(this._config.priority, status);
81
+ const score = this.getScore(URLS_POINTS, status);
83
82
  return {
84
83
  score,
85
84
  status
@@ -1 +1 @@
1
- {"version":3,"file":"UrlKeywordAssessment.js","names":["Text","merge","Assessment","AssessmentResult","SLUG_KEYWORD_ID","enhanceResearcherForChinese","SlugKeywordAssessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","enhancedResearcher","getSlug","getKeyword","_keywordInSlug","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","isFrontPage","hasKeyword","hasSlug","hasResearch","percentWordMatches","getScore"],"sources":["../../../../../src/scoring/assessments/seo/UrlKeywordAssessment.js"],"sourcesContent":["import {Text} from '@shopify/polaris';\nimport {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {SLUG_KEYWORD_ID} from '@axyseo/const/analysis';\nimport {enhanceResearcherForChinese} from '../../../languageProcessing/helpers/language/chineseHelperFactory.js';\n\n/**\n * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.\n */\nclass SlugKeywordAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SLUG_KEYWORD_ID,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-url',\n fixPosition: 'url handle',\n ctaType: 'fix',\n priority: 'medium',\n title: 'Keyword in URL',\n content: {\n good: 'Keyword is included in URL.',\n improve: '',\n bad: 'Missing keyword in URL. Include it for relevance and better SEO.'\n }\n };\n\n this.identifier = SLUG_KEYWORD_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n // Enhance researcher for Chinese if needed - specifically for URL context\n const enhancedResearcher = enhanceResearcherForChinese(\n researcher,\n paper.getSlug(),\n paper.getKeyword(),\n true // isUrlContext = true for enhanced Chinese URL matching\n );\n\n this._keywordInSlug = enhancedResearcher.getResearch('keywordCountInSlug');\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult();\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return (\n !paper.isFrontPage() &&\n paper.hasKeyword() &&\n paper.hasSlug() &&\n researcher.hasResearch('keywordCountInSlug')\n );\n }\n\n /**\n *\n * @returns {{score: number, status: (string)}}\n */\n calculateResult() {\n const status = (() => {\n return this._keywordInSlug.percentWordMatches >= 50 ? 'good' : 'bad';\n })();\n\n const score = this.getScore(this._config.priority, status);\n\n return {\n score,\n status\n };\n }\n}\n\nexport default SlugKeywordAssessment;\n"],"mappings":"AAAA,SAAQA,IAAI,QAAO,kBAAkB;AACrC,SAAQC,KAAK,QAAO,QAAQ;AAE5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe;AACvB,SAAQC,2BAA2B;;AAEnC;AACA;AACA;AACA,MAAMC,qBAAqB,SAASJ,UAAU,CAAC;EAC7C;AACF;AACA;AACA;AACA;AACA;EACEK,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEN,eAAe;MACnBO,MAAM,EACJ,4FAA4F;MAC9FC,WAAW,EAAE,YAAY;MACzBC,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE,QAAQ;MAClBC,KAAK,EAAE,gBAAgB;MACvBC,OAAO,EAAE;QACPC,IAAI,EAAE,6BAA6B;QACnCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGhB,eAAe;IACjC,IAAI,CAACiB,OAAO,GAAGpB,KAAK,CAACQ,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B;IACA,MAAMC,kBAAkB,GAAGpB,2BAA2B,CACpDmB,UAAU,EACVD,KAAK,CAACG,OAAO,CAAC,CAAC,EACfH,KAAK,CAACI,UAAU,CAAC,CAAC,EAClB,IAAI,CAAC;IACP,CAAC;IAED,IAAI,CAACC,cAAc,GAAGH,kBAAkB,CAACI,WAAW,CAAC,oBAAoB,CAAC;IAE1E,MAAMC,gBAAgB,GAAG,IAAI3B,gBAAgB,CAAC;MAACK,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,OACE,CAACD,KAAK,CAACe,WAAW,CAAC,CAAC,IACpBf,KAAK,CAACgB,UAAU,CAAC,CAAC,IAClBhB,KAAK,CAACiB,OAAO,CAAC,CAAC,IACfhB,UAAU,CAACiB,WAAW,CAAC,oBAAoB,CAAC;EAEhD;;EAEA;AACF;AACA;AACA;EACET,eAAeA,CAAA,EAAG;IAChB,MAAMI,MAAM,GAAG,CAAC,MAAM;MACpB,OAAO,IAAI,CAACR,cAAc,CAACc,kBAAkB,IAAI,EAAE,GAAG,MAAM,GAAG,KAAK;IACtE,CAAC,EAAE,CAAC;IAEJ,MAAMR,KAAK,GAAG,IAAI,CAACS,QAAQ,CAAC,IAAI,CAACtB,OAAO,CAACP,QAAQ,EAAEsB,MAAM,CAAC;IAE1D,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAEA,eAAe9B,qBAAqB","ignoreList":[]}
1
+ {"version":3,"file":"UrlKeywordAssessment.js","names":["merge","Assessment","AssessmentResult","SLUG_KEYWORD_ID","URLS_POINTS","enhanceResearcherForChinese","SlugKeywordAssessment","constructor","config","defaultConfig","id","docUrl","fixPosition","ctaType","priority","title","content","good","improve","bad","identifier","_config","getResult","paper","researcher","enhancedResearcher","getSlug","getKeyword","_keywordInSlug","getResearch","assessmentResult","calculatedResult","calculateResult","setScore","score","setStatus","status","isApplicable","percentWordMatches","getScore"],"sources":["../../../../../src/scoring/assessments/seo/UrlKeywordAssessment.js"],"sourcesContent":["import {merge} from 'lodash';\n\nimport Assessment from '../assessment';\nimport AssessmentResult from '../../../values/AssessmentResult';\nimport {SLUG_KEYWORD_ID, URLS_POINTS} from '@axyseo/const/analysis';\nimport {enhanceResearcherForChinese} from '@axyseo/languageProcessing/helpers/language/chineseHelperFactory';\n\n/**\n * Represents the Slug keyword assessment. This assessment checks if the keyword is present in the slug.\n */\nclass SlugKeywordAssessment extends Assessment {\n /**\n * Sets the identifier and the config.\n *\n * @param {Object} config The configuration to use.\n * @returns {void}\n */\n constructor(config = {}) {\n super();\n\n const defaultConfig = {\n id: SLUG_KEYWORD_ID,\n docUrl:\n 'https://docs.avada.io/seo-suite-help-center/seo-audit/on-page-seo/checklist#keyword-in-url',\n fixPosition: 'url handle',\n ctaType: 'fix',\n priority: 'medium',\n title: 'Keyword in URL',\n content: {\n good: 'Keyword is included in URL.',\n improve: '',\n bad: 'Missing keyword in URL. Include it for relevance and better SEO.'\n }\n };\n\n this.identifier = SLUG_KEYWORD_ID;\n this._config = merge(defaultConfig, config);\n }\n\n /**\n * Executes the Assessment and returns a result.\n *\n * @param {Paper} paper The Paper object to assess.\n * @param {Researcher} researcher The Researcher object containing all available researches.\n *\n * @returns {AssessmentResult} The result of the assessment, containing both a score and a descriptive text.\n */\n getResult({paper, researcher}) {\n // Enhance researcher for Chinese if needed - specifically for URL context\n const enhancedResearcher = enhanceResearcherForChinese(\n researcher,\n paper.getSlug(),\n paper.getKeyword(),\n true // isUrlContext = true for enhanced Chinese URL matching\n );\n\n this._keywordInSlug = enhancedResearcher.getResearch('keywordCountInSlug');\n\n const assessmentResult = new AssessmentResult({config: this._config});\n\n const calculatedResult = this.calculateResult();\n\n assessmentResult.setScore(calculatedResult.score);\n assessmentResult.setStatus(calculatedResult.status);\n return assessmentResult;\n }\n\n /**\n * Checks whether the paper has a keyword and a slug.\n *\n * @param {Paper} paper The paper to use for the assessment.\n * @param {Researcher} researcher The researcher object.\n *\n * @returns {boolean} True if the paper contains a keyword and a slug, and if the keywordCountInSlug research is available on the researcher.\n */\n isApplicable(paper, researcher) {\n return true;\n }\n\n /**\n *\n * @returns {{score: number, status: (string)}}\n */\n calculateResult() {\n const status = (() => {\n return this._keywordInSlug.percentWordMatches >= 50 ? 'good' : 'bad';\n })();\n\n const score = this.getScore(URLS_POINTS, status);\n\n return {\n score,\n status\n };\n }\n}\n\nexport default SlugKeywordAssessment;\n"],"mappings":"AAAA,SAAQA,KAAK,QAAO,QAAQ;AAE5B,OAAOC,UAAU;AACjB,OAAOC,gBAAgB;AACvB,SAAQC,eAAe,EAAEC,WAAW;AACpC,SAAQC,2BAA2B;;AAEnC;AACA;AACA;AACA,MAAMC,qBAAqB,SAASL,UAAU,CAAC;EAC7C;AACF;AACA;AACA;AACA;AACA;EACEM,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,KAAK,CAAC,CAAC;IAEP,MAAMC,aAAa,GAAG;MACpBC,EAAE,EAAEP,eAAe;MACnBQ,MAAM,EACJ,4FAA4F;MAC9FC,WAAW,EAAE,YAAY;MACzBC,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE,QAAQ;MAClBC,KAAK,EAAE,gBAAgB;MACvBC,OAAO,EAAE;QACPC,IAAI,EAAE,6BAA6B;QACnCC,OAAO,EAAE,EAAE;QACXC,GAAG,EAAE;MACP;IACF,CAAC;IAED,IAAI,CAACC,UAAU,GAAGjB,eAAe;IACjC,IAAI,CAACkB,OAAO,GAAGrB,KAAK,CAACS,aAAa,EAAED,MAAM,CAAC;EAC7C;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEc,SAASA,CAAC;IAACC,KAAK;IAAEC;EAAU,CAAC,EAAE;IAC7B;IACA,MAAMC,kBAAkB,GAAGpB,2BAA2B,CACpDmB,UAAU,EACVD,KAAK,CAACG,OAAO,CAAC,CAAC,EACfH,KAAK,CAACI,UAAU,CAAC,CAAC,EAClB,IAAI,CAAC;IACP,CAAC;IAED,IAAI,CAACC,cAAc,GAAGH,kBAAkB,CAACI,WAAW,CAAC,oBAAoB,CAAC;IAE1E,MAAMC,gBAAgB,GAAG,IAAI5B,gBAAgB,CAAC;MAACM,MAAM,EAAE,IAAI,CAACa;IAAO,CAAC,CAAC;IAErE,MAAMU,gBAAgB,GAAG,IAAI,CAACC,eAAe,CAAC,CAAC;IAE/CF,gBAAgB,CAACG,QAAQ,CAACF,gBAAgB,CAACG,KAAK,CAAC;IACjDJ,gBAAgB,CAACK,SAAS,CAACJ,gBAAgB,CAACK,MAAM,CAAC;IACnD,OAAON,gBAAgB;EACzB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEO,YAAYA,CAACd,KAAK,EAAEC,UAAU,EAAE;IAC9B,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;EACEQ,eAAeA,CAAA,EAAG;IAChB,MAAMI,MAAM,GAAG,CAAC,MAAM;MACpB,OAAO,IAAI,CAACR,cAAc,CAACU,kBAAkB,IAAI,EAAE,GAAG,MAAM,GAAG,KAAK;IACtE,CAAC,EAAE,CAAC;IAEJ,MAAMJ,KAAK,GAAG,IAAI,CAACK,QAAQ,CAACnC,WAAW,EAAEgC,MAAM,CAAC;IAEhD,OAAO;MACLF,KAAK;MACLE;IACF,CAAC;EACH;AACF;AAEA,eAAe9B,qBAAqB","ignoreList":[]}