feat: Aggiunto sistema completo di gestione profili per Data Coupler

- Creata nuova libreria Components con componenti Blazor riutilizzabili
  * ProfileSelector: dropdown per selezione profili salvati
  * ProfileSaver: componente per salvare configurazioni correnti come profili
  * ProfileManagement: modale per gestione profili salvati
  * ProfileQuickActions: bottoni azioni rapide per operazioni sui profili

- Esteso CredentialManager con entità e servizi per DataCouplerProfile
  * Aggiunto modello DataCouplerProfile con configurazioni mapping e metadati
  * Implementata migrazione Entity Framework per memorizzazione profili
  * Creato DataCouplerProfileService per operazioni CRUD
  * Aggiunto CredentialDbContextFactory per operazioni database design-time

- Migliorato componente principale DataCoupler con integrazione profili
  * Integrata funzionalità caricamento/salvataggio profili
  * Aggiunto selettore profili nella parte superiore dell'interfaccia
  * Mantenuta retrocompatibilità con funzionalità esistenti
  * Migliorata esperienza utente con gestione configurazioni salvate

- Aggiornata struttura progetto e dipendenze
  * Aggiunto progetto Components alla soluzione
  * Aggiornati riferimenti progetti e import
  * Rimosso progetto obsoleto TestDatabaseFix

Questo aggiornamento migliora significativamente il flusso di lavoro permettendo agli utenti di salvare, caricare e gestire configurazioni complete di accoppiamento dati come
This commit is contained in:
2025-07-02 00:00:05 +02:00
parent 1435c013d3
commit 7e450a358b
34 changed files with 2430 additions and 422 deletions
+115
View File
@@ -0,0 +1,115 @@
@* Componente per salvare la configurazione corrente come profilo *@
<div class="card mb-3">
<div class="card-header bg-success text-white">
<h6 class="mb-0">
<i class="fas fa-save"></i> Salva Configurazione Corrente
</h6>
</div>
<div class="card-body">
@if (!ShowSaveForm)
{
<button type="button" class="btn btn-success" @onclick="ShowSaveDialog" disabled="@(!CanSave)">
<i class="fas fa-plus"></i> Salva come Nuovo Profilo
</button>
@if (!CanSave)
{
<small class="text-muted d-block mt-1">
<i class="fas fa-info-circle"></i>
Configura fonte e destinazione per abilitare il salvataggio
</small>
}
}
else
{
<EditForm Model="ProfileData" OnValidSubmit="SaveProfile">
<DataAnnotationsValidator />
<div class="row">
<div class="col-md-6">
<div class="mb-3">
<label class="form-label">Nome Profilo <span class="text-danger">*</span></label>
<InputText @bind-Value="ProfileData.Name" class="form-control"
placeholder="Es: Export Clienti a CRM" />
<ValidationMessage For="@(() => ProfileData.Name)" />
</div>
</div>
<div class="col-md-6">
<div class="mb-3">
<label class="form-label">Descrizione</label>
<InputText @bind-Value="ProfileData.Description" class="form-control"
placeholder="Descrizione opzionale del profilo" />
</div>
</div>
</div>
@if (!string.IsNullOrEmpty(SaveMessage))
{
<div class="alert alert-@(SaveMessageType) mb-3">
<i class="fas fa-@(SaveMessageType == "success" ? "check-circle" : "exclamation-triangle")"></i>
@SaveMessage
</div>
}
<!-- Anteprima Configurazione -->
<div class="mb-3">
<label class="form-label">Configurazione da salvare:</label>
<div class="bg-light p-3 rounded small">
<div class="row">
<div class="col-md-6">
<strong>Fonte:</strong> @GetSourceSummary()<br />
@if (!string.IsNullOrEmpty(SourceSchema))
{
<span class="text-muted">Schema: @SourceSchema</span><br />
}
@if (!string.IsNullOrEmpty(SourceTable))
{
<span class="text-muted">Tabella: @SourceTable</span>
}
</div>
<div class="col-md-6">
<strong>Destinazione:</strong> @GetDestinationSummary()<br />
@if (!string.IsNullOrEmpty(DestinationSchema))
{
<span class="text-muted">Schema: @DestinationSchema</span><br />
}
@if (!string.IsNullOrEmpty(DestinationTable))
{
<span class="text-muted">Tabella: @DestinationTable</span>
}
@if (!string.IsNullOrEmpty(DestinationEndpoint))
{
<span class="text-muted">Endpoint: @DestinationEndpoint</span>
}
</div>
</div>
@if (FieldMappings != null && FieldMappings.Any())
{
<hr class="my-2" />
<small class="text-muted">
<i class="fas fa-exchange-alt"></i>
@FieldMappings.Count mapping dei campi configurati
</small>
}
</div>
</div>
<div class="text-end">
<button type="button" class="btn btn-secondary me-2" @onclick="CancelSave">
<i class="fas fa-times"></i> Annulla
</button>
<button type="submit" class="btn btn-success" disabled="@IsSaving">
@if (IsSaving)
{
<span class="spinner-border spinner-border-sm" role="status"></span>
}
else
{
<i class="fas fa-save"></i>
}
Salva Profilo
</button>
</div>
</EditForm>
}
</div>
</div>