ckeditor5 1.5.0 → 1.5.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +127 -54
- data/lib/ckeditor5/rails/engine.rb +5 -3
- data/lib/ckeditor5/rails/version.rb +1 -1
- metadata +10 -10
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 1fd62e59f6152397ca06404b956ee4b89452eff91679fd8c87436ab620c511f8
|
4
|
+
data.tar.gz: 0b740379678382ab910743ec7041f0b284db0a0c4f377eba52c609eaa705cf4f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 9e359270ad4714fa0a080d70cee7f43ebf874670dddc191c1ee2d6233ea85a0e45e0df975ed89de36fd323d978e371d8751807eee32caf34ff545e04fe41c2ba
|
7
|
+
data.tar.gz: 701d19ceae2a64fa455ec46456c6af2d921393606ddb7b2565862f1b20524d9dda58d77800774f300bb294d9c620400506772fcd850309d0078e2abb354f8955
|
data/README.md
CHANGED
@@ -20,7 +20,7 @@ Add this line to your application's Gemfile:
|
|
20
20
|
gem 'ckeditor5'
|
21
21
|
```
|
22
22
|
|
23
|
-
In your config:
|
23
|
+
In your config (the default config is defined [here](https://github.com/Mati365/ckeditor5-rails/blob/main/lib/ckeditor5/rails/presets/manager.rb)):
|
24
24
|
|
25
25
|
```rb
|
26
26
|
# config/initializers/ckeditor5.rb
|
@@ -67,6 +67,10 @@ Voilà! You have CKEditor 5 integrated with your Rails application. 🎉
|
|
67
67
|
- [`plugins(*names, **kwargs)` method](#pluginsnames-kwargs-method)
|
68
68
|
- [`inline_plugin(name, code)` method](#inline_pluginname-code-method)
|
69
69
|
- [Including CKEditor 5 assets 📦](#including-ckeditor-5-assets-)
|
70
|
+
- [Format 📝](#format-)
|
71
|
+
- [Using default preset](#using-default-preset)
|
72
|
+
- [Custom preset](#custom-preset)
|
73
|
+
- [Inline preset definition](#inline-preset-definition)
|
70
74
|
- [Lazy loading 🚀](#lazy-loading-)
|
71
75
|
- [GPL usage 🆓](#gpl-usage-)
|
72
76
|
- [Commercial usage 💰](#commercial-usage-)
|
@@ -141,16 +145,18 @@ CKEditor5::Rails.configure do
|
|
141
145
|
end
|
142
146
|
```
|
143
147
|
|
144
|
-
In order to override existing presets, you can use the `
|
148
|
+
In order to override existing presets, you can use the `presets.override` method. The method takes the name of the preset you want to override and a block with the old configuration. The example below shows how to hide the menubar in the default preset:
|
145
149
|
|
146
150
|
```rb
|
147
151
|
# config/initializers/ckeditor5.rb
|
148
152
|
|
149
153
|
CKEditor5::Rails.configure do
|
150
|
-
|
154
|
+
presets.override :custom do
|
155
|
+
menubar visible: false
|
151
156
|
|
152
|
-
|
153
|
-
|
157
|
+
toolbar do
|
158
|
+
remove :underline, :heading
|
159
|
+
end
|
154
160
|
end
|
155
161
|
end
|
156
162
|
```
|
@@ -169,7 +175,7 @@ Defines the CDN to be used for CKEditor 5 assets. The example below shows how to
|
|
169
175
|
```rb
|
170
176
|
# config/initializers/ckeditor5.rb
|
171
177
|
|
172
|
-
|
178
|
+
CKEditor5::Rails.configure do
|
173
179
|
# ... other configuration
|
174
180
|
|
175
181
|
cdn :jsdelivr
|
@@ -181,7 +187,7 @@ It also allows you to define a custom CDN by passing a block with the bundle, ve
|
|
181
187
|
```rb
|
182
188
|
# config/initializers/ckeditor5.rb
|
183
189
|
|
184
|
-
|
190
|
+
CKEditor5::Rails.configure do
|
185
191
|
# ... other configuration
|
186
192
|
|
187
193
|
cdn do |bundle, version, path|
|
@@ -199,7 +205,7 @@ Defines the version of CKEditor 5 to be used. The example below shows how to set
|
|
199
205
|
```rb
|
200
206
|
# config/initializers/ckeditor5.rb
|
201
207
|
|
202
|
-
|
208
|
+
CKEditor5::Rails.configure do
|
203
209
|
# ... other configuration
|
204
210
|
|
205
211
|
version '43.2.0'
|
@@ -213,7 +219,7 @@ Defines the license of CKEditor 5. The example below shows how to set the licens
|
|
213
219
|
```rb
|
214
220
|
# config/initializers/ckeditor5.rb
|
215
221
|
|
216
|
-
|
222
|
+
CKEditor5::Rails.configure do
|
217
223
|
# ... other configuration
|
218
224
|
|
219
225
|
gpl
|
@@ -227,7 +233,7 @@ Defines the license key of CKEditor 5. It calls `premium` method internally. The
|
|
227
233
|
```rb
|
228
234
|
# config/initializers/ckeditor5.rb
|
229
235
|
|
230
|
-
|
236
|
+
CKEditor5::Rails.configure do
|
231
237
|
# ... other configuration
|
232
238
|
|
233
239
|
license_key 'your-license-key'
|
@@ -241,7 +247,7 @@ Defines if premium package should be included in JS assets. The example below sh
|
|
241
247
|
```rb
|
242
248
|
# config/initializers/ckeditor5.rb
|
243
249
|
|
244
|
-
|
250
|
+
CKEditor5::Rails.configure do
|
245
251
|
# ... other configuration
|
246
252
|
|
247
253
|
premium
|
@@ -255,7 +261,7 @@ Defines the translations of CKEditor 5. You can pass the language codes as argum
|
|
255
261
|
```rb
|
256
262
|
# config/initializers/ckeditor5.rb
|
257
263
|
|
258
|
-
|
264
|
+
CKEditor5::Rails.configure do
|
259
265
|
# ... other configuration
|
260
266
|
|
261
267
|
translations :pl, :es
|
@@ -267,9 +273,10 @@ end
|
|
267
273
|
```rb
|
268
274
|
# config/initializers/ckeditor5.rb
|
269
275
|
|
270
|
-
|
271
|
-
|
276
|
+
CKEditor5::Rails.configure do
|
277
|
+
# ... other configuration
|
272
278
|
|
279
|
+
translations :pl
|
273
280
|
language :pl
|
274
281
|
end
|
275
282
|
```
|
@@ -281,7 +288,7 @@ Defines the CKBox plugin to be included in the editor. The example below shows h
|
|
281
288
|
```rb
|
282
289
|
# config/initializers/ckeditor5.rb
|
283
290
|
|
284
|
-
|
291
|
+
CKEditor5::Rails.configure do
|
285
292
|
# ... other configuration
|
286
293
|
|
287
294
|
ckbox '2.5.4', theme: :lark
|
@@ -303,7 +310,7 @@ The example below sets the editor type to `multiroot` in the custom preset:
|
|
303
310
|
```rb
|
304
311
|
# config/initializers/ckeditor5.rb
|
305
312
|
|
306
|
-
|
313
|
+
CKEditor5::Rails.configure do
|
307
314
|
# ... other configuration
|
308
315
|
|
309
316
|
type :multiroot
|
@@ -322,7 +329,7 @@ The `should_group_when_full` keyword argument determines whether the toolbar sho
|
|
322
329
|
```rb
|
323
330
|
# config/initializers/ckeditor5.rb
|
324
331
|
|
325
|
-
|
332
|
+
CKEditor5::Rails.configure do
|
326
333
|
# ... other configuration
|
327
334
|
|
328
335
|
toolbar :undo, :redo, :|, :heading, :|, :bold, :italic, :underline, :|,
|
@@ -338,7 +345,7 @@ If you want to add or prepend items to the existing toolbar, you can use the blo
|
|
338
345
|
```rb
|
339
346
|
# config/initializers/ckeditor5.rb
|
340
347
|
|
341
|
-
|
348
|
+
CKEditor5::Rails.configure do
|
342
349
|
# ... other configuration
|
343
350
|
|
344
351
|
toolbar do
|
@@ -353,7 +360,7 @@ If you want to remove items from the toolbar, you can use the `remove` method:
|
|
353
360
|
```rb
|
354
361
|
# config/initializers/ckeditor5.rb
|
355
362
|
|
356
|
-
|
363
|
+
CKEditor5::Rails.configure do
|
357
364
|
# ... other configuration
|
358
365
|
|
359
366
|
toolbar do
|
@@ -369,7 +376,7 @@ Defines the visibility of the menubar. By default, it's set to `true`.
|
|
369
376
|
```rb
|
370
377
|
# config/initializers/ckeditor5.rb
|
371
378
|
|
372
|
-
|
379
|
+
CKEditor5::Rails.configure do
|
373
380
|
# ... other configuration
|
374
381
|
|
375
382
|
toolbar :undo, :redo, :|, :heading, :|, :bold, :italic, :underline, :|,
|
@@ -385,7 +392,7 @@ Defines the language of the editor. You can pass the language code as an argumen
|
|
385
392
|
```rb
|
386
393
|
# config/initializers/ckeditor5.rb
|
387
394
|
|
388
|
-
|
395
|
+
CKEditor5::Rails.configure do
|
389
396
|
# ... other configuration
|
390
397
|
|
391
398
|
language :pl
|
@@ -397,7 +404,7 @@ In order to set the language for the content, you can pass the `content` keyword
|
|
397
404
|
```rb
|
398
405
|
# config/initializers/ckeditor5.rb
|
399
406
|
|
400
|
-
|
407
|
+
CKEditor5::Rails.configure do
|
401
408
|
# ... other configuration
|
402
409
|
|
403
410
|
language :en, content: :pl
|
@@ -411,7 +418,7 @@ Allows you to set custom configuration options. You can pass the name of the opt
|
|
411
418
|
```rb
|
412
419
|
# config/initializers/ckeditor5.rb
|
413
420
|
|
414
|
-
|
421
|
+
CKEditor5::Rails.configure do
|
415
422
|
# ... other configuration
|
416
423
|
|
417
424
|
configure :link, {
|
@@ -429,7 +436,7 @@ The example below show how to import Bold plugin from the `ckeditor5` npm packag
|
|
429
436
|
```rb
|
430
437
|
# config/initializers/ckeditor5.rb
|
431
438
|
|
432
|
-
|
439
|
+
CKEditor5::Rails.configure do
|
433
440
|
# ... other configuration
|
434
441
|
|
435
442
|
plugin :Bold
|
@@ -441,7 +448,7 @@ In order to import a plugin from a custom ESM package, you can pass the `import_
|
|
441
448
|
```rb
|
442
449
|
# config/initializers/ckeditor5.rb
|
443
450
|
|
444
|
-
|
451
|
+
CKEditor5::Rails.configure do
|
445
452
|
# ... other configuration
|
446
453
|
|
447
454
|
plugin :YourPlugin, import_name: 'your-package'
|
@@ -453,7 +460,7 @@ In order to import a plugin from a custom Window entry, you can pass the `window
|
|
453
460
|
```rb
|
454
461
|
# config/initializers/ckeditor5.rb
|
455
462
|
|
456
|
-
|
463
|
+
CKEditor5::Rails.configure do
|
457
464
|
# ... other configuration
|
458
465
|
|
459
466
|
plugin :YourPlugin, window_name: 'YourPlugin'
|
@@ -467,7 +474,7 @@ Defines the plugins to be included in the editor. You can specify multiple plugi
|
|
467
474
|
```rb
|
468
475
|
# config/initializers/ckeditor5.rb
|
469
476
|
|
470
|
-
|
477
|
+
CKEditor5::Rails.configure do
|
471
478
|
# ... other configuration
|
472
479
|
|
473
480
|
plugins :Bold, :Italic, :Underline, :Link
|
@@ -481,7 +488,7 @@ Use with caution as this is an inline definition of the plugin code, and you can
|
|
481
488
|
```rb
|
482
489
|
# config/initializers/ckeditor5.rb
|
483
490
|
|
484
|
-
|
491
|
+
CKEditor5::Rails.configure do
|
485
492
|
# ... other configuration
|
486
493
|
|
487
494
|
inline_plugin :MyCustomPlugin, <<~JS
|
@@ -507,32 +514,88 @@ To include CKEditor 5 assets in your application, you can use the `ckeditor5_ass
|
|
507
514
|
|
508
515
|
Keep in mind that you need to include the helper result in the `head` section of your layout. In examples below, we use `content_for` helper to include the assets in the `head` section of the view.
|
509
516
|
|
510
|
-
###
|
517
|
+
### Format 📝
|
511
518
|
|
512
|
-
|
513
|
-
<summary>Loading JS and CSS Assets</summary>
|
519
|
+
#### Using default preset
|
514
520
|
|
515
|
-
|
521
|
+
The example below users the default preset defined [here](https://github.com/Mati365/ckeditor5-rails/blob/main/lib/ckeditor5/rails/presets/manager.rb).
|
516
522
|
|
517
|
-
|
523
|
+
```erb
|
524
|
+
<!-- app/views/demos/index.html.erb -->
|
518
525
|
|
519
|
-
|
526
|
+
<% content_for :head do %>
|
527
|
+
<%= ckeditor5_assets %>
|
528
|
+
<% end %>
|
529
|
+
```
|
520
530
|
|
521
|
-
|
531
|
+
If you want to fetch some additional translations, you can extend your initializer with the following configuration:
|
532
|
+
|
533
|
+
```rb
|
534
|
+
# config/initializers/ckeditor5.rb
|
535
|
+
|
536
|
+
CKEditor5::Rails.configure do
|
537
|
+
# ... rest of the configuration
|
538
|
+
|
539
|
+
translations :pl, :es
|
540
|
+
end
|
541
|
+
```
|
522
542
|
|
523
|
-
|
543
|
+
#### Custom preset
|
544
|
+
|
545
|
+
To specify a custom preset, you need to pass the `preset` keyword argument with the name of the preset. The example below shows how to include the assets for the custom preset:
|
524
546
|
|
525
547
|
```erb
|
526
548
|
<!-- app/views/demos/index.html.erb -->
|
527
549
|
|
528
550
|
<% content_for :head do %>
|
529
|
-
<%= ckeditor5_assets
|
551
|
+
<%= ckeditor5_assets preset: :custom %>
|
530
552
|
<% end %>
|
531
553
|
```
|
532
554
|
|
533
|
-
|
555
|
+
In order to define such preset, you can use the following configuration:
|
556
|
+
|
557
|
+
```rb
|
558
|
+
# config/initializers/ckeditor5.rb
|
559
|
+
|
560
|
+
CKEditor5::Rails.configure do
|
561
|
+
# ... rest of the configuration
|
562
|
+
|
563
|
+
presets.define :custom do
|
564
|
+
# ... your preset configuration
|
565
|
+
|
566
|
+
translations :pl, :es
|
567
|
+
end
|
568
|
+
end
|
569
|
+
```
|
570
|
+
|
571
|
+
#### Inline preset definition
|
572
|
+
|
573
|
+
It's possible to define the preset directly in the `ckeditor5_assets` helper method. It allows you to dynamically specify version, cdn provider or even translations in the view. The example below inherits the default preset and adds Polish translations and other options:
|
574
|
+
|
575
|
+
```erb
|
576
|
+
<!-- app/views/demos/index.html.erb -->
|
577
|
+
|
578
|
+
<% content_for :head do %>
|
579
|
+
<%= ckeditor5_assets version: '43.3.0', cdn: :jsdelivr, translations: [:pl], license_key: '<YOUR KEY> OR GPL' %>
|
580
|
+
<% end %>
|
581
|
+
```
|
582
|
+
|
583
|
+
### Lazy loading 🚀
|
584
|
+
|
585
|
+
<details>
|
586
|
+
<summary>Loading JS and CSS Assets</summary>
|
587
|
+
|
588
|
+
All JS assets defined by the `ckeditor5_assets` helper method are loaded **asynchronously**. It means that the assets are loaded in the background without blocking the rendering of the page. However, the CSS assets are loaded **synchronously** to prevent the flash of unstyled content and ensure that the editor is styled correctly.
|
589
|
+
|
590
|
+
It has been achieved by using web components, together with import maps, which are supported by modern browsers. The web components are used to define the editor and its plugins, while the import maps are used to define the dependencies between the assets.
|
591
|
+
|
592
|
+
</details>
|
593
|
+
|
594
|
+
### GPL usage 🆓
|
534
595
|
|
535
|
-
|
596
|
+
If you want to use CKEditor 5 under the GPL license, you can include the assets using the `ckeditor5_assets` without passing any arguments. It'll include the necessary assets for the GPL license from one of the most popular CDNs. In our scenario, we use the `jsdelivr` CDN which is the default one.
|
597
|
+
|
598
|
+
Example:
|
536
599
|
|
537
600
|
```erb
|
538
601
|
<!-- app/views/demos/index.html.erb -->
|
@@ -542,7 +605,7 @@ Version is optional as long as you defined it in the `config/initializers/ckedit
|
|
542
605
|
<% end %>
|
543
606
|
```
|
544
607
|
|
545
|
-
|
608
|
+
In that scenario it's recommended to add `gpl` method to the initializer along with the version:
|
546
609
|
|
547
610
|
```rb
|
548
611
|
# config/initializers/ckeditor5.rb
|
@@ -553,49 +616,59 @@ CKEditor5::Rails.configure do
|
|
553
616
|
end
|
554
617
|
```
|
555
618
|
|
556
|
-
In order to use `unpkg` CDN, you can
|
619
|
+
In order to use `unpkg` CDN, you can extend your initializer with the following configuration:
|
557
620
|
|
558
|
-
```
|
559
|
-
|
621
|
+
```rb
|
622
|
+
# config/initializers/ckeditor5.rb
|
560
623
|
|
561
|
-
|
562
|
-
|
563
|
-
|
624
|
+
CKEditor5::Rails.configure do
|
625
|
+
# ... rest of the configuration
|
626
|
+
|
627
|
+
cdn :unpkg
|
628
|
+
end
|
564
629
|
```
|
565
630
|
|
566
|
-
|
631
|
+
However, you can also specify the CDN directly in the view:
|
567
632
|
|
568
633
|
```erb
|
569
634
|
<!-- app/views/demos/index.html.erb -->
|
570
635
|
|
571
636
|
<% content_for :head do %>
|
572
|
-
<%=
|
637
|
+
<%= ckeditor5_assets cdn: :unpkg %>
|
573
638
|
<% end %>
|
574
639
|
```
|
575
640
|
|
576
|
-
|
641
|
+
or using helper function:
|
577
642
|
|
578
643
|
```erb
|
579
644
|
<!-- app/views/demos/index.html.erb -->
|
580
645
|
|
581
646
|
<% content_for :head do %>
|
582
|
-
<%=
|
647
|
+
<%= ckeditor5_jsdelivr_assets %>
|
583
648
|
<% end %>
|
584
649
|
```
|
585
650
|
|
586
|
-
|
651
|
+
### Commercial usage 💰
|
652
|
+
|
653
|
+
If you want to use CKEditor 5 under a commercial license, you have to specify license key. It can be done in the initializer:
|
587
654
|
|
588
655
|
```rb
|
589
656
|
# config/initializers/ckeditor5.rb
|
590
657
|
|
591
658
|
CKEditor5::Rails.configure do
|
592
|
-
|
659
|
+
license_key 'your-license-key'
|
593
660
|
end
|
594
661
|
```
|
595
662
|
|
596
|
-
|
663
|
+
```erb
|
664
|
+
<!-- app/views/demos/index.html.erb -->
|
665
|
+
|
666
|
+
<% content_for :head do %>
|
667
|
+
<%= ckeditor5_assets %>
|
668
|
+
<% end %>
|
669
|
+
```
|
597
670
|
|
598
|
-
|
671
|
+
or directly in the view:
|
599
672
|
|
600
673
|
```erb
|
601
674
|
<!-- app/views/demos/index.html.erb -->
|
@@ -14,9 +14,11 @@ module CKEditor5::Rails
|
|
14
14
|
ActiveSupport.on_load(:action_view) { include Helpers }
|
15
15
|
end
|
16
16
|
|
17
|
-
initializer 'ckeditor5.simple_form',
|
18
|
-
|
19
|
-
|
17
|
+
initializer 'ckeditor5.simple_form', after: :load_config_initializers do
|
18
|
+
if defined?(::SimpleForm)
|
19
|
+
require_relative 'hooks/simple_form'
|
20
|
+
::SimpleForm::FormBuilder.map_type :ckeditor5, to: Hooks::SimpleForm::CKEditor5Input
|
21
|
+
end
|
20
22
|
end
|
21
23
|
|
22
24
|
initializer 'ckeditor5.form_builder' do
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ckeditor5
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.5.
|
4
|
+
version: 1.5.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Mateusz Bagiński
|
@@ -9,28 +9,28 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2024-11-
|
12
|
+
date: 2024-11-05 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rails
|
16
16
|
requirement: !ruby/object:Gem::Requirement
|
17
17
|
requirements:
|
18
|
-
- - "~>"
|
19
|
-
- !ruby/object:Gem::Version
|
20
|
-
version: '7.0'
|
21
18
|
- - ">="
|
22
19
|
- !ruby/object:Gem::Version
|
23
|
-
version:
|
20
|
+
version: '6.0'
|
21
|
+
- - "<"
|
22
|
+
- !ruby/object:Gem::Version
|
23
|
+
version: '8.0'
|
24
24
|
type: :runtime
|
25
25
|
prerelease: false
|
26
26
|
version_requirements: !ruby/object:Gem::Requirement
|
27
27
|
requirements:
|
28
|
-
- - "~>"
|
29
|
-
- !ruby/object:Gem::Version
|
30
|
-
version: '7.0'
|
31
28
|
- - ">="
|
32
29
|
- !ruby/object:Gem::Version
|
33
|
-
version:
|
30
|
+
version: '6.0'
|
31
|
+
- - "<"
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '8.0'
|
34
34
|
description:
|
35
35
|
email: cziken58@gmail.com
|
36
36
|
executables: []
|