Merge branch 'main' of https://git.azuze.fr/kawa/SharepointToolbox-Web
This commit is contained in:
@@ -5,60 +5,61 @@
|
||||
@inject ISessionManager SessionMgr
|
||||
@inject IElevationCoordinator Elevation
|
||||
@inject IFileTransferService TransferSvc
|
||||
@inject TranslationSource T
|
||||
@rendermode InteractiveServer
|
||||
|
||||
<h1 class="page-title">File Transfer</h1>
|
||||
<h1 class="page-title">@T["transfer.page.title"]</h1>
|
||||
|
||||
@if (!Session.HasProfile) { <NoProfilePrompt /> return; }
|
||||
@if (UserContext.Role < UserRole.TechN1) { <WriteGuard /> return; }
|
||||
|
||||
<div class="card">
|
||||
<div class="card-title">Source</div>
|
||||
<div class="card-title">@T["transfer.source"]</div>
|
||||
<SitePicker Profile="Session.CurrentProfile!" @bind-SelectedSites="_srcSites" Single="true" />
|
||||
<div class="form-row mt-8">
|
||||
<LibraryPicker Profile="Session.CurrentProfile!" SiteUrl="@(_srcSites.FirstOrDefault()?.Url)" @bind-Library="_srcLibrary" Label="Source Library" />
|
||||
<LibraryPicker Profile="Session.CurrentProfile!" SiteUrl="@(_srcSites.FirstOrDefault()?.Url)" @bind-Library="_srcLibrary" Label="@T["transfer.sourcelibrary"]" />
|
||||
<div class="form-group">
|
||||
<label class="form-label">Source Folder (optional)</label>
|
||||
<input class="form-input" @bind="_srcFolder" placeholder="SubFolder/Path" />
|
||||
<label class="form-label">@T["transfer.sourcefolder.optional"]</label>
|
||||
<input class="form-input" @bind="_srcFolder" placeholder="@T["transfer.sourcefolder.placeholder"]" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="card">
|
||||
<div class="card-title">Destination</div>
|
||||
<div class="card-title">@T["transfer.destination"]</div>
|
||||
<SitePicker Profile="Session.CurrentProfile!" @bind-SelectedSites="_dstSites" Single="true" />
|
||||
<div class="form-row mt-8">
|
||||
<LibraryPicker Profile="Session.CurrentProfile!" SiteUrl="@(_dstSites.FirstOrDefault()?.Url)" @bind-Library="_dstLibrary" Label="Destination Library" />
|
||||
<LibraryPicker Profile="Session.CurrentProfile!" SiteUrl="@(_dstSites.FirstOrDefault()?.Url)" @bind-Library="_dstLibrary" Label="@T["transfer.destlibrary"]" />
|
||||
<div class="form-group">
|
||||
<label class="form-label">Destination Folder (optional)</label>
|
||||
<label class="form-label">@T["transfer.destfolder.optional"]</label>
|
||||
<input class="form-input" @bind="_dstFolder" />
|
||||
</div>
|
||||
</div>
|
||||
<div class="form-row">
|
||||
<div class="form-group">
|
||||
<label class="form-label">Transfer Mode</label>
|
||||
<label class="form-label">@T["transfer.mode"]</label>
|
||||
<select class="form-select" @bind="_mode" style="width:100px">
|
||||
<option value="Copy">Copy</option>
|
||||
<option value="Move">Move</option>
|
||||
<option value="Copy">@T["transfer.mode.copy"]</option>
|
||||
<option value="Move">@T["transfer.mode.move"]</option>
|
||||
</select>
|
||||
</div>
|
||||
<div class="form-group">
|
||||
<label class="form-label">Conflict Policy</label>
|
||||
<label class="form-label">@T["transfer.conflict"]</label>
|
||||
<select class="form-select" @bind="_conflict" style="width:120px">
|
||||
<option value="Skip">Skip</option>
|
||||
<option value="Overwrite">Overwrite</option>
|
||||
<option value="Rename">Rename</option>
|
||||
<option value="Skip">@T["transfer.conflict.skip"]</option>
|
||||
<option value="Overwrite">@T["transfer.conflict.overwrite"]</option>
|
||||
<option value="Rename">@T["transfer.conflict.rename.short"]</option>
|
||||
</select>
|
||||
</div>
|
||||
<div class="form-group" style="display:flex;align-items:center;padding-top:20px">
|
||||
<label><input type="checkbox" @bind="_includeSourceFolder" /> Include source folder</label>
|
||||
<label><input type="checkbox" @bind="_includeSourceFolder" /> @T["transfer.chk.include_source_short"]</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="flex-row mt-8">
|
||||
<button class="btn btn-primary" @onclick="RunTransfer" disabled="@_running">
|
||||
@(_running ? "Transferring…" : "Start Transfer")
|
||||
@(_running ? T["transfer.transferring"] : T["transfer.start"])
|
||||
</button>
|
||||
@if (_running) { <button class="btn btn-secondary" @onclick="Cancel">Cancel</button> }
|
||||
@if (_running) { <button class="btn btn-secondary" @onclick="Cancel">@T["btn.cancel"]</button> }
|
||||
</div>
|
||||
<ProgressPanel IsRunning="_running" StatusMessage="@_status" Current="_current" Total="_total" />
|
||||
</div>
|
||||
@@ -69,14 +70,14 @@
|
||||
{
|
||||
<div class="card">
|
||||
<div class="alert @(_summary.HasFailures ? "alert-warn" : "alert-success")">
|
||||
Transferred: @_summary.SuccessCount / @_summary.TotalCount files.
|
||||
@if (_summary.HasFailures) { <span>Failures: @_summary.FailedCount</span> }
|
||||
@string.Format(T["transfer.result.transferred"], _summary.SuccessCount, _summary.TotalCount)
|
||||
@if (_summary.HasFailures) { <span>@string.Format(T["transfer.result.failures"], _summary.FailedCount)</span> }
|
||||
</div>
|
||||
@if (_summary.HasFailures)
|
||||
{
|
||||
<div class="data-table-wrap mt-8">
|
||||
<table class="data-table">
|
||||
<thead><tr><th>File</th><th>Error</th></tr></thead>
|
||||
<thead><tr><th>@T["versions.col.file"]</th><th>@T["report.col.error"]</th></tr></thead>
|
||||
<tbody>
|
||||
@foreach (var f in _summary.FailedItems)
|
||||
{
|
||||
@@ -109,8 +110,8 @@
|
||||
{
|
||||
var srcUrl = _srcSites.FirstOrDefault()?.Url;
|
||||
var dstUrl = _dstSites.FirstOrDefault()?.Url;
|
||||
if (string.IsNullOrWhiteSpace(srcUrl)) { _error = "Please select a source site."; return; }
|
||||
if (string.IsNullOrWhiteSpace(dstUrl)) { _error = "Please select a destination site."; return; }
|
||||
if (string.IsNullOrWhiteSpace(srcUrl)) { _error = T["transfer.err.no_source_site"]; return; }
|
||||
if (string.IsNullOrWhiteSpace(dstUrl)) { _error = T["transfer.err.no_dest_site"]; return; }
|
||||
var job = new TransferJob
|
||||
{
|
||||
SourceSiteUrl = srcUrl, SourceLibrary = _srcLibrary, SourceFolderPath = _srcFolder,
|
||||
@@ -126,9 +127,9 @@
|
||||
var dstCtx = await SessionMgr.GetOrCreateContextAsync(dstUrl, Session.CurrentProfile!, c);
|
||||
return await TransferSvc.TransferAsync(srcCtx, dstCtx, job, progress, c);
|
||||
}, _cts.Token);
|
||||
_status = $"Complete: {_summary.SuccessCount} transferred.";
|
||||
_status = string.Format(T["transfer.status.complete"], _summary.SuccessCount);
|
||||
}
|
||||
catch (OperationCanceledException) { _status = "Cancelled."; }
|
||||
catch (OperationCanceledException) { _status = T["transfer.status.cancelled"]; }
|
||||
catch (Exception ex) { _error = ex.Message; }
|
||||
finally { _running = false; await InvokeAsync(StateHasChanged); }
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user