Willkommen auf myCSharp.de! Anmelden | kostenlos registrieren
 | Suche | FAQ

Hauptmenü
myCSharp.de
» Startseite
» Forum
» Suche
» Regeln
» Wie poste ich richtig?

Mitglieder
» Liste / Suche
» Wer ist online?

Ressourcen
» FAQ
» Artikel
» C#-Snippets
» Jobbörse
» Microsoft Docs

Team
» Kontakt
» Cookies
» Spenden
» Datenschutz
» Impressum

  • »
  • Portal
  • |
  • Mitglieder
Beiträge von Sascha87
Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Zitat von Palladin007
Warum machst Du das denn nicht im ViewModel?
Einfach die Liste mit den Rechten auf CanAddFPFoer filtern und einer zweiten Property zuweisen - oder direkt die erste Liste gefiltert anbieten.
Und wenn es immer nur ein Recht geben kann, suchst Du halt das eine Recht raus.
Dann brauchst Du den ganzen Kram nicht.

Ich bin absoluter Anfänger und verstehe den Ansatz nicht. Daher versuche ich mit Lösungen zurecht zu kommen, die es im Internet gibt.

Deinen Tipp werde ich versuchen, vielen lieben Dank!

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Das Anzeigen und Nicht-Anzeigen des Buttons habe ich hinbekommen.
Ich habe einfach eine Liste um den Button erstellt. Dort konnte ich ItemsSource und SelectedItem anwenden. Jetzt kann ich nur nicht mehr auf den Command des Buttons zugreifen.

Dem Binding habe ich ein "RelativeSource" hinzugefügt. Die eigentliche Bindung zum Command funktioniert. Allerdings führt er nichts aus.


<UserControl.DataContext>
        <vm:ViewModel></vm:ViewModel>
    </UserControl.DataContext>


<ListBox ItemsSource="{Binding Rechte, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" SelectedItem="{Binding ProRechte, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" FontSize="{Binding SelectedFont, UpdateSourceTrigger=PropertyChanged}" BorderThickness="0" Background="WhiteSmoke">
                                        <ListBox.ItemContainerStyle>
                                            <Style TargetType="ListBoxItem">
                                                <Setter Property="Visibility" Value="{Binding CanAddFPFoer, Converter={StaticResource BoolToVis}}" />
                                            </Style>
                                        </ListBox.ItemContainerStyle>
                                        <ListBox.ItemTemplate>
                                            <DataTemplate>
                                                <StackPanel Orientation="Horizontal">
                                                    <Button Content="Eintragen" Command="{Binding RelativeSource={RelativeSource AncestorType={x:Type vm:ViewModel}}, Path=FoerderEintragen}" Padding="5 5 5 5" Margin="5 15 5 0" />
                                                </StackPanel>
                                            </DataTemplate>
                                        </ListBox.ItemTemplate>
                                    </ListBox>


Als Bindungsfehler taucht folgendes aus:
Fehler
Quelle nicht gefunden: RelativeResource FindAncestor, AncestorType="ViewModel", AncestorLevel="1"

Hätte jemand einen heißen Tipp für mich?
Vielen lieben Dank und einen guten Start in den Tag!
Grüße
Sascha

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Das war der entscheidende Hinweis!

Vielen lieben Dank!

Grüße
Sascha

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Das habe ich bisher noch nicht benötigt. Wie gebe ich dem denn Rechte?

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Im getter steht er anscheinend auf Null....

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Ok, ich glaube, ich bin ein Schritt weiter.

Ich habe jetzt die folgende Property erstellt:


Recht _rechte;
        public Recht ProRechte
        {
            get
            {
                return _rechte;
            }
            set
            {
                if (value == null)
                    return;
                OnPropertyChanged(ref _rechte, value);
            }
        }

Im xaml Code kann ich auf den Wert zugreifen:


<Button Content="Löschen" Command="{Binding FoerderLoeschen}" FontSize="{Binding SelectedFont, UpdateSourceTrigger=PropertyChanged}" Visibility="{Binding ProRechte.CanDelFPFoer, Converter={StaticResource BoolToVis}}" Padding="5 5 5 5" Margin="5 15 5 0"/>

Nur gibt er mir keinen Wert aus?
Was ich vorhabe: Ich habe in der Datenbank eine 1 oder NULL gespeichert.
Ich lese die Werte als Nullable Bool aus und gebe sie als Liste weiter.

Ich möchte die Buttons anzeigen oder verstecken, je nach Wert. Dazu gibt es den BooleanToVisibilityConverter.

Allerdings wandelt er es nicht um bzw. ich vermute, dass ich meinen Wert nicht bekomme. Kann ich irgendwie überprüfen, ob true oder false ankommt?

Vielen lieben Dank!

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Hättest du eventuell einen Tipp wie ich innerhalb einer Property nur auf ein Element der Klasse zugreife?

EDIT: Hat sich erledigt.

Thema: Button mit ItemsSource
Am im Forum: GUI: WPF und XAML

Guten Morgen zusammen,
ich möchte ein ItemsSource an ein Button Binden. Der Grund ist, ich benötige Unterwerte einer Klasse.

Bei einer ListBox kann ich "Rechte" als ItemsSource Binden und in den ListBox.ItemTemplates kann ich tiefer darauf zugreifen (Rechte.HatRechte).

Leider geht es bei den Buttons nicht. Dort kann ich nur "Rechte" Binden. Nach ein wenig googln kam ich auf die Funktion "ItemsControl".


<ItemsControl ItemsSource="{Binding Rechte}" >
                                            <ItemsControl.ItemTemplate>
                                                <DataTemplate>
                                                    <StackPanel>
                                                        <Button Content="Löschen" Command="{Binding FoerderLoeschen}" FontSize="{Binding SelectedFont, UpdateSourceTrigger=PropertyChanged}" Visibility="{Binding Rechte.CanDelFPFoer, Converter={StaticResource BoolToVis}}" Padding="5 5 5 5" Margin="5 15 5 0"/>
                                                    </StackPanel>
                                                </DataTemplate>
                                            </ItemsControl.ItemTemplate>
                                        </ItemsControl>

Soweit kann ich "Rechte" Binden und in dem Button auf "Rechte.CanDelFPFoer" zugreifen. Mein Problem ist, ich bekomme für jeden Unterwert einen Button ausgegeben. Sprich statt 1 Button bekomme ich in dem Fall 30. Wie kann ich das auf 1 Button begrenzen? Gibt es eine Alternative zu ItemsControl? Gehe ich die Sache komplett falsch an?

Vielen lieben Dank und Grüße
Sascha

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Gut, dann anders.

Wenn ich die Methode von Th69 richtig verstehe, wird nur der Wert an die URL gehängt, der auch gefüllt ist, richtig?

Ich bekomme auf der anderen Seite dann Schwierigkeiten. Das Script auf dem Server erwartet genau die URL.
Woher soll das Script denn wissen, wenn die Werte in einer ganz anderen Reihenfolge versendet werden?

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Gibt es die Möglichkeit, wenn ich keinen Wert habe, dass dann "-" gesetzt wird?

Auch, wenn es nicht der Ansicht von Abt entspricht, finde ich den Weg ganz gut. So hätte ich keine leeren Felder in der DB und beim auslesen habe ich direkt ein Zeichen in der Liste, das zeigt, dass dort keine Werte vorhanden sind und ergänzt werden müssen.
Denn genau das Zeichen setze ich so oder so als


TargetNullValue=-

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Leider nein. Mir würde ein Default Value wie "-" reichen.

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Du hast recht, die Methode wird immer aufgerufen.

Mein RestAPI Link wird nur nicht korrekt gefüllt. Daher gibt es auch keine Einträge in der Datenbank.

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Vielen lieben Dank Th69!
Soweit klappt alles.
Das Einzige, das mir aufgefallen ist, der Speichert die Daten erst in der Datenbank, wenn man alle Zellen einmal angeklickt hat.
Manche Zellen sollen zwischendurch leer bleiben. Wäre das in der Umsetzung noch möglich? Oder muss ich eher auf CellEditEnding gehen?

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Das hatte ich ursprünglich. Leider bekomme ich beim JSon Objekten Probleme:


var arr = JsonConvert.DeserializeObject<JArray>(restResponse.Content);
                    foreach (JObject obj in arr)
                    {
                        var KompetenzID = (string)obj["id"];
                        var Kompetenz = (string)obj["Kompetenz"];
                        var SHDID = (string)obj["SHDID"];
                        var Ergebnis = (string)obj["Ergebnis"];
                        var Stufe = (string)obj["Stufe"];
                        var Niveau = (string)obj["Niveau"];
                        var Note = (string)obj["Note"];
                        DateTime Datum = (DateTime)obj["Datum"];
                        var Kuerzel = (string)obj["Kuerzel"];
                        var background = (string)obj["background"];

                        _kompetenzen.Add(new LDKompetenz(KompetenzID, Kompetenz, SHDID, Ergebnis, Stufe, Niveau, Note, Datum, Kuerzel, background, name, ViewFingerPrint));
                    }

Ich habe Tabelle 1 mit 20 Daten. In Tabelle 2 habe ich die Nutzerinformationen dazu. Nicht zu jeder Zeile aus Tabelle 1 gibt es Nutzerdaten. Daher kann es passieren, dass DateTime Datum = null ist.
Dann bekomme ich eine Fehlermeldung (siehe Bild).

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Vielen vielen Dank! Mein Verständnis erweitert sich und es funktioniert fast.

Ein einziges Problem habe ich noch. Das Datum gebe ich als String weiter.

Den string ändere ich ab, damit es kein Backslash im string ist


var newdate = Datum.Replace(@"/", "-");

Allerdings lässt er die Uhrzeit. Wie bekomme ich die wohl weg?

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Zitat von T-Virus
Nachträglich noch der Tipp:
Wenn du Strings hardcoden musst, dann macht das über Konstanten.
Literale im Code sind eine sehr unschöne Sache und gehen auch bei einigen Umsetzungen auch in Richtung Magic Strings.

Auch wäre es besser wenn du anstelle von "" als Wert String.Empty verwendest.
Durch "" im Code erzeugst du zusätzliche Literale, was die Laufzeitumgebung zwar abfängt aber durch String.Empty wird eine statische Instanz verwendet und der Code ist auch klarer ausgedrückt.

Auch würde ich empfehlen die Deserialierung des Json umzubauen.
Was du im Grund hast, ist eine Liste von Objekten.
Du kannst hier einfach List<T> als Container verwenden und eine entsprechende Klasse anlegen, die ein einzelnes Objekt der Api abbildet.
Dadurch sparst du dir den Aufwand die Eigenschaften einzeln auslesen und die Liste selbst aufbauen zu müssen.
Kann an der Stelle der Deseralisierer übernehmen.
Spart dir unnötigen Aufwand und Zeit bei der Umsetzung

T-Virus

Ok, danke für die Tipps! Dann werde ich mir mal anschauen wie es mit den Listen funktioniert.

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Ok, das teste ich mal.

Ich benötige noch die Variabel "Name" aus der ViewModel. Das ist eine TextBox aus der View.

Dazu habe ich folgendes in der ViewModel:


        private string _name = "1";
        public string Name
        {
            get
            {
                return _name;
            }
            set
            {
                if (value == "" && value == null)
                    return;
                _name = value;
                LDKompetenzen = LDKompetenzen.Load(LDCurrentFach.FachID, LDCurrentThema.ThemaID, ViewFingerPrint, Name);
                OnPropertyChanged(ref _name, value);
            }
        }

Kann ich es ganz normal mit Name {get set} in der LDKompetenz laden?

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Das ist hier meine Klasse:



class LDKompetenzen : ObservableCollection<LDKompetenz>
    {
        private static readonly LDKompetenzen _kompetenzen = new LDKompetenzen();

        private LDKompetenzen() { }

        public static LDKompetenzen Load(string fachID, string themenID, string ViewFingerPrint, string name)
        {
            _kompetenzen.Clear();
            try
            {
                var client = new RestClient("MEINEDOMAIN");

                var request = new RestRequest("ld/kompetenzen/{fachid}/{themenid}/{SHDID}", Method.GET)
                .AddHeader("Authorization", "Bearer " + ViewFingerPrint)
                .AddUrlSegment("fachid", fachID)
                .AddUrlSegment("SHDID", name)
                .AddUrlSegment("themenid", themenID);

                IRestResponse restResponse = client.Execute(request);
                HttpStatusCode statusCode = restResponse.StatusCode;
                if ((int)statusCode != 401)
                {
                    var arr = JsonConvert.DeserializeObject<JArray>(restResponse.Content);
                    foreach (JObject obj in arr)
                    {
                        var KompetenzID = (string)obj["id"];
                        var Kompetenz = (string)obj["Kompetenz"];
                        var SHDID = (string)obj["SHDID"];
                        var Ergebnis = (string)obj["Ergebnis"];
                        var Stufe = (string)obj["Stufe"];
                        var Niveau = (string)obj["Niveau"];
                        var Note = (string)obj["Note"];
                        var Datum = (string)obj["Datum"];
                        var Kuerzel = (string)obj["Kuerzel"];
                        var background = (string)obj["background"];

                            _kompetenzen.Add(new LDKompetenz(KompetenzID, Kompetenz, SHDID, Ergebnis, Stufe, Niveau, Note, Datum, Kuerzel, background));
                    }
                }
                else
                {
                    var KompetenzID = "0";
                    var Kompetenz = "";
                    var SHDID = "";
                    var Ergebnis = "";
                    var Stufe = "";
                    var Niveau = "";
                    var Note = "";
                    var Datum = "";
                    var Kuerzel = "";
                    var background = "white";

                    _kompetenzen.Add(new LDKompetenz(KompetenzID, Kompetenz, SHDID, Ergebnis, Stufe, Niveau, Note, Datum, Kuerzel, background));
                }
            }
            catch (Exception e)
            {
                MessageBox.Show(e.ToString());
            }
            return _kompetenzen;
        }
    }

