using System; using System.Data.SqlClient; using System.Windows; using System.Windows.Controls; using System.Windows.Input; using System.Windows.Media; using UI.Database; namespace UI.Configuracao { public partial class ConfiguracaoBanco : Window { // ── Estado do mostrar/ocultar senha ────────────────────────── private bool _senhaVisivel = false; private const string IconeOlhoAberto = "M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 " + "11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 " + "5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 " + "3-1.34 3-3-1.34-3-3-3z"; private const string IconeOlhoFechado = "M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 " + "2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 " + "2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 " + "10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 " + "22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 " + "1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 " + "0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z"; public ConfiguracaoBanco() { InitializeComponent(); CarregarConfiguracoes(); AtualizarCamposAutenticacao(); } // ── Arrastar janela ───────────────────────────────────────── private void Window_MouseDown(object sender, MouseButtonEventArgs e) { if (e.LeftButton == MouseButtonState.Pressed) DragMove(); } // ── Fechar janela ──────────────────────────────────────────── private void BtnFechar_Click(object sender, RoutedEventArgs e) { this.Close(); } // ── Mostrar/ocultar senha ──────────────────────────────────── private void BtnVerSenha_Click(object sender, RoutedEventArgs e) { _senhaVisivel = !_senhaVisivel; if (_senhaVisivel) { TxtSenhaVisivel.Text = PboxSenha.Password; PboxSenha.Visibility = Visibility.Collapsed; TxtSenhaVisivel.Visibility = Visibility.Visible; TxtSenhaVisivel.Focus(); TxtSenhaVisivel.CaretIndex = TxtSenhaVisivel.Text.Length; IconeOlho.Data = Geometry.Parse(IconeOlhoFechado); IconeOlho.Fill = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#3B82F6")); } else { PboxSenha.Password = TxtSenhaVisivel.Text; TxtSenhaVisivel.Visibility = Visibility.Collapsed; PboxSenha.Visibility = Visibility.Visible; PboxSenha.Focus(); IconeOlho.Data = Geometry.Parse(IconeOlhoAberto); IconeOlho.Fill = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#4A6FA5")); } } // ── Carrega configurações salvas ao abrir a janela ─────────── private void CarregarConfiguracoes() { DBConfig config = ConfiguracaoService.Carregar(); TxtServidor.Text = config.Servidor; TxtBancoDados.Text = config.Banco; TxtUsuario.Text = config.Usuario; PboxSenha.Password = config.Senha; ToggleAutenticacao.IsChecked = config.Integrada; foreach (ComboBoxItem item in CmbSgbd.Items) { if (item.Content?.ToString() == config.Sgbd) { CmbSgbd.SelectedItem = item; break; } } foreach (ComboBoxItem item in CmbProvedor.Items) { if (item.Content?.ToString() == config.Provedor) { CmbProvedor.SelectedItem = item; break; } } } // ── Atualiza provedor ao trocar o SGBD ─────────────────────── private void CmbSgbd_SelectionChanged(object sender, SelectionChangedEventArgs e) { if (CmbProvedor == null) return; string sgbd = (CmbSgbd.SelectedItem as ComboBoxItem)?.Content?.ToString() ?? ""; switch (sgbd) { case "SQL Server": CmbProvedor.SelectedIndex = 0; if (TxtProvedorInfo != null) TxtProvedorInfo.Text = "System.Data.SqlClient"; break; case "MySQL": CmbProvedor.SelectedIndex = 2; if (TxtProvedorInfo != null) TxtProvedorInfo.Text = "MySql.Data.MySqlClient"; break; case "PostgreSQL": CmbProvedor.SelectedIndex = 3; if (TxtProvedorInfo != null) TxtProvedorInfo.Text = "Npgsql"; break; case "SQLite": CmbProvedor.SelectedIndex = 4; if (TxtProvedorInfo != null) TxtProvedorInfo.Text = "System.Data.SQLite"; break; default: CmbProvedor.SelectedIndex = 0; break; } } // ── Toggle autenticação integrada ──────────────────────────── private void ToggleAutenticacao_Changed(object sender, RoutedEventArgs e) { AtualizarCamposAutenticacao(); } private void AtualizarCamposAutenticacao() { bool integrada = ToggleAutenticacao.IsChecked == true; if (TxtUsuario != null) { TxtUsuario.IsEnabled = !integrada; TxtUsuario.Opacity = integrada ? 0.4 : 1.0; } if (PboxSenha != null) { PboxSenha.IsEnabled = !integrada; PboxSenha.Opacity = integrada ? 0.4 : 1.0; } // Sincroniza o TxtSenhaVisivel junto com o PboxSenha if (TxtSenhaVisivel != null) { TxtSenhaVisivel.IsEnabled = !integrada; TxtSenhaVisivel.Opacity = integrada ? 0.4 : 1.0; } } // ── Testar conexão ─────────────────────────────────────────── private void BtnTestarConexao_Click(object sender, RoutedEventArgs e) { string servidor = TxtServidor.Text.Trim(); string banco = TxtBancoDados.Text.Trim(); string usuario = TxtUsuario.Text.Trim(); string senha = _senhaVisivel ? TxtSenhaVisivel.Text : PboxSenha.Password; bool integrada = ToggleAutenticacao.IsChecked == true; if (string.IsNullOrWhiteSpace(servidor) || string.IsNullOrWhiteSpace(banco)) { MostrarResultado(false, "Preencha o servidor e o banco de dados."); return; } try { string connStr = integrada ? $"Server={servidor};Database={banco};Integrated Security=True;TrustServerCertificate=True;" : $"Server={servidor};Database={banco};User Id={usuario};Password={senha};TrustServerCertificate=True;"; using (var conn = new SqlConnection(connStr)) { conn.Open(); MostrarResultado(true, "Conexão bem-sucedida!"); DadosConexao.Servidor = servidor; DadosConexao.Banco = banco; DadosConexao.Usuario = usuario; DadosConexao.Senha = senha; } } catch (Exception ex) { MostrarResultado(false, $"Falha: {ex.Message}"); } } private void MostrarResultado(bool sucesso, string mensagem) { PanelResultado.Visibility = Visibility.Visible; TxtResultado.Text = mensagem; var cor = sucesso ? "#22C55E" : "#EF4444"; TxtResultado.Foreground = new SolidColorBrush((Color)ColorConverter.ConvertFromString(cor)); EllipseResultado.Fill = new SolidColorBrush((Color)ColorConverter.ConvertFromString(cor)); } // ── Salvar configurações ───────────────────────────────────── private void BtnSalvar_Click(object sender, RoutedEventArgs e) { if (string.IsNullOrWhiteSpace(TxtServidor.Text) || string.IsNullOrWhiteSpace(TxtBancoDados.Text)) { MessageBox.Show("Preencha o servidor e o nome do banco.", "Atenção", MessageBoxButton.OK, MessageBoxImage.Warning); return; } // Garante a senha correta independente de qual controle está visível string senha = _senhaVisivel ? TxtSenhaVisivel.Text : PboxSenha.Password; var config = new DBConfig { Servidor = TxtServidor.Text.Trim(), Banco = TxtBancoDados.Text.Trim(), Usuario = TxtUsuario.Text.Trim(), Senha = senha, Integrada = ToggleAutenticacao.IsChecked == true, Sgbd = (CmbSgbd.SelectedItem as ComboBoxItem)?.Content?.ToString() ?? "SQL Server", Provedor = (CmbProvedor.SelectedItem as ComboBoxItem)?.Content?.ToString() ?? "System.Data.SqlClient" }; ConfiguracaoService.Salvar(config); MessageBox.Show("Configurações salvas com sucesso!", "Salvo", MessageBoxButton.OK, MessageBoxImage.Information); this.Close(); } } }