Skip to content
Navigation Menu
{{ message }}
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathchat_gemini.pls
More file actions
340 lines (289 loc) · 11.1 KB
/
chat_gemini.pls
File metadata and controls
340 lines (289 loc) · 11.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
*---------------------------------------------------------------
.
. Program Name: chat_gemini.pls
. Description: PL/B AI and speech recognition using Gemini
.
. Revision History:
.
. Date: 07/23/2025 SM
. Original code
.
INCLUDE plbequ.inc
INCLUDE plbmeth.inc
// Runtime status variables
isGui BOOLEAN
isWebSrv BOOLEAN
isPlbSrv BOOLEAN
isWebview BOOLEAN
isWebCliApp BOOLEAN
isSmallScreen BOOLEAN
// Global data
mainForm PLFORM chatbot_gemini.plf
chatDtMessages DATATABLE
Client CLIENT
jsonData DIM 200
emptyAns INIT "<<empty>>"
%ENCRYPTON
apiKey INIT "Add your Gemini API key here" // gemini
%ENCRYPTOFF
*................................................................
.
. Code start
.
CALL Main
LOOP
EVENTWAIT
REPEAT
STOP
*................................................................
.
. Check what type of runtime support we have
.
CheckStatus LFUNCTION
ENTRY
runtimeData DIM 50
runtimeVersion DIM 5
unused DIM 1
plbRuntime DIM 9
WidthData DIM 5
checkWidth FORM 5
.
. Check for character mode runtime
.
GETMODE *GUI=isGui
IF (isGui)
.
. check windows console.
.
CLOCK VERSION,runtimeData
UNPACK runtimeData,runtimeVersion,unused,plbRuntime
CHOP plbRuntime
IF (NOCASE plbRuntime == "PLBCON")
CLEAR isGui
ENDIF
IF (NOCASE plbRuntime == "PLBWEBSV")
SET isWebSrv
ENDIF
IF (NOCASE plbRuntime == "PLBSERVE")
SET isPlbSrv
ENDIF
ENDIF
IF (isGui)
WINHIDE
Client.Getstate Giving isWebCliApp Using $CLI_STATE_CORDOVA
Client.Getstate Giving isWebview Using $CLI_STATE_BOOTSTRAP5
.
. Check for a small screen (such as iphone)
.
IF (isWebSrv)
Client.GetWinInfo Giving WidthData Using 0x2
MOVE WidthData To checkWidth
MOVE (checkWidth <= 700) to isSmallScreen
ENDIF
ENDIF
FUNCTIONEND
*................................................................
.
. Load a supporting HTML file
.
LoadSupportHtml LFUNCTION
htmlCtl HTMLCONTROL ^
fileName DIM 250
ENTRY
htmlFile FILE
htmlBuffer DIM ^
fileSize INTEGER 4
fullFileName DIM 250
seq FORM "-1"
EXCEPTSET NoFile IF IO
OPEN htmlFile,fileName,Read
*
.Read the registration file into a buffer
.
GETFILE htmlFile,TxtName=fullFileName
FINDFILE fullFileName,FileSize=fileSize
IF (!fileSize)
INCR fileSize
ENDIF
.
DMAKE htmlBuffer,fileSize
.
READ htmlFile,Seq;*ABSON,htmlBuffer
htmlCtl.InnerHtml Using htmlBuffer,$HTML_HAS_EVENTS
CLOSE htmlFile
DFREE htmlBuffer
noFile
FUNCTIONEND
*................................................................
.
. Card Button Event
.
CardBtn LFUNCTION
ENTRY
eventResult FORM 10
item FORM 5
subItem FORM 5
EVENTINFO 0,result=eventResult
CALC item = ( eventResult / 100 )
CALC subItem = ( eventResult - ( item * 100 ) )
chatDtMessages.DeleteRow USING item
FUNCTIONEND
*................................................................
.
. Add one card
.
AddCard LFUNCTION
type DIM 20
info DIM ^
ENTRY
title DIM 10
footer DIM 30
dateTime DATETIME
cleanInfo DIM 64000
dateTime.SetToNow Using $TRUE
dateTime.GetAsString Giving footer Using "Time: %h:%M:%S %a"
// For questions, wrap in pre tag for readability
IF (type == "Question")
PACK cleanInfo,"<pre class='bg-light text-secondary ms-4 shadow-sm pre-question'>":
info,"</pre>"
MOVE "Me", title
ELSE // For responses
PACK cleanInfo,"<div class='bg-light shadow-sm pre-response'>":
info,"</div>"
MOVE "Chatbot", title
ENDIF
chatDtMessages.AddRow USING title:
*subitem1=type:
*subitem2=cleanInfo:
*subitem3="Remove":
*subitem4=footer
FUNCTIONEND
*................................................................
.
. SetupCards
.
SetupCards LFUNCTION
ENTRY
CREATE chatDtMessages
chatDtMessages.AddColumn Using 0, *ContentType=$TC_HEADER
chatDtMessages.AddColumn Using 1, *ContentType=$TC_TITLE
chatDtMessages.AddColumn Using 2, *ContentType=$TC_DETAILS
chatDtMessages.AddColumn Using 3, *ContentType=$TC_BUTTON1
chatDtMessages.AddColumn Using 4, *ContentType=$TC_FOOTER
chatDtMessages.AddColumn Using 5
EVENTREG chatDtMessages,$UPDATED,CardBtn
FUNCTIONEND
*................................................................
.
. Ask the question to Gemini
.
AskQuestion LFUNCTION
ENTRY
chars FORM 4
jsCall DIM 8192
decryptedApiKey DIM 200
question DIM 8192
result FORM 4
GETPROP chatEdtQuestion, text=question
CHOP question
COUNT chars from question
chatHtmlSpeech.SetAttr using "chatResp","text",emptyAns // Clear previous response
MOVE apiKey,decryptedApiKey // Decrypt API key
DECRYPT decryptedApiKey
IF (chars > 0 AND chars < 4000 ) // Limit question to 4000 characters
CALL AddCard Using "Question", question
PACK jsCall Using "askGemini('",question,"','",decryptedApiKey,"');"
Client.jsrun Using jsCall
Client.FlushMessages
ENDIF
SETPROP chatEdtQuestion, text=""
FUNCTIONEND
*................................................................
.
. Speech event and chat response event handler
.
ChatEvent LFUNCTION
ENTRY
data DIM 64000
cleanData DIM 64000
readyFlag DIM 10
result FORM 4
SCAN "chatResp" in JsonData
IF EQUAL // Check if the response is ready
chatHtmlSpeech.GetAttr giving readyFlag using "chatResp","data-ready"
CHOP readyFlag
IF (readyFlag == "true")
CLEAR data // Clear data first
.
. Try methods in order until we get content
. Method 1: Try processed content
.
chatHtmlSpeech.GetAttr giving data using "chatResp","data-processed"
CHOP data
.
. Method 2: If processed is empty, try innerHTML
.
IF (data == "")
CLEAR data
chatHtmlSpeech.GetAttr giving data using "chatResp","innerHTML"
CHOP data
ENDIF
.
. Method 3: If still empty, try text content
.
IF (data == "")
CLEAR data
chatHtmlSpeech.GetAttr giving data using "chatResp","text"
CHOP data
ENDIF
.
. If we got content by any method, add the card
.
IF (data != "")
MOVE data,cleanData
CALL AddCard Using "Response",cleanData
SETFOCUS chatEdtQuestion
ENDIF
ENDIF
ENDIF
SCAN "chatQues" in JsonData
IF EQUAL
CLEAR data
chatHtmlSpeech.GetAttr giving data using "chatQues","text"
CHOP data
IF (data != "" AND data != "<<empty>>")
SETPROP chatEdtQuestion, text=data
SETFOCUS chatEdtQuestion
ENDIF
ENDIF
FUNCTIONEND
*................................................................
.
. Main - Main program entry point
.
Main LFUNCTION
ENTRY
result FORM 4
CALL CheckStatus
IF (!isGui)
KEYIN "This runtime can't run this program. ",result
STOP
ENDIF
IF (!isWebview)
ALERT STOP,"This program requires WebView support.",result
STOP
ENDIF
.
. On smaller screens change to % positioning for left and width
.
IF (isWebCliApp || isSmallScreen)
SETMODE *PERCENTCONVERT=1
ENDIF
FORMLOAD mainForm
CALL SetupCards
chatDtMessages.HtmlBind Using chatHtmlMessages,$TBL_HTML_CARD
CALL LoadSupportHtml Using chatHtmlSpeech,"chat_gemini.html" // Load the HTML file
EVENTREG chatHtmlSpeech,$JQueryEvent,ChatEvent,ARG1=JsonData // Register event handler for JavaScript events
chatFrmMain.SetAsClient
Client.SetUTF8Convert Using 0
FUNCTIONEND
You can’t perform that action at this time.
