1
|
|
|
/** |
2
|
|
|
* This file is part of the O2System Venus UI Framework package. |
3
|
|
|
* |
4
|
|
|
* For the full copyright and license information, please view the LICENSE |
5
|
|
|
* file that was distributed with this source code. |
6
|
|
|
* |
7
|
|
|
* @author Steeve Andrian Salim |
8
|
|
|
* @copyright Copyright (c) Steeve Andrian Salim |
9
|
|
|
*/ |
10
|
|
|
// ------------------------------------------------------------------------ |
11
|
|
|
|
12
|
|
|
import tinymce from 'tinymce/tinymce'; |
13
|
|
|
import 'tinymce/themes/modern/theme'; |
14
|
|
|
import 'tinymce/themes/inlite/theme'; |
15
|
|
|
|
16
|
|
|
import 'tinymce/skins/lightgray/skin.min.css'; |
17
|
|
|
import 'tinymce/skins/lightgray/content.min.css'; |
18
|
|
|
import 'tinymce/skins/lightgray/content.inline.min.css'; |
19
|
|
|
import 'tinymce/skins/lightgray/content.mobile.min.css'; |
20
|
|
|
import 'tinymce/skins/lightgray/skin.mobile.min.css'; |
21
|
|
|
|
22
|
|
|
import 'tinymce/plugins/advlist/plugin.js'; |
23
|
|
|
import 'tinymce/plugins/autolink/plugin.js'; |
24
|
|
|
import 'tinymce/plugins/lists/plugin.js'; |
25
|
|
|
import 'tinymce/plugins/link/plugin.js'; |
26
|
|
|
import 'tinymce/plugins/image/plugin.js'; |
27
|
|
|
import 'tinymce/plugins/charmap/plugin.js'; |
28
|
|
|
import 'tinymce/plugins/print/plugin.js'; |
29
|
|
|
import 'tinymce/plugins/preview/plugin.js'; |
30
|
|
|
import 'tinymce/plugins/anchor/plugin.js'; |
31
|
|
|
import 'tinymce/plugins/textcolor/plugin.js'; |
32
|
|
|
import 'tinymce/plugins/code/plugin.js'; |
33
|
|
|
import 'tinymce/plugins/visualblocks/plugin.js'; |
34
|
|
|
import 'tinymce/plugins/searchreplace/plugin.js'; |
35
|
|
|
import 'tinymce/plugins/fullscreen/plugin.js'; |
36
|
|
|
import 'tinymce/plugins/insertdatetime/plugin.js'; |
37
|
|
|
import 'tinymce/plugins/media/plugin.js'; |
38
|
|
|
import 'tinymce/plugins/contextmenu/plugin.js'; |
39
|
|
|
import 'tinymce/plugins/table/plugin.js'; |
40
|
|
|
import 'tinymce/plugins/paste/plugin.js'; |
41
|
|
|
import 'tinymce/plugins/wordcount/plugin.js'; |
42
|
|
|
import 'tinymce/plugins/help/plugin.js'; |
43
|
|
|
/** |
44
|
|
|
* Class Editor |
45
|
|
|
* |
46
|
|
|
* @author Teguh Rianto |
47
|
|
|
* @package Components |
48
|
|
|
*/ |
49
|
|
|
|
50
|
|
|
export default class Editor { |
51
|
|
|
constructor() { |
52
|
|
|
tinymce.init({ |
53
|
|
|
selector: '.tinymce', |
54
|
|
|
height: 300, |
55
|
|
|
menubar: false, |
56
|
|
|
themes: "inlite", |
57
|
|
|
statusbar: false, |
58
|
|
|
skin: false, |
59
|
|
|
plugins: [ |
60
|
|
|
'advlist autolink lists link image charmap print preview anchor textcolor', |
61
|
|
|
'searchreplace visualblocks code fullscreen', |
62
|
|
|
'insertdatetime media table contextmenu paste code help wordcount' |
63
|
|
|
], |
64
|
|
|
toolbar: 'insert | formatselect | bold italic blockquote alignleft aligncenter alignright alignjustify bullist numlist outdent indent removeformat | code', |
65
|
|
|
setup : function(ed) |
66
|
|
|
{ |
67
|
|
|
ed.on('init', function() |
68
|
|
|
{ |
69
|
|
|
this.getDoc().body.style.fontSize = '1rem'; |
70
|
|
|
this.getDoc().body.style.fontFamily = 'Arial'; |
71
|
|
|
this.getDoc().body.style.color = '#666'; |
72
|
|
|
}); |
73
|
|
|
}, |
74
|
|
|
}); |
75
|
|
|
|
76
|
|
|
tinymce.init({ |
77
|
|
|
selector: '.tinymce-inline', |
78
|
|
|
theme: 'inlite', |
79
|
|
|
plugins: [ |
80
|
|
|
'advlist autolink lists link image charmap print preview anchor textcolor', |
81
|
|
|
'searchreplace visualblocks code fullscreen', |
82
|
|
|
'insertdatetime media table contextmenu paste code help wordcount' |
83
|
|
|
], |
84
|
|
|
insert_toolbar: 'formatselect | bullist numlist outdent indent | quickimage quicktable media codesample', |
85
|
|
|
selection_toolbar: 'formatselect | bold italic quicklink blockquote alignleft aligncenter alignright alignjustify removeformat ', |
86
|
|
|
inline: true, |
87
|
|
|
paste_data_images: true, |
88
|
|
|
skin: false, |
89
|
|
|
}); |
90
|
|
|
} |
91
|
|
|
} |