Skip to content
Navigation Menu
{{ message }}
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathchatbot.pls
More file actions
307 lines (260 loc) · 9.2 KB
/
chatbot.pls
File metadata and controls
307 lines (260 loc) · 9.2 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
*---------------------------------------------------------------
.
. Program Name: chatbot.pls
. Description: PL/B AI and speech recognition
.
. Revision History:
.
. Date: 09/20/2024
. 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.plf
chatDtMessages DATATABLE
Client CLIENT
jsonData DIM 200
emptyAns INIT "<<empty>>"
%ENCRYPTON
eapiKey INIT "Add your OpenAI API key here"
%ENCRYPTOFF
*---------------------------------------------------------------
// <program wide variables>
*................................................................
.
. 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
footer DIM 30
dateTime DATETIME
cleanInfo DIM 10240
dateTime.SetToNow Using $TRUE
dateTime.GetAsString Giving footer Using "Time: %h:%M:%S %a"
PACK cleanInfo,"<pre style='text-wrap: pretty'>",info,"</pre>"
chatDtMessages.AddRow USING "ChatBot":
*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
SETPROP chatDtMessages.columns(2), *ALIGNMENT=$CENTER
EVENTREG chatDtMessages,$UPDATED,CardBtn
FUNCTIONEND
*................................................................
.
. Ask the question to chatGPT
.
AskQuestion LFUNCTION
ENTRY
chars FORM 4
jsCall DIM 4096
apiKey DIM 200
question DIM 2048
GETPROP chatEdtQuestion, text=question
CHOP question
COUNT chars from question
chatHtmlSpeech.SetAttr using "chatResp","text",emptyAns
MOVE eapiKey,apiKey
DECRYPT apiKey
.
. Limit question to 2000 characters
.
IF (chars > 0 AND chars < 2000 )
CALL AddCard Using "Question",question
.
. Setup and call the aysnc javascript routine
.
PACK jsCall Using "askGpt('",question,"','",apiKey,"');"
Client.jsrun Using jsCall
Client.FlushMessages
ENDIF
SETPROP chatEdtQuestion, text=""
FUNCTIONEND
*................................................................
.
. Speech event and chat response event handler
.
ChatEvent LFUNCTION
ENTRY
data DIM 10240
.
. Look for and handle a chat response
.
SCAN "chatResp" in JsonData
IF EQUAL
chatHtmlSpeech.GetAttr giving data using "chatResp","text"
IF (data != emptyAns )
CHOP data
CALL AddCard Using "Response",data
SETFOCUS chatEdtQuestion
ENDIF
ENDIF
.
. Look for and handle a speech recognition event
.
SCAN "chatQues" in JsonData
IF EQUAL
chatHtmlSpeech.GetAttr giving data using "chatQues","text"
IF (data != emptyAns )
CHOP data
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,"chatbot_sup.html"
EVENTREG chatHtmlSpeech,$JQueryEvent,ChatEvent,ARG1=JsonData
chatFrmMain.SetAsClient
Client.SetUTF8Convert Using 0
FUNCTIONEND
You can’t perform that action at this time.
