&ANALYZE-SUSPEND _VERSION-NUMBER AB_v10r12 GUI ADM2 &ANALYZE-RESUME &Scoped-define WINDOW-NAME CURRENT-WINDOW &Scoped-define FRAME-NAME gBestellvorschlagDaten {adecomm/appserv.i} &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _DEFINITIONS gBestellvorschlagDaten /*------------------------------------------------------------------------ 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 --- */ DEFINE INPUT-OUTPUT PARAMETER iohtParam AS HANDLE NO-UNDO. /* Local Variable Definitions --- */ { incl/dlgdefinition.i } { src/adm2/widgetprto.i } /* _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 designated FRAME-NAME and/or first browse and/or first query */ &Scoped-define FRAME-NAME gBestellvorschlagDaten /* Standard List Definitions */ &Scoped-Define ENABLED-OBJECTS RECT-2 F_Knr F_Adresse F_LetzteBestellung ~ F_Intervall F_Lieferfrist F_Bestandesdatum F_Reserviertdatum T_Bewegungen ~ F_vonDatum F_bisDatum F_Aufrunden T_Verbrauch T_Unter Btn_OK Btn_Cancel &Scoped-Define DISPLAYED-OBJECTS F_Knr F_Adresse F_LetzteBestellung ~ F_Intervall F_Lieferfrist F_Bestandesdatum F_Reserviertdatum T_Bewegungen ~ F_vonDatum F_bisDatum F_Aufrunden T_Verbrauch T_Unter /* Custom List Definitions */ /* List-1,List-2,List-3,List-4,List-5,List-6 */ &Scoped-define List-6 F_LetzteBestellung F_Intervall F_Lieferfrist ~ F_Bestandesdatum F_Reserviertdatum T_Bewegungen F_vonDatum F_bisDatum ~ F_Aufrunden T_Verbrauch T_Unter /* _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. DEFINE BUTTON Btn_OK LABEL "OK" SIZE 15 BY 1. DEFINE VARIABLE F_Adresse AS CHARACTER FORMAT "X(256)":U LABEL "/" VIEW-AS FILL-IN NATIVE SIZE 63.2 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Aufrunden AS DECIMAL FORMAT "zz9.99":U INITIAL 0 LABEL "ganzes GGebinde ab % Füllung" VIEW-AS FILL-IN NATIVE SIZE 12 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Bestandesdatum AS DATE FORMAT "99.99.9999":U LABEL "Bestandesaktiv bis" VIEW-AS FILL-IN NATIVE SIZE 16 BY 1 TOOLTIP "Lieferungen bis zu diesem Datum im Bestand berücksichtigen" BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_bisDatum AS DATE FORMAT "99.99.9999":U LABEL "-" VIEW-AS FILL-IN NATIVE SIZE 16 BY 1 TOOLTIP "Zeitbereich für Bewegungen des Artikels" BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Intervall AS INTEGER FORMAT "zz9":U INITIAL 0 LABEL "Intervall" VIEW-AS FILL-IN NATIVE SIZE 6 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Knr AS INTEGER FORMAT "999999":U INITIAL 0 LABEL "Lieferant" VIEW-AS FILL-IN NATIVE SIZE 10 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_LetzteBestellung AS DATE FORMAT "99.99.9999":U LABEL "Datum letzte Bestellung" VIEW-AS FILL-IN NATIVE SIZE 16 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Lieferfrist AS INTEGER FORMAT "zz9":U INITIAL 0 LABEL "Lieferfrist" VIEW-AS FILL-IN NATIVE SIZE 6 BY 1 BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_Reserviertdatum AS DATE FORMAT "99.99.9999":U LABEL "Reservationen bis" VIEW-AS FILL-IN NATIVE SIZE 16 BY 1 TOOLTIP "Zukünftige Lieferung berücksichigen bis zu diesem Datum" BGCOLOR 15 NO-UNDO. DEFINE VARIABLE F_vonDatum AS DATE FORMAT "99.99.9999":U LABEL "Bewegungen von -bis" VIEW-AS FILL-IN NATIVE SIZE 16 BY 1 TOOLTIP "Zeitbereich für Bewegungen des Artikels" BGCOLOR 15 NO-UNDO. DEFINE RECTANGLE RECT-2 EDGE-PIXELS 2 GRAPHIC-EDGE NO-FILL SIZE 108 BY 11.91. DEFINE VARIABLE T_Bewegungen AS LOGICAL INITIAL NO LABEL "Nur Artikel mit Bewegungen" VIEW-AS TOGGLE-BOX SIZE 40 BY 1 NO-UNDO. DEFINE VARIABLE T_Unter AS LOGICAL INITIAL YES LABEL "nur Best.Pt. unterschrittene" VIEW-AS TOGGLE-BOX SIZE 40 BY 1 NO-UNDO. DEFINE VARIABLE T_Verbrauch AS LOGICAL INITIAL NO LABEL "Verbrauch rechnen" VIEW-AS TOGGLE-BOX SIZE 40 BY 1 NO-UNDO. /* ************************ Frame Definitions *********************** */ DEFINE FRAME gBestellvorschlagDaten F_Knr AT ROW 2 COL 23.4 COLON-ALIGNED WIDGET-ID 4 NO-TAB-STOP F_Adresse AT ROW 2 COL 37 COLON-ALIGNED WIDGET-ID 6 NO-TAB-STOP F_LetzteBestellung AT ROW 3.52 COL 37 COLON-ALIGNED WIDGET-ID 8 F_Intervall AT ROW 4.52 COL 37 COLON-ALIGNED WIDGET-ID 10 F_Lieferfrist AT ROW 4.52 COL 54.8 COLON-ALIGNED WIDGET-ID 24 F_Bestandesdatum AT ROW 4.52 COL 82.8 COLON-ALIGNED WIDGET-ID 26 F_Reserviertdatum AT ROW 5.52 COL 37 COLON-ALIGNED WIDGET-ID 22 T_Bewegungen AT ROW 7 COL 39 WIDGET-ID 20 F_vonDatum AT ROW 8 COL 37 COLON-ALIGNED WIDGET-ID 28 F_bisDatum AT ROW 8 COL 56 COLON-ALIGNED WIDGET-ID 30 F_Aufrunden AT ROW 9.33 COL 37 COLON-ALIGNED WIDGET-ID 32 T_Verbrauch AT ROW 10.52 COL 39 WIDGET-ID 18 T_Unter AT ROW 11.52 COL 39 WIDGET-ID 16 Btn_OK AT ROW 14 COL 37.6 Btn_Cancel AT ROW 14 COL 58.8 RECT-2 AT ROW 1.48 COL 3 WIDGET-ID 2 SPACE(1.99) SKIP(2.93) WITH VIEW-AS DIALOG-BOX KEEP-TAB-ORDER SIDE-LABELS NO-UNDERLINE THREE-D SCROLLABLE TITLE "Daten für den Bestellvorschlag" CANCEL-BUTTON Btn_Cancel WIDGET-ID 100. /* *********************** 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 APPSERVER */ &ANALYZE-RESUME _END-PROCEDURE-SETTINGS &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _INCLUDED-LIB gBestellvorschlagDaten /* ************************* 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 gBestellvorschlagDaten FRAME-NAME */ ASSIGN FRAME gBestellvorschlagDaten:SCROLLABLE = FALSE FRAME gBestellvorschlagDaten:HIDDEN = TRUE. ASSIGN F_Adresse:READ-ONLY IN FRAME gBestellvorschlagDaten = TRUE. /* SETTINGS FOR FILL-IN F_Aufrunden IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR FILL-IN F_Bestandesdatum IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR FILL-IN F_bisDatum IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR FILL-IN F_Intervall IN FRAME gBestellvorschlagDaten 6 */ ASSIGN F_Knr:READ-ONLY IN FRAME gBestellvorschlagDaten = TRUE. /* SETTINGS FOR FILL-IN F_LetzteBestellung IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR FILL-IN F_Lieferfrist IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR FILL-IN F_Reserviertdatum IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR FILL-IN F_vonDatum IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR TOGGLE-BOX T_Bewegungen IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR TOGGLE-BOX T_Unter IN FRAME gBestellvorschlagDaten 6 */ /* SETTINGS FOR TOGGLE-BOX T_Verbrauch IN FRAME gBestellvorschlagDaten 6 */ /* _RUN-TIME-ATTRIBUTES-END */ &ANALYZE-RESUME /* Setting information for Queries and Browse Widgets fields */ &ANALYZE-SUSPEND _QUERY-BLOCK DIALOG-BOX gBestellvorschlagDaten /* Query rebuild information for DIALOG-BOX gBestellvorschlagDaten _Options = "SHARE-LOCK" _Query is NOT OPENED */ /* DIALOG-BOX gBestellvorschlagDaten */ &ANALYZE-RESUME /* ************************ Control Triggers ************************ */ &Scoped-define SELF-NAME gBestellvorschlagDaten &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL gBestellvorschlagDaten gBestellvorschlagDaten ON END-ERROR OF FRAME gBestellvorschlagDaten /* Daten für den Bestellvorschlag */ DO: RUN ENDE. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL gBestellvorschlagDaten gBestellvorschlagDaten ON WINDOW-CLOSE OF FRAME gBestellvorschlagDaten /* Daten für den Bestellvorschlag */ 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 gBestellvorschlagDaten ON CHOOSE OF Btn_Cancel IN FRAME gBestellvorschlagDaten /* abbrechen */ DO: btnOK = FALSE. 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 gBestellvorschlagDaten ON CHOOSE OF Btn_OK IN FRAME gBestellvorschlagDaten /* OK */ DO: btnOK = TRUE. RUN ENDE. RETURN NO-APPLY. END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &Scoped-define SELF-NAME T_Bewegungen &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CONTROL T_Bewegungen gBestellvorschlagDaten ON VALUE-CHANGED OF T_Bewegungen IN FRAME gBestellvorschlagDaten /* Nur Artikel mit Bewegungen */ DO: ASSIGN {&List-6}. F_VonDatum:HIDDEN = (IF T_Bewegungen THEN FALSE ELSE TRUE). F_BisDatum:HIDDEN = (IF T_Bewegungen THEN FALSE ELSE TRUE). END. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &UNDEFINE SELF-NAME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _MAIN-BLOCK gBestellvorschlagDaten /* *************************** Main Block *************************** */ { incl/dlgmainblock.i } ON 'RETURN':U OF T_Verbrauch, T_Unter, T_Bewegungen IN FRAME {&FRAME-NAME} DO: APPLY 'TAB' TO SELF. END. {src/adm2/dialogmn.i} /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME /* ********************** Internal Procedures *********************** */ &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE adm-create-objects gBestellvorschlagDaten _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 disable_UI gBestellvorschlagDaten _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 gBestellvorschlagDaten. END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE enableObject gBestellvorschlagDaten PROCEDURE enableObject : /*------------------------------------------------------------------------------*/ /* Purpose: */ /* Parameters: */ /* Notes: */ /*------------------------------------------------------------------------------*/ F_Knr = iohtParam::iKnr. FIND Adresse NO-LOCK WHERE Adresse.Firma = AdFirma AND Adresse.Knr = F_Knr. FIND Liefst NO-LOCK WHERE Liefst.Firma = Firma AND Liefst.Knr = F_Knr. ASSIGN F_Adresse = Adresse.Anzeig_br F_LetzteBestellung = iohtParam::dLetztBest F_Intervall = iohtParam::iIntervall F_Lieferfrist = iohtParam::iLieferfrist F_Bestandesdatum = iohtParam::dBestandesdatum F_Reserviertdatum = iohtParam::dReserviertdatum F_vonDatum = iohtParam::dvon F_bisDatum = iohtParam::dbis F_Aufrunden = iohtParam::nAufrunden T_Bewegungen = iohtParam::lBewegungen T_Unter = iohtParam::lUnter T_Verbrauch = iohtParam::lVerbrauch . iohtParam::lOK = FALSE. { incl/dlgenableobject.i } F_VonDatum:HIDDEN = (IF T_Bewegungen THEN FALSE ELSE TRUE). F_BisDatum:HIDDEN = (IF T_Bewegungen THEN FALSE ELSE TRUE). END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE enable_UI gBestellvorschlagDaten _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 F_Knr F_Adresse F_LetzteBestellung F_Intervall F_Lieferfrist F_Bestandesdatum F_Reserviertdatum T_Bewegungen F_vonDatum F_bisDatum F_Aufrunden T_Verbrauch T_Unter WITH FRAME gBestellvorschlagDaten. ENABLE RECT-2 F_Knr F_Adresse F_LetzteBestellung F_Intervall F_Lieferfrist F_Bestandesdatum F_Reserviertdatum T_Bewegungen F_vonDatum F_bisDatum F_Aufrunden T_Verbrauch T_Unter Btn_OK Btn_Cancel WITH FRAME gBestellvorschlagDaten. VIEW FRAME gBestellvorschlagDaten. {&OPEN-BROWSERS-IN-QUERY-gBestellvorschlagDaten} END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME &ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE ENDE gBestellvorschlagDaten PROCEDURE ENDE : /*------------------------------------------------------------------------------*/ /* Purpose: */ /* Parameters: */ /* Notes: */ /*------------------------------------------------------------------------------*/ IF btnOK THEN DO: DO WITH FRAME {&FRAME-NAME}: ASSIGN {&List-6}. ASSIGN iohtParam::dLetztBest = TODAY iohtParam::iIntervall = F_Intervall iohtParam::iLieferfrist = F_Lieferfrist iohtParam::dReserviertdatum = F_Reserviertdatum iohtParam::dBestandesdatum = F_Bestandesdatum iohtParam::nAufrunden = F_Aufrunden iohtParam::dVon = F_vonDatum iohtParam::dBis = F_bisDatum iohtParam::lBewegungen = T_Bewegungen iohtParam::lUnter = T_Unter iohtParam::lVerbrauch = T_Verbrauch iohtParam::lOK = TRUE . btnOK = FALSE. END. IF F_Intervall > 0 THEN DO: FIND Liefst WHERE Liefst.Firma = Firma AND Liefst.Knr = F_Knr. ASSIGN Liefst.Bestell_Intervall = F_Intervall Liefst.Lieferzeit = F_Lieferfrist. RELEASE Liefst. END. END. { incl/dlgende.i } END PROCEDURE. /* _UIB-CODE-BLOCK-END */ &ANALYZE-RESUME