Und die greift auf folgende zu:



        public LDKompetenz(string kompetenzID, string kompetenz, string shdID, string ergebnis, string stufe, string niveau, string note, string datum, string kuerzel, string background)
        {
            KompetenzID = kompetenzID;
            Kompetenz = kompetenz;
            SHDID = shdID;
            Ergebnis = ergebnis;
            Stufe = stufe;
            Niveau = niveau;
            Note = note;
            Datum = datum;
            Kuerzel = kuerzel;
            Background = background;
        }

        //Anzeige Fördermaßnahmen
        public string KompetenzID { get; set; }
        public string Kompetenz { get; set; }
        public string SHDID { get; set; }
        public string Ergebnis { get; set; }
        public string Stufe { get; set; }
        public string Niveau { get; set; }
        public string Note { get; set; }
        public string Datum { get; set; }
        public string Kuerzel { get; set; }
        public string Name { get; set; }
        public string Background { get; set; }

        public bool IsSelected { get; set; }

        public override string ToString()
        {
            return $"{Kompetenz}";
        }
    }

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Ok, dann habe ich das falsch verstanden.

Die LDKompetenzen hole ich so in das ViewModel:


public LDKompetenzen LDKompetenzen { get; set; }

So lade ich die "Current" Version:


LDKompetenz _ldcurrentKompetenz = null;
        public LDKompetenz LDCurrentKompetenz
        {
            get { return _ldcurrentKompetenz; }
            set
            {
                if (value == null)
                    return;
                OnPropertyChanged(ref _ldcurrentKompetenz, value);
            }
        }

So lade ich die Daten in die View:


LDKompetenzen = LDKompetenzen.Load(LDCurrentFach.FachID, value.ThemaID, ViewFingerPrint, Name);

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Das ist meine ViewModel.
In deinem Beispiel sowie unzählige andere wurde es dort implementiert.

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Also, folgendes habe ich gemacht:

ViewModel:
Die Klasse erweitert:


class LDViewModel : NotifyPropertyBase, IEditableObject

Anschließend folgendes gefüllt:


    public void EndEdit()
        {
            var client = new RestClient("https://xxxxxxxxde/");
            var request = new RestRequest("ld/LDUpdate/{name}/{kompetenzID/{ergebnis}/{stufe}/{niveau}/{note}/{datum}/{kuerzel}", Method.POST)
                .AddUrlSegment("name", Name)
                .AddUrlSegment("kompetenzID", LDCurrentKompetenz.KompetenzID)
                .AddUrlSegment("ergebnis", LDCurrentKompetenz.Ergebnis)
                .AddUrlSegment("stufe", LDCurrentKompetenz.Stufe)
                .AddUrlSegment("niveau", LDCurrentKompetenz.Niveau)
                .AddUrlSegment("note", LDCurrentKompetenz.Note)
                .AddUrlSegment("datum", LDCurrentKompetenz.Datum)
                .AddUrlSegment("kuerzel", LDCurrentKompetenz.Kuerzel)
                .AddHeader("Authorization", "Bearer " + ViewFingerPrint);

            IRestResponse restResponse = client.Execute(request);

            if (restResponse.StatusCode == HttpStatusCode.BadRequest)
            {
                MessageBox.Show("Irgendetwas stimmt mit der Verbindung nicht.");
            }
            else
            {
                MessageBox.Show("Die Leistungsdokumentation wurde erfolgreich aktualisiert.");
            }
        }

