@ckeditor/ckeditor5-ai 44.1.0 → 44.2.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (369) hide show
  1. package/LICENSE.md +1 -1
  2. package/README.md +1 -1
  3. package/build/ai.js +2 -2
  4. package/build/translations/cs.js +1 -1
  5. package/dist/index-content.css +2 -2
  6. package/dist/index-editor.css +2 -2
  7. package/dist/index.css +9 -9
  8. package/dist/index.js +3 -3
  9. package/dist/translations/af.d.ts +2 -2
  10. package/dist/translations/af.js +2 -2
  11. package/dist/translations/af.umd.js +2 -2
  12. package/dist/translations/ar.d.ts +2 -2
  13. package/dist/translations/ar.js +2 -2
  14. package/dist/translations/ar.umd.js +2 -2
  15. package/dist/translations/ast.d.ts +2 -2
  16. package/dist/translations/ast.js +2 -2
  17. package/dist/translations/ast.umd.js +2 -2
  18. package/dist/translations/az.d.ts +2 -2
  19. package/dist/translations/az.js +2 -2
  20. package/dist/translations/az.umd.js +2 -2
  21. package/dist/translations/bg.d.ts +2 -2
  22. package/dist/translations/bg.js +2 -2
  23. package/dist/translations/bg.umd.js +2 -2
  24. package/dist/translations/bn.d.ts +2 -2
  25. package/dist/translations/bn.js +2 -2
  26. package/dist/translations/bn.umd.js +2 -2
  27. package/dist/translations/bs.d.ts +2 -2
  28. package/dist/translations/bs.js +2 -2
  29. package/dist/translations/bs.umd.js +2 -2
  30. package/dist/translations/ca.d.ts +2 -2
  31. package/dist/translations/ca.js +2 -2
  32. package/dist/translations/ca.umd.js +2 -2
  33. package/dist/translations/cs.d.ts +2 -2
  34. package/dist/translations/cs.js +2 -2
  35. package/dist/translations/cs.umd.js +2 -2
  36. package/dist/translations/da.d.ts +2 -2
  37. package/dist/translations/da.js +2 -2
  38. package/dist/translations/da.umd.js +2 -2
  39. package/dist/translations/de-ch.d.ts +2 -2
  40. package/dist/translations/de-ch.js +2 -2
  41. package/dist/translations/de-ch.umd.js +2 -2
  42. package/dist/translations/de.d.ts +2 -2
  43. package/dist/translations/de.js +2 -2
  44. package/dist/translations/de.umd.js +2 -2
  45. package/dist/translations/el.d.ts +2 -2
  46. package/dist/translations/el.js +2 -2
  47. package/dist/translations/el.umd.js +2 -2
  48. package/dist/translations/en-au.d.ts +2 -2
  49. package/dist/translations/en-au.js +2 -2
  50. package/dist/translations/en-au.umd.js +2 -2
  51. package/dist/translations/en-gb.d.ts +2 -2
  52. package/dist/translations/en-gb.js +2 -2
  53. package/dist/translations/en-gb.umd.js +2 -2
  54. package/dist/translations/en.d.ts +2 -2
  55. package/dist/translations/en.js +2 -2
  56. package/dist/translations/en.umd.js +2 -2
  57. package/dist/translations/eo.d.ts +2 -2
  58. package/dist/translations/eo.js +2 -2
  59. package/dist/translations/eo.umd.js +2 -2
  60. package/dist/translations/es-co.d.ts +2 -2
  61. package/dist/translations/es-co.js +2 -2
  62. package/dist/translations/es-co.umd.js +2 -2
  63. package/dist/translations/es.d.ts +2 -2
  64. package/dist/translations/es.js +2 -2
  65. package/dist/translations/es.umd.js +2 -2
  66. package/dist/translations/et.d.ts +2 -2
  67. package/dist/translations/et.js +2 -2
  68. package/dist/translations/et.umd.js +2 -2
  69. package/dist/translations/eu.d.ts +2 -2
  70. package/dist/translations/eu.js +2 -2
  71. package/dist/translations/eu.umd.js +2 -2
  72. package/dist/translations/fa.d.ts +2 -2
  73. package/dist/translations/fa.js +2 -2
  74. package/dist/translations/fa.umd.js +2 -2
  75. package/dist/translations/fi.d.ts +2 -2
  76. package/dist/translations/fi.js +2 -2
  77. package/dist/translations/fi.umd.js +2 -2
  78. package/dist/translations/fr.d.ts +2 -2
  79. package/dist/translations/fr.js +2 -2
  80. package/dist/translations/fr.umd.js +2 -2
  81. package/dist/translations/gl.d.ts +2 -2
  82. package/dist/translations/gl.js +2 -2
  83. package/dist/translations/gl.umd.js +2 -2
  84. package/dist/translations/gu.d.ts +2 -2
  85. package/dist/translations/gu.js +2 -2
  86. package/dist/translations/gu.umd.js +2 -2
  87. package/dist/translations/he.d.ts +2 -2
  88. package/dist/translations/he.js +2 -2
  89. package/dist/translations/he.umd.js +2 -2
  90. package/dist/translations/hi.d.ts +2 -2
  91. package/dist/translations/hi.js +2 -2
  92. package/dist/translations/hi.umd.js +2 -2
  93. package/dist/translations/hr.d.ts +2 -2
  94. package/dist/translations/hr.js +2 -2
  95. package/dist/translations/hr.umd.js +2 -2
  96. package/dist/translations/hu.d.ts +2 -2
  97. package/dist/translations/hu.js +2 -2
  98. package/dist/translations/hu.umd.js +2 -2
  99. package/dist/translations/hy.d.ts +2 -2
  100. package/dist/translations/hy.js +2 -2
  101. package/dist/translations/hy.umd.js +2 -2
  102. package/dist/translations/id.d.ts +2 -2
  103. package/dist/translations/id.js +2 -2
  104. package/dist/translations/id.umd.js +2 -2
  105. package/dist/translations/it.d.ts +2 -2
  106. package/dist/translations/it.js +2 -2
  107. package/dist/translations/it.umd.js +2 -2
  108. package/dist/translations/ja.d.ts +2 -2
  109. package/dist/translations/ja.js +2 -2
  110. package/dist/translations/ja.umd.js +2 -2
  111. package/dist/translations/jv.d.ts +2 -2
  112. package/dist/translations/jv.js +2 -2
  113. package/dist/translations/jv.umd.js +2 -2
  114. package/dist/translations/kk.d.ts +2 -2
  115. package/dist/translations/kk.js +2 -2
  116. package/dist/translations/kk.umd.js +2 -2
  117. package/dist/translations/km.d.ts +2 -2
  118. package/dist/translations/km.js +2 -2
  119. package/dist/translations/km.umd.js +2 -2
  120. package/dist/translations/kn.d.ts +2 -2
  121. package/dist/translations/kn.js +2 -2
  122. package/dist/translations/kn.umd.js +2 -2
  123. package/dist/translations/ko.d.ts +2 -2
  124. package/dist/translations/ko.js +2 -2
  125. package/dist/translations/ko.umd.js +2 -2
  126. package/dist/translations/ku.d.ts +2 -2
  127. package/dist/translations/ku.js +2 -2
  128. package/dist/translations/ku.umd.js +2 -2
  129. package/dist/translations/lt.d.ts +2 -2
  130. package/dist/translations/lt.js +2 -2
  131. package/dist/translations/lt.umd.js +2 -2
  132. package/dist/translations/lv.d.ts +2 -2
  133. package/dist/translations/lv.js +2 -2
  134. package/dist/translations/lv.umd.js +2 -2
  135. package/dist/translations/ms.d.ts +2 -2
  136. package/dist/translations/ms.js +2 -2
  137. package/dist/translations/ms.umd.js +2 -2
  138. package/dist/translations/nb.d.ts +2 -2
  139. package/dist/translations/nb.js +2 -2
  140. package/dist/translations/nb.umd.js +2 -2
  141. package/dist/translations/ne.d.ts +2 -2
  142. package/dist/translations/ne.js +2 -2
  143. package/dist/translations/ne.umd.js +2 -2
  144. package/dist/translations/nl.d.ts +2 -2
  145. package/dist/translations/nl.js +2 -2
  146. package/dist/translations/nl.umd.js +2 -2
  147. package/dist/translations/no.d.ts +2 -2
  148. package/dist/translations/no.js +2 -2
  149. package/dist/translations/no.umd.js +2 -2
  150. package/dist/translations/oc.d.ts +2 -2
  151. package/dist/translations/oc.js +2 -2
  152. package/dist/translations/oc.umd.js +2 -2
  153. package/dist/translations/pl.d.ts +2 -2
  154. package/dist/translations/pl.js +2 -2
  155. package/dist/translations/pl.umd.js +2 -2
  156. package/dist/translations/pt-br.d.ts +2 -2
  157. package/dist/translations/pt-br.js +2 -2
  158. package/dist/translations/pt-br.umd.js +2 -2
  159. package/dist/translations/pt.d.ts +2 -2
  160. package/dist/translations/pt.js +2 -2
  161. package/dist/translations/pt.umd.js +2 -2
  162. package/dist/translations/ro.d.ts +2 -2
  163. package/dist/translations/ro.js +2 -2
  164. package/dist/translations/ro.umd.js +2 -2
  165. package/dist/translations/ru.d.ts +2 -2
  166. package/dist/translations/ru.js +2 -2
  167. package/dist/translations/ru.umd.js +2 -2
  168. package/dist/translations/si.d.ts +2 -2
  169. package/dist/translations/si.js +2 -2
  170. package/dist/translations/si.umd.js +2 -2
  171. package/dist/translations/sk.d.ts +2 -2
  172. package/dist/translations/sk.js +2 -2
  173. package/dist/translations/sk.umd.js +2 -2
  174. package/dist/translations/sl.d.ts +2 -2
  175. package/dist/translations/sl.js +2 -2
  176. package/dist/translations/sl.umd.js +2 -2
  177. package/dist/translations/sq.d.ts +2 -2
  178. package/dist/translations/sq.js +2 -2
  179. package/dist/translations/sq.umd.js +2 -2
  180. package/dist/translations/sr-latn.d.ts +2 -2
  181. package/dist/translations/sr-latn.js +2 -2
  182. package/dist/translations/sr-latn.umd.js +2 -2
  183. package/dist/translations/sr.d.ts +2 -2
  184. package/dist/translations/sr.js +2 -2
  185. package/dist/translations/sr.umd.js +2 -2
  186. package/dist/translations/sv.d.ts +2 -2
  187. package/dist/translations/sv.js +2 -2
  188. package/dist/translations/sv.umd.js +2 -2
  189. package/dist/translations/th.d.ts +2 -2
  190. package/dist/translations/th.js +2 -2
  191. package/dist/translations/th.umd.js +2 -2
  192. package/dist/translations/ti.d.ts +2 -2
  193. package/dist/translations/ti.js +2 -2
  194. package/dist/translations/ti.umd.js +2 -2
  195. package/dist/translations/tk.d.ts +2 -2
  196. package/dist/translations/tk.js +2 -2
  197. package/dist/translations/tk.umd.js +2 -2
  198. package/dist/translations/tr.d.ts +2 -2
  199. package/dist/translations/tr.js +2 -2
  200. package/dist/translations/tr.umd.js +2 -2
  201. package/dist/translations/tt.d.ts +2 -2
  202. package/dist/translations/tt.js +2 -2
  203. package/dist/translations/tt.umd.js +2 -2
  204. package/dist/translations/ug.d.ts +2 -2
  205. package/dist/translations/ug.js +2 -2
  206. package/dist/translations/ug.umd.js +2 -2
  207. package/dist/translations/uk.d.ts +2 -2
  208. package/dist/translations/uk.js +2 -2
  209. package/dist/translations/uk.umd.js +2 -2
  210. package/dist/translations/ur.d.ts +2 -2
  211. package/dist/translations/ur.js +2 -2
  212. package/dist/translations/ur.umd.js +2 -2
  213. package/dist/translations/uz.d.ts +2 -2
  214. package/dist/translations/uz.js +2 -2
  215. package/dist/translations/uz.umd.js +2 -2
  216. package/dist/translations/vi.d.ts +2 -2
  217. package/dist/translations/vi.js +2 -2
  218. package/dist/translations/vi.umd.js +2 -2
  219. package/dist/translations/zh-cn.d.ts +2 -2
  220. package/dist/translations/zh-cn.js +2 -2
  221. package/dist/translations/zh-cn.umd.js +2 -2
  222. package/dist/translations/zh.d.ts +2 -2
  223. package/dist/translations/zh.js +2 -2
  224. package/dist/translations/zh.umd.js +2 -2
  225. package/lang/translations/af.po +1 -1
  226. package/lang/translations/ar.po +1 -1
  227. package/lang/translations/ast.po +1 -1
  228. package/lang/translations/az.po +1 -1
  229. package/lang/translations/bg.po +1 -1
  230. package/lang/translations/bn.po +1 -1
  231. package/lang/translations/bs.po +1 -1
  232. package/lang/translations/ca.po +1 -1
  233. package/lang/translations/cs.po +2 -2
  234. package/lang/translations/da.po +1 -1
  235. package/lang/translations/de-ch.po +1 -1
  236. package/lang/translations/de.po +1 -1
  237. package/lang/translations/el.po +1 -1
  238. package/lang/translations/en-au.po +1 -1
  239. package/lang/translations/en-gb.po +1 -1
  240. package/lang/translations/en.po +1 -1
  241. package/lang/translations/eo.po +1 -1
  242. package/lang/translations/es-co.po +1 -1
  243. package/lang/translations/es.po +1 -1
  244. package/lang/translations/et.po +1 -1
  245. package/lang/translations/eu.po +1 -1
  246. package/lang/translations/fa.po +1 -1
  247. package/lang/translations/fi.po +1 -1
  248. package/lang/translations/fr.po +1 -1
  249. package/lang/translations/gl.po +1 -1
  250. package/lang/translations/gu.po +1 -1
  251. package/lang/translations/he.po +1 -1
  252. package/lang/translations/hi.po +1 -1
  253. package/lang/translations/hr.po +1 -1
  254. package/lang/translations/hu.po +1 -1
  255. package/lang/translations/hy.po +1 -1
  256. package/lang/translations/id.po +1 -1
  257. package/lang/translations/it.po +1 -1
  258. package/lang/translations/ja.po +1 -1
  259. package/lang/translations/jv.po +1 -1
  260. package/lang/translations/kk.po +1 -1
  261. package/lang/translations/km.po +1 -1
  262. package/lang/translations/kn.po +1 -1
  263. package/lang/translations/ko.po +1 -1
  264. package/lang/translations/ku.po +1 -1
  265. package/lang/translations/lt.po +1 -1
  266. package/lang/translations/lv.po +1 -1
  267. package/lang/translations/ms.po +1 -1
  268. package/lang/translations/nb.po +1 -1
  269. package/lang/translations/ne.po +1 -1
  270. package/lang/translations/nl.po +1 -1
  271. package/lang/translations/no.po +1 -1
  272. package/lang/translations/oc.po +1 -1
  273. package/lang/translations/pl.po +1 -1
  274. package/lang/translations/pt-br.po +1 -1
  275. package/lang/translations/pt.po +1 -1
  276. package/lang/translations/ro.po +1 -1
  277. package/lang/translations/ru.po +1 -1
  278. package/lang/translations/si.po +1 -1
  279. package/lang/translations/sk.po +1 -1
  280. package/lang/translations/sl.po +1 -1
  281. package/lang/translations/sq.po +1 -1
  282. package/lang/translations/sr-latn.po +1 -1
  283. package/lang/translations/sr.po +1 -1
  284. package/lang/translations/sv.po +1 -1
  285. package/lang/translations/th.po +1 -1
  286. package/lang/translations/ti.po +1 -1
  287. package/lang/translations/tk.po +1 -1
  288. package/lang/translations/tr.po +1 -1
  289. package/lang/translations/tt.po +1 -1
  290. package/lang/translations/ug.po +1 -1
  291. package/lang/translations/uk.po +1 -1
  292. package/lang/translations/ur.po +1 -1
  293. package/lang/translations/uz.po +1 -1
  294. package/lang/translations/vi.po +1 -1
  295. package/lang/translations/zh-cn.po +1 -1
  296. package/lang/translations/zh.po +1 -1
  297. package/package.json +31 -8
  298. package/src/adapters/aiadapter.d.ts +1 -1
  299. package/src/adapters/aiadapter.js +2 -2
  300. package/src/adapters/aitextadapter.d.ts +1 -1
  301. package/src/adapters/aitextadapter.js +2 -2
  302. package/src/adapters/awstextadapter.d.ts +1 -1
  303. package/src/adapters/awstextadapter.js +2 -2
  304. package/src/adapters/openaitextadapter.d.ts +1 -1
  305. package/src/adapters/openaitextadapter.js +2 -2
  306. package/src/aiassistant.d.ts +21 -3
  307. package/src/aiassistant.js +2 -2
  308. package/src/aiassistantediting.d.ts +3 -3
  309. package/src/aiassistantediting.js +2 -2
  310. package/src/aiassistantui.d.ts +1 -1
  311. package/src/aiassistantui.js +2 -2
  312. package/src/aiconfig.d.ts +1 -1
  313. package/src/aiconfig.js +1 -1
  314. package/src/augmentation.d.ts +1 -1
  315. package/src/augmentation.js +1 -1
  316. package/src/index.d.ts +3 -2
  317. package/src/index.js +2 -2
  318. package/src/legacyerrors.d.ts +1 -1
  319. package/src/legacyerrors.js +2 -2
  320. package/src/ui/aiassistantcontroller.d.ts +1 -1
  321. package/src/ui/aiassistantcontroller.js +3 -3
  322. package/src/ui/form/aiformcontentarea.d.ts +1 -1
  323. package/src/ui/form/aiformcontentarea.js +2 -2
  324. package/src/ui/form/aiformerrorview.d.ts +1 -1
  325. package/src/ui/form/aiformerrorview.js +2 -2
  326. package/src/ui/form/aiformpromptview.d.ts +1 -1
  327. package/src/ui/form/aiformpromptview.js +2 -2
  328. package/src/ui/form/aiformtoolbarview.d.ts +1 -1
  329. package/src/ui/form/aiformtoolbarview.js +2 -2
  330. package/src/ui/form/aiformview.d.ts +1 -1
  331. package/src/ui/form/aiformview.js +2 -2
  332. package/src/ui/form/aihistorylistitemview.d.ts +1 -1
  333. package/src/ui/form/aihistorylistitemview.js +2 -2
  334. package/src/ui/form/aihistorylistview.d.ts +1 -1
  335. package/src/ui/form/aihistorylistview.js +2 -2
  336. package/src/ui/form/prompthistory.d.ts +1 -1
  337. package/src/ui/form/prompthistory.js +2 -2
  338. package/src/ui/showaiassistantcommand.d.ts +1 -1
  339. package/src/ui/showaiassistantcommand.js +2 -2
  340. package/src/utils/common-translations.d.ts +1 -1
  341. package/src/utils/common-translations.js +2 -2
  342. package/src/utils/normalizecommandsconfig.d.ts +1 -1
  343. package/src/utils/normalizecommandsconfig.js +2 -2
  344. package/theme/ai-dropdown.css +1 -1
  345. package/theme/ai-form.css +1 -1
  346. package/theme/ai.css +1 -1
  347. package/dist/adapters/aiadapter.d.ts +0 -60
  348. package/dist/adapters/aitextadapter.d.ts +0 -150
  349. package/dist/adapters/awstextadapter.d.ts +0 -183
  350. package/dist/adapters/openaitextadapter.d.ts +0 -187
  351. package/dist/aiassistant.d.ts +0 -393
  352. package/dist/aiassistantediting.d.ts +0 -59
  353. package/dist/aiassistantui.d.ts +0 -62
  354. package/dist/aiconfig.d.ts +0 -73
  355. package/dist/augmentation.d.ts +0 -31
  356. package/dist/index.d.ts +0 -17
  357. package/dist/legacyerrors.d.ts +0 -9
  358. package/dist/ui/aiassistantcontroller.d.ts +0 -113
  359. package/dist/ui/form/aiformcontentarea.d.ts +0 -52
  360. package/dist/ui/form/aiformerrorview.d.ts +0 -30
  361. package/dist/ui/form/aiformpromptview.d.ts +0 -50
  362. package/dist/ui/form/aiformtoolbarview.d.ts +0 -62
  363. package/dist/ui/form/aiformview.d.ts +0 -145
  364. package/dist/ui/form/aihistorylistitemview.d.ts +0 -22
  365. package/dist/ui/form/aihistorylistview.d.ts +0 -39
  366. package/dist/ui/form/prompthistory.d.ts +0 -24
  367. package/dist/ui/showaiassistantcommand.d.ts +0 -44
  368. package/dist/utils/common-translations.d.ts +0 -13
  369. package/dist/utils/normalizecommandsconfig.d.ts +0 -18
