Diff: STRATO-apps/wordpress_03/app/wp-content/plugins/aimogen-pro/scripts/classic-editor.js
Keine Baseline-Datei – Diff nur gegen leer.
1
-
1
+
"use strict";
2
+
function aiomatic_uniq_fast(a)
3
+
{
4
+
var seen = {};
5
+
var out = [];
6
+
var len = a.length;
7
+
var j = 0;
8
+
for(var i = 0; i < len; i++) {
9
+
var item = a[i];
10
+
var jsit = JSON.stringify(item);
11
+
if(seen[jsit] !== 1) {
12
+
seen[jsit] = 1;
13
+
out[j++] = item;
14
+
}
15
+
}
16
+
return out;
17
+
}
18
+
(function() {
19
+
let menu = [];
20
+
tinymce.create("tinymce.plugins.aiomatic_editor", {
21
+
init : function(ed, url) {
22
+
if ("object" == typeof aiomatic && "object" == typeof aiomatic.prompts)
23
+
{
24
+
for (let operation in aiomatic.prompts)
25
+
{
26
+
let prompt = aiomatic.prompts[operation];
27
+
let icon = 'text';
28
+
let thumb = 'toc';
29
+
if(prompt[1] == 'image')
30
+
{
31
+
icon = 'format-image';
32
+
thumb = 'image';
33
+
}
34
+
menu.push({
35
+
text: operation,
36
+
classes: 'aiomatic-classic-button',
37
+
icon: thumb,
38
+
onclick: async function () {
39
+
ed = tinymce.activeEditor;
40
+
let selectedText = ed.selection.getContent({format: 'text'});
41
+
let send_prompt = prompt[0].replace('%%selected_text%%', selectedText);
42
+
if(send_prompt.includes('%%'))
43
+
{
44
+
var pid = document.getElementById('post_ID');
45
+
if(pid !== undefined && pid !== null && pid != '')
46
+
{
47
+
var postId = pid.value;
48
+
const ajaxurl = aiomatic.ajaxurl;
49
+
const nonce = aiomatic.nonce;
50
+
const xdata = new FormData();
51
+
xdata.append( 'postId', postId );
52
+
xdata.append( 'nonce', nonce );
53
+
xdata.append( 'send_prompt', send_prompt );
54
+
xdata.append( 'action', 'aiomatic_shortcode_replacer' );
55
+
const response = await fetch(ajaxurl, {
56
+
method: 'POST',
57
+
body: xdata
58
+
}).catch(async error => {
59
+
console.log('An exception occurred: ' + error.text());
60
+
})
61
+
62
+
if (!response.ok)
63
+
{
64
+
console.log('An error occurred: ' + response.text());
65
+
}
66
+
else
67
+
{
68
+
const ret = await response.json();
69
+
if (ret.message !== undefined) {
70
+
console.log('A general error occurred: ' + response.text());
71
+
}
72
+
else
73
+
{
74
+
send_prompt = ret.data.content;
75
+
}
76
+
}
77
+
}
78
+
}
79
+
let dom = tinymce.activeEditor.dom;
80
+
let $ = tinymce.dom.DomQuery;
81
+
82
+
const loadingSpinnerId = await aiomatic_classic_addAutocompleteContainer(aiomatic.placement, ed);
83
+
84
+
ed.selection.collapse();
85
+
let spinner = dom.select('#' + loadingSpinnerId);
86
+
87
+
let autocompletedText = '';
88
+
try {
89
+
if(icon == 'text')
90
+
{
91
+
autocompletedText = await aiomatic_classic_doAutocompleteRequest(send_prompt);
92
+
if(autocompletedText === undefined)
93
+
{
94
+
throw new Error('Failed to generate text!');
95
+
}
96
+
autocompletedText = autocompletedText.replace(/\n/g, '<br/>');
97
+
}
98
+
else
99
+
{
100
+
if(icon == 'format-image')
101
+
{
102
+
autocompletedText = await aiomatic_classic_doImageRequest(send_prompt);
103
+
if(autocompletedText === undefined)
104
+
{
105
+
throw new Error('Failed to generate text!');
106
+
}
107
+
}
108
+
}
109
+
} catch (error) {
110
+
$(spinner).remove();
111
+
alert('An API error occurred with the following response body: \n\n' + error.message);
112
+
return;
113
+
}
114
+
115
+
$(spinner).removeAttr('class');
116
+
$(spinner).removeAttr('id');
117
+
118
+
$(spinner).html(autocompletedText);
119
+
120
+
ed.undoManager.add();
121
+
}
122
+
});
123
+
}
124
+
var uniqueMenu = aiomatic_uniq_fast(menu);
125
+
uniqueMenu.forEach((item, index) => {
126
+
item.id = `menuitem-${index}`;
127
+
});
128
+
ed.addButton("aiomatic", {
129
+
type: 'menubutton',
130
+
title : "Aimogen Content Wizard",
131
+
tooltip: 'Aimogen Content Wizard',
132
+
image: aiomatic.xicon,
133
+
icon: false,
134
+
menu: uniqueMenu
135
+
});
136
+
}
137
+
},
138
+
createControl : function(n, cm) {
139
+
return null;
140
+
},
141
+
getInfo : function() {
142
+
return {
143
+
longname : "Aimogen Buttons",
144
+
author : "CodeRevolution",
145
+
version : "1.0"
146
+
};
147
+
}
148
+
});
149
+
tinymce.PluginManager.add("aiomatic_editor", tinymce.plugins.aiomatic_editor);
150
+
})();
151
+
152
+
const aiomatic_createLoadingSpinner = function (selectedNode, loadingSpinnerId) {
153
+
let spinnersrc = "";
154
+
let spinnerHtml = '';
155
+
if (['li'].includes(selectedNode.tagName.toLowerCase())) {
156
+
spinnerHtml = '<' + selectedNode.tagName + ' id="' + loadingSpinnerId + '" class="aiomatic-mce-loading"><img src="' + spinnersrc + '"></' + selectedNode.tagName + '>';
157
+
} else {
158
+
spinnerHtml = '<p id="' + loadingSpinnerId + '" class="aiomatic-mce-loading"><img src="' + spinnersrc + '"></p>';
159
+
}
160
+
161
+
return spinnerHtml;
162
+
}
163
+
164
+
const aiomatic_classic_doAutocompleteRequest = async function (text) {
165
+
const ajaxurl = aiomatic.ajaxurl;
166
+
const nonce = aiomatic.nonce;
167
+
const xdata = new FormData();
168
+
xdata.append( 'prompt', text );
169
+
xdata.append( 'nonce', nonce );
170
+
xdata.append( 'action', 'aiomatic_editor' );
171
+
const response = await fetch(ajaxurl, {
172
+
method: 'POST',
173
+
body: xdata
174
+
}).catch(async error => {
175
+
throw new Error(await error.text());
176
+
})
177
+
178
+
if (!response.ok) {
179
+
throw new Error(await response.text());
180
+
}
181
+
182
+
const ret = await response.json();
183
+
if (ret.message !== undefined) {
184
+
throw new Error(await response.text());
185
+
}
186
+
return ret.data.content;
187
+
}
188
+
189
+
const aiomatic_classic_doImageRequest = async function (text) {
190
+
const ajaxurl = aiomatic.ajaxurl;
191
+
const nonce = aiomatic.nonce;
192
+
const xdata = new FormData();
193
+
xdata.append( 'prompt', text );
194
+
xdata.append( 'nonce', nonce );
195
+
xdata.append( 'action', 'aiomatic_imager' );
196
+
const response = await fetch(ajaxurl, {
197
+
method: 'POST',
198
+
body: xdata
199
+
}).catch(async error => {
200
+
throw new Error(await error.text());
201
+
})
202
+
203
+
if (!response.ok) {
204
+
throw new Error(await response.text());
205
+
}
206
+
207
+
const ret = await response.json();
208
+
if (ret.message !== undefined) {
209
+
throw new Error(await response.text());
210
+
}
211
+
return ret.data.content;
212
+
}
213
+
const aiomatic_classic_addAutocompleteContainer = async function (placement, ed) {
214
+
let $ = tinymce.dom.DomQuery;
215
+
const loadingSpinnerId = Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);
216
+
217
+
let selectionRange = ed.selection.getRng();
218
+
if (placement === 'below') {
219
+
let selectedNode = ed.selection.getEnd();
220
+
221
+
let spinnerHtml = aiomatic_createLoadingSpinner(
222
+
selectedNode,
223
+
loadingSpinnerId,
224
+
)
225
+
let spinnerDom = $(spinnerHtml)[0];
226
+
227
+
let parentNode = selectionRange.endContainer.parentNode;
228
+
if (parentNode.tagName.toLowerCase() === 'li') {
229
+
$(selectedNode).after(spinnerDom);
230
+
} else if (selectedNode.textContent) {
231
+
selectionRange.collapse(false);
232
+
selectionRange.insertNode(spinnerDom);
233
+
ed.selection.collapse();
234
+
} else {
235
+
$(selectedNode).after(spinnerDom);
236
+
}
237
+
238
+
} else {
239
+
let selectedNode = ed.selection.getStart();
240
+
let spinnerHtml = aiomatic_createLoadingSpinner(
241
+
selectedNode,
242
+
loadingSpinnerId,
243
+
)
244
+
let spinnerDom = $(spinnerHtml)[0];
245
+
246
+
let parentNode = selectionRange.startContainer.parentNode;
247
+
if (parentNode.tagName.toLowerCase() === 'li') {
248
+
$(selectedNode).before(spinnerDom);
249
+
} else if (selectedNode.textContent) {
250
+
selectionRange.collapse(true);
251
+
selectionRange.insertNode(spinnerDom);
252
+
ed.selection.collapse();
253
+
} else {
254
+
$(selectedNode).before(spinnerDom);
255
+
}
256
+
}
257
+
258
+
ed.undoManager.add();
259
+
260
+
return loadingSpinnerId;
261
+
}