core-maugli 1.0.2

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 (206) hide show
  1. package/LICENSE +727 -0
  2. package/README.md +108 -0
  3. package/bin/index.js +9 -0
  4. package/bin/init.js +38 -0
  5. package/package.json +73 -0
  6. package/public/blackbox.webp +0 -0
  7. package/public/favicon.svg +10 -0
  8. package/public/footerlabel.svg +18 -0
  9. package/public/icon-192.png +0 -0
  10. package/public/icon-512.png +0 -0
  11. package/public/img/page-images/blog_default.webp +0 -0
  12. package/public/logo-icon.svg +3 -0
  13. package/public/logoblog-icon.svg +10 -0
  14. package/public/manifest.webmanifest +21 -0
  15. package/public/maugli_for_animation.svg +6 -0
  16. package/public/mauglilabel.svg +17 -0
  17. package/public/tr-about-1200.webp +0 -0
  18. package/public/tr-about-400.webp +0 -0
  19. package/public/tr-about-800.webp +0 -0
  20. package/public/tr-about.webp +0 -0
  21. package/public/tr-post-1-1200.webp +0 -0
  22. package/public/tr-post-1-400.webp +0 -0
  23. package/public/tr-post-1-800.webp +0 -0
  24. package/public/tr-post0-1200.webp +0 -0
  25. package/public/tr-post0-400.webp +0 -0
  26. package/public/tr-post0-800.webp +0 -0
  27. package/public/tr-post0.webp +0 -0
  28. package/public/tr-prewiew.webp +0 -0
  29. package/resize-all.cjs +29 -0
  30. package/scripts/featured.js +208 -0
  31. package/scripts/update-with-backup.js +34 -0
  32. package/scripts/upgrade-config.js +90 -0
  33. package/scripts/verify-assets.js +28 -0
  34. package/src/assets/img/default/autor_default.webp +0 -0
  35. package/src/assets/img/default/blog_default.webp +0 -0
  36. package/src/assets/img/default/product_default.webp +0 -0
  37. package/src/assets/img/default/project_default.webp +0 -0
  38. package/src/assets/img/default/rubric_default.webp +0 -0
  39. package/src/assets/img/examples/authors/anna.webp +0 -0
  40. package/src/assets/img/examples/authors/carlos.webp +0 -0
  41. package/src/assets/img/examples/authors/daria.webp +0 -0
  42. package/src/assets/img/examples/authors/dmitry.webp +0 -0
  43. package/src/assets/img/examples/authors/igor.webp +0 -0
  44. package/src/assets/img/examples/authors/john.webp +0 -0
  45. package/src/assets/img/examples/blog/post-1-avtomatizaciya-marketinga-kak-ii-osvobozhdaet-predprinimatelei-ot-cifrovogo-rabstva.webp +0 -0
  46. package/src/assets/img/examples/blog/post_11.webp +0 -0
  47. package/src/assets/img/examples/blog/post_12.webp +0 -0
  48. package/src/assets/img/examples/blog/post_1_jsonld_guide.webp +0 -0
  49. package/src/assets/img/examples/blog/test-post.webp +0 -0
  50. package/src/assets/img/examples/blog/tr-post-1.webp +0 -0
  51. package/src/assets/img/examples/products/product_1.webp +0 -0
  52. package/src/assets/img/examples/products/product_2.webp +0 -0
  53. package/src/assets/img/examples/projects/project_1.webp +0 -0
  54. package/src/assets/img/examples/projects/project_2.webp +0 -0
  55. package/src/components/ArticleMeta.astro +103 -0
  56. package/src/components/AuthorCard.astro +95 -0
  57. package/src/components/AuthorLink.astro +25 -0
  58. package/src/components/AuthorLinksGroup.astro +135 -0
  59. package/src/components/Avatar.astro +32 -0
  60. package/src/components/BaseHead.astro +121 -0
  61. package/src/components/Breadcrumbs.astro +90 -0
  62. package/src/components/Button.astro +25 -0
  63. package/src/components/Card.astro +99 -0
  64. package/src/components/ContentFooter.astro +147 -0
  65. package/src/components/CopyLinkButton.astro +133 -0
  66. package/src/components/CountBadge.astro +17 -0
  67. package/src/components/Footer.astro +122 -0
  68. package/src/components/FormattedDate.astro +59 -0
  69. package/src/components/Header.astro +18 -0
  70. package/src/components/HeroImage.astro +38 -0
  71. package/src/components/IconButton.astro +23 -0
  72. package/src/components/Image.astro +13 -0
  73. package/src/components/InfoCard.astro +123 -0
  74. package/src/components/LanguageSwitcher.astro +122 -0
  75. package/src/components/MaugliFloatingLabel.astro +454 -0
  76. package/src/components/MobileTagsAndShare.astro +71 -0
  77. package/src/components/Nav.astro +151 -0
  78. package/src/components/NavLink.astro +31 -0
  79. package/src/components/Pagination.astro +70 -0
  80. package/src/components/PostPreview.astro +22 -0
  81. package/src/components/ProductBannerCard.astro +47 -0
  82. package/src/components/ProductPreview.astro +21 -0
  83. package/src/components/ProjectPreview.astro +21 -0
  84. package/src/components/RubricCard.astro +142 -0
  85. package/src/components/ShareIcon.astro +93 -0
  86. package/src/components/ShareLink.astro +58 -0
  87. package/src/components/Subscribe.astro +68 -0
  88. package/src/components/SummaryFAQCard.astro +106 -0
  89. package/src/components/TableOfContents.astro +143 -0
  90. package/src/components/TagPill.astro +41 -0
  91. package/src/components/TagPills.astro +42 -0
  92. package/src/components/TagsAndShare.astro +379 -0
  93. package/src/components/TagsSection.astro +203 -0
  94. package/src/components/ThemeToggle.astro +58 -0
  95. package/src/config/maugli.config.ts +213 -0
  96. package/src/content/authors/daria-zorina.md +42 -0
  97. package/src/content/authors/default-autor.md +47 -0
  98. package/src/content/authors/igor-sokolov.md +43 -0
  99. package/src/content/authors/john-walker.md +46 -0
  100. package/src/content/blog/jsonld-guide.md +260 -0
  101. package/src/content/blog/post-0.md +49 -0
  102. package/src/content/blog/post-1-avtomatizaciya-marketinga-kak-ii-osvobozhdaet-predprinimatelei-ot-cifrovogo-rabstva.md +72 -0
  103. package/src/content/blog/post-agent-experience-mcp-biznes-v-epohu-ii-agentov.md +116 -0
  104. package/src/content/blog/test-post-2025-07-11.md +73 -0
  105. package/src/content/config.ts +80 -0
  106. package/src/content/pages/about.md +40 -0
  107. package/src/content/pages/about.mdx +27 -0
  108. package/src/content/pages/authors.mdx +49 -0
  109. package/src/content/pages/blog.mdx +31 -0
  110. package/src/content/pages/contact.md +10 -0
  111. package/src/content/pages/products.mdx +30 -0
  112. package/src/content/pages/projects.mdx +28 -0
  113. package/src/content/pages/rubrics.mdx +35 -0
  114. package/src/content/pages/terms.md +12 -0
  115. package/src/content/products/example-product.md +28 -0
  116. package/src/content/products/maugli-editor.md +35 -0
  117. package/src/content/products/maugli-freeblog.md +162 -0
  118. package/src/content/projects/example-project.md +28 -0
  119. package/src/content/projects/project-1.md +70 -0
  120. package/src/content/projects/project-2.md +33 -0
  121. package/src/content/tags/ai-business.mdx +18 -0
  122. package/src/content/tags/automation.mdx +18 -0
  123. package/src/content/tags/content-strategy.mdx +18 -0
  124. package/src/content/tags/growth-marketing.mdx +18 -0
  125. package/src/content/tags/industry-reviews.mdx +18 -0
  126. package/src/content/tags/interesting.mdx +18 -0
  127. package/src/content/tags/seo-ai-seo.mdx +18 -0
  128. package/src/content.config.ts +260 -0
  129. package/src/data/site-config.ts +164 -0
  130. package/src/i18n/de.json +126 -0
  131. package/src/i18n/en.json +126 -0
  132. package/src/i18n/es.json +126 -0
  133. package/src/i18n/fr.json +126 -0
  134. package/src/i18n/index.ts +10 -0
  135. package/src/i18n/ja.json +126 -0
  136. package/src/i18n/languages.ts +23 -0
  137. package/src/i18n/pt.json +126 -0
  138. package/src/i18n/ru.json +123 -0
  139. package/src/i18n/zh.json +126 -0
  140. package/src/icons/ArrowLeft.astro +13 -0
  141. package/src/icons/ArrowRight.astro +13 -0
  142. package/src/icons/flags/brazil.svg +14 -0
  143. package/src/icons/flags/china.svg +15 -0
  144. package/src/icons/flags/france.svg +12 -0
  145. package/src/icons/flags/germany.svg +12 -0
  146. package/src/icons/flags/japan.svg +11 -0
  147. package/src/icons/flags/russia.svg +12 -0
  148. package/src/icons/flags/spain.svg +12 -0
  149. package/src/icons/flags/united arab emirates.svg +13 -0
  150. package/src/icons/flags/united states.svg +15 -0
  151. package/src/icons/socials/BlueskyIcon.astro +9 -0
  152. package/src/icons/socials/EmailIcon.astro +8 -0
  153. package/src/icons/socials/LinkedinIcon.astro +9 -0
  154. package/src/icons/socials/MastodonIcon.astro +9 -0
  155. package/src/icons/socials/MediumIcon.astro +9 -0
  156. package/src/icons/socials/RedditIcon.astro +11 -0
  157. package/src/icons/socials/TelegramIcon.astro +11 -0
  158. package/src/icons/socials/TwitterIcon.astro +9 -0
  159. package/src/img/default/autor_default.webp +0 -0
  160. package/src/img/default/default.webp +0 -0
  161. package/src/img/default/rubric_default.webp +0 -0
  162. package/src/img/default/test.webp +0 -0
  163. package/src/img/default/test2.webp +0 -0
  164. package/src/img/examples/authors/anna.webp +0 -0
  165. package/src/img/examples/authors/carlos.webp +0 -0
  166. package/src/img/examples/authors/daria.webp +0 -0
  167. package/src/img/examples/authors/dmitry.webp +0 -0
  168. package/src/img/examples/authors/igor.webp +0 -0
  169. package/src/img/examples/authors/john.webp +0 -0
  170. package/src/img/examples/blog/post-1-avtomatizaciya-marketinga-kak-ii-osvobozhdaet-predprinimatelei-ot-cifrovogo-rabstva.webp +0 -0
  171. package/src/img/examples/blog/post-2-avtomatizaciya-kontenta-kak-neiroseti-ubivayut-perfekcionizm-v-biznese.webp +0 -0
  172. package/src/img/examples/blog/post-3-laik-ne-valyuta-kak-avtomatizaciya-marketinga-spasaet-ot-lozhnyh-metrik.webp +0 -0
  173. package/src/img/examples/blog/post-5-5-fatalnyh-oshibok-marketinga-kotorye-ubivayut-startapy-na-starte.webp +0 -0
  174. package/src/img/examples/blog/post-6-5-strategii-kontent-marketinga-dlya-startapov-avtomatizaciya-i-revolyuciya.webp +0 -0
  175. package/src/img/examples/blog/post-7-viralnyi-kontent-ne-udacha-a-strategiya-avtomatizaciya-marketinga.webp +0 -0
  176. package/src/img/examples/blog/post-agent-experience-mcp-biznes-v-epohu-ii-agentov.webp +0 -0
  177. package/src/img/examples/blog/post_1_jsonld_guide.webp +0 -0
  178. package/src/img/examples/blog/tr-post-1.webp +0 -0
  179. package/src/layouts/BaseLayout.astro +59 -0
  180. package/src/pages/404.astro +24 -0
  181. package/src/pages/[...id].astro +50 -0
  182. package/src/pages/about.astro +0 -0
  183. package/src/pages/authors/[...page].astro +105 -0
  184. package/src/pages/authors/[id].astro +165 -0
  185. package/src/pages/blog/[...page].astro +59 -0
  186. package/src/pages/blog/[id].astro +175 -0
  187. package/src/pages/index.astro +90 -0
  188. package/src/pages/products/[...page].astro +50 -0
  189. package/src/pages/products/[id].astro +221 -0
  190. package/src/pages/projects/[...page].astro +74 -0
  191. package/src/pages/projects/[id].astro +165 -0
  192. package/src/pages/projects/tags/[id]/[...page].astro +58 -0
  193. package/src/pages/rss.xml.js +5 -0
  194. package/src/pages/tags/[id]/[...page].astro +110 -0
  195. package/src/pages/tags/index.astro +124 -0
  196. package/src/scripts/infoCardFadeIn.js +22 -0
  197. package/src/styles/global.css +272 -0
  198. package/src/utils/common-utils.ts +0 -0
  199. package/src/utils/content-loader.ts +14 -0
  200. package/src/utils/data-utils.ts +49 -0
  201. package/src/utils/featuredManager.ts +118 -0
  202. package/src/utils/posts.ts +43 -0
  203. package/src/utils/reading-time.ts +28 -0
  204. package/src/utils/remark-slugify.js +8 -0
  205. package/src/utils/rss.ts +23 -0
  206. package/typograf-batch.js +49 -0
