&ANALYZE-SUSPEND _VERSION-NUMBER AB_v9r12 GUI ADM2 &ANALYZE-RESUME &Scoped-define WINDOW-NAME CURRENT-WINDOW &Scoped-define FRAME-NAME gFehlwerte &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _DEFINITIONS gFehlwerte /*------------------------------------------------------------------------ File: Description: from cntnrdlg.w - ADM2 SmartDialog Template Input Parameters: Output Parameters: Author: Created: ------------------------------------------------------------------------*/ /* This .W file was created with the Progress AppBuilder. */ /*----------------------------------------------------------------------*/ /* 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 ************************** */ /* Parameters Definitions --- */ DEF INPUT PARAMETER ipFehlwert AS CHAR NO-UNDO. /* Local Variable Definitions --- */ DEF VAR MaxPage AS INT NO-UNDO. DEF VAR AktSeite AS INT NO-UNDO. DEF VAR FMutFlag AS LOG NO-UNDO. DEF VAR i1 AS INT NO-UNDO. DEF TEMP-TABLE tFehlwerte FIELD Feld AS CHAR FIELD Wert AS CHAR. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-PREPROCESSOR-BLOCK /* ******************** Preprocessor Definitions ******************** */ &Scoped-define PROCEDURE-TYPE SmartDialog &Scoped-define DB-AWARE no &Scoped-define ADM-CONTAINER DIALOG-BOX &Scoped-define ADM-SUPPORTED-LINKS Data-Target,Data-Source,Page-Target,Update-Source,Update-Target /* Name of first Frame and/or Browse and/or first Query */ &Scoped-define FRAME-NAME gFehlwerte /* Standard List Definitions */ &Scoped-Define ENABLED-OBJECTS CB_Fehlwerte F_Wert Btn_OK Btn_Cancel RECT-4 &Scoped-Define DISPLAYED-OBJECTS CB_Fehlwerte F_Wert /* Custom List Definitions */ /* List-1,List-2,List-3,List-4,List-5,List-6 */ /* _UIB-PREPROCESSOR-BLOCK-END */ &ANALYZE-RESUME /* *********************** Control Definitions ********************** */ /* Define a dialog box */ /* Definitions of the field level widgets */ DEFINE BUTTON Btn_Cancel AUTO-END-KEY LABEL "&abbrechen" SIZE 15 BY 1.14. DEFINE BUTTON Btn_OK AUTO-GO LABEL "&speichern" SIZE 15 BY 1.14. DEFINE VARIABLE CB_Fehlwerte AS CHARACTER FORMAT "X(256)":U LABEL "Fehlwertfeld" VIEW-AS COMBO-BOX INNER-LINES 5 LIST-ITEMS "Item 1" DROP-DOWN-LIST SIZE 30 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Wert AS CHARACTER FORMAT "x(100)":U LABEL "Wert" VIEW-AS FILL-IN NATIVE SIZE 14 BY 1 BGCOLOR 15 NO-UNDO. DEFINE RECTANGLE RECT-4 EDGE-PIXELS 2 GRAPHIC-EDGE NO-FILL SIZE 84 BY 4.67. /* ************************ Frame Definitions *********************** */ DEFINE FRAME gFehlwerte CB_Fehlwerte AT ROW 2 COL 16.2 COLON-ALIGNED F_Wert AT ROW 2 COL 60.2 COLON-ALIGNED Btn_OK AT ROW 4 COL 24.6 Btn_Cancel AT ROW 4 COL 41.8 RECT-4 AT ROW 1.29 COL 2.2 SPACE(1.19) SKIP(0.27) WITH VIEW-AS DIALOG-BOX KEEP-TAB-ORDER SIDE-LABELS NO-UNDERLINE THREE-D SCROLLABLE TITLE "Fehlwerte erfassen" DEFAULT-BUTTON Btn_OK CANCEL-BUTTON Btn_Cancel. /* *********************** Procedure Settings ************************ */ &ANALYZE-SUSPEND _PROCEDURE-SETTINGS /* Settings for THIS-PROCEDURE Type: SmartDialog Allow: Basic,Browse,DB-Fields,Query,Smart Container Links: Data-Target,Data-Source,Page-Target,Update-Source,Update-Target Design Page: 1 Other Settings: COMPILE */ &ANALYZE-RESUME _END-PROCEDURE-SETTINGS &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _INCLUDED-LIB gFehlwerte /* ************************* Included-Libraries *********************** */ {src/adm2/containr.i} /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME /* *********** Runtime Attributes and AppBuilder Settings *********** */ &ANALYZE-SUSPEND _RUN-TIME-ATTRIBUTES /* SETTINGS FOR DIALOG-BOX gFehlwerte */ ASSIGN FRAME gFehlwerte:SCROLLABLE = FALSE FRAME gFehlwerte:HIDDEN = TRUE. /* _RUN-TIME-ATTRIBUTES-END */ &ANALYZE-RESUME /* Setting information for Queries and Browse Widgets fields */ &ANALYZE-SUSPEND _QUERY-BLOCK DIALOG-BOX gFehlwerte /* Query rebuild information for DIALOG-BOX gFehlwerte _Options = "SHARE-LOCK" _Query is NOT OPENED */ /* DIALOG-BOX gFehlwerte */ &ANALYZE-RESUME /* ************************ Control Triggers ************************ */ &Scoped-define SELF-NAME gFehlwerte &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL gFehlwerte gFehlwerte ON END-ERROR OF FRAME gFehlwerte /* Fehlwerte erfassen */ DO: RUN ENDE. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL gFehlwerte gFehlwerte ON GO OF FRAME gFehlwerte /* Fehlwerte erfassen */ DO: RUN ENDE_PROGRAMM ( INPUT THIS-PROCEDURE:FILE-NAME ) NO-ERROR. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL gFehlwerte gFehlwerte ON WINDOW-CLOSE OF FRAME gFehlwerte /* Fehlwerte erfassen */ DO: RUN ENDE. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME Btn_Cancel &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL Btn_Cancel gFehlwerte ON CHOOSE OF Btn_Cancel IN FRAME gFehlwerte /* abbrechen */ DO: RUN ENDE. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME Btn_OK &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL Btn_OK gFehlwerte ON CHOOSE OF Btn_OK IN FRAME gFehlwerte /* speichern */ DO: RUN FW_SCHREIBEN. RUN ENDE. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME CB_Fehlwerte &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL CB_Fehlwerte gFehlwerte ON RETURN OF CB_Fehlwerte IN FRAME gFehlwerte /* Fehlwertfeld */ DO: APPLY 'TAB' TO SELF. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL CB_Fehlwerte gFehlwerte ON VALUE-CHANGED OF CB_Fehlwerte IN FRAME gFehlwerte /* Fehlwertfeld */ DO: FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = SELF:SCREEN-VALUE. F_Wert:SCREEN-VALUE = tFehlwerte.Wert. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME F_Wert &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL F_Wert gFehlwerte ON LEAVE OF F_Wert IN FRAME gFehlwerte /* Wert */ DO: DEF VAR ix AS INT NO-UNDO. DEF VAR Anzeige AS CHAR NO-UNDO. DEF VAR Wert AS CHAR NO-UNDO. DO WITH FRAME {&FRAME-NAME}: F_Wert = SELF:SCREEN-VALUE. FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = CB_Fehlwerte:SCREEN-VALUE. tFehlwerte.Wert = F_Wert. APPLY 'ENTRY' TO CB_Fehlwerte. RETURN NO-APPLY. END. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL F_Wert gFehlwerte ON RETURN OF F_Wert IN FRAME gFehlwerte /* Wert */ DO: APPLY 'TAB' TO SELF. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &UNDEFINE SELF-NAME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _MAIN-BLOCK gFehlwerte /* *************************** Main Block *************************** */ MaxPage = 1. AktSeite = 1. SESSION:DATA-ENTRY-RETURN = TRUE. /* ------------------------------------------------------------------ */ {src/adm2/dialogmn.i} /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME /* ********************** Internal Procedures *********************** */ &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE adm-create-objects gFehlwerte _ADM-CREATE-OBJECTS PROCEDURE adm-create-objects : /*------------------------------------------------------------------------------ Purpose: Create handles for all SmartObjects used in this procedure. After SmartObjects are initialized, then SmartLinks are added. Parameters: ------------------------------------------------------------------------------*/ END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE changePage gFehlwerte PROCEDURE changePage : /*------------------------------------------------------------------------------ Purpose: Super Override Parameters: Notes: ------------------------------------------------------------------------------*/ /* Code placed here will execute PRIOR to standard behavior. */ RUN SUPER. AktSeite = DYNAMIC-FUNCTION('getCurrentPage':U). CASE AktSeite: WHEN 1 THEN DO: /* RUN addLink ( h_dyntoolbar , 'TableIO':U , h_v-auftr ). */ /* RUN addLink ( h_dyntoolbar , 'Navigation':U , h_d-auftr ). */ /* RUN ToolbarInit ( INPUT h_d-auftr ). */ RUN ENTRY_CURSOR. END. WHEN 2 THEN DO: RUN ENTRY_CURSOR. END. END CASE. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE disable_UI gFehlwerte _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 gFehlwerte. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE enableObject gFehlwerte PROCEDURE enableObject : /*------------------------------------------------------------------------------ Purpose: Super Override Parameters: Notes: ------------------------------------------------------------------------------*/ /* Code placed here will execute PRIOR to standard behavior. */ RUN SUPER. RUN FENSTER_TITEL ( INPUT FRAME {&FRAME-NAME}:HANDLE ) NO-ERROR. RUN FW_LESEN. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE enable_UI gFehlwerte _DEFAULT-ENABLE PROCEDURE enable_UI : /*------------------------------------------------------------------------------ Purpose: ENABLE the User Interface Parameters: Notes: Here we display/view/enable the widgets in the user-interface. In addition, OPEN all queries associated with each FRAME and BROWSE. These statements here are based on the "Other Settings" section of the widget Property Sheets. ------------------------------------------------------------------------------*/ DISPLAY CB_Fehlwerte F_Wert WITH FRAME gFehlwerte. ENABLE CB_Fehlwerte F_Wert Btn_OK Btn_Cancel RECT-4 WITH FRAME gFehlwerte. VIEW FRAME gFehlwerte. {&OPEN-BROWSERS-IN-QUERY-gFehlwerte} END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE ENDE gFehlwerte PROCEDURE ENDE : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ AktSeite = DYNAMIC-FUNCTION('getCurrentPage':U) NO-ERROR. IF AktSeite > 1 THEN DO: RUN selectPage ( INPUT 1 ). RETURN NO-APPLY. END. RUN ENDE_PROGRAMM ( INPUT THIS-PROCEDURE:FILE-NAME ). APPLY 'GO' TO FRAME {&FRAME-NAME}. RETURN NO-APPLY. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE ENTRY_CURSOR gFehlwerte PROCEDURE ENTRY_CURSOR : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ AktSeite = DYNAMIC-FUNCTION('getCurrentPage':U). CASE AktSeite: /* WHEN 1 THEN RUN applyEntry IN h_v-adresse ( INPUT ? ). */ /* WHEN 2 THEN RUN applyEntry IN h_f-adrkomm ( INPUT ? ). */ /* WHEN 3 THEN RUN applyEntry IN h_b-auftbb ( INPUT ? ). */ /* WHEN 4 THEN RUN applyEntry IN h_b-aufdet ( INPUT ? ). */ /* WHEN 5 THEN RUN applyEntry IN h_b-aufstreu ( INPUT ? ). */ /* WHEN 6 THEN RUN applyEntry IN h_b-auffak ( INPUT ? ). */ /* WHEN 7 THEN RUN applyEntry IN h_b-position ( INPUT ? ). */ END CASE. RETURN NO-APPLY. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE exitObject gFehlwerte PROCEDURE exitObject : /*------------------------------------------------------------------------------ Purpose: Super Override Parameters: Notes: ------------------------------------------------------------------------------*/ RUN ENDE. RETURN NO-APPLY. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE FW_LESEN gFehlwerte PROCEDURE FW_LESEN : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DEF VAR FwFelder AS CHAR NO-UNDO. DEF VAR FwFeld AS CHAR NO-UNDO. DEF VAR FwValue AS CHAR NO-UNDO. DEF VAR ix AS INT NO-UNDO. DEF VAR i1 AS INT NO-UNDO. DEF VAR iof AS LOG NO-UNDO. DO WITH FRAME {&FRAME-NAME}: CB_Fehlwerte:DELIMITER = ';'. EMPTY TEMP-TABLE tFehlwerte. GET-KEY-VALUE SECTION ipFehlwert KEY ? VALUE FwFelder. DO ix = 1 TO NUM-ENTRIES(FwFelder, ','): FwFeld = ENTRY (ix , FwFelder , ','). GET-KEY-VALUE SECTION ipFehlwert KEY FwFeld VALUE FwValue. CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = FwFeld tFehlwerte.Wert = FwValue. END. IF ipFehlwert = 'FwDebitor' THEN DO: FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'Kred_Lim_Vers' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'Kred_Lim_Vers' tFehlwerte.Wert = '5000'. END. FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwSicherheit' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwSicherheit' tFehlwerte.Wert = '85.00'. END. END. IF ipFehlwert = 'FwSteuer' THEN DO: FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwLkz' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwLkz' tFehlwerte.Wert = 'CH'. END. FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwFRW' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwFRW' tFehlwerte.Wert = 'CHF'. END. FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwSprcd' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwSprcd' tFehlwerte.Wert = '01'. END. END. IF ipFehlwert = 'FwAuftrag' THEN DO: FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwLKW' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwLKW' tFehlwerte.Wert = '0'. END. FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwFahrer' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwFahrer' tFehlwerte.Wert = '0'. END. FIND FIRST tFehlwerte WHERE tFehlwerte.Feld = 'FwBeiFahr' NO-ERROR. IF NOT AVAILABLE tFehlwerte THEN DO: CREATE tFehlwerte. ASSIGN tFehlwerte.Feld = 'FwBeiFahr' tFehlwerte.Wert = '0'. END. END. FOR EACH tFehlwerte BY tFehlwerte.Feld: CB_Fehlwerte:ADD-LAST( tFehlwerte.Feld ). END. CB_Fehlwerte:SCREEN-VALUE = ENTRY(1, CB_Fehlwerte:LIST-ITEMS, ';') NO-ERROR. APPLY 'VALUE-CHANGED' TO CB_Fehlwerte. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE FW_SCHREIBEN gFehlwerte PROCEDURE FW_SCHREIBEN : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ FOR EACH tFehlwerte: PUT-KEY-VALUE SECTION ipFehlwert KEY tFehlwerte.Feld VALUE tFehlwerte.Wert. DELETE tFehlwerte. END. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE NEXTPAGE gFehlwerte PROCEDURE NEXTPAGE : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ AktSeite = DYNAMIC-FUNCTION('getCurrentPage':U). IF AktSeite = MaxPage THEN AktSeite = 1. ELSE AktSeite = AktSeite + 1. RUN selectPage ( INPUT AktSeite ). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE PREVPAGE gFehlwerte PROCEDURE PREVPAGE : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ AktSeite = DYNAMIC-FUNCTION('getCurrentPage':U). IF AktSeite = 1 THEN AktSeite = MaxPage. ELSE AktSeite = AktSeite - 1. RUN selectPage ( INPUT AktSeite ). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE selectPage gFehlwerte PROCEDURE selectPage : /*------------------------------------------------------------------------------ Purpose: Super Override Parameters: Notes: ------------------------------------------------------------------------------*/ DEF INPUT PARAMETER piPageNum AS INT NO-UNDO. DEF VAR FMutFlag AS LOG NO-UNDO. DEF VAR MutProg AS CHAR NO-UNDO. FMutFlag = DYNAMIC-FUNCTION('getMutflagAlt':U) NO-ERROR. DO WHILE TRUE: IF NOT FMutFlag THEN LEAVE. MutProg = DYNAMIC-FUNCTION('GETMUTPROG':U). IF MutProg <> THIS-PROCEDURE:FILE-NAME THEN LEAVE. RETURN NO-APPLY. END. CASE piPageNum: END CASE. AktSeite = DYNAMIC-FUNCTION('getCurrentPage':U). CASE AktSeite: WHEN 1 THEN DO: /* RUN removeLink ( h_dyntoolbar , 'TableIO':U , h_v-auftr ). */ /* RUN removeLink ( h_dyntoolbar , 'Navigation':U , h_d-auftr ). */ END. END CASE. RUN SUPER( INPUT piPageNum). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE TOOLBAR gFehlwerte PROCEDURE TOOLBAR : /*------------------------------------------------------------------------------ Purpose: Parameters: Notes: ------------------------------------------------------------------------------*/ DEF INPUT PARAMETER pcAction AS CHAR NO-UNDO. /* RUN TOOLBAR IN h_dyntoolbar ( INPUT pcAction ). */ END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME