&ANALYZE-SUSPEND _VERSION-NUMBER UIB_v8r12 GUI ADM1 &ANALYZE-RESUME /* Connected Databases anadat PROGRESS */ &Scoped-define WINDOW-NAME CURRENT-WINDOW &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _DEFINITIONS B-table-Win /*------------------------------------------------------------------------ File: Description: from BROWSER.W - Basic SmartBrowser Object Template Input Parameters: Output Parameters: ------------------------------------------------------------------------*/ /* This .W file was created with the Progress UIB. */ /*----------------------------------------------------------------------*/ /* Create an unnamed pool to store all the widgets created by this procedure. This is a good default which assures that this procedure's triggers and internal procedures will execute in this procedure's storage, and that proper cleanup will occur on deletion of the procedure. */ CREATE WIDGET-POOL. /* *************************** Definitions ************************** */ &Scoped-define ERSTES-FELD Menge &Scoped-define ZWEITES-FELD Menge &Scoped-define LETZTES-FELD Menge &Scoped-define INPUT-FELDER BesGebKo.Menge &Scoped-define DATEI-NAME BesGebKo /* *************************** Definitions ************************** */ /* Parameters Definitions --- */ /* Local Variable Definitions --- */ /* --------------------------------------------------------------------------- */ DEF VAR VUpdate AS LOG INIT FALSE NO-UNDO. DEF VAR VSpeichern AS LOG INIT FALSE NO-UNDO. DEF VAR VNeu AS LOG INIT FALSE NO-UNDO. DEF VAR FErfassen AS LOG INIT FALSE NO-UNDO. DEF VAR PHandle AS HANDLE NO-UNDO. DEF VAR XHandle AS HANDLE NO-UNDO. DEF VAR LHandle AS HANDLE NO-UNDO. DEF VAR ch AS CHAR NO-UNDO. DEF VAR VText AS CHAR FORMAT "x(30)" NO-UNDO. DEF VAR QOpen AS LOG INIT FALSE NO-UNDO. DEF VAR FQOpen AS LOG INIT FALSE NO-UNDO. DEF VAR Vorhanden AS LOG NO-UNDO. DEF VAR VRecid AS RECID NO-UNDO. DEF VAR VROWID AS ROWID NO-UNDO. DEF VAR Feldname AS CHAR NO-UNDO. DEF VAR FeldInhalt AS CHAR NO-UNDO. DEF VAR BStatus AS INT INIT 0 NO-UNDO. DEF BUFFER B{&DATEI-NAME} FOR {&DATEI-NAME}. /* --------------------------------------------------------------------------- */ /* Parameters Definitions --- */ /* Local Variable Definitions --- */ DEF VAR VBetrag AS DEC NO-UNDO. DEF VAR ok AS LOG NO-UNDO. DEF VAR VKnr AS INT NO-UNDO. DEF VAR VDoknr AS INT NO-UNDO. DEF VAR VDatum AS DATE NO-UNDO. DEF VAR VMWST AS INT NO-UNDO. DEF VAR FCuDw AS LOG NO-UNDO. /* ---------- Globale Variablen ---------------------------------- */ { v8/globvar.i" " " " "SHARED" } { v8/debivar.i " " " " "SHARED" } { v8/artivar.i " " " " "SHARED" } { v8/contvar.i " " " " "SHARED" } /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-PREPROCESSOR-BLOCK /* ******************** Preprocessor Definitions ******************** */ &Scoped-define PROCEDURE-TYPE SmartBrowser &Scoped-define DB-AWARE no &Scoped-define ADM-SUPPORTED-LINKS Record-Source,Record-Target,TableIO-Target /* Name of designated FRAME-NAME and/or first browse and/or first query */ &Scoped-define FRAME-NAME F-Main &Scoped-define BROWSE-NAME br_table /* Internal Tables (found by Frame, Query & Browse Queries) */ &Scoped-define INTERNAL-TABLES BesGebKo /* Define KEY-PHRASE in case it is used by any query. */ &Scoped-define KEY-PHRASE TRUE /* Definitions for BROWSE br_table */ &Scoped-define FIELDS-IN-QUERY-br_table BesGebKo.Menge VText @ VText ~ VBetrag @ VBetrag &Scoped-define ENABLED-FIELDS-IN-QUERY-br_table BesGebKo.Menge &Scoped-define ENABLED-TABLES-IN-QUERY-br_table BesGebKo &Scoped-define FIRST-ENABLED-TABLE-IN-QUERY-br_table BesGebKo &Scoped-define QUERY-STRING-br_table FOR EACH BesGebKo WHERE ~{&KEY-PHRASE} ~ AND BesGebKo.Firma = GVFirma ~ AND BesGebKo.Besnr = VDoknr NO-LOCK ~ BY BesGebKo.Sort_Cd &Scoped-define OPEN-QUERY-br_table OPEN QUERY br_table FOR EACH BesGebKo WHERE ~{&KEY-PHRASE} ~ AND BesGebKo.Firma = GVFirma ~ AND BesGebKo.Besnr = VDoknr NO-LOCK ~ BY BesGebKo.Sort_Cd. &Scoped-define TABLES-IN-QUERY-br_table BesGebKo &Scoped-define FIRST-TABLE-IN-QUERY-br_table BesGebKo /* Definitions for FRAME F-Main */ /* Standard List Definitions */ &Scoped-Define ENABLED-OBJECTS RECT-9 br_table E_Adresse &Scoped-Define DISPLAYED-OBJECTS F_Besnr E_Adresse /* Custom List Definitions */ /* List-1,List-2,List-3,List-4,List-5,List-6 */ /* _UIB-PREPROCESSOR-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _XFTR "Foreign Keys" B-table-Win _INLINE /* Actions: ? adm/support/keyedit.w ? ? ? */ /* STRUCTURED-DATA &BROWSE-NAME ************************** * Set attributes related to FOREIGN KEYS */ RUN set-attribute-list ( 'Keys-Accepted = "", Keys-Supplied = ""':U). /************************** */ /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _XFTR "Advanced Query Options" B-table-Win _INLINE /* Actions: ? adm/support/advqedit.w ? ? ? */ /* STRUCTURED-DATA &BROWSE-NAME ************************ * Set attributes related to SORTBY-OPTIONS */ RUN set-attribute-list ( 'SortBy-Options = ""':U). /************************ */ /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME /* *********************** Control Definitions ********************** */ /* Definitions of the field level widgets */ DEFINE BUTTON Btn_Erfassen LABEL "&Erfassen" SIZE 19.8 BY 1.19. DEFINE BUTTON Btn_Loeschen LABEL "&Löschen" SIZE 19.8 BY 1.19. DEFINE BUTTON Btn_Speichern LABEL "&Speichern" SIZE 19.8 BY 1.19. DEFINE VARIABLE E_Adresse AS CHARACTER VIEW-AS EDITOR NO-WORD-WRAP MAX-CHARS 500 SIZE 47.8 BY 5.43 BGCOLOR 15 FONT 16 NO-UNDO. DEFINE VARIABLE F_Besnr AS INTEGER FORMAT "999999":U INITIAL 0 LABEL "Dokumentnummer" VIEW-AS FILL-IN NATIVE SIZE 12.4 BY 1 BGCOLOR 15 NO-UNDO. DEFINE RECTANGLE RECT-9 EDGE-PIXELS 2 GRAPHIC-EDGE NO-FILL SIZE 111.8 BY 22. /* Query definitions */ &ANALYZE-SUSPEND DEFINE QUERY br_table FOR BesGebKo SCROLLING. &ANALYZE-RESUME /* Browse definitions */ DEFINE BROWSE br_table &ANALYZE-SUSPEND _UIB-CODE-BLOCK _DISPLAY-FIELDS br_table B-table-Win _STRUCTURED QUERY br_table NO-LOCK DISPLAY BesGebKo.Menge FORMAT "zz,zz9-":U VText @ VText COLUMN-LABEL "Bezeichnung" FORMAT "x(30)":U VBetrag @ VBetrag COLUMN-LABEL "Betrag" FORMAT "zzz,zz9.99-":U ENABLE BesGebKo.Menge /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME WITH NO-ASSIGN NO-ROW-MARKERS SEPARATORS SIZE 56 BY 20.86 BGCOLOR 15 . /* ************************ Frame Definitions *********************** */ DEFINE FRAME F-Main br_table AT ROW 1.57 COL 3.6 Btn_Erfassen AT ROW 1.86 COL 61.4 Btn_Speichern AT ROW 3.05 COL 61.4 Btn_Loeschen AT ROW 4.33 COL 61.4 F_Besnr AT ROW 7.57 COL 94.8 COLON-ALIGNED E_Adresse AT ROW 8.81 COL 61.4 NO-LABEL RECT-9 AT ROW 1 COL 1 WITH 1 DOWN NO-BOX KEEP-TAB-ORDER OVERLAY SIDE-LABELS NO-UNDERLINE THREE-D AT COL 1 ROW 1 SCROLLABLE DEFAULT-BUTTON Btn_Speichern. /* *********************** Procedure Settings ************************ */ &ANALYZE-SUSPEND _PROCEDURE-SETTINGS /* Settings for THIS-PROCEDURE Type: SmartBrowser Allow: Basic,Browse Frames: 1 Add Fields to: EXTERNAL-TABLES Other Settings: PERSISTENT-ONLY */ /* This procedure should always be RUN PERSISTENT. Report the error, */ /* then cleanup and return. */ IF NOT THIS-PROCEDURE:PERSISTENT THEN DO: MESSAGE "{&FILE-NAME} should only be RUN PERSISTENT.":U VIEW-AS ALERT-BOX ERROR BUTTONS OK. RETURN. END. &ANALYZE-RESUME _END-PROCEDURE-SETTINGS /* ************************* Create Window ************************** */ &ANALYZE-SUSPEND _CREATE-WINDOW /* DESIGN Window definition (used by the UIB) CREATE WINDOW B-table-Win ASSIGN HEIGHT = 22.29 WIDTH = 112.2. /* END WINDOW DEFINITION */ */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _INCLUDED-LIB B-table-Win /* ************************* Included-Libraries *********************** */ {src/adm/method/browser.i} /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME /* *********** Runtime Attributes and AppBuilder Settings *********** */ &ANALYZE-SUSPEND _RUN-TIME-ATTRIBUTES /* SETTINGS FOR WINDOW B-table-Win NOT-VISIBLE,,RUN-PERSISTENT */ /* SETTINGS FOR FRAME F-Main NOT-VISIBLE FRAME-NAME Size-to-Fit */ /* BROWSE-TAB br_table RECT-9 F-Main */ ASSIGN FRAME F-Main:SCROLLABLE = FALSE FRAME F-Main:HIDDEN = TRUE FRAME F-Main:RESIZABLE = TRUE. /* SETTINGS FOR BUTTON Btn_Erfassen IN FRAME F-Main NO-ENABLE */ ASSIGN Btn_Erfassen:PRIVATE-DATA IN FRAME F-Main = "Abbrechen". /* SETTINGS FOR BUTTON Btn_Loeschen IN FRAME F-Main NO-ENABLE */ /* SETTINGS FOR BUTTON Btn_Speichern IN FRAME F-Main NO-ENABLE */ ASSIGN E_Adresse:RETURN-INSERTED IN FRAME F-Main = TRUE E_Adresse:READ-ONLY IN FRAME F-Main = TRUE. /* SETTINGS FOR FILL-IN F_Besnr IN FRAME F-Main NO-ENABLE */ /* _RUN-TIME-ATTRIBUTES-END */ &ANALYZE-RESUME /* Setting information for Queries and Browse Widgets fields */ &ANALYZE-SUSPEND _QUERY-BLOCK BROWSE br_table /* Query rebuild information for BROWSE br_table _TblList = "AnaDat.BesGebKo" _Options = "NO-LOCK KEY-PHRASE" _OrdList = "AnaDat.BesGebKo.Sort_Cd|yes" _Where[1] = "BesGebKo.Firma = GVFirma AND BesGebKo.Besnr = VDoknr" _FldNameList[1] > AnaDat.BesGebKo.Menge "BesGebKo.Menge" ? ? "decimal" ? ? ? ? ? ? yes ? no no ? yes no no "U" "" "" "" "" "" "" 0 no 0 no no _FldNameList[2] > "_" "VText @ VText" "Bezeichnung" "x(30)" ? ? ? ? ? ? ? no ? no no ? yes no no "U" "" "" "" "" "" "" 0 no 0 no no _FldNameList[3] > "_" "VBetrag @ VBetrag" "Betrag" "zzz,zz9.99-" ? ? ? ? ? ? ? no ? no no ? yes no no "U" "" "" "" "" "" "" 0 no 0 no no _Query is NOT OPENED */ /* BROWSE br_table */ &ANALYZE-RESUME &ANALYZE-SUSPEND _QUERY-BLOCK FRAME F-Main /* Query rebuild information for FRAME F-Main _Options = "NO-LOCK" _Query is NOT OPENED */ /* FRAME F-Main */ &ANALYZE-RESUME /* ************************ Control Triggers ************************ */ &Scoped-define BROWSE-NAME br_table &Scoped-define SELF-NAME br_table &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL br_table B-table-Win ON ROW-DISPLAY OF br_table IN FRAME F-Main DO: RUN ANZEIGE. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL br_table B-table-Win ON ROW-ENTRY OF br_table IN FRAME F-Main DO: {src/adm/template/brsentry.i} END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL br_table B-table-Win ON ROW-LEAVE OF br_table IN FRAME F-Main DO: LKY = LASTKEY. LHandle = LAST-EVENT:WIDGET-LEAVE. XHandle = LAST-EVENT:WIDGET-ENTER. DO WHILE VUpdate AND NOT FErfassen WITH FRAME {&FRAME-NAME}: IF KEYFUNCTION(LKY) = 'END-ERROR' THEN DO: VSpeichern = FALSE. RUN ERFASSEN. RETURN NO-APPLY. END. IF NOT FCuDw THEN DO: IF {&BROWSE-NAME}:CURRENT-ROW-MODIFIED = FALSE THEN DO: VSpeichern = FALSE. VUpdate = FALSE. RUN ERFASSEN. RETURN NO-APPLY. END. END. IF LKY = KEYCODE('RETURN') THEN DO: RUN SPEICHERN. RETURN NO-APPLY. END. IF LKY = KEYCODE('TAB') AND LHandle:NAME = '{&LETZTES-FELD}' THEN DO: RUN SPEICHERN. RETURN NO-APPLY. END. IF VALID-HANDLE(XHandle) THEN DO: DO WHILE XHandle:TYPE = 'BUTTON': IF XHandle:NAME = 'Btn_Erfassen' THEN RETURN. IF XHandle:NAME = 'Btn_Speichern' THEN RETURN. APPLY 'ENTRY' TO LHandle. RETURN NO-APPLY. END. END. RETURN NO-APPLY. END. FErfassen = FALSE. {src/adm/template/brsleave.i} END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL br_table B-table-Win ON VALUE-CHANGED OF br_table IN FRAME F-Main DO: RUN ANZEIGE. {src/adm/template/brschnge.i} END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME Btn_Erfassen &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL Btn_Erfassen B-table-Win ON CHOOSE OF Btn_Erfassen IN FRAME F-Main /* Erfassen */ DO: IF VUpdate THEN VSpeichern = FALSE. VUpdate = FALSE. RUN ERFASSEN. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME Btn_Loeschen &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL Btn_Loeschen B-table-Win ON CHOOSE OF Btn_Loeschen IN FRAME F-Main /* Löschen */ DO: RUN LOESCHEN. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME Btn_Speichern &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL Btn_Speichern B-table-Win ON CHOOSE OF Btn_Speichern IN FRAME F-Main /* Speichern */ DO: VUpdate = FALSE. RUN SPEICHERN. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &UNDEFINE SELF-NAME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _MAIN-BLOCK B-table-Win /* *************************** Main Block *************************** */ FCuDw = FALSE. &IF DEFINED(UIB_IS_RUNNING) <> 0 &THEN RUN dispatch IN THIS-PROCEDURE ('initialize':U). &ENDIF FIND Steuer WHERE Steuer.Firma = GVFirma NO-LOCK NO-ERROR. IF Steuer.Fwi06 = 0 THEN VMWST = 1. ELSE VMWST = Steuer.Fwi06. /* ------ Triggers ---------------------------------------------------- */ ON ALT-- OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN new-state ( INPUT 'Prev_Page, MAIN':U ). RETURN NO-APPLY. END. ON ALT-+ OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN new-state ( INPUT 'Next_Page, MAIN':U ). RETURN NO-APPLY. END. ON CURSOR-UP OF {&INPUT-FELDER} IN BROWSE {&BROWSE-NAME} DO: IF NOT VUpdate THEN RETURN. DO WITH FRAME {&FRAME-NAME}: FCuDw = TRUE. RUN SPEICHERN. ok = {&BROWSE-NAME}:SELECT-PREV-ROW(). IF NOT ok THEN RETURN NO-APPLY. {&BROWSE-NAME}:FETCH-SELECTED-ROW(1). RUN ANZEIGE. RUN SPEICHERN. FCuDw = FALSE. RETURN NO-APPLY. END. END. ON CURSOR-DOWN OF {&INPUT-FELDER} IN BROWSE {&BROWSE-NAME} DO: IF NOT VUpdate THEN RETURN. DO WITH FRAME {&FRAME-NAME}: FCuDw = TRUE. RUN SPEICHERN. ok = {&BROWSE-NAME}:SELECT-NEXT-ROW(). IF NOT ok THEN RETURN NO-APPLY. {&BROWSE-NAME}:FETCH-SELECTED-ROW(1). RUN ANZEIGE. RUN SPEICHERN. FCuDw = FALSE. RETURN NO-APPLY. END. END. ON INSERT-MODE OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN ERFASSEN. END. ON RETURN OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN SPEICHERN. END. ON DELETE-CHARACTER OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN LOESCHEN. END. ON CTRL-CURSOR-RIGHT OF {&WINDOW-NAME} OR CTRL-CURSOR-RIGHT OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN new-state ( INPUT 'Next_Page, MAIN':U ). RETURN NO-APPLY. END. ON CTRL-CURSOR-LEFT OF {&WINDOW-NAME} OR CTRL-CURSOR-LEFT OF BROWSE {&BROWSE-NAME} DO: IF VUpdate THEN RETURN NO-APPLY. RUN new-state ( INPUT 'Prev_Page, MAIN':U ). RETURN NO-APPLY. END. ON ENTRY OF {&DATEI-NAME}.{&ERSTES-FELD} IN BROWSE {&BROWSE-NAME} DO: IF NOT VNeu THEN DO: APPLY 'ENTRY' TO {&DATEI-NAME}.{&ZWEITES-FELD} IN BROWSE {&BROWSE-NAME}. RETURN NO-APPLY. END. END. ON RETURN OF {&DATEI-NAME}.{&ERSTES-FELD} IN BROWSE {&BROWSE-NAME} DO: IF NOT VUpdate THEN RETURN. APPLY 'TAB' TO SELF. RETURN NO-APPLY. END. ON END-ERROR OF {&INPUT-FELDER} IN BROWSE {&BROWSE-NAME} OR END-ERROR OF BROWSE {&BROWSE-NAME} DO: VSpeichern = FALSE. IF NOT VUpdate THEN DO: RUN new-state ( INPUT 'ENDE, MAIN':U ). RETURN NO-APPLY. END. APPLY 'ENTRY' TO Btn_Erfassen IN FRAME {&FRAME-NAME}. END. ON LEFT-MOUSE-DOWN, RIGHT-MOUSE-DOWN, MIDDLE-MOUSE-DOWN OF BROWSE {&BROWSE-NAME} DO: DO WHILE TRUE: IF NOT VUpdate THEN LEAVE. XHandle = {&BROWSE-NAME}:CURRENT-COLUMN IN FRAME {&FRAME-NAME}. IF NOT VALID-HANDLE(XHandle) THEN XHandle = LAST-EVENT:WIDGET-LEAVE. IF VALID-HANDLE(XHandle) THEN DO: APPLY 'LEAVE' TO XHandle. RETURN. END. LEAVE. END. END. ON LEAVE OF {&DATEI-NAME}.{&ERSTES-FELD} IN BROWSE {&BROWSE-NAME} DO: IF NOT VUpdate THEN RETURN. LKY = LASTKEY. LHandle = LAST-EVENT:WIDGET-ENTER. IF VALID-HANDLE(LHandle) THEN DO: IF LHandle:TYPE = 'BUTTON' AND LHandle:PRIVATE-DATA = 'Abbrechen' THEN DO: VSpeichern = FALSE. APPLY 'ENTRY' TO Btn_Erfassen IN FRAME {&FRAME-NAME}. RETURN NO-APPLY. END. END. IF NOT VSpeichern THEN RETURN. XHandle = {&BROWSE-NAME}:CURRENT-COLUMN IN FRAME {&FRAME-NAME}. Feldname = XHandle:NAME. Feldinhalt = XHandle:SCREEN-VALUE. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME /* ********************** Internal Procedures *********************** */ &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE adm-row-available B-table-Win _ADM-ROW-AVAILABLE PROCEDURE adm-row-available : /*------------------------------------------------------------------------------ Purpose: Dispatched to this procedure when the Record- Source has a new row available. This procedure tries to get the new row (or foriegn keys) from the Record-Source and process it. Parameters: ------------------------------------------------------------------------------*/ /* Define variables needed by this internal procedure. */ {src/adm/template/row-head.i} /* Process the newly available records (i.e. display fields, open queries, and/or pass records on to any RECORD-TARGETS). */ {src/adm/template/row-end.i} END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE ANZEIGE B-table-Win PROCEDURE ANZEIGE : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ VText = ''. IF AVAILABLE {&DATEI-NAME} THEN DO: VRecid = RECID({&DATEI-NAME}) NO-ERROR. VROWID = ROWID({&DATEI-NAME}) NO-ERROR. IF NOT AVAILABLE {&DATEI-NAME} THEN RETURN. FIND GebRueck USE-INDEX GebRueck-k1 NO-LOCK WHERE GebRueck.Firma = GVFirma AND GebRueck.Geb_Cd = BesGebKo.Geb_Cd NO-ERROR. IF AVAILABLE GebRueck THEN VText = GebRueck.Bez. ELSE VText = FILL('?', 20). VBetrag = BesGebKo.Betrag_1 + BesGebKo.Betrag_2 + BesGebKo.Betrag_3. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE BUTTON_ENABLE B-table-Win PROCEDURE BUTTON_ENABLE : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DEF INPUT PARAMETER Art AS INT NO-UNDO. DO WITH FRAME {&FRAME-NAME}: IF Art < 90 THEN BStatus = Art. IF Art = 98 THEN Art = 9. IF Art = 99 THEN Art = BStatus. IF AVAILABLE Besko AND Besko.Best_Sta <> 2 THEN Art = 9. CASE Art: WHEN 1 THEN DO: ENABLE Btn_Erfassen. DISABLE Btn_Speichern Btn_Loeschen. END. WHEN 2 THEN DO: ENABLE Btn_Erfassen Btn_Speichern Btn_Loeschen. END. WHEN 3 THEN DO: DISABLE Btn_Loeschen. ENABLE Btn_Speichern. END. WHEN 9 THEN DO: DISABLE Btn_Erfassen Btn_Speichern Btn_Loeschen. END. END CASE. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE CREATE_GebKontr B-table-Win PROCEDURE CREATE_GebKontr : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DO WITH FRAME {&FRAME-NAME}: FIND LAST GebKontr USE-INDEX GebKontr-k1 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr NO-LOCK NO-ERROR. IF NOT AVAILABLE GebKontr THEN ix = 1. ELSE ix = GebKontr.Trnr + 1. CREATE GebKontr. ASSIGN GebKontr.Firma = GVFirma GebKontr.Knr = VKnr GebKontr.Trnr = ix GebKontr.Geb_Cd = GebKonto.Geb_Cd GebKontr.Doknr = VDoknr GebKontr.Datum = VDatum GebKontr.Preis = GebKonto.Depot. LVRecid = RECID(GebKontr). IF GebKonto.MWST_Art = 0 THEN DO: ASSIGN GebKontr.MWST_Cd = 11 GebKontr.MWST_% = 0 GebKontr.MWST_Inkl = TRUE. RETURN. END. IF GebKonto.MWST_Art = 1 THEN DO: FIND Wust USE-INDEX Wust-k1 WHERE Wust.CodeK = VMWST AND Wust.CodeA = Artst.MWST NO-LOCK NO-ERROR. END. IF GebKonto.MWST_Art = 2 THEN DO: FIND FIRST Wust USE-INDEX Wust-k2 WHERE Wust.WuCd = GebKonto.MWST_Cd NO-LOCK NO-ERROR. END. IF NOT AVAILABLE Wust THEN DO: ASSIGN GebKontr.MWST_Cd = 11 GebKontr.MWST_% = 0 GebKontr.MWST_Inkl = TRUE. RETURN. END. FIND LAST MWSTAns USE-INDEX MWSTAns-k1 WHERE MWSTAns.MWST_Cd = Wust.WuCd AND MWSTAns.Datum <= TODAY NO-LOCK. ASSIGN GebKontr.MWST_Cd = Wust.WuCd GebKontr.MWST_% = MWSTAns.Ansatz GebKontr.MWST_Inkl = Wust.Incl. END. RETURN. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE disable_UI B-table-Win _DEFAULT-DISABLE PROCEDURE disable_UI : /*------------------------------------------------------------------------------ Purpose: DISABLE the User Interface Parameters: Notes: Here we clean-up the user-interface by deleting dynamic widgets we have created and/or hide frames. This procedure is usually called when we are ready to "clean-up" after running. ------------------------------------------------------------------------------*/ /* Hide all frames. */ HIDE FRAME F-Main. IF THIS-PROCEDURE:PERSISTENT THEN DELETE PROCEDURE THIS-PROCEDURE. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE ERFASSEN B-table-Win PROCEDURE ERFASSEN : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DO WITH FRAME {&FRAME-NAME}: IF Btn_Erfassen:SENSITIVE = FALSE THEN RETURN NO-APPLY. APPLY 'ENTRY' TO Btn_Erfassen. CASE Btn_Erfassen:LABEL: WHEN '&Erfassen' THEN DO: RETURN NO-APPLY. END. WHEN '&Abbrechen' THEN DO: VSpeichern = FALSE. RUN adm-disable-fields. RUN adm-cancel-record. VUpdate = FALSE. VNeu = FALSE. FErfassen = FALSE. Btn_Erfassen:LABEL = '&Erfassen'. Btn_Speichern:LABEL = '&Aendern'. IF Vorhanden THEN RUN BUTTON_ENABLE ( 2 ). ELSE RUN BUTTON_ENABLE ( 1 ). END. END CASE. END. IF NOT VUpdate THEN RUN state-changed ( INPUT THIS-PROCEDURE, INPUT 'browser_entry' ). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE GEBINDE_BUCHEN B-table-Win PROCEDURE GEBINDE_BUCHEN : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DEF INPUT PARAMETER Art AS INT NO-UNDO. DO WHILE Art = 1. DO WHILE BesGebKo.Kto_Cd1 <> '': FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd1 NO-ERROR. IF NOT AVAILABLE GebKonto THEN LEAVE. IF GebKonto.Depot = 0 THEN LEAVE. FIND FIRST GebKontr USE-INDEX GebKontr-k2 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr AND GebKontr.Geb_Cd = GebKonto.Geb_Cd AND GebKontr.Doknr = VDoknr AND GebKontr.Datum = VDatum NO-ERROR. IF NOT AVAILABLE GebKontr THEN DO: RUN CREATE_GebKontr. FIND GebKontr WHERE RECID(GebKontr) = LVRecid. END. GebKontr.Ausgang = GebKontr.Ausgang + (BesGebKo.Menge * BesGebKo.Anz_1). LEAVE. END. DO WHILE BesGebKo.Kto_Cd2 <> '': FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd2 NO-ERROR. IF NOT AVAILABLE GebKonto THEN LEAVE. IF GebKonto.Depot = 0 THEN LEAVE. FIND FIRST GebKontr USE-INDEX GebKontr-k2 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr AND GebKontr.Geb_Cd = GebKonto.Geb_Cd AND GebKontr.Doknr = VDoknr AND GebKontr.Datum = VDatum NO-ERROR. IF NOT AVAILABLE GebKontr THEN DO: RUN CREATE_GebKontr. FIND GebKontr WHERE RECID(GebKontr) = LVRecid. END. GebKontr.Ausgang = GebKontr.Ausgang + (BesGebKo.Menge * BesGebKo.Anz_2). LEAVE. END. DO WHILE BesGebKo.Kto_Cd3 <> '': FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd3 NO-ERROR. IF NOT AVAILABLE GebKonto THEN LEAVE. IF GebKonto.Depot = 0 THEN LEAVE. FIND FIRST GebKontr USE-INDEX GebKontr-k2 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr AND GebKontr.Geb_Cd = GebKonto.Geb_Cd AND GebKontr.Doknr = VDoknr AND GebKontr.Datum = VDatum NO-ERROR. IF NOT AVAILABLE GebKontr THEN DO: RUN CREATE_GebKontr. FIND GebKontr WHERE RECID(GebKontr) = LVRecid. END. GebKontr.Ausgang = GebKontr.Ausgang + (BesGebKo.Menge * BesGebKo.Anz_3). LEAVE. END. /* FIND BesGebKo OF BesGebKo. { v8/BesGebKo.i "BesGebKo" "BesGebKo" } */ RETURN. END. DO WHILE Art = 2. DO WHILE BesGebKo.Kto_Cd1 <> '': FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd1 NO-ERROR. IF NOT AVAILABLE GebKonto THEN LEAVE. IF GebKonto.Depot = 0 THEN LEAVE. FIND FIRST GebKontr USE-INDEX GebKontr-k2 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr AND GebKontr.Geb_Cd = GebKonto.Geb_Cd AND GebKontr.Doknr = VDoknr AND GebKontr.Datum = VDatum NO-ERROR. IF NOT AVAILABLE GebKontr THEN DO: RUN CREATE_GebKontr. FIND GebKontr WHERE RECID(GebKontr) = LVRecid. END. GebKontr.Ausgang = GebKontr.Ausgang - (BesGebKo.Menge * BesGebKo.Anz_1). LEAVE. END. DO WHILE BesGebKo.Kto_Cd2 <> '': FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd2 NO-ERROR. IF NOT AVAILABLE GebKonto THEN LEAVE. IF GebKonto.Depot = 0 THEN LEAVE. FIND FIRST GebKontr USE-INDEX GebKontr-k2 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr AND GebKontr.Geb_Cd = GebKonto.Geb_Cd AND GebKontr.Doknr = VDoknr AND GebKontr.Datum = VDatum NO-ERROR. IF NOT AVAILABLE GebKontr THEN DO: RUN CREATE_GebKontr. FIND GebKontr WHERE RECID(GebKontr) = LVRecid. END. GebKontr.Ausgang = GebKontr.Ausgang - (BesGebKo.Menge * BesGebKo.Anz_2). LEAVE. END. DO WHILE BesGebKo.Kto_Cd3 <> '': FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd3 NO-ERROR. IF NOT AVAILABLE GebKonto THEN LEAVE. IF GebKonto.Depot = 0 THEN LEAVE. FIND FIRST GebKontr USE-INDEX GebKontr-k2 WHERE GebKontr.Firma = GVFirma AND GebKontr.Knr = VKnr AND GebKontr.Geb_Cd = GebKonto.Geb_Cd AND GebKontr.Doknr = VDoknr AND GebKontr.Datum = VDatum NO-ERROR. IF NOT AVAILABLE GebKontr THEN DO: RUN CREATE_GebKontr. FIND GebKontr WHERE RECID(GebKontr) = LVRecid. END. GebKontr.Ausgang = GebKontr.Ausgang - (BesGebKo.Menge * BesGebKo.Anz_3). LEAVE. END. RETURN. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE local-assign-record B-table-Win PROCEDURE local-assign-record : /*------------------------------------------------------------------------------ Purpose: Override standard ADM method Notes: ------------------------------------------------------------------------------*/ RUN dispatch IN THIS-PROCEDURE ( INPUT 'assign-record':U ) . IF VNeu THEN DO: END. ELSE DO: END. ASSIGN BesGebKo.Betrag_1 = BesGebKo.Anz_1 * BesGebKo.Wert_1 * BesGebKo.Menge BesGebKo.Betrag_2 = BesGebKo.Anz_2 * BesGebKo.Wert_2 * BesGebKo.Menge BesGebKo.Betrag_3 = BesGebKo.Anz_3 * BesGebKo.Wert_3 * BesGebKo.Menge. VBetrag = BesGebKo.Betrag_1 + BesGebKo.Betrag_2 + BesGebKo.Betrag_3. RUN dispatch IN THIS-PROCEDURE ('display-fields':U). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE local-hide B-table-Win PROCEDURE local-hide : /*------------------------------------------------------------------------------ Purpose: Override standard ADM method Notes: ------------------------------------------------------------------------------*/ IF VUpdate THEN DO: APPLY 'ENTRY' TO Btn_Erfassen IN FRAME {&FRAME-NAME}. RUN ERFASSEN. END. RUN dispatch IN THIS-PROCEDURE ( INPUT 'hide':U ) . FQOpen = FALSE. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE local-open-query B-table-Win PROCEDURE local-open-query : /*------------------------------------------------------------------------------ Purpose: Override standard ADM method Notes: ------------------------------------------------------------------------------*/ QOpen = FALSE. Vorhanden = FALSE. RUN dispatch IN THIS-PROCEDURE ( INPUT 'open-query':U ). QOpen = TRUE. DO WHILE TRUE WITH FRAME {&FRAME-NAME}: IF NUM-RESULTS("{&BROWSE-NAME}":U) = ? THEN LEAVE. IF NUM-RESULTS("{&BROWSE-NAME}":U) = 0 THEN LEAVE. Vorhanden = TRUE. LEAVE. END. DO WITH FRAME {&FRAME-NAME}: IF Vorhanden THEN DO: RUN BUTTON_ENABLE ( 2 ). APPLY 'VALUE-CHANGED' TO BROWSE {&BROWSE-NAME}. END. ELSE DO: RUN BUTTON_ENABLE ( 1 ). END. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE local-view B-table-Win PROCEDURE local-view : /*------------------------------------------------------------------------------ Purpose: Override standard ADM method Notes: ------------------------------------------------------------------------------*/ VKnr = LVLnr. VDoknr = LVBesnr. FIND Besko USE-INDEX Besko-k1 WHERE Besko.Firma = GVFirma AND Besko.Besnr = LVBesnr NO-LOCK NO-ERROR. FIND FIRST BesGebKo USE-INDEX BesGebKo-k1 WHERE BesGebKo.Firma = GVFirma AND BesGebKo.Besnr = VDoknr NO-LOCK NO-ERROR. DO WHILE NOT AVAILABLE BesGebKo: FOR EACH GebRueck NO-LOCK TRANSACTION: CREATE BesGebKo. ASSIGN BesGebKo.Firma = GVFirma BesGebKo.Besnr = VDoknr BesGebKo.Sort_Cd = GebRueck.Sort_Cd BesGebKo.Geb_Cd = GebRueck.Geb_Cd BesGebKo.Anz_1 = GebRueck.Anz_1 BesGebKo.Kto_Cd1 = GebRueck.Kto_Cd1 BesGebKo.Anz_2 = GebRueck.Anz_2 BesGebKo.Kto_Cd2 = GebRueck.Kto_Cd2 BesGebKo.Anz_3 = GebRueck.Anz_3 BesGebKo.Kto_Cd3 = GebRueck.Kto_Cd3. IF BesGebKo.Kto_Cd1 <> '' THEN DO: FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd1 NO-LOCK. BesGebKo.Wert_1 = GebKonto.Depot. END. IF BesGebKo.Kto_Cd2 <> '' THEN DO: FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd2 NO-LOCK. BesGebKo.Wert_2 = GebKonto.Depot. END. IF BesGebKo.Kto_Cd3 <> '' THEN DO: FIND GebKonto USE-INDEX GebKonto-k1 WHERE GebKonto.Firma = GVFirma AND GebKonto.Geb_Cd = BesGebKo.Kto_Cd3 NO-LOCK. BesGebKo.Wert_3 = GebKonto.Depot. END. END. LEAVE. END. RUN dispatch IN THIS-PROCEDURE ( INPUT 'view':U ) . FQOpen = TRUE. RUN BUTTON_ENABLE ( INPUT 2 ). DO WITH FRAME {&FRAME-NAME}: Btn_Erfassen:LABEL IN FRAME {&FRAME-NAME} = '&Erfassen'. Btn_Speichern:LABEL IN FRAME {&FRAME-NAME} = '&Aendern'. RUN dispatch IN THIS-PROCEDURE ('open-query':U). RUN dispatch IN THIS-PROCEDURE ('disable-fields':U). F_Besnr = VDoknr. E_Adresse = ''. FIND Adresse USE-INDEX Adresse-k1 WHERE Adresse.Firma = AdFirma AND Adresse.Knr = VKnr NO-LOCK NO-ERROR. IF AVAILABLE Adresse THEN DO: E_Adresse = Adresse.Anschrift[03] + CHR(10) + Adresse.Anschrift[04] + CHR(10) + Adresse.Anschrift[05] + CHR(10) + Adresse.Anschrift[06] + CHR(10) + Adresse.Anschrift[07] + CHR(10) + Adresse.Anschrift[08] + CHR(10) + Adresse.Anschrift[09] + CHR(10) + Adresse.Anschrift[10]. END. DISPLAY F_Besnr E_Adresse {&List-5}. IF Besko.Best_Sta <> 2 THEN DO: MESSAGE "Das Gebinde kann nur im Status Eingang/Gebinde mutiert werden" VIEW-AS ALERT-BOX ERROR. RUN BUTTON_ENABLE ( INPUT 98 ). APPLY 'ENTRY' TO BROWSE {&BROWSE-NAME}. RETURN NO-APPLY. END. IF NUM-RESULTS("{&BROWSE-NAME}":U) = ? THEN LEAVE. IF NUM-RESULTS("{&BROWSE-NAME}":U) = 0 THEN LEAVE. {&BROWSE-NAME}:SELECT-FOCUSED-ROW(). APPLY 'ENTRY' TO BROWSE {&BROWSE-NAME}. RETURN NO-APPLY. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE LOESCHEN B-table-Win PROCEDURE LOESCHEN : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ IF Btn_Loeschen:SENSITIVE IN FRAME {&FRAME-NAME} = FALSE THEN RETURN NO-APPLY. APPLY 'ENTRY' TO Btn_Erfassen IN FRAME {&FRAME-NAME}. RUN BUTTON_ENABLE ( 9 ). Ja = FALSE. { v8/loeschen.i } IF NOT Ja THEN DO: RUN BUTTON_ENABLE ( 2 ). RUN state-changed ( INPUT THIS-PROCEDURE, INPUT 'browser_entry' ). RETURN. END. RUN dispatch IN THIS-PROCEDURE ('delete-record':U). DO WHILE TRUE WITH FRAME {&FRAME-NAME}: Vorhanden = FALSE. IF NUM-RESULTS("{&BROWSE-NAME}":U) = ? THEN LEAVE. IF NUM-RESULTS("{&BROWSE-NAME}":U) = 0 THEN LEAVE. Vorhanden = TRUE. LEAVE. END. IF Vorhanden THEN RUN BUTTON_ENABLE ( 2 ). ELSE RUN BUTTON_ENABLE ( 1 ). RUN state-changed ( INPUT THIS-PROCEDURE, INPUT 'browser_entry' ). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE send-records B-table-Win _ADM-SEND-RECORDS PROCEDURE send-records : /*------------------------------------------------------------------------------ Purpose: Send record ROWID's for all tables used by this file. Parameters: see template/snd-head.i ------------------------------------------------------------------------------*/ /* Define variables needed by this internal procedure. */ {src/adm/template/snd-head.i} /* For each requested table, put it's ROWID in the output list. */ {src/adm/template/snd-list.i "BesGebKo"} /* Deal with any unexpected table requests before closing. */ {src/adm/template/snd-end.i} END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE SPEICHERN B-table-Win PROCEDURE SPEICHERN : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DEF VAR XROWID AS ROWID NO-UNDO. DO WITH FRAME {&FRAME-NAME}: IF Btn_Speichern:SENSITIVE = FALSE THEN RETURN NO-APPLY. APPLY 'ENTRY' TO Btn_Speichern. CASE Btn_Speichern:LABEL: WHEN '&Aendern' THEN DO: RUN adm-enable-fields. APPLY 'ENTRY' TO {&DATEI-NAME}.{&ZWEITES-FELD} IN BROWSE {&BROWSE-NAME}. VUpdate = TRUE. VNeu = FALSE. VSpeichern = TRUE. Btn_Erfassen:LABEL = '&Abbrechen'. Btn_Speichern:LABEL = '&Speichern'. RUN BUTTON_ENABLE ( 3 ). END. WHEN '&Speichern' THEN DO: VUpdate = FALSE. RUN adm-disable-fields. RUN adm-update-record. RUN adm-end-update. VNeu = FALSE. VSpeichern = FALSE. Btn_Erfassen:LABEL = '&Erfassen'. Btn_Speichern:LABEL = '&Aendern'. IF Vorhanden THEN RUN BUTTON_ENABLE ( 2 ). ELSE RUN BUTTON_ENABLE ( 1 ). END. END CASE. END. IF NOT VUpdate THEN RUN state-changed ( INPUT THIS-PROCEDURE, INPUT 'browser_entry' ). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE state-changed B-table-Win PROCEDURE state-changed : /* ----------------------------------------------------------- Purpose: Parameters: Notes: -------------------------------------------------------------*/ DEFINE INPUT PARAMETER p-issuer-hdl AS HANDLE NO-UNDO. DEFINE INPUT PARAMETER p-state AS CHARACTER NO-UNDO. CASE p-state: WHEN 'first-record' THEN DO: RUN ANZEIGE. RUN set-attribute-list('Query-Position=':U + p-state). RETURN NO-APPLY. END. WHEN 'browser_entry' THEN DO: APPLY 'ENTRY' TO BROWSE {&BROWSE-NAME}. RETURN NO-APPLY. END. {src/adm/template/bstates.i} END CASE. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME