d-htmldokumente.w 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603
  1. &ANALYZE-SUSPEND _VERSION-NUMBER AB_v10r12 GUI ADM2
  2. &ANALYZE-RESUME
  3. /* Connected Databases
  4. framework PROGRESS
  5. */
  6. &Scoped-define WINDOW-NAME CURRENT-WINDOW
  7. {adecomm/appserv.i}
  8. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _DEFINITIONS dTables
  9. /*------------------------------------------------------------------------
  10. File:
  11. Description: from DATA.W - Template For SmartData objects in the ADM
  12. Input Parameters:
  13. <none>
  14. Output Parameters:
  15. <none>
  16. Modified: February 24, 1999
  17. ------------------------------------------------------------------------*/
  18. /* This .W file was created with the Progress AppBuilder. */
  19. /*----------------------------------------------------------------------*/
  20. /* Create an unnamed pool to store all the widgets created
  21. by this procedure. This is a good default which assures
  22. that this procedure's triggers and internal procedures
  23. will execute in this procedure's storage, and that proper
  24. cleanup will occur on deletion of the procedure. */
  25. CREATE WIDGET-POOL.
  26. /* *************************** Definitions ************************** */
  27. /* Parameters Definitions --- */
  28. /* Local Variable Definitions --- */
  29. &SCOPED-DEFINE Tabelle htmldokumente
  30. &SCOPED-DEFINE TabWhere /* USE-INDEX Benutzer-k1 ~
  31. WHERE {&Tabelle}.Benutzer = tRowObject.Benutzer
  32. */
  33. { incl/datdefinition.i }
  34. DEFINE VARIABLE cMandant AS CHARACTER NO-UNDO.
  35. DEFINE VARIABLE cBenutzer AS CHARACTER NO-UNDO.
  36. DEFINE VARIABLE cProgramm AS CHARACTER NO-UNDO.
  37. DEFINE VARIABLE iSprcd AS INTEGER NO-UNDO.
  38. /* _UIB-CODE-BLOCK-END */
  39. &ANALYZE-RESUME
  40. &ANALYZE-SUSPEND _UIB-PREPROCESSOR-BLOCK
  41. /* ******************** Preprocessor Definitions ******************** */
  42. &Global-define DATA-LOGIC-PROCEDURE .p
  43. &Scoped-define PROCEDURE-TYPE SmartDataObject
  44. &Scoped-define DB-AWARE yes
  45. &Scoped-define ADM-SUPPORTED-LINKS Data-Source,Data-Target,Navigation-Target,Update-Target,Commit-Target,Filter-Target
  46. /* Db-Required definitions. */
  47. &IF DEFINED(DB-REQUIRED) = 0 &THEN
  48. &GLOBAL-DEFINE DB-REQUIRED TRUE
  49. &ENDIF
  50. &GLOBAL-DEFINE DB-REQUIRED-START &IF {&DB-REQUIRED} &THEN
  51. &GLOBAL-DEFINE DB-REQUIRED-END &ENDIF
  52. &Scoped-define QUERY-NAME Query-Main
  53. /* Internal Tables (found by Frame, Query & Browse Queries) */
  54. &Scoped-define INTERNAL-TABLES htmldokumente
  55. /* Definitions for QUERY Query-Main */
  56. &Scoped-Define ENABLED-FIELDS mandant benutzer program art sprcd htmltext
  57. &Scoped-define ENABLED-FIELDS-IN-htmldokumente mandant benutzer program art ~
  58. sprcd htmltext
  59. &Scoped-Define DATA-FIELDS mandant benutzer program art sprcd htmltext
  60. &Scoped-define DATA-FIELDS-IN-htmldokumente mandant benutzer program art ~
  61. sprcd htmltext
  62. &Scoped-Define MANDATORY-FIELDS
  63. &Scoped-Define APPLICATION-SERVICE
  64. &Scoped-Define ASSIGN-LIST
  65. &Scoped-Define DATA-FIELD-DEFS "d-htmldokumente.i"
  66. &Scoped-Define DATA-TABLE-NO-UNDO NO-UNDO
  67. &Scoped-define QUERY-STRING-Query-Main FOR EACH htmldokumente NO-LOCK INDEXED-REPOSITION
  68. {&DB-REQUIRED-START}
  69. &Scoped-define OPEN-QUERY-Query-Main OPEN QUERY Query-Main FOR EACH htmldokumente NO-LOCK INDEXED-REPOSITION.
  70. {&DB-REQUIRED-END}
  71. &Scoped-define TABLES-IN-QUERY-Query-Main htmldokumente
  72. &Scoped-define FIRST-TABLE-IN-QUERY-Query-Main htmldokumente
  73. /* Custom List Definitions */
  74. /* List-1,List-2,List-3,List-4,List-5,List-6 */
  75. /* _UIB-PREPROCESSOR-BLOCK-END */
  76. &ANALYZE-RESUME
  77. /* ************************ Function Prototypes ********************** */
  78. {&DB-REQUIRED-START}
  79. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION-FORWARD getCurrentRecid dTables _DB-REQUIRED
  80. FUNCTION getCurrentRecid RETURNS RECID
  81. ( /* parameter-definitions */ ) FORWARD.
  82. /* _UIB-CODE-BLOCK-END */
  83. &ANALYZE-RESUME
  84. {&DB-REQUIRED-END}
  85. {&DB-REQUIRED-START}
  86. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION-FORWARD getQueryBuffer dTables _DB-REQUIRED
  87. FUNCTION getQueryBuffer RETURNS HANDLE
  88. ( /* parameter-definitions */ ) FORWARD.
  89. /* _UIB-CODE-BLOCK-END */
  90. &ANALYZE-RESUME
  91. {&DB-REQUIRED-END}
  92. {&DB-REQUIRED-START}
  93. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION-FORWARD openQuery dTables _DB-REQUIRED
  94. FUNCTION openQuery RETURNS LOGICAL
  95. ( /* parameter-definitions */ ) FORWARD.
  96. /* _UIB-CODE-BLOCK-END */
  97. &ANALYZE-RESUME
  98. {&DB-REQUIRED-END}
  99. /* *********************** Control Definitions ********************** */
  100. {&DB-REQUIRED-START}
  101. /* Query definitions */
  102. &ANALYZE-SUSPEND
  103. DEFINE QUERY Query-Main FOR
  104. htmldokumente SCROLLING.
  105. &ANALYZE-RESUME
  106. {&DB-REQUIRED-END}
  107. /* ************************ Frame Definitions *********************** */
  108. /* *********************** Procedure Settings ************************ */
  109. &ANALYZE-SUSPEND _PROCEDURE-SETTINGS
  110. /* Settings for THIS-PROCEDURE
  111. Type: SmartDataObject
  112. Allow: Query
  113. Frames: 0
  114. Add Fields to: Neither
  115. Other Settings: PERSISTENT-ONLY COMPILE APPSERVER DB-AWARE
  116. */
  117. /* This procedure should always be RUN PERSISTENT. Report the error, */
  118. /* then cleanup and return. */
  119. IF NOT THIS-PROCEDURE:PERSISTENT THEN
  120. DO:
  121. MESSAGE "{&FILE-NAME} should only be RUN PERSISTENT.":U
  122. VIEW-AS ALERT-BOX ERROR BUTTONS OK.
  123. RETURN.
  124. END.
  125. &ANALYZE-RESUME _END-PROCEDURE-SETTINGS
  126. /* ************************* Create Window ************************** */
  127. &ANALYZE-SUSPEND _CREATE-WINDOW
  128. /* DESIGN Window definition (used by the UIB)
  129. CREATE WINDOW dTables ASSIGN
  130. HEIGHT = 1.62
  131. WIDTH = 46.6.
  132. /* END WINDOW DEFINITION */
  133. */
  134. &ANALYZE-RESUME
  135. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _INCLUDED-LIB dTables
  136. /* ************************* Included-Libraries *********************** */
  137. {src/adm2/data.i}
  138. /* _UIB-CODE-BLOCK-END */
  139. &ANALYZE-RESUME
  140. /* *********** Runtime Attributes and AppBuilder Settings *********** */
  141. &ANALYZE-SUSPEND _RUN-TIME-ATTRIBUTES
  142. /* SETTINGS FOR WINDOW dTables
  143. VISIBLE,,RUN-PERSISTENT */
  144. /* _RUN-TIME-ATTRIBUTES-END */
  145. &ANALYZE-RESUME
  146. /* Setting information for Queries and Browse Widgets fields */
  147. &ANALYZE-SUSPEND _QUERY-BLOCK QUERY Query-Main
  148. /* Query rebuild information for SmartDataObject Query-Main
  149. _TblList = "FRAMEWORK.htmldokumente"
  150. _Options = "NO-LOCK INDEXED-REPOSITION"
  151. _FldNameList[1] > FRAMEWORK.htmldokumente.mandant
  152. "mandant" "mandant" ? ? "character" ? ? ? ? ? ? yes ? no 8.4 yes ?
  153. _FldNameList[2] > FRAMEWORK.htmldokumente.benutzer
  154. "benutzer" "benutzer" ? ? "character" ? ? ? ? ? ? yes ? no 30 yes ?
  155. _FldNameList[3] > FRAMEWORK.htmldokumente.program
  156. "program" "program" ? ? "character" ? ? ? ? ? ? yes ? no 20 yes ?
  157. _FldNameList[4] > FRAMEWORK.htmldokumente.art
  158. "art" "art" ? ? "character" ? ? ? ? ? ? yes ? no 20 yes ?
  159. _FldNameList[5] > FRAMEWORK.htmldokumente.sprcd
  160. "sprcd" "sprcd" ? ? "integer" ? ? ? ? ? ? yes ? no 5.2 yes ?
  161. _FldNameList[6] > FRAMEWORK.htmldokumente.htmltext
  162. "htmltext" "htmltext" ? ? "character" ? ? ? ? ? ? yes ? no 32000 yes ?
  163. _Design-Parent is WINDOW dTables @ ( 1.14 , 2.6 )
  164. */ /* QUERY Query-Main */
  165. &ANALYZE-RESUME
  166. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _MAIN-BLOCK dTables
  167. /* *************************** Main Block *************************** */
  168. { incl/datmainblock.i }
  169. fOpen = FALSE.
  170. &IF DEFINED(UIB_IS_RUNNING) <> 0 &THEN
  171. RUN initializeObject.
  172. &ENDIF
  173. /* _UIB-CODE-BLOCK-END */
  174. &ANALYZE-RESUME
  175. /* ********************** Internal Procedures *********************** */
  176. {&DB-REQUIRED-START}
  177. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE dataAvailable dTables _DB-REQUIRED
  178. PROCEDURE dataAvailable :
  179. /*------------------------------------------------------------------------------
  180. Purpose: Super Override
  181. Parameters:
  182. Notes:
  183. ------------------------------------------------------------------------------*/
  184. { incl/datdataavailable.i }
  185. END PROCEDURE.
  186. /* _UIB-CODE-BLOCK-END */
  187. &ANALYZE-RESUME
  188. {&DB-REQUIRED-END}
  189. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE disable_UI dTables _DEFAULT-DISABLE
  190. PROCEDURE disable_UI :
  191. /*------------------------------------------------------------------------------
  192. Purpose: DISABLE the User Interface
  193. Parameters: <none>
  194. Notes: Here we clean-up the user-interface by deleting
  195. dynamic widgets we have created and/or hide
  196. frames. This procedure is usually called when
  197. we are ready to "clean-up" after running.
  198. ------------------------------------------------------------------------------*/
  199. /* Hide all frames. */
  200. IF THIS-PROCEDURE:PERSISTENT THEN DELETE PROCEDURE THIS-PROCEDURE.
  201. END PROCEDURE.
  202. /* _UIB-CODE-BLOCK-END */
  203. &ANALYZE-RESUME
  204. {&DB-REQUIRED-START}
  205. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE INAKTIVIEREN dTables _DB-REQUIRED
  206. PROCEDURE INAKTIVIEREN :
  207. /*------------------------------------------------------------------------------
  208. Purpose:
  209. Parameters: <none>
  210. Notes:
  211. ------------------------------------------------------------------------------*/
  212. { incl/datinaktivieren.i }
  213. END PROCEDURE.
  214. /* _UIB-CODE-BLOCK-END */
  215. &ANALYZE-RESUME
  216. {&DB-REQUIRED-END}
  217. {&DB-REQUIRED-START}
  218. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE initializeObject dTables _DB-REQUIRED
  219. PROCEDURE initializeObject :
  220. /*------------------------------------------------------------------------------
  221. Purpose: Super Override
  222. Parameters:
  223. Notes:
  224. ------------------------------------------------------------------------------*/
  225. { incl/datinitialize.i }
  226. END PROCEDURE.
  227. /* _UIB-CODE-BLOCK-END */
  228. &ANALYZE-RESUME
  229. {&DB-REQUIRED-END}
  230. {&DB-REQUIRED-START}
  231. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE REAKTIVIEREN dTables _DB-REQUIRED
  232. PROCEDURE REAKTIVIEREN :
  233. /*------------------------------------------------------------------------------
  234. Purpose:
  235. Parameters: <none>
  236. Notes:
  237. ------------------------------------------------------------------------------*/
  238. { incl/datreaktivieren.i }
  239. END PROCEDURE.
  240. /* _UIB-CODE-BLOCK-END */
  241. &ANALYZE-RESUME
  242. {&DB-REQUIRED-END}
  243. {&DB-REQUIRED-START}
  244. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE REPOS_TABELLE dTables _DB-REQUIRED
  245. PROCEDURE REPOS_TABELLE :
  246. /*------------------------------------------------------------------------------
  247. Purpose:
  248. Parameters: <none>
  249. Notes:
  250. ------------------------------------------------------------------------------*/
  251. { incl/datrepos.i }
  252. END PROCEDURE.
  253. /* _UIB-CODE-BLOCK-END */
  254. &ANALYZE-RESUME
  255. {&DB-REQUIRED-END}
  256. {&DB-REQUIRED-START}
  257. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_BENUTZER dTables _DB-REQUIRED
  258. PROCEDURE SET_BENUTZER :
  259. /*------------------------------------------------------------------------------
  260. Purpose:
  261. Parameters: <none>
  262. Notes:
  263. ------------------------------------------------------------------------------*/
  264. DEFINE INPUT PARAMETER ipcBenutzer AS CHARACTER NO-UNDO.
  265. cBenutzer = ipcBenutzer.
  266. DYNAMIC-FUNCTION('openQuery':U) NO-ERROR.
  267. END PROCEDURE.
  268. /* _UIB-CODE-BLOCK-END */
  269. &ANALYZE-RESUME
  270. {&DB-REQUIRED-END}
  271. {&DB-REQUIRED-START}
  272. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_FILTER dTables _DB-REQUIRED
  273. PROCEDURE SET_FILTER :
  274. /*------------------------------------------------------------------------------
  275. Purpose:
  276. Parameters: <none>
  277. Notes:
  278. ------------------------------------------------------------------------------*/
  279. { incl/datsetfilter.i }
  280. END PROCEDURE.
  281. /* _UIB-CODE-BLOCK-END */
  282. &ANALYZE-RESUME
  283. {&DB-REQUIRED-END}
  284. {&DB-REQUIRED-START}
  285. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_MANDANT dTables _DB-REQUIRED
  286. PROCEDURE SET_MANDANT :
  287. /*------------------------------------------------------------------------------
  288. Purpose:
  289. Parameters: <none>
  290. Notes:
  291. ------------------------------------------------------------------------------*/
  292. DEFINE INPUT PARAMETER ipcMandant AS CHARACTER NO-UNDO.
  293. cMandant = ipcMandant.
  294. DYNAMIC-FUNCTION('openQuery':U) NO-ERROR.
  295. END PROCEDURE.
  296. /* _UIB-CODE-BLOCK-END */
  297. &ANALYZE-RESUME
  298. {&DB-REQUIRED-END}
  299. {&DB-REQUIRED-START}
  300. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_OPENFLAG dTables _DB-REQUIRED
  301. PROCEDURE SET_OPENFLAG :
  302. /*------------------------------------------------------------------------------
  303. Purpose:
  304. Parameters: <none>
  305. Notes:
  306. ------------------------------------------------------------------------------*/
  307. { incl/datsetopenflag.i }
  308. END PROCEDURE.
  309. /* _UIB-CODE-BLOCK-END */
  310. &ANALYZE-RESUME
  311. {&DB-REQUIRED-END}
  312. {&DB-REQUIRED-START}
  313. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_PROGRAMM dTables _DB-REQUIRED
  314. PROCEDURE SET_PROGRAMM :
  315. /*------------------------------------------------------------------------------
  316. Purpose:
  317. Parameters: <none>
  318. Notes:
  319. ------------------------------------------------------------------------------*/
  320. DEFINE INPUT PARAMETER ipcProgramm AS CHARACTER NO-UNDO.
  321. cProgramm = ipcProgramm.
  322. DYNAMIC-FUNCTION('openQuery':U) NO-ERROR.
  323. END PROCEDURE.
  324. /* _UIB-CODE-BLOCK-END */
  325. &ANALYZE-RESUME
  326. {&DB-REQUIRED-END}
  327. {&DB-REQUIRED-START}
  328. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_SORT dTables _DB-REQUIRED
  329. PROCEDURE SET_SORT :
  330. /*------------------------------------------------------------------------------
  331. Purpose:
  332. Parameters: <none>
  333. Notes:
  334. ------------------------------------------------------------------------------*/
  335. { incl/datsetsort.i }
  336. END PROCEDURE.
  337. /* _UIB-CODE-BLOCK-END */
  338. &ANALYZE-RESUME
  339. {&DB-REQUIRED-END}
  340. {&DB-REQUIRED-START}
  341. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_SPRCD dTables _DB-REQUIRED
  342. PROCEDURE SET_SPRCD :
  343. /*------------------------------------------------------------------------------
  344. Purpose:
  345. Parameters: <none>
  346. Notes:
  347. ------------------------------------------------------------------------------*/
  348. DEFINE INPUT PARAMETER ipcSprcd AS CHARACTER NO-UNDO.
  349. iSprcd = INTEGER(ipcSprcd).
  350. DYNAMIC-FUNCTION('openQuery':U) NO-ERROR.
  351. END PROCEDURE.
  352. /* _UIB-CODE-BLOCK-END */
  353. &ANALYZE-RESUME
  354. {&DB-REQUIRED-END}
  355. /* ************************ Function Implementations ***************** */
  356. {&DB-REQUIRED-START}
  357. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION getCurrentRecid dTables _DB-REQUIRED
  358. FUNCTION getCurrentRecid RETURNS RECID
  359. ( /* parameter-definitions */ ) :
  360. /*------------------------------------------------------------------------------
  361. Purpose:
  362. Notes:
  363. ------------------------------------------------------------------------------*/
  364. { incl/datgetcurrentrecid.i }
  365. END FUNCTION.
  366. /* _UIB-CODE-BLOCK-END */
  367. &ANALYZE-RESUME
  368. {&DB-REQUIRED-END}
  369. {&DB-REQUIRED-START}
  370. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION getQueryBuffer dTables _DB-REQUIRED
  371. FUNCTION getQueryBuffer RETURNS HANDLE
  372. ( /* parameter-definitions */ ) :
  373. /*------------------------------------------------------------------------------
  374. Purpose:
  375. Notes:
  376. ------------------------------------------------------------------------------*/
  377. RETURN BUFFER rowObject:HANDLE.
  378. END FUNCTION.
  379. /* _UIB-CODE-BLOCK-END */
  380. &ANALYZE-RESUME
  381. {&DB-REQUIRED-END}
  382. {&DB-REQUIRED-START}
  383. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION openQuery dTables _DB-REQUIRED
  384. FUNCTION openQuery RETURNS LOGICAL
  385. ( /* parameter-definitions */ ) :
  386. /*------------------------------------------------------------------------------
  387. Purpose: Super Override
  388. Notes:
  389. ------------------------------------------------------------------------------*/
  390. DEFINE VARIABLE Felder AS CHARACTER NO-UNDO.
  391. DEFINE VARIABLE Inhalt AS CHARACTER NO-UNDO.
  392. DEFINE VARIABLE ix AS INTEGER NO-UNDO.
  393. DEFINE VARIABLE cFeld AS CHARACTER NO-UNDO.
  394. IF NOT fOpen THEN RETURN FALSE.
  395. xWhere = ''.
  396. xSort = ''.
  397. xString = ''.
  398. Felder = DYNAMIC-FUNCTION('getForeignFields':U) NO-ERROR.
  399. Inhalt = DYNAMIC-FUNCTION('getForeignValues':U) NO-ERROR.
  400. /* ix = LOOKUP('Feld', Felder, ',') / 2. */
  401. /* cFeld = ENTRY (ix , Inhalt, CHR(01)). */
  402. xWhere
  403. = 'htmldokumente.mandant = ' + QUOTER(cMandant) + ' AND '
  404. + 'htmldokumente.Benutzer = ' + QUOTER(cBenutzer) + ' '.
  405. /* xString = 'FOR EACH Debop ' + xSort + 'WHERE ' */
  406. /* + 'Debop.Firma = "' + Firma + '" AND ' */
  407. /* + 'Debop.Knr = ' + STRING(Knr) + ' ' */
  408. /* + 'NO-LOCK BY Debop.FakDat DESCENDING INDEXED-REPOSITION '. */
  409. { incl/datopenquery.i }
  410. IF xWhere <> '' THEN DYNAMIC-FUNCTION('setQueryWhere':U , INPUT xWhere ).
  411. IF xSort <> '' THEN DYNAMIC-FUNCTION('setQuerySort':U , INPUT xSort ).
  412. IF xString <> '' THEN DYNAMIC-FUNCTION('setQueryString':U, INPUT xString).
  413. RETURN SUPER( ).
  414. END FUNCTION.
  415. /* _UIB-CODE-BLOCK-END */
  416. &ANALYZE-RESUME
  417. {&DB-REQUIRED-END}