frayerjj-frontend 0.1.34 → 0.1.35

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 (2) hide show
  1. package/package.json +1 -1
  2. package/src/init.js +84 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "frayerjj-frontend",
3
- "version": "0.1.34",
3
+ "version": "0.1.35",
4
4
  "description": "My base frontend for various projects",
5
5
  "main": "src/index.js",
6
6
  "type": "module",
package/src/init.js CHANGED
@@ -2,9 +2,66 @@ import { message } from './message';
2
2
  import { modal } from './modal';
3
3
  import { validate } from './validate';
4
4
  import { loading } from './loading';
5
+ import { ClassicEditor } from '@ckeditor/ckeditor5-build-classic';
5
6
 
6
7
  export const init = () => {
7
8
 
9
+ class CkeUploadAdapter {
10
+ constructor(loader, uri, token) {
11
+ this.loader = loader;
12
+ this.uri = uri;
13
+ this.token = token;
14
+ }
15
+ upload() {
16
+ return this.loader.file
17
+ .then(file => new Promise((resolve, reject) => {
18
+ this._initRequest();
19
+ this._initListeners(resolve, reject, file);
20
+ this._sendRequest(file);
21
+ }));
22
+ }
23
+ abort() {
24
+ if (this.xhr) this.xhr.abort();
25
+ }
26
+ _initRequest() {
27
+ const xhr = this.xhr = new XMLHttpRequest();
28
+ xhr.open('POST', this.uri, true);
29
+ xhr.setRequestHeader('X-CSRFToken', this.token);
30
+ xhr.responseType = 'json';
31
+ }
32
+ _initListeners(resolve, reject, file) {
33
+ const xhr = this.xhr;
34
+ const loader = this.loader;
35
+ const genericErrorText = `Couldn't upload file: ${ file.name }.`;
36
+ xhr.addEventListener( 'error', () => reject(genericErrorText) );
37
+ xhr.addEventListener( 'abort', () => reject() );
38
+ xhr.addEventListener( 'load', () => {
39
+ const response = xhr.response;
40
+ if (!response || response.error) return reject(response && response.error ? response.error.message : genericErrorText);
41
+ resolve({ default: response.url });
42
+ });
43
+ if (xhr.upload) {
44
+ xhr.upload.addEventListener('progress', evt => {
45
+ if (evt.lengthComputable) {
46
+ loader.uploadTotal = evt.total;
47
+ loader.uploaded = evt.loaded;
48
+ }
49
+ });
50
+ }
51
+ }
52
+ _sendRequest(file) {
53
+ const data = new FormData();
54
+ data.append('file', file);
55
+ this.xhr.send(data);
56
+ }
57
+ };
58
+
59
+ window.CkeUploadAdapterPlugin = function(editor) {
60
+ editor.plugins.get('FileRepository').createUploadAdapter = (loader) => {
61
+ return new CkeUploadAdapter(loader, editor.config._config.extraParams.uri, editor.config._config.extraParams.token);
62
+ };
63
+ };
64
+
8
65
  loading.init();
9
66
 
10
67
  window.addEventListener('load', () => {
@@ -78,6 +135,33 @@ export const init = () => {
78
135
  toTop.style.visibility = "hidden";
79
136
  }
80
137
  });
138
+
139
+ window.editors = [];
140
+ document.querySelectorAll('.wysiwyg').forEach(el => {
141
+ ClassicEditor.create(el, {
142
+ licenseKey: 'GPL',
143
+ htmlSupport: {
144
+ allow: [
145
+ {
146
+ name: /.*/,
147
+ attributes: true,
148
+ classes: true,
149
+ styles: true
150
+ }
151
+ ]
152
+ },
153
+ extraParams: {
154
+ uri: document.querySelector('meta[name="asset-upload"]').getAttribute('content'),
155
+ token: document.querySelector('meta[name="csrf-token"]').getAttribute('content')
156
+ },
157
+ extraPlugins: [ CkeUploadAdapterPlugin ]
158
+ }).then(editor => {
159
+ window.editors[el.id] = editor;
160
+ }).catch( error => {
161
+ console.error( 'There was a problem initializing the editor.', error );
162
+ });
163
+ });
164
+
81
165
  });
82
166
 
83
167
  }