@@ -0,0 +1,213 @@
1
+ // MAUGLI_CONFIG_VERSION — config version for CLI/automation compatibility
2
+ export const MAUGLI_CONFIG_VERSION = '0.1';
3
+ // Main configuration interface for the Maugli project
4
+ export interface MaugliConfig {
5
+ // Show example/demo content (for CLI/empty blog setup)
6
+ showExamples?: boolean;
7
+ // Default author ID (used if no author is specified)
8
+ defaultAuthorId?: string;
9
+ // Show authors without articles (default: true)
10
+ showAuthorsWithoutArticles?: boolean;
11
+ // Config version for CLI/automation compatibility
12
+ configVersion?: string;
13
+ // Automation settings for integration with Maugli farm (not used on frontend)
14
+ automation?: {
15
+ farmName?: string; // Name of the farm/channel for integration
16
+ farmChannelId?: string; // Blog/channel ID for Maugli farm integration
17
+ farmAuthorIds?: string[]; // Array of farm author IDs for API
18
+ farmRubricIds?: string[]; // Array of farm rubric IDs for API
19
+ farmProductIds?: string[]; // Array of farm product IDs for API
20
+ farmProjectIds?: string[]; // Array of farm project/case IDs for API
21
+ };
22
+ // Brand and logo settings
23
+ brand: {
24
+ name: string; // Brand name
25
+ description: string; // Brand description
26
+ logoLight: string; // Logo for navigation (light theme). Used for dark theme if logoDark is not specified.
27
+ logoDark?: string; // Logo for navigation (dark theme). If not specified, logoLight is used.
28
+ logoHref?: string; // Logo link (main site). If not specified, links to blog index.
29
+ logoBreadcrumbsLight: string; // Logo for breadcrumbs (light theme). Used for dark theme if logoBreadcrumbsDark is not specified.
30
+ logoBreadcrumbsDark?: string; // Logo for breadcrumbs (dark theme). If not specified, logoBreadcrumbsLight is used.
31
+ };
32
+ // SEO and Open Graph settings
33
+ seo: {
34
+ titleSuffix: string; // Suffix for page titles
35
+ defaultImage: string; // Default image for SEO
36
+ author: string; // Default author (getter)
37
+ jsonld?: Record<string, any>; // JSON-LD structured data
38
+ };
39
+ // Default images for various entities
40
+ defaultBlogImage: string; // Default blog image
41
+ defaultProductImage: string; // Default product image
42
+ defaultProjectImage: string; // Default project/case image
43
+ defaultAuthorImage: string; // Default author image
44
+ defaultRubricImage: string; // Default rubric/category image
45
+ // Feature toggles
46
+ features: {
47
+ enableSubscribe: boolean; // Enable subscribe block
48
+ enableMultiLang: boolean; // Enable multilingual support
49
+ enableFAQ: boolean; // Enable FAQ block
50
+ enableRSS: boolean; // Enable RSS feed
51
+ };
52
+ // Control display of tags/rubrics
53
+ // Theme switcher
54
+ enableThemeSwitcher?: boolean; // Enable theme switcher (true by default)
55
+ // Social and contact links (displayed in the footer)
56
+ links?: Record<string, string>; // Social/contact links for footer
57
+ navLinks?: Array<{ key: string; label: string; href: string }>; // Navigation links
58
+ // Language and copyright
59
+ defaultLang?: string; // Default language code
60
+ copyright?: string; // Copyright string
61
+ // Page titles for different sections
62
+ pageTitles?: Record<string, string>; // Custom page titles
63
+ // Subscribe block settings
64
+ subscribe?: {
65
+ enabled?: boolean; // Enable subscribe block
66
+ heading?: string; // Subscribe heading
67
+ mutedText?: string; // Subscribe muted text
68
+ formUrl?: string; // Subscribe form URL
69
+ };
70
+ // Author and language switcher
71
+ showAuthorArticleCount?: boolean; // Show article count for author
72
+ showLangSwitcher?: boolean; // Show language switcher
73
+ // Control display of tags/rubrics
74
+ showOnlyRubricsTags?: boolean; // true — show only rubrics, false — show all tags
75
+ langLinks?: Record<string, string>; // External links for each language
76
+ authorsDescription?: string; // Authors block description (override localization)
77
+ // Template and security
78
+ isProTemplate?: boolean; // Is this a pro template
79
+ secretKey?: string; // Secret key for pro features
80
+ // Home page title override
81
+ indexTitle?: string; // Custom title for index page
82
+ }
83
+ // Main exported configuration object for the Maugli project
84
+ export const maugliConfig: MaugliConfig = {
85
+ configVersion: MAUGLI_CONFIG_VERSION, // Config version for CLI/automation compatibility
86
+ showExamples: true, // Show example/demo content (set false to hide all demo content)
87
+ brand: {
88
+ name: 'Maugli', // Brand name
89
+ description: 'Content farm for smart automation', // Brand description
90
+ logoLight: '/logoblog-icon.svg', // Logo for navigation (light theme). Used for dark theme if logoDark is not specified.
91
+ // Logo for navigation (dark theme). If not specified, logoLight is used.
92
+ logoDark: undefined,
93
+ // Logo link (main site). If not specified, links to blog index.
94
+ logoHref: 'https://maugli.cfd',
95
+ logoBreadcrumbsLight: '/logo-icon.svg', // Logo for breadcrumbs (light theme). Used for dark theme if logoBreadcrumbsDark is not specified.
96
+ // Logo for breadcrumbs (dark theme). If not specified, logoBreadcrumbsLight is used.
97
+ logoBreadcrumbsDark: undefined,
98
+ },
99
+ // Automation block for Maugli farm integration (not used on frontend)
100
+ automation: {
101
+ farmName: '', // Name of the farm/channel for integration
102
+ farmChannelId: '', // Blog/channel ID for Maugli farm integration
103
+ farmAuthorIds: [], // Array of farm author IDs for API
104
+ farmRubricIds: [], // Array of farm rubric IDs for API
105
+ farmProductIds: [], // Array of farm product IDs for API
106
+ farmProjectIds: [], // Array of farm project/case IDs for API
107
+ },
108
+ enableThemeSwitcher: true, // Enable theme switcher (true by default)
109
+ seo: {
110
+ titleSuffix: ' — Maugli', // Suffix for page titles
111
+ defaultImage: '/default-image.webp', // Default image for SEO
112
+ get author() { return maugliConfig.defaultAuthorId || 'ИlyichAI'; }, // Default author (getter)
113
+ jsonld: {
114
+ organization: {
115
+ name: 'Maugli AI Content Farm',
116
+ url: 'https://maugli.cfd/',
117
+ logo: 'https://maugli.cfd/images/logo.svg',
118
+ sameAs: [
119
+ 'https://www.linkedin.com/company/maugli',
120
+ 'https://twitter.com/maugli_ai',
121
+ 'https://t.me/maugli_channel'
122
+ ],
123
+ contact: {
124
+ email: 'info@maugli.cfd',
125
+ contactType: 'customer support'
126
+ }
127
+ },
128
+ website: {
129
+ name: 'Maugli Content Farm',
130
+ url: 'https://maugli.cfd/',
131
+ searchTemplate: 'https://maugli.cfd/search?q={search_term_string}'
132
+ },
133
+ articleDefaults: {
134
+ publisher: 'Maugli Content Farm',
135
+ author: 'Maugli Editorial Team',
136
+ image: 'https://maugli.cfd/images/default-article.jpg',
137
+ language: 'maugliConfig.defaultLang'
138
+ },
139
+ schema: {
140
+ '@context': 'https://schema.org',
141
+ '@type': 'Organization',
142
+ name: 'Maugli',
143
+ url: 'https://maugli.cfd',
144
+ logo: 'https://maugli.cfd/logoblog-icon.svg',
145
+ founder: 'Daria Zorina'
146
+ }
147
+ }
148
+ },
149
+ defaultBlogImage: 'src/assets/img/default/blog_default.webp', // Default blog image
150
+ defaultProductImage: 'src/assets/img/default/product_default.webp', // Default product image
151
+ defaultProjectImage: 'src/assets/img/default/project_default.webp', // Default project/case image
152
+ defaultAuthorImage: 'src/assets/img/default/autor_default.webp', // Default author image
153
+ defaultRubricImage: 'src/assets/img/default/rubric_default.webp', // Default rubric/category image
154
+ features: {
155
+ enableSubscribe: true, // Enable subscribe block
156
+ enableMultiLang: false, // Enable multilingual support
157
+ enableFAQ: true, // Enable FAQ block
158
+ enableRSS: true, // Enable RSS feed
159
+ },
160
+ showOnlyRubricsTags: true, // Show only rubrics by default
161
+
162
+ links: {
163
+ products: '/products', // Products page
164
+ about: '/about', // About page
165
+ email: 'mailto:info@maugli.cfd', // Contact email
166
+ telegram: 'https://t.me/mauglibot', // Telegram link
167
+ mastodon: '', // Mastodon link
168
+ medium: 'https://medium.com/@maugli', // Medium link
169
+ bluesky: '', // Bluesky link
170
+ reddit: '', // Reddit link
171
+ linkedin: 'https://linkedin.com/company/maugli', // LinkedIn link
172
+ twitter: 'https://twitter.com/mauglibot', // Twitter link
173
+ }, // Contacts displayed in the footer
174
+ navLinks: [
175
+ { key: 'blog', label: '', href: '/' }, // Blog main page
176
+ { key: 'products', label: '', href: '/products' }, // Products page
177
+ { key: 'projects', label: '', href: '/projects' }, // Projects page
178
+ { key: 'authors', label: '', href: '/authors' }, // Authors page
179
+ { key: 'tags', label: '', href: '/tags' }, // Tags page
180
+ ],
181
+ defaultLang: 'en', // Default language code
182
+ copyright: '© Maugli, 2025. All rights reserved.', // Copyright string
183
+ pageTitles: {
184
+ home: 'https://maugli.cfd', // Home page title
185
+ products: '', // Products page title
186
+ authors: '', // Authors page title
187
+ tags: '' // Tags page title
188
+ },
189
+ subscribe: {
190
+ enabled: false, // Enable subscribe block
191
+ heading: '', // Subscribe heading
192
+ mutedText: '', // Subscribe muted text
193
+ formUrl: 'https://your-form-url.com' // Subscribe form URL
194
+ },
195
+ defaultAuthorId: 'default-autor', // Default author id (used if no author is specified). Use the filename of the author .md file without the .md extension
196
+ showAuthorsWithoutArticles: true, // Show authors without articles (default: true)
197
+ showAuthorArticleCount: true, // Show article count for author
198
+ showLangSwitcher: true, // Show language switcher
199
+ langLinks: {
200
+ ru: 'https://maugli.cfd/ru', // Russian version
201
+ en: 'https://maugli.cfd/en', // English version
202
+ es: 'https://maugli.cfd/es', // Spanish version
203
+ de: 'https://maugli.cfd/de', // German version
204
+ pt: 'https://google.com', // Portuguese version
205
+ fr: 'https://google.com', // French version
206
+ zh: 'https://google.com', // Chinese version
207
+ ja: 'https://google.com', // Japanese version
208
+ },
209
+ authorsDescription: '', // Authors block description (override localization)
210
+ indexTitle: 'Maugli Blog', // Custom title for index page
211
+ isProTemplate: false, // Is this a pro template
212
+ secretKey: '0000-0000-0000-0000-0000', // Secret key for pro features
213
+ };
@@ -0,0 +1,42 @@
1
+ ---
2
+ name: 'Дарья Зорина'
3
+ position: 'Founder, CEO'
4
+ description: 'Основатель и креативный директор Maugli AI Editorial System. Эксперт в AI-контенте, GPT-SEO и многоканальных стратегиях'
5
+ avatar: 'src/img/examples/authors/daria.webp'
6
+ socials:
7
+ telegram: 'https://t.me/darrrina'
8
+ linkedin: 'https://www.linkedin.com/in/dariazorina'
9
+ medium: 'https://medium.com/@dariaz'
10
+ email: 'daria.zorina@maugli.cfd'
11
+ twitter: 'https://twitter.com/fake_daria'
12
+ mastodon: 'https://mastodon.social/@fake_daria'
13
+ bluesky: 'https://bsky.app/profile/fake_daria'
14
+ reddit: 'https://reddit.com/user/fake_daria'
15
+ facebook: 'https://facebook.com/fake.daria'
16
+ seo:
17
+ title: 'Дарья Зорина - Founder, CEO | Maugli Content Farm'
18
+ description: 'Основатель и креативный директор Maugli AI Editorial System. Эксперт в AI-контенте, GPT-SEO и многоканальных стратегиях'
19
+ keywords:
20
+ - founder
21
+ - автоматизация бизнеса
22
+ - ИИ автоматизация
23
+ - контент-стратегии
24
+ - AI content
25
+ image:
26
+ src: 'src/img/examples/authors/daria.webp'
27
+ alt: 'Дарья Зорина'
28
+ caption: 'Основатель и креативный директор Maugli AI Editorial System'
29
+ jsonld:
30
+ '@context': 'https://schema.org'
31
+ '@type': 'Person'
32
+ name: 'Дарья Зорина'
33
+ jobTitle: 'Founder, CEO'
34
+ url: 'https://maugli.cfd'
35
+ image: 'src/img/examples/authors/daria.webp'
36
+ sameAs:
37
+ - 'https://www.linkedin.com/in/dariazorina'
38
+
39
+ isExample: true
40
+ ---
41
+
42
+ Дарья — основатель и креативный директор Maugli AI Editorial System. Эксперт в AI-контенте, GPT-SEO и многоканальных стратегиях.
@@ -0,0 +1,47 @@
1
+ ---
2
+ name: 'Default Author'
3
+ position: 'Editor-in-Chief'
4
+ description: 'Default author and content editor for Maugli Blog. Used by default when no custom author is configured.'
5
+ avatar: 'src/img/default/autor_default.webp'
6
+ socials:
7
+ telegram: 'https://t.me/mauglibot'
8
+ linkedin: 'https://www.linkedin.com/company/maugli'
9
+ medium: 'https://medium.com/@maugli'
10
+ email: 'info@maugli.cfd'
11
+ twitter: 'https://twitter.com/mauglibot'
12
+ mastodon: 'https://mastodon.social/@maugli'
13
+ bluesky: 'https://bsky.app/profile/maugli'
14
+ reddit: 'https://reddit.com/user/maugli'
15
+ facebook: 'https://facebook.com/maugli'
16
+ seo:
17
+ title: 'Default Author | Maugli Blog'
18
+ description: 'Default content editor for Maugli Blog. Expert in AI content, SEO, and multichannel strategies.'
19
+ keywords:
20
+ - default author
21
+ - AI content
22
+ - SEO
23
+ image:
24
+ src: 'src/img/default/autor_default.webp'
25
+ alt: 'Default Author'
26
+ caption: 'Default editor of Maugli Blog'
27
+ jsonld:
28
+ '@context': 'https://schema.org'
29
+ '@type': 'Person'
30
+ name: 'Default Author'
31
+ jobTitle: 'Editor-in-Chief'
32
+ url: 'https://maugli.cfd'
33
+ image: 'src/img/default/autor_default.webp'
34
+ sameAs:
35
+ - 'https://t.me/mauglibot'
36
+ - 'https://www.linkedin.com/company/maugli'
37
+ - 'https://medium.com/@maugli'
38
+ - 'https://twitter.com/mauglibot'
39
+ - 'https://mastodon.social/@maugli'
40
+ - 'https://bsky.app/profile/maugli'
41
+ - 'https://reddit.com/user/maugli'
42
+ - 'https://facebook.com/maugli'
43
+
44
+ isExample: true
45
+ ---
46
+
47
+ This author is used by default for all posts if no custom author is specified.
@@ -0,0 +1,43 @@
1
+ ---
2
+ name: 'Игорь Соколов'
3
+ position: 'Редактор'
4
+ description: 'Редактор русской версии Maugli AI Editorial System. Пишет продуктовые статьи и экспертные материалы о нейросетях, GPT-SEO и автоматизации контента.'
5
+ avatar: 'src/img/examples/authors/igor.webp'
6
+ socials:
7
+ medium: 'https://medium.com/@igor.sokolov_7726'
8
+ email: 'igor.sokolov@maugli.cfd'
9
+ seo:
10
+ title: 'Игорь Соколов - Редактор | Maugli Content Farm'
11
+ description: 'Редактор русской версии Maugli AI Editorial System. Пишет экспертные материалы о нейросетях, GPT-SEO и автоматизации контента.'
12
+ keywords:
13
+ - growth marketing
14
+ - маркетинг роста
15
+ - аналитика
16
+ - конверсии
17
+ image:
18
+ src: 'src/img/examples/authors/igor.webp'
19
+ alt: 'Игорь Соколов'
20
+ caption: 'Редактор русской версии Maugli AI Editorial System'
21
+ jsonld:
22
+ '@context': 'https://schema.org'
23
+ '@type': 'Person'
24
+ name: 'Игорь Соколов'
25
+ alternateName:
26
+ - 'Igor Sokolov'
27
+ jobTitle: 'Редактор русской версии блога Maugli'
28
+ worksFor:
29
+ '@type': 'Organization'
30
+ name: 'Maugli AI Editorial System'
31
+ url: 'https://maugli.cfd'
32
+ image: 'src/img/examples/authors/igor.webp'
33
+ url: 'https://medium.com/@igor.sokolov_7726'
34
+ sameAs:
35
+ - 'mailto:igor.sokolov@maugli.cfd'
36
+ description: 'Редактор русской версии Maugli AI Editorial System. Пишет аналитические статьи о нейросетях, GPT-SEO, автоматизации контента и продуктовых стратегиях.'
37
+
38
+ isExample: true
39
+ ---
40
+
41
+ Игорь — редактор русской версии Maugli AI Editorial System и контент-аналитик, который пишет экспертные материалы о нейросетях, автоматизации и контент-стратегиях.
42
+
43
+ Игорь умеет переводить сложные технические и AI-концепции на простой бизнес-язык, поясняя их ценность без технического перегруза. Показывает реальные кейсы, использует факты и цифры, рассказывает о продуктах Maugli.
@@ -0,0 +1,46 @@
1
+ ---
2
+ name: 'John Walker'
3
+ position: 'Editor'
4
+ description: 'AI evangelist and content strategist with over 10 years of experience at the intersection of AI, content automation, and business strategy.'
5
+ avatar: 'src/img/examples/authors/john.webp'
6
+ socials:
7
+ linkedin: 'https://www.linkedin.com/company/maugli-ai-editorial-system'
8
+ medium: 'https://medium.com/@john.walker_90417'
9
+ email: 'john.walker@maugli.cfd'
10
+ seo:
11
+ title: 'John Walker – Editor | Maugli AI Editorial System'
12
+ description: 'John Walker is an AI evangelist and content strategist at Maugli AI Editorial System. He writes analytical content on AI-driven SEO, content workflows, and automation strategies.'
13
+ keywords:
14
+ - AI evangelist
15
+ - content automation
16
+ - GPT SEO
17
+ - editorial strategy
18
+ image:
19
+ src: 'src/img/examples/authors/john.webp'
20
+ alt: 'John Walker'
21
+ caption: 'Editor at Maugli AI Editorial System'
22
+ jsonld:
23
+ '@context': 'https://schema.org'
24
+ '@type': 'Person'
25
+ name: 'John Walker'
26
+ alternateName:
27
+ - 'Джон Уокер'
28
+ jobTitle: 'Editor'
29
+ worksFor:
30
+ '@type': 'Organization'
31
+ name: 'Maugli AI Editorial System'
32
+ url: 'https://maugli.cfd/en'
33
+ image: 'src/img/examples/authors/john.webp'
34
+ url: 'https://medium.com/@john.walker_90417'
35
+ sameAs:
36
+ - 'mailto:john.walker@maugli.cfd'
37
+ - 'https://www.linkedin.com/company/maugli-ai-editorial-system'
38
+ description: 'John Walker is an AI evangelist and content strategist at Maugli AI Editorial System. He writes analytical pieces on GPT-ready SEO, AI-driven workflows, and automation strategies that save time and deliver measurable results.'
39
+ isExample: true
40
+ ---
41
+
42
+ **John Walker** — AI evangelist and content strategist with over 10 years of experience at the intersection of AI, content automation, and business strategy.
43
+
44
+ He specializes in translating complex AI concepts into **clear, actionable frameworks** for founders, product teams, and digital leaders. His editorial style combines clarity and structure (inspired by Jason Fried) with analytical precision.
45
+
46
+ As part of **Maugli AI Editorial System**, John curates **analytical content on GPT-ready SEO, AI-powered content workflows, and automation strategies** designed to save time, optimize resources, and deliver measurable results.
@@ -0,0 +1,260 @@
1
+ ---
2
+ title: "Как попасть в\_AI-выдачу Google и\_рекомендации GPT в\_2025: гайд по\_JSON-LD"
3
+ excerpt: >-
4
+ О том как продвигать контент в AI-выдачах Google, Bing, ChatGPT и Perplexity,
5
+ и почему Maugli Editorial System решает задачу автоматически
6
+ publishDate: 2025-07-20T00:00:00.000Z
7
+ isFeatured: false
8
+ author: dmitry-growth-marketer
9
+ tags:
10
+ - SEO & AI SEO
11
+ - JSON-LD
12
+ - AI-рекомендации
13
+ - Google
14
+ - НовыйМир
15
+ seo:
16
+ title: 'Как попасть в AI-выдачу Google и GPT в 2025: полный гайд по JSON-LD'
17
+ description: >-
18
+ О том как продвигать контент в AI-выдачах Google, Bing, ChatGPT и
19
+ Perplexity, и почему Maugli Editorial System решает задачу автоматически.
20
+ keywords:
21
+ - Maugli Free Blog
22
+ - JSON-LD
23
+ - AI-SEO
24
+ - автоматизация контента
25
+ - Maugli Editorial System
26
+ - рекомендации нейросетей
27
+ image:
28
+ src: /src/assets/img/examples/blog/test-post.webp
29
+ alt: JSON-LD в Maugli Editorial System
30
+ width: '1200'
31
+ height: '630'
32
+ generativeEngineOptimization:
33
+ generated:
34
+ summary: >-
35
+ Как JSON-LD помогает попадать в AI-выдачу Google, Bing, ChatGPT и других
36
+ нейросетей, а также о том, как Maugli Editorial System решает задачу
37
+ разметки и AI-SEO автоматически.
38
+ highlights:
39
+ - >-
40
+ JSON-LD — ключ к видимости в 2025: AI-поисковики читают только
41
+ структурированные данные.
42
+ - >-
43
+ Maugli Editorial System автоматически создаёт JSON-LD для статей, FAQ и
44
+ продуктов.
45
+ - Мультиблоги и автоматизация повышают шансы попасть в AI-рекомендации.
46
+ faq:
47
+ - question: Почему JSON-LD так важен для AI-выдачи?
48
+ answer: >-
49
+ Без структурированных данных AI-сервисы не могут корректно извлекать
50
+ ответы, поэтому статьи без JSON-LD остаются «невидимыми» для ChatGPT и
51
+ Google.
52
+ - question: Как попадать в рекомендации нейросетей и AI-выдачи?
53
+ answer: >-
54
+ Генерировать правильнный JSON-LD для всех публикаций и FAQ. Это
55
+ ускоряет индексацию и повышает шансы попадания в выдачу.
56
+ - question: Как настроить JSON-LD самостоятельно?
57
+ answer: >-
58
+ Выберите тип разметки (Article, FAQPage, Product), укажите ключевые
59
+ данные и проверьте их через Google Rich Results Test.
60
+ - question: Как мультиблоги помогают в AI-SEO?
61
+ answer: >-
62
+ Несколько блогов вокруг продукта создают больше ссылок и точек входа
63
+ для AI-рекомендаций, увеличивая охват и видимость.
64
+ jsonld:
65
+ '@context': https://schema.org
66
+ '@type': Article
67
+ headline: 'Как попасть в AI-выдачу Google и рекомендации GPT в 2025: гайд по JSON-LD'
68
+ description: >-
69
+ Как JSON-LD помогает попадать в AI-выдачу Google, Bing, ChatGPT и других
70
+ нейросетей, а также о том, как автоматизация решает задачу разметки и
71
+ AI-SEO.
72
+ datePublished: '2025-07-20'
73
+ dateModified: '2025-07-21'
74
+ author:
75
+ '@type': Person
76
+ name: dmitry-growth-marketer
77
+ publisher:
78
+ '@type': Organization
79
+ name: Maugli Editorial System
80
+ logo:
81
+ '@type': ImageObject
82
+ url: /logo-maugli.webp
83
+ width: 200
84
+ height: 200
85
+ image:
86
+ '@type': ImageObject
87
+ url: src/assets/img/examples/blog/post_1_jsonld_guide.webp
88
+ width: 1200
89
+ height: 630
90
+ caption: JSON-LD и AI-SEO
91
+ mainEntityOfPage:
92
+ '@type': WebPage
93
+ '@id': https://maugli.cfd/blog/jsonld-guide
94
+ mainEntity:
95
+ - '@type': Question
96
+ name: Почему JSON-LD так важен для AI-выдачи?
97
+ acceptedAnswer:
98
+ '@type': Answer
99
+ text: >-
100
+ Без структурированных данных AI-сервисы не могут корректно извлекать
101
+ ответы, поэтому статьи без JSON-LD остаются «невидимыми» для ChatGPT и
102
+ Google.
103
+ - '@type': Question
104
+ name: Как попадать в рекомендации нейросетей и AI-выдачи?
105
+ acceptedAnswer:
106
+ '@type': Answer
107
+ text: >-
108
+ Генерировать правильный JSON-LD для всех публикаций и FAQ. Это
109
+ ускоряет индексацию и повышает шансы попадания в выдачу.
110
+ - '@type': Question
111
+ name: Как настроить JSON-LD самостоятельно?
112
+ acceptedAnswer:
113
+ '@type': Answer
114
+ text: >-
115
+ Выберите тип разметки (Article, FAQPage, Product), укажите ключевые
116
+ данные и проверьте их через Google Rich Results Test.
117
+ - '@type': Question
118
+ name: Как мультиблоги помогают в AI-SEO?
119
+ acceptedAnswer:
120
+ '@type': Answer
121
+ text: >-
122
+ Несколько блогов вокруг продукта создают больше ссылок и точек входа
123
+ для AI-рекомендаций, увеличивая охват и видимость.
124
+ isExample: true
125
+ ---
126
+ Сегодня поисковые системы и AI-выдачи (Google, Bing, ChatGPT, Perplexity) всё меньше похожи на классические списки ссылок. Они стремятся выдавать готовые ответы, а не просто набор страниц. Для бизнеса это означает одно: чтобы контент «подняли» в ответах, он должен быть понятен алгоритмам.
127
+
128
+ Технически здесь нет магии — речь о структурированных данных. Это способ объяснить поисковикам, что на странице: где заголовок, где дата, где ответы на вопросы. Многие забывают, что основной стандарт для этого — **JSON-LD**. Без него статьи теряют шанс попасть в расширенные сниппеты или ответы AI, и трафик уходит конкурентам.
129
+
130
+ ---
131
+
132
+ ## Maugli делает JSON-LD «из коробки»
133
+
134
+ В обычной CMS JSON-LD — это ручная настройка. Надо понимать [Schema.org](http://Schema.org), прописывать теги, проверять их через Rich Results Test, исправлять ошибки. Это как вручную вставлять навигационные знаки на дороге — долго и легко ошибиться.
135
+
136
+ **В Maugli Editorial System специально обученный ИИ-агент сам заботится о JSON-LD по умолчанию.** Он размечает статьи так, чтобы поисковики и AI-платформы (Google, Bing, ChatGPT) понимали смысл контента и поднимали его в выдаче.
137
+
138
+ Это значит, что ваш блог автоматически получает приоритет в AI-выдаче, потому что алгоритмы сразу видят структуру и суть текста.
139
+
140
+ ## Что это даёт бизнесу?
141
+
142
+ 1. Повышает шансы на попадание в ответы нейросетей и расширенные сниппеты Google.
143
+ 2. Ускоряет индексацию — поисковики «схватывают» контент без ошибок.
144
+ 3. Снимает головную боль с технической оптимизацией: можно сосредоточиться на смысле, а не на коде.
145
+
146
+ С **Maugli Editorial System** не нужно даже думать о JSON-LD. Хотя, с ним не надо думать о контенте в принципе.
147
+
148
+ Кстати, вот как выглядит JSON-LD этой статьи:
149
+
150
+ ```json
151
+ jsonld:
152
+ '@context': https://schema.org
153
+ '@type': Article
154
+ headline: 'Как попасть в AI-выдачу Google и рекомендации GPT в 2025: гайд по JSON-LD'
155
+ description: >-
156
+ Как JSON-LD помогает попадать в AI-выдачу Google, Bing, ChatGPT и других
157
+ нейросетей, а также о том, как автоматизация решает задачу разметки и
158
+ AI-SEO.
159
+ datePublished: '20.07.2025'
160
+ dateModified: '21.07.2025'
161
+ author:
162
+ '@type': Person
163
+ name: dmitry-growth-marketer
164
+ publisher:
165
+ '@type': Organization
166
+ name: Maugli Editorial System
167
+ logo:
168
+ '@type': ImageObject
169
+ url: /logo-maugli.webp
170
+ width: 200
171
+ height: 200
172
+ image:
173
+ '@type': ImageObject
174
+ url: /post_1_jsonld_guide.webp
175
+ width: 1200
176
+ height: 630
177
+ caption: JSON-LD и AI-SEO
178
+ mainEntityOfPage:
179
+ '@type': WebPage
180
+ '@id': https://maugli.cfd/blog/jsonld-guide
181
+ mainEntity:
182
+  — '@type': Question
183
+ name: 'Почему JSON-LD так важен для AI-выдачи? '
184
+ acceptedAnswer:
185
+ '@type': Answer
186
+ text: >-
187
+ Без структурированных данных AI-сервисы не могут корректно извлекать
188
+ ответы, поэтому статьи без JSON-LD остаются «невидимыми» для ChatGPT и Google.
189
+  — '@type': Question
190
+ name: 'Как попадать в рекомендации нейросетей и AI-выдачи? '
191
+ acceptedAnswer:
192
+ '@type': Answer
193
+ text: >-
194
+ Генерировать правильный JSON-LD для всех публикаций и FAQ. Это ускоряет индексацию и повышает шансы попадания в выдачу.
195
+  — '@type': Question
196
+ name: 'Как настроить JSON-LD самостоятельно? '
197
+ acceptedAnswer:
198
+ '@type': Answer
199
+ text: >-
200
+ Выберите тип разметки (Article, FAQPage, Product), укажите ключевые данные и проверьте их через Google Rich Results Test.
201
+  — '@type': Question
202
+ name: 'Как мультиблоги помогают в AI-SEO? '
203
+ acceptedAnswer:
204
+ '@type': Answer
205
+ text: >-
206
+ Несколько блогов вокруг продукта создают больше ссылок и точек входа для AI-рекомендаций, увеличивая охват и видимость.
207
+ ```
208
+
209
+ ---
210
+
211
+ ## Почему это важно для поисковой выдачи и рекомендаций в нейросетях?
212
+
213
+ Поисковые системы перестали быть «списками ссылок». Google, Bing, ChatGPT, Perplexity — все они всё больше работают как ответчики. Они не просто индексируют текст, а **пытаются понять, что в нём написано**, чтобы выдать пользователю готовый ответ.
214
+
215
+ Для этого им нужны структурированные данные. Это как подписи к фотографиям: без них алгоритм не отличит закат на Мальдивах от апельсина на столе. В мире веба эти подписи называются **JSON-LD**.
216
+
217
+ > JSON-LD — это язык, на котором сайты «объясняют» себя поисковым системам.
218
+
219
+ **Он сообщает: «Это статья, опубликованная такого-то числа, автор — вот этот, а ниже — раздел с ответами на вопросы». Без этой разметки контент — «немой» для ИИ.**
220
+
221
+ Простой пример: у вас есть блок FAQ на странице, но без JSON-LD он — просто текст. Google не покажет его в расширенном сниппете. А ChatGPT или Bing Copilot не возьмут его как готовый ответ. Трафик уйдёт конкурентам, у которых разметка есть.
222
+
223
+ Кроме того, в Maugli Editorial Team — FAQ и Саммари создаются на основе каждой статьи. А значит, повышает продукт в выдаче по всем фронтам.
224
+
225
+ ## Как подготовка к рекомендациям реализована в бесплатном шаблоне Maugli
226
+
227
+ Maugli шаблон блога уже содержит базовую разметку JSON-LD. Это означает, что структура для статей и FAQ предусмотрена изначально, однако настроить под себя и прописать данные все-таки придется.
228
+
229
+ > **Совет: ** если предпочитаете создавать контент вручную можно автоматизировать создание FAQ и остального содержания JSON-LD, используя даже [Airtable](https://airtable.com/invite/r/X0cxNqaM), либо создать [GPT’s](https://openai.com/index/introducing-gpts/#: ~: text=chatgpt.com/create, a%20new%20window)), который будет делать эту работу по строго обозначенной структуре на основе содержимого статьи.
230
+
231
+ Шаблон Maugli Free Blog позволяет легко подключить любую автоматизацию JSON-LD.
232
+
233
+ ---
234
+
235
+ ### Что важно учитывать при настройке JSON-LD:
236
+
237
+ — **Для статей: ** обязательно укажите `@type: Article`, заголовок, описание, дату публикации, автора.
238
+ — **Для продуктов: ** используйте `@type: Product`, добавьте имя, описание, цену, изображения.
239
+ — **Для кейсов: ** подходит `@type: CreativeWork` или `Article` с дополнительными полями (например, ключевые инсайты или результаты).
240
+ — Обязательно включите краткое саммари и блок FAQ. В шаблоне Maugli можно это не только прописать в JSON-LD, но и сделать видимы пользователям в начале страницы. Как в этой статье.
241
+
242
+ ---
243
+
244
+ Если делаете вручную, зайдите на [**Google Rich Results Test**](https://search.google.com/test/rich-results), вставьте свой JSON-LD и убедитесь, что нет ошибок.
245
+
246
+ ---
247
+
248
+ ## Как JSON-LD помогает попасть в AI-выдачу?
249
+
250
+ AI-сервисы не «читают» страницы как люди. Им нужны готовые ответы, и они берут их из JSON-LD. По сути, **каждый FAQ в вашем блоге — это «кнопка» для AI-поиска, чтобы он взял ваш ответ вместо ответа конкурента.**
251
+
252
+ ### Что важно знать:
253
+
254
+ 1. **JSON-LD — ключ к видимости.** Без него статьи остаются «невидимыми» для AI-поисковиков и не попадают в блоки быстрых ответов.
255
+ 2. **Не ограничивайтесь одним блогом.** Шаблон Maugli позволяет быстро разворачивать несколько блогов вокруг вашего продукта. Чем больше блогов и ссылок, тем выше вероятность, что AI-рекомендации будут вести к вам.
256
+ 3. **Мульти-блоги.** Maugli изначально разработан для мультиблогов: подключайте к своему продукту несколько блогов, имеющих разные форматы и заточенные под разные целевые сегменты.
257
+
258
+ ---
259
+
260
+ **Хотите вообще не думать о контенте? ** Подключите **Maugli Editorial System** — и весь процесс контента и его автоматизации, включая AI-SEO и JSON-LD, будет полностью закрыт. Вам останется только заниматься продуктом и получать клиентов, которых к вам приведут нейросети, благодаря рекомендациям.