d-orte.w 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  1. &ANALYZE-SUSPEND _VERSION-NUMBER AB_v10r12 GUI ADM2
  2. &ANALYZE-RESUME
  3. /* Connected Databases
  4. anadat 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. &glob DATA-LOGIC-PROCEDURE .p
  30. &SCOPED-DEFINE Tabelle Orte
  31. &SCOPED-DEFINE TabWhere /* USE-INDEX Benutzer-k1 ~
  32. WHERE {&Tabelle}.Benutzer = tRowObject.Benutzer
  33. */
  34. { incl/datdefinition.i }
  35. /* _UIB-CODE-BLOCK-END */
  36. &ANALYZE-RESUME
  37. &ANALYZE-SUSPEND _UIB-PREPROCESSOR-BLOCK
  38. /* ******************** Preprocessor Definitions ******************** */
  39. &Scoped-define PROCEDURE-TYPE SmartDataObject
  40. &Scoped-define DB-AWARE yes
  41. &Scoped-define ADM-SUPPORTED-LINKS Data-Source,Data-Target,Navigation-Target,Update-Target,Commit-Target,Filter-Target
  42. /* Db-Required definitions. */
  43. &IF DEFINED(DB-REQUIRED) = 0 &THEN
  44. &GLOBAL-DEFINE DB-REQUIRED TRUE
  45. &ENDIF
  46. &GLOBAL-DEFINE DB-REQUIRED-START &IF {&DB-REQUIRED} &THEN
  47. &GLOBAL-DEFINE DB-REQUIRED-END &ENDIF
  48. &Scoped-define QUERY-NAME Query-Main
  49. /* Internal Tables (found by Frame, Query & Browse Queries) */
  50. &Scoped-define INTERNAL-TABLES Orte
  51. /* Definitions for QUERY Query-Main */
  52. &Scoped-Define ENABLED-FIELDS Lkz Ort Ortkb Plz
  53. &Scoped-define ENABLED-FIELDS-IN-Orte Lkz Ort Ortkb Plz
  54. &Scoped-Define DATA-FIELDS Lkz Ort Ortkb Plz
  55. &Scoped-define DATA-FIELDS-IN-Orte Lkz Ort Ortkb Plz
  56. &Scoped-Define MANDATORY-FIELDS Lkz Plz
  57. &Scoped-Define APPLICATION-SERVICE
  58. &Scoped-Define ASSIGN-LIST
  59. &Scoped-Define DATA-FIELD-DEFS "d-orte.i"
  60. &Scoped-Define DATA-TABLE-NO-UNDO NO-UNDO
  61. &Scoped-define QUERY-STRING-Query-Main FOR EACH Orte NO-LOCK INDEXED-REPOSITION
  62. {&DB-REQUIRED-START}
  63. &Scoped-define OPEN-QUERY-Query-Main OPEN QUERY Query-Main FOR EACH Orte NO-LOCK INDEXED-REPOSITION.
  64. {&DB-REQUIRED-END}
  65. &Scoped-define TABLES-IN-QUERY-Query-Main Orte
  66. &Scoped-define FIRST-TABLE-IN-QUERY-Query-Main Orte
  67. /* Custom List Definitions */
  68. /* List-1,List-2,List-3,List-4,List-5,List-6 */
  69. /* _UIB-PREPROCESSOR-BLOCK-END */
  70. &ANALYZE-RESUME
  71. /* ************************ Function Prototypes ********************** */
  72. {&DB-REQUIRED-START}
  73. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION-FORWARD getQueryBuffer dTables _DB-REQUIRED
  74. FUNCTION getQueryBuffer RETURNS HANDLE
  75. ( /* parameter-definitions */ ) FORWARD.
  76. /* _UIB-CODE-BLOCK-END */
  77. &ANALYZE-RESUME
  78. {&DB-REQUIRED-END}
  79. {&DB-REQUIRED-START}
  80. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION-FORWARD openQuery dTables _DB-REQUIRED
  81. FUNCTION openQuery RETURNS LOGICAL
  82. ( /* parameter-definitions */ ) FORWARD.
  83. /* _UIB-CODE-BLOCK-END */
  84. &ANALYZE-RESUME
  85. {&DB-REQUIRED-END}
  86. /* *********************** Control Definitions ********************** */
  87. {&DB-REQUIRED-START}
  88. /* Query definitions */
  89. &ANALYZE-SUSPEND
  90. DEFINE QUERY Query-Main FOR
  91. Orte SCROLLING.
  92. &ANALYZE-RESUME
  93. {&DB-REQUIRED-END}
  94. /* ************************ Frame Definitions *********************** */
  95. /* *********************** Procedure Settings ************************ */
  96. &ANALYZE-SUSPEND _PROCEDURE-SETTINGS
  97. /* Settings for THIS-PROCEDURE
  98. Type: SmartDataObject
  99. Allow: Query
  100. Frames: 0
  101. Add Fields to: Neither
  102. Other Settings: PERSISTENT-ONLY COMPILE APPSERVER DB-AWARE
  103. */
  104. /* This procedure should always be RUN PERSISTENT. Report the error, */
  105. /* then cleanup and return. */
  106. IF NOT THIS-PROCEDURE:PERSISTENT THEN DO:
  107. MESSAGE "{&FILE-NAME} should only be RUN PERSISTENT.":U
  108. VIEW-AS ALERT-BOX ERROR BUTTONS OK.
  109. RETURN.
  110. END.
  111. &ANALYZE-RESUME _END-PROCEDURE-SETTINGS
  112. /* ************************* Create Window ************************** */
  113. &ANALYZE-SUSPEND _CREATE-WINDOW
  114. /* DESIGN Window definition (used by the UIB)
  115. CREATE WINDOW dTables ASSIGN
  116. HEIGHT = 1.62
  117. WIDTH = 46.6.
  118. /* END WINDOW DEFINITION */
  119. */
  120. &ANALYZE-RESUME
  121. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _INCLUDED-LIB dTables
  122. /* ************************* Included-Libraries *********************** */
  123. {src/adm2/data.i}
  124. /* _UIB-CODE-BLOCK-END */
  125. &ANALYZE-RESUME
  126. /* *********** Runtime Attributes and AppBuilder Settings *********** */
  127. &ANALYZE-SUSPEND _RUN-TIME-ATTRIBUTES
  128. /* SETTINGS FOR WINDOW dTables
  129. VISIBLE,,RUN-PERSISTENT */
  130. /* _RUN-TIME-ATTRIBUTES-END */
  131. &ANALYZE-RESUME
  132. /* Setting information for Queries and Browse Widgets fields */
  133. &ANALYZE-SUSPEND _QUERY-BLOCK QUERY Query-Main
  134. /* Query rebuild information for SmartDataObject Query-Main
  135. _TblList = "AnaDat.Orte"
  136. _Options = "NO-LOCK INDEXED-REPOSITION"
  137. _FldNameList[1] > AnaDat.Orte.Lkz
  138. "Lkz" "Lkz" ? ? "character" ? ? ? ? ? ? yes ? yes 3.4 yes ?
  139. _FldNameList[2] > AnaDat.Orte.Ort
  140. "Ort" "Ort" ? ? "character" ? ? ? ? ? ? yes ? no 40 yes ?
  141. _FldNameList[3] > AnaDat.Orte.Ortkb
  142. "Ortkb" "Ortkb" ? ? "character" ? ? ? ? ? ? yes ? no 10 yes ?
  143. _FldNameList[4] > AnaDat.Orte.Plz
  144. "Plz" "Plz" ? ? "character" ? ? ? ? ? ? yes ? yes 12 yes ?
  145. _Design-Parent is WINDOW dTables @ ( 1.14 , 2.6 )
  146. */ /* QUERY Query-Main */
  147. &ANALYZE-RESUME
  148. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _MAIN-BLOCK dTables
  149. /* *************************** Main Block *************************** */
  150. { incl/datmainblock.i }
  151. &IF DEFINED(UIB_IS_RUNNING) <> 0 &THEN
  152. RUN initializeObject.
  153. &ENDIF
  154. /* _UIB-CODE-BLOCK-END */
  155. &ANALYZE-RESUME
  156. /* ********************** Internal Procedures *********************** */
  157. {&DB-REQUIRED-START}
  158. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE dataAvailable dTables _DB-REQUIRED
  159. PROCEDURE dataAvailable :
  160. /*------------------------------------------------------------------------------
  161. Purpose: Super Override
  162. Parameters:
  163. Notes:
  164. ------------------------------------------------------------------------------*/
  165. { incl/datdataavailable.i }
  166. END PROCEDURE.
  167. /* _UIB-CODE-BLOCK-END */
  168. &ANALYZE-RESUME
  169. {&DB-REQUIRED-END}
  170. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE disable_UI dTables _DEFAULT-DISABLE
  171. PROCEDURE disable_UI :
  172. /*------------------------------------------------------------------------------
  173. Purpose: DISABLE the User Interface
  174. Parameters: <none>
  175. Notes: Here we clean-up the user-interface by deleting
  176. dynamic widgets we have created and/or hide
  177. frames. This procedure is usually called when
  178. we are ready to "clean-up" after running.
  179. ------------------------------------------------------------------------------*/
  180. /* Hide all frames. */
  181. IF THIS-PROCEDURE:PERSISTENT THEN DELETE PROCEDURE THIS-PROCEDURE.
  182. END PROCEDURE.
  183. /* _UIB-CODE-BLOCK-END */
  184. &ANALYZE-RESUME
  185. {&DB-REQUIRED-START}
  186. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE INAKTIVIEREN dTables _DB-REQUIRED
  187. PROCEDURE INAKTIVIEREN :
  188. /*------------------------------------------------------------------------------
  189. Purpose:
  190. Parameters: <none>
  191. Notes:
  192. ------------------------------------------------------------------------------*/
  193. { incl/datinaktivieren.i }
  194. END PROCEDURE.
  195. /* _UIB-CODE-BLOCK-END */
  196. &ANALYZE-RESUME
  197. {&DB-REQUIRED-END}
  198. {&DB-REQUIRED-START}
  199. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE initializeObject dTables _DB-REQUIRED
  200. PROCEDURE initializeObject :
  201. /*------------------------------------------------------------------------------
  202. Purpose: Super Override
  203. Parameters:
  204. Notes:
  205. ------------------------------------------------------------------------------*/
  206. { incl/datinitialize.i }
  207. END PROCEDURE.
  208. /* _UIB-CODE-BLOCK-END */
  209. &ANALYZE-RESUME
  210. {&DB-REQUIRED-END}
  211. {&DB-REQUIRED-START}
  212. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE REAKTIVIEREN dTables _DB-REQUIRED
  213. PROCEDURE REAKTIVIEREN :
  214. /*------------------------------------------------------------------------------
  215. Purpose:
  216. Parameters: <none>
  217. Notes:
  218. ------------------------------------------------------------------------------*/
  219. { incl/datreaktivieren.i }
  220. END PROCEDURE.
  221. /* _UIB-CODE-BLOCK-END */
  222. &ANALYZE-RESUME
  223. {&DB-REQUIRED-END}
  224. {&DB-REQUIRED-START}
  225. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE REPOS_TABELLE dTables _DB-REQUIRED
  226. PROCEDURE REPOS_TABELLE :
  227. /*------------------------------------------------------------------------------
  228. Purpose:
  229. Parameters: <none>
  230. Notes:
  231. ------------------------------------------------------------------------------*/
  232. { incl/datrepos.i }
  233. END PROCEDURE.
  234. /* _UIB-CODE-BLOCK-END */
  235. &ANALYZE-RESUME
  236. {&DB-REQUIRED-END}
  237. {&DB-REQUIRED-START}
  238. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_FILTER dTables _DB-REQUIRED
  239. PROCEDURE SET_FILTER :
  240. /*------------------------------------------------------------------------------
  241. Purpose:
  242. Parameters: <none>
  243. Notes:
  244. ------------------------------------------------------------------------------*/
  245. { incl/datsetfilter.i }
  246. END PROCEDURE.
  247. /* _UIB-CODE-BLOCK-END */
  248. &ANALYZE-RESUME
  249. {&DB-REQUIRED-END}
  250. {&DB-REQUIRED-START}
  251. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_OPENFLAG dTables _DB-REQUIRED
  252. PROCEDURE SET_OPENFLAG :
  253. /*------------------------------------------------------------------------------
  254. Purpose:
  255. Parameters: <none>
  256. Notes:
  257. ------------------------------------------------------------------------------*/
  258. { incl/datsetopenflag.i }
  259. END PROCEDURE.
  260. /* _UIB-CODE-BLOCK-END */
  261. &ANALYZE-RESUME
  262. {&DB-REQUIRED-END}
  263. {&DB-REQUIRED-START}
  264. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SET_SORT dTables _DB-REQUIRED
  265. PROCEDURE SET_SORT :
  266. /*------------------------------------------------------------------------------
  267. Purpose:
  268. Parameters: <none>
  269. Notes:
  270. ------------------------------------------------------------------------------*/
  271. { incl/datsetsort.i }
  272. END PROCEDURE.
  273. /* _UIB-CODE-BLOCK-END */
  274. &ANALYZE-RESUME
  275. {&DB-REQUIRED-END}
  276. /* ************************ Function Implementations ***************** */
  277. {&DB-REQUIRED-START}
  278. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION getQueryBuffer dTables _DB-REQUIRED
  279. FUNCTION getQueryBuffer RETURNS HANDLE
  280. ( /* parameter-definitions */ ) :
  281. /*------------------------------------------------------------------------------
  282. Purpose:
  283. Notes:
  284. ------------------------------------------------------------------------------*/
  285. RETURN BUFFER rowObject:HANDLE.
  286. END FUNCTION.
  287. /* _UIB-CODE-BLOCK-END */
  288. &ANALYZE-RESUME
  289. {&DB-REQUIRED-END}
  290. {&DB-REQUIRED-START}
  291. &ANALYZE-SUSPEND _UIB-CODE-BLOCK _FUNCTION openQuery dTables _DB-REQUIRED
  292. FUNCTION openQuery RETURNS LOGICAL
  293. ( /* parameter-definitions */ ) :
  294. /*------------------------------------------------------------------------------
  295. Purpose: Super Override
  296. Notes:
  297. ------------------------------------------------------------------------------*/
  298. DEF VAR Felder AS CHAR NO-UNDO.
  299. DEF VAR Inhalt AS CHAR NO-UNDO.
  300. DEF VAR ix AS INT NO-UNDO.
  301. DEF VAR cFeld AS CHAR NO-UNDO.
  302. /* IF NOT fOpen THEN RETURN FALSE. */
  303. xWhere = ''.
  304. xSort = ''.
  305. xString = ''.
  306. Felder = DYNAMIC-FUNCTION('getForeignFields':U) NO-ERROR.
  307. Inhalt = DYNAMIC-FUNCTION('getForeignValues':U) NO-ERROR.
  308. /* ix = LOOKUP('Feld', Felder, ',') / 2. */
  309. /* cFeld = ENTRY (ix , Inhalt, CHR(01)). */
  310. /* xWhere = 'Aufko.Firma = ' + QUOTER(Firma) + ' AND ' */
  311. /* + 'Aufko.Auf_Sta = ' + STRING(Auf_Sta) + ' '. */
  312. /* xString = 'FOR EACH Debop ' + xSort + 'WHERE ' */
  313. /* + 'Debop.Firma = "' + Firma + '" AND ' */
  314. /* + 'Debop.Knr = ' + STRING(Knr) + ' ' */
  315. /* + 'NO-LOCK BY Debop.FakDat DESCENDING INDEXED-REPOSITION '. */
  316. { incl/datopenquery.i }
  317. IF xWhere <> '' THEN DYNAMIC-FUNCTION('setQueryWhere':U , INPUT xWhere ).
  318. IF xString <> '' THEN DYNAMIC-FUNCTION('setQueryString':U, INPUT xString).
  319. IF xSort <> '' THEN DYNAMIC-FUNCTION('setQuerySort':U , INPUT xSort ).
  320. RETURN SUPER( ).
  321. END FUNCTION.
  322. /* _UIB-CODE-BLOCK-END */
  323. &ANALYZE-RESUME
  324. {&DB-REQUIRED-END}