@@ -1,393 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module ai/aiassistant
11
- * @publicApi
12
- */
13
- import { type Locale } from 'ckeditor5/src/utils.js';
14
- import { Plugin, type Editor } from 'ckeditor5/src/core.js';
15
- import AIAssistantUI from './aiassistantui.js';
16
- import AIAssistantEditing from './aiassistantediting.js';
17
- /**
18
- * AI assistant plugin that allows you to use external AI models to generate content or improve existing content.
19
- *
20
- * The feature uses following {@link module:ai/adapters/aitextadapter~AITextAdapterRequestData#actionId `actionId`} values:
21
- *
22
- * * `aiAssistant:command:<commandId>` for the predefined commands, where `<commandId>` is the ID of the predefined command,
23
- * * `aiAssistant:custom` for custom queries provided by the user.
24
- */
25
- export default class AIAssistant extends Plugin {
26
- /**
27
- * @inheritDoc
28
- */
29
- static get requires(): readonly [typeof AIAssistantUI, typeof AIAssistantEditing];
30
- /**
31
- * @inheritDoc
32
- */
33
- static get pluginName(): "AIAssistant";
34
- /**
35
- * @inheritDoc
36
- */
37
- static get isOfficialPlugin(): true;
38
- /**
39
- * @inheritDoc
40
- */
41
- static get isPremiumPlugin(): true;
42
- /**
43
- * @inheritDoc
44
- */
45
- constructor(editor: Editor);
46
- }
47
- /**
48
- * A function that returns the list of the default AI commands definitions in the given localization context.
49
- */
50
- export declare function getDefaultCommands(locale: Locale): Array<GroupDefinition>;
51
- /**
52
- * The configuration of the AI Assistant feature.
53
- *
54
- * The properties defined in this config are set in the `config.ai.aiAssistant` namespace.
55
- *
56
- * ```ts
57
- * ClassicEditor
58
- * .create( editorElement, {
59
- * ai: {
60
- * aiAssistant: {
61
- * // AI Assistant configuration.
62
- * }
63
- * }
64
- * } )
65
- * .then( ... )
66
- * .catch( ... );
67
- * ```
68
- *
69
- * See {@link module:ai/aiconfig~AIConfig the full AI configuration}.
70
- *
71
- * See {@link module:core/editor/editorconfig~EditorConfig all editor options}.
72
- */
73
- export interface AIAssistantConfig {
74
- /**
75
- * A list of all AI commands groups definitions to be displayed in the `'aiCommands'` UI dropdown.
76
- *
77
- * Setting this property will overwrite the default list of predefined commands.
78
- *
79
- * You can avoid creating any groups by providing a list of command definitions directly. In this case,
80
- * commands will render as a flat list in the user interface.
81
- *
82
- * The default configuration is as follows. It can be obtained through {@link ~getDefaultCommands}:
83
- *
84
- * ```json
85
- * [ {
86
- * groupId: 'editOrReview',
87
- * groupLabel: 'Edit or review',
88
- * commands: [
89
- * {
90
- * id: 'improveWriting',
91
- * label: 'Improve writing',
92
- * prompt: 'Fix spelling mistakes, use proper grammar and apply good writing practices. Do not lose the original meaning.'
93
- * },
94
- * {
95
- * id: 'makeShorter',
96
- * label: 'Make shorter',
97
- * prompt: 'Remove any repetitive, redundant, or non-essential writing in this content ' +
98
- * 'without changing the meaning or losing any key information.'
99
- * },
100
- * {
101
- * id: 'makeLonger',
102
- * label: 'Make longer',
103
- * prompt: 'Improve this content by using descriptive language and inserting more information and more detailed explanations.'
104
- * },
105
- * {
106
- * id: 'simplifyLanguage',
107
- * label: 'Simplify language',
108
- * prompt: 'Simplify the writing style of this content ' +
109
- * 'and reduce the complexity, so that the content is easy to understand.'
110
- * }
111
- * ]
112
- * },
113
- * {
114
- * groupId: 'generate',
115
- * groupLabel: 'Generate from selection',
116
- * commands: [
117
- * {
118
- * id: 'summarize',
119
- * label: 'Summarize',
120
- * prompt: 'Summarize this content into one paragraph of text. Include only the key ideas and conclusions. Keep it short. '
121
- * },
122
- * {
123
- * id: 'continue',
124
- * label: 'Continue',
125
- * prompt: 'Start with the provided content and write at the end of it continuing this topic. Keep the added part short.'
126
- * }
127
- * ]
128
- * },
129
- * {
130
- * groupId: 'changeTone',
131
- * groupLabel: 'Change tone',
132
- * commands: [
133
- * {
134
- * id: 'professional',
135
- * label: 'Professional',
136
- * prompt: 'Improve using polished, formal, and respectful language ' +
137
- * 'to convey professional expertise and competence.'
138
- * },
139
- * {
140
- * id: 'casual',
141
- * label: 'Casual',
142
- * prompt: 'Improve using casual, informal language to convey a casual conversation with a real person.'
143
- * },
144
- * {
145
- * id: 'direct',
146
- * label: 'Direct',
147
- * prompt: 'Improve using direct language using only the essential information.'
148
- * },
149
- * {
150
- * id: 'confident',
151
- * label: 'Confident',
152
- * prompt: 'Improve using compelling, optimistic language to convey confidence in the writing.'
153
- * },
154
- * {
155
- * id: 'friendly',
156
- * label: 'Friendly',
157
- * prompt: 'Improve using friendly, comforting language, to convey understanding and empathy.'
158
- * }
159
- * ]
160
- * },
161
- * {
162
- * groupId: 'changeStyle',
163
- * groupLabel: 'Change style',
164
- * commands: [
165
- * {
166
- * id: 'business',
167
- * label: 'Business',
168
- * prompt: 'Rewrite this content as a business professional with formal language.'
169
- * },
170
- * {
171
- * id: 'legal',
172
- * label: 'Legal',
173
- * prompt: 'Rewrite this content as a legal professional using valid legal terminology.'
174
- * },
175
- * {
176
- * id: 'journalism',
177
- * label: 'Journalism',
178
- * prompt: 'Rewrite this content as a journalist using engaging language to convey the importance of the information.'
179
- * },
180
- * {
181
- * id: 'poetic',
182
- * label: 'Poetic',
183
- * prompt: 'Rewrite this content as a poem using poetic techniques without losing the original meaning.'
184
- * }
185
- * ]
186
- * },
187
- * {
188
- * groupId: 'translate',
189
- * groupLabel: 'Translate',
190
- * commands: [
191
- * {
192
- * id: 'translateEnglish',
193
- * label: 'English',
194
- * prompt: 'Translate the content to English language.'
195
- * },
196
- * {
197
- * id: 'translateSpanish',
198
- * label: 'Spanish',
199
- * prompt: 'Translate the content to Spanish language.'
200
- * },
201
- * {
202
- * id: 'translatePortuguese',
203
- * label: 'Portuguese',
204
- * prompt: 'Translate the content to Portuguese language.'
205
- * },
206
- * {
207
- * id: 'translateGerman',
208
- * label: 'German',
209
- * prompt: 'Translate the content to German language.'
210
- * },
211
- * {
212
- * id: 'translateFrench',
213
- * label: 'French',
214
- * prompt: 'Translate the content to French language.'
215
- * },
216
- * {
217
- * id: 'translateChinese',
218
- * label: 'Simplified Chinese',
219
- * prompt: 'Translate the content to Simplified Chinese language.'
220
- * },
221
- * {
222
- * id: 'translateHindi',
223
- * label: 'Hindi',
224
- * prompt: 'Translate the content to Hindi language.'
225
- * },
226
- * {
227
- * id: 'translateArabic',
228
- * label: 'Arabic',
229
- * prompt: 'Translate the content to Arabic language.'
230
- * }
231
- * ]
232
- * } ]
233
- * ```
234
- */
235
- commands?: Array<GroupDefinition> | Array<CommandDefinition>;
236
- /**
237
- * A list of additional AI commands groups definitions that will extend
238
- * {@link module:ai/aiassistant~AIAssistantConfig#commands default commands}.
239
- *
240
- * You can define new AI commands groups or add new AI commands to existing groups. If you add AI commands to an existing group,
241
- * you do not need to specify `groupLabel` property. Use the (optional) `order` property to control the position of new groups
242
- * and commands.
243
- *
244
- * An example configuration:
245
- *
246
- * ```json
247
- * {
248
- * aiAssistant: {
249
- * extraCommandGroups: [
250
- * // Add an AI command to an existing group:
251
- * {
252
- * groupId: 'changeTone',
253
- * commands: [
254
- * {
255
- * id: 'sad',
256
- * label: 'Sad',
257
- * prompt: 'Rewrite this text to make it sound sad and depressing.',
258
- * // You can specify the position of this command among existing ones. Commands use zero-based numbering.
259
- * order: 2
260
- * }
261
- * ]
262
- * },
263
- * // Create a new AI commands group:
264
- * {
265
- * groupId: 'transformations',
266
- * groupLabel: 'Transformations',
267
- * // You can specify the position of this group among existing ones. Groups use zero-based numbering.
268
- * order: 3,
269
- * commands: [
270
- * {
271
- * id: 'addEmojis',
272
- * label: 'Add emojis',
273
- * prompt: 'Analyze each sentence of this text. After each sentence add an emoji that summarizes the sentence.'
274
- * },
275
- * // ...
276
- * ]
277
- * },
278
- * ],
279
- * // ...
280
- * }
281
- * }
282
- * ```
283
- */
284
- extraCommandGroups?: Array<GroupDefinition>;
285
- /**
286
- * A list of ids of AI commands to be removed.
287
- *
288
- * Learn more about {@link module:ai/aiassistant~CommandDefinition command definition and its id}.
289
- *
290
- * An example configuration:
291
- *
292
- * ```json
293
- * {
294
- * aiAssistant: {
295
- * removeCommands: [
296
- * 'improveWriting',
297
- * // ...
298
- * ],
299
- * // ...
300
- * }
301
- * }
302
- * ```
303
- */
304
- removeCommands?: Array<string>;
305
- /**
306
- * An additional CSS class name (or names) added to the AI assistant content area (model response area).
307
- *
308
- * Because the content area is usually detached from the flow of the document, this configuration
309
- * allows for better integration with application's stylesheets and improves the consistency of content
310
- * styles.
311
- */
312
- contentAreaCssClass?: string;
313
- /**
314
- * The AI assistant feature will be disabled if the document selection includes any of these elements.
315
- *
316
- * Use this property if AI assistant does not work properly with your custom features.
317
- *
318
- * Currently, by default, AI assistant is disabled for following model elements:
319
- *
320
- * * Media embed (`'media'`) -- does not display in response area,
321
- * * HTML embed (`'rawHtml'`) -- sometimes does not display in response area, security uncertainty,
322
- * * Table of contents (`'tableOfContents'`) -- does not display properly in response area, long processing time.
323
- *
324
- * You can set this list to include more model elements or clear it to enable the above features.
325
- *
326
- * Note, that all or some of these features may become enabled in the future.
327
- *
328
- * @default [ 'media', 'rawHtml', 'tableOfContents' ]
329
- */
330
- disabledElements?: Array<string>;
331
- }
332
- export type GroupDefinition = {
333
- /**
334
- * The unique identifier of the group. It can be referenced while extending existing groups
335
- * using {@link module:ai/aiassistant~AIAssistantConfig#extraCommandGroups}.
336
- */
337
- groupId: string;
338
- /**
339
- * The human-readable label of the group.
340
- */
341
- groupLabel?: string;
342
- /**
343
- * The array of command definitions that belong to the group.
344
- */
345
- commands: Array<CommandDefinition>;
346
- /**
347
- * The order of the group on the list. The lower the number, the higher the group is displayed on the list.
348
- * If not specified, the position of this group will be determined by the order of
349
- * {@link module:ai/aiassistant~AIAssistantConfig#commands configuration}.
350
- *
351
- * If a new group is added without `order` property, it will be added at the end.
352
- *
353
- * The order uses zero-based numbering (the first group's order is `0`).
354
- */
355
- order?: number;
356
- };
357
- export type CommandDefinition = {
358
- /**
359
- * The unique identifier of the command. It can be referenced while removing commands. See
360
- * {@link module:ai/aiassistant~AIAssistantConfig#removeCommands} to learn more.
361
- */
362
- id: string;
363
- /**
364
- * The human-readable label of the command.
365
- */
366
- label: string;
367
- /**
368
- * The instruction that will be passed to the AI model.
369
- *
370
- * It is wrapped in a "full prompt template" for better results.
371
- */
372
- prompt: string;
373
- /**
374
- * By default, all commands require a selection for the assistant to work on. If the selection is collapsed,
375
- * it automatically expands to the nearest block boundaries to provide the AI context.
376
- *
377
- * Setting this to `false` allows the command to work on a collapsed selection and prevent selection expansion.
378
- * This is helpful, for instance, for commands that generate content from scratch.
379
- *
380
- * **Note**: If not specified, the default is `true`.
381
- */
382
- requiresContent?: boolean;
383
- /**
384
- * The order of the command on the list. The lower the number, the higher the command is displayed on the list.
385
- * If not specified, the position of this command will be determined by the order of
386
- * {@link module:ai/aiassistant~AIAssistantConfig#commands configuration}.
387
- *
388
- * If a new command is added without `order` property, it will be added at the end of the group.
389
- *
390
- * The order uses zero-based numbering (the first command's order is `0`).
391
- */
392
- order?: number;
393
- };
@@ -1,59 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- import { Plugin } from 'ckeditor5/src/core.js';
10
- import type { Position } from 'ckeditor5/src/engine.js';
11
- /**
12
- * The AI assistant editing plugin.
13
- */
14
- export default class AIAssistantEditing extends Plugin {
15
- /**
16
- * @inheritDoc
17
- */
18
- static get pluginName(): "AIAssistantEditing";
19
- /**
20
- * @inheritDoc
21
- */
22
- static get isOfficialPlugin(): true;
23
- /**
24
- * @inheritDoc
25
- */
26
- static get isPremiumPlugin(): true;
27
- /**
28
- * @inheritDoc
29
- */
30
- init(): void;
31
- /**
32
- * @inheritDoc
33
- */
34
- afterInit(): void;
35
- /**
36
- * Displays a fake visual selection.
37
- *
38
- * This adds a 'ai-ui-candidate' (for the commands dropdown) or 'ai-ui' (for the assistant dialog)
39
- * marker into the document that is rendered as a highlight on selected text fragment.
40
- */
41
- showFakeVisualSelection(): void;
42
- /**
43
- * Removes a fake visual selection.
44
- *
45
- * This clears a 'ai-ui-candidate' (for the commands dropdown) or 'ai-ui' (for the assistant dialog)
46
- * marker from the document.
47
- */
48
- hideFakeVisualSelection(): void;
49
- /**
50
- * Converts the HTML string into the model fragment and inserts it at the specified position.
51
- *
52
- * If a position is not provided, the insertion will replace the visual selection marker.
53
- */
54
- insertContent(content: string, position?: Position): void;
55
- /**
56
- * Converts the HTML string into the model fragment and inserts it below the visual selection marker.
57
- */
58
- insertContentBelow(content: string): void;
59
- }
@@ -1,62 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module ai/aiassistantui
11
- * @publicApi
12
- */
13
- import { Plugin, type Editor } from 'ckeditor5/src/core.js';
14
- import { Dialog } from 'ckeditor5/src/ui.js';
15
- import AIAssistantEditing from './aiassistantediting.js';
16
- import AIAdapter from './adapters/aiadapter.js';
17
- import '../theme/ai.css';
18
- import '../theme/ai-dropdown.css';
19
- import '../theme/ai-form.css';
20
- import { ClipboardMarkersUtils } from 'ckeditor5/src/clipboard.js';
21
- /**
22
- * The UI plugin of the AI assistant.
23
- */
24
- export default class AIAssistantUI extends Plugin {
25
- /**
26
- * @inheritDoc
27
- */
28
- static get pluginName(): "AIAssistantUI";
29
- /**
30
- * @inheritDoc
31
- */
32
- static get isOfficialPlugin(): true;
33
- /**
34
- * @inheritDoc
35
- */
36
- static get isPremiumPlugin(): true;
37
- /**
38
- * @inheritDoc
39
- */
40
- static get requires(): readonly [typeof ClipboardMarkersUtils, typeof AIAssistantEditing, typeof AIAdapter, typeof Dialog];
41
- /**
42
- * @inheritDoc
43
- */
44
- constructor(editor: Editor);
45
- /**
46
- * @inheritDoc
47
- */
48
- init(): void;
49
- destroy(): void;
50
- /**
51
- * Initializes the AI Assistant main view and displays it in a dialog, based on the selection. Also, shows fake selection marker.
52
- *
53
- * @param query The initial query. If set, the AI assistant will automatically submit given query to the AI service.
54
- * @param label Label to be displayed in the AI assistant query input field while the AI assistant processes the initial query.
55
- * @param actionId The id of the executed action. It can be used in extended and custom adapters to customize the request.
56
- */
57
- showUI(query?: string, label?: string, actionId?: string): void;
58
- /**
59
- * Hides the AI dialog.
60
- */
61
- hideUI(): void;
62
- }
@@ -1,73 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module ai/aiconfig
11
- * @publicApi
12
- */
13
- import type { AIAssistantConfig } from './aiassistant.js';
14
- import type { OpenAITextAdapterConfig } from './adapters/openaitextadapter.js';
15
- import type { AWSTextAdapterConfig } from './adapters/awstextadapter.js';
16
- /**
17
- * The configuration for all AI-related functionalities.
18
- *
19
- * Provides configuration properties for both AI features and AI adapters (which connect to the external AI services),
20
- *
21
- * ```ts
22
- * ClassicEditor
23
- * .create( editorElement, {
24
- * ai: {
25
- * openAI: {
26
- * requestHeaders: {
27
- * Authorization: 'Bearer API_KEY'
28
- * }
29
- * },
30
- * useTheme: false
31
- * }
32
- * } )
33
- * .then( ... )
34
- * .catch( ... );
35
- * ```
36
- *
37
- * See {@link module:core/editor/editorconfig~EditorConfig all editor configuration options}.
38
- */
39
- export default interface AIConfig {
40
- /**
41
- * The configuration of the {@link module:ai/aiassistant~AIAssistant AI Assistant feature}.
42
- *
43
- * Read more in {@link module:ai/aiassistant~AIAssistantConfig}.
44
- */
45
- aiAssistant?: AIAssistantConfig;
46
- /**
47
- * The configuration for the {@link module:ai/adapters/openaitextadapter~OpenAITextAdapter `OpenAITextAdapter`}.
48
- *
49
- * This is required only if you connect to OpenAI or Azure OpenAI service.
50
- *
51
- * Read more in {@link module:ai/adapters/openaitextadapter~OpenAITextAdapterConfig}.
52
- */
53
- openAI?: OpenAITextAdapterConfig;
54
- /**
55
- * The configuration for the {@link module:ai/adapters/awstextadapter~AWSTextAdapter `AWSTextAdapter`}.
56
- *
57
- * This is required only if you connect to Amazon Bedrock service.
58
- *
59
- * Read more in {@link module:ai/adapters/awstextadapter~AWSTextAdapterConfig}.
60
- */
61
- aws?: AWSTextAdapterConfig;
62
- /**
63
- * Enables or disables the colored UI theme for AI features.
64
- *
65
- * * Leaving this property unset will preserve the default theme on AI features UI elements.
66
- * * Setting this property to **`false`** will remove the default theme from AI features UI elements.
67
- *
68
- * See the AI Assistant integration guide to learn how you can use CSS variables to change the default theme to a different color.
69
- *
70
- * @default true
71
- */
72
- useTheme?: boolean;
73
- }
@@ -1,31 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- import type AIAssistant from './aiassistant.js';
10
- import type ShowAIAssistantCommand from './ui/showaiassistantcommand.js';
11
- import type AIAssistantEditing from './aiassistantediting.js';
12
- import type AIAssistantUI from './aiassistantui.js';
13
- import type AIConfig from './aiconfig.js';
14
- import type AIAdapter from './adapters/aiadapter.js';
15
- declare module '@ckeditor/ckeditor5-core' {
16
- interface EditorConfig {
17
- /**
18
- * Configuration for AI features.
19
- */
20
- ai?: AIConfig;
21
- }
22
- interface PluginsMap {
23
- [AIAdapter.pluginName]: AIAdapter;
24
- [AIAssistant.pluginName]: AIAssistant;
25
- [AIAssistantUI.pluginName]: AIAssistantUI;
26
- [AIAssistantEditing.pluginName]: AIAssistantEditing;
27
- }
28
- interface CommandsMap {
29
- showAIAssistant: ShowAIAssistantCommand;
30
- }
31
- }
package/dist/index.d.ts DELETED
@@ -1,17 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- /**
10
- * @module ai
11
- */
12
- export { default as AIAssistant } from './aiassistant.js';
13
- export { default as AIAdapter, AIRequestError } from './adapters/aiadapter.js';
14
- export { default as AITextAdapter, type AITextAdapterRequestData, type RequestHeaders, type RequestParameters, type AITextAdapterDataCallback } from './adapters/aitextadapter.js';
15
- export { default as OpenAITextAdapter, type OpenAITextAdapterConfig } from './adapters/openaitextadapter.js';
16
- export { default as AWSTextAdapter, type AWSTextAdapterConfig } from './adapters/awstextadapter.js';
17
- import './augmentation.js';
@@ -1,9 +0,0 @@
1
- /**
2
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
3
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
4
- */
5
- /**
6
- * @license Copyright (c) 2003-2024, CKSource Holding sp. z o.o. All rights reserved.
7
- * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options
8
- */
9
- export {};