Allerdings reagiert er nicht. Woher weiß er, welches DataGrid gemeint ist?

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Genau, die Klasse ist als ObservableCollection deklariert. In diese Klasse kann ich dann eine weitere Methode mit IEditableObject einfügen?
Es tut mir Leid, es ist Neuland für mich

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Ich weiß nicht was mich da geritten hat.....4.7.2 meine ich.

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Vielen Dank für die Links.
Beim ersten Link: Ich nutze .NET 4,75 (Galasoft geht nur bis 4.5). Daher kann ich keine "Galasoft WPF" hinzufügen.

Link 2: Ich nutze in meiner ViewModel INotifyPropertyChanged.

Funktioniert es, wenn ich eine entsprechende Funktion in die Viewmodel schreibe mit IEditableObject?

Thema: Daten aus DataGrid per RestAPI speichern
Am im Forum: GUI: WPF und XAML

Verwendetes Datenbanksystem: MariaDB
Verwendete API: RestSharp

Hallo zusammen,
erneut habe ich eine Frage.
Aktuell lade ich einige Daten per RestApi in ein DataGrid. Die Anzeige, der darin enthaltenen Daten funktioniert soweit ganz gut.
Jetzt möchte ich die einzelnen Zeilen abändern und automatisch in der Datenbank speichern können.
Das speichern sollte ebenfalls mittels RestSharp funktionieren.

Nur, wie gehe ich da am besten vor? Wie bekomme ich die Inhalt der einzelnen Zeilen eines DataGrid.
Wie speichere ich den geänderten Wert automatisch? Oder geht es nur per Button?

Hier mein Code:


<DataGrid ItemsSource="{Binding LDKompetenzen}" AutoGenerateColumns="False" CanUserDeleteRows="False" CanUserAddRows="False" CanUserSortColumns="True" FontSize="12" Height="Auto" BorderThickness="0">
                <DataGrid.Resources>
                    <Style BasedOn="{StaticResource {x:Type DataGridColumnHeader}}" TargetType="{x:Type DataGridColumnHeader}" >
                        <Setter Property="Background" Value="LightGray" />
                        <Setter Property="Foreground" Value="Black" />
                        <Setter Property="BorderBrush" Value="Black"/>
                        <Setter Property="BorderThickness" Value="1 1 1 1"/>
                        <Setter Property="Margin" Value="-1,-1,0,0" />
                        <Setter Property="Height" Value="28" />
                        <Setter Property="Width" Value="auto"/>
                        <Setter Property="HorizontalContentAlignment" Value="Center"/>
                        <Setter Property="FontWeight" Value="SemiBold"/>
                        <Setter Property="FontStyle" Value="Italic"/>
                        <Setter Property="FontSize" Value="15"/>
                        <Setter Property="Padding" Value="15,0,15,0"/>
                    </Style>
                </DataGrid.Resources>
                <DataGrid.Columns>
                    <DataGridTextColumn Header="Kompetenz" Binding="{Binding Kompetenz}" IsReadOnly="True">
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="{x:Type TextBlock}">
                                <Setter Property="TextBlock.Background" Value="{Binding Background}" />
                                <Setter Property="HorizontalAlignment" Value="Stretch"/>
                                <Setter Property="VerticalAlignment" Value="Stretch"/>
                                <Setter Property="TextAlignment" Value="Center"/>
                                <Setter Property="Padding" Value="0,20,0,0"/>
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>
                    <DataGridTemplateColumn Header="Farben" IsReadOnly="True">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <StackPanel Orientation="Horizontal" VerticalAlignment="Center">
                                    <Button Content="" Background="White" Margin="2" Padding="5,3,5,3"></Button>
                                    <Button Content="" Background="Yellow" Margin="2" Padding="5,3,5,3"></Button>
                                    <Button Content="" Background="LightGreen" Margin="2" Padding="5,3,5,3"></Button>
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
                    <DataGridTextColumn Header="Stufe" Binding="{Binding Stufe, UpdateSourceTrigger=LostFocus, Mode=TwoWay}" >
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="{x:Type TextBlock}">
                                <Setter Property="HorizontalAlignment" Value="Center"/>
                                <Setter Property="VerticalAlignment" Value="Center"/>
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>
                    <DataGridTextColumn Header="Niveau" Binding="{Binding Niveau, UpdateSourceTrigger=LostFocus, Mode=TwoWay}">
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="{x:Type TextBlock}">
                                <Setter Property="HorizontalAlignment" Value="Center"/>
                                <Setter Property="VerticalAlignment" Value="Center"/>
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>
                    <DataGridTextColumn Header="Ergebnis" Binding="{Binding Ergebnis, UpdateSourceTrigger=LostFocus, Mode=TwoWay}">
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="{x:Type TextBlock}">
                                <Setter Property="HorizontalAlignment" Value="Center"/>
                                <Setter Property="VerticalAlignment" Value="Center"/>
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>
                    <DataGridTextColumn Header="Note" Binding="{Binding Note, UpdateSourceTrigger=LostFocus, Mode=TwoWay}">
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="{x:Type TextBlock}">
                                <Setter Property="HorizontalAlignment" Value="Center"/>
                                <Setter Property="VerticalAlignment" Value="Center"/>
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>
                    <DataGridTemplateColumn Header="Datum">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <DatePicker SelectedDate="{Binding Datum, UpdateSourceTrigger=LostFocus, Mode=TwoWay}" BorderThickness="0" VerticalAlignment="Center" HorizontalAlignment="Center"/>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
                    <DataGridTextColumn Header="Kürzel" Binding="{Binding Kuerzel, UpdateSourceTrigger=LostFocus, Mode=TwoWay}">
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="{x:Type TextBlock}">
                                <Setter Property="HorizontalAlignment" Value="Center"/>
                                <Setter Property="VerticalAlignment" Value="Center"/>
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>
                </DataGrid.Columns>
            </DataGrid>


Ich bin für einige Gedankenansetze von euch sehr Dankbar!

Grüße
Sascha

Thema: RestAPI oder vergleichbares
Am im Forum: Datentechnologien

Es ging mir nur im meinen letzten Post und nicht um den kompletten Thread. Ich hatte ursprünglich eine Frage gestellt die sich erledigt hat.

Thema: RestAPI oder vergleichbares
Am im Forum: Datentechnologien


Es hat sich erledigt. Post bitte löschen.

Thema: RestAPI oder vergleichbares
Am im Forum: Datentechnologien

Vielen Dank für die vielen Tipps! Ich werde mir das ganze anschauen und mein Script entsprechend anpassen.

Ich bin aktuell bei der Authentifizierung und Autorisierung.

In C# nutze ich RestSharp.

Mit:


var client = new RestClient("http://example.com");
client.Authenticator = new SimpleAuthenticator("username", "foo", "password", "bar");

var request = new RestRequest("resource", Method.GET);
client.Execute(request);

schicke ich die Anfrage an den Server und bekommen die Info, ob die Anmeldedaten passen, zurück. Soweit verständlich.

Auf der anderen Seite nutze ich Lumen (Laravel). Dort muss ich die Daten annehmen und prüfen. Es gibt grundsätzlich bei mir keine Useraccounts. Soll ich extra eine Tabelle anlegen und mit dieser vergleichen? Macht das Sinn?

Wenn ich in RestSharp den Benutzername und das Passwort einfüge, kann das Programm nicht dennoch "ausgelesen" werden und die Zugangsdaten sind offen?

Über hilfreiche Tipps wäre ich sehr Dankbar!
Liebe Grüße und einen schönen Sonntag noch!
Sascha

Thema: RestAPI oder vergleichbares
Am im Forum: Datentechnologien

Das war der passende Tipp, vielen lieben Dank!

Thema: RestAPI oder vergleichbares
Am im Forum: Datentechnologien

Vielen Dank für deine Tipp!
Die Authentifizierung kommt später. Als Anfänger baue ich eins nach dem anderen aus. Es muss für mich erst die Grundfunktion klappen bevor ich es "zubaue".
Ich weiß, eine seltsame Herangehensweise, aber so lerne ich am besten.

Ich habe jetzt, mittels json_encode die Daten umgewandelt.


[url]https://api.heinrich-luebke-schule.de/api/faecher[/url]

Leider kommt der gleiche Fehler.

Wie genau prüfst du, ob die Daten als json zurück geliefert werden?

Liebe Grüße
Sascha