ant-design-blazor/components/progress/Progress.razor

144 lines
6.6 KiB
C#
Raw Normal View History

@namespace AntDesign
@inherits AntDomComponentBase
feat(module: overlay): OverlayTrigger not bound to a div (#937) * feat(module:overlay): OverlayTrigger not bound to a div * feat(module:overlay): OverlayTrigger not bound to a div * feat(module:overlay): Logic transfer to single Overlay * feat(module:overlay): remove obsolete duplication * feat(module:Tooltip): Add for unbounded oncontextmenu event handler * feat(module:tooltip): unbound js event listeners remove * docs(module:tooltip): unbound explanation * fix(module:button): attach Ref to top level html element @ref * feat(module:dropdown&tooltip&popconfirm&popover): Overlay not bound to a div * docs(module:dropdown&tooltip&popconfirm&popover): unbound explanation * feat(module:OverlayTrigger): common logic relocation * feat(module:overlaytrigger): Overlay not bound to a div * feat(module:DatePicker): Overlay not bound to a div * feat(module:select): Overlay not boud to div * fix(module:select): onclickarrow event relocation * fix(module:select): rename Show to OnArrowClick * feat(module:avatar): Overlay not bound to a div * docs(module:avatar): demo switch to unbound version * feat(module:autocomplete): partial OverlayTrigger not bound to a div * feat(module:slider): tooltip * docs(module:slider): tooltip * fix(module:overlay): add SetVisible method * feat: set Ref where missing, performance components register Ref when missing IsFixed flag for CascadeValue changed hard-code sequence numbers when using RenderTreeBuilder Rate component use Tooltip Unbound version Tabs test fix * fix: revert changes (accidental) * feat(module:upload): tooltip with unbound usage * feat(module:table): column use of unbound tooltip * feat(module:autocomplete):overlay unbound from div * fix(module:upload): missing div restore Co-authored-by: James Yeung <shunjiey@hotmail.com>
2021-01-21 17:20:10 +08:00
<div class="@ClassMapper.Class" style="@Style" id="@Id" @ref="Ref">
@if (Type == ProgressType.Line)
{
@if (Steps == 0)
{
<div class="ant-progress-outer">
<div class="ant-progress-inner">
<div class="ant-progress-bg" style="@_bgStyle">
</div>
@if (SuccessPercent != 0)
{
<div class="ant-progress-success-bg" style="@_bgSuccessStyle">
</div>
}
</div>
</div>
}
else
{
<div class="ant-progress-steps-outer">
@for (int i = 0; i < Steps; i++)
{
int index = i;
if (Percent >= 100 / Steps * (index + 1))
{
<div class="ant-progress-steps-item" style="width: @(Size == ProgressSize.Default?"14":"2")px; height: 8px; background-color: @(ToRGB(StrokeColor.AsT0));"></div>
}
else
{
<div class="ant-progress-steps-item" style="width: @(Size == ProgressSize.Default?"14":"2")px; height: 8px;"></div>
}
}
@if (Status == ProgressStatus.Success)
{
<span class="ant-progress-text">
<Icon Type="check-circle" Theme="@IconThemeType.Fill" />
</span>
}
else if (Status == ProgressStatus.Exception)
{
<span class="ant-progress-text">
<Icon Type="close-circle" Theme="@IconThemeType.Fill" />
</span>
}
else
{
<span title="@Format(Percent)" class="ant-progress-text">@Format(Percent)</span>
}
</div>
}
}
else if (Type == ProgressType.Circle)
{
<div class="@(StrokeColor.IsT1?"ant-progress-inner ant-progress-circle-gradient": "ant-progress-inner")" style="@_bgStyle">
<svg xmlns="http://www.w3.org/2000/svg" class="ant-progress-circle" viewBox="0 0 100 100">
@if (StrokeColor.IsT1)
{
<defs>
<linearGradient id="ant-progress-gradient-@Id" x1="100%" y1="0%" x2="0%" y2="0%">
@foreach (var pair in StrokeColor.AsT1)
{
<stop stop-color="@ToRGB(pair.Value)" offset="@(pair.Key)" />
}
</linearGradient>
</defs>
}
<path class="ant-progress-circle-trail" style="@_circleTrailStyle" fill-opacity="0" stroke="@TrailColor" stroke-linecap="@StrokeLinecap.Name" stroke-width="@StrokeWidth" d="M 50 50 m 0 -47 a 47 47 0 1 1 0 94 a 47 47 0 1 1 0 -94" />
@if (SuccessPercent != 0)
{
<path class="ant-progress-circle-path" style="@_circleSuccessStyle" opacity="1" fill-opacity="0" stroke="" stroke-linecap="@StrokeLinecap.Name" stroke-width="@StrokeWidth" d="M 50 50 m 0 -47 a 47 47 0 1 1 0 94 a 47 47 0 1 1 0 -94" />
}
<path class="ant-progress-circle-path" style="@_circlePathStyle" opacity="1" fill-opacity="0" stroke="@(StrokeColor.IsT1?$"url(#ant-progress-gradient-{Id})":StrokeColor.AsT0)" stroke-linecap="@StrokeLinecap.Name" stroke-width="@StrokeWidth" d="M 50 50 m 0 -47 a 47 47 0 1 1 0 94 a 47 47 0 1 1 0 -94" />
</svg>
@if (Status == ProgressStatus.Success && !_format)
{
<span class="ant-progress-text">
<Icon Type="check-circle" Theme="@IconThemeType.Fill" />
</span>
}
else if (Status == ProgressStatus.Exception && !_format)
{
<span class="ant-progress-text">
<Icon Type="close-circle" Theme="@IconThemeType.Fill" />
</span>
}
else
{
<span title="@Format(Percent)" class="ant-progress-text">@Format(Percent)</span>
}
</div>
}
else
{
<div class="ant-progress-inner" style="width: @(Width)px; height: @(Width)px; font-size: 24px;">
<svg xmlns="http://www.w3.org/2000/svg" class="ant-progress-circle" viewBox="0 0 100 100">
<path class="ant-progress-circle-trail" style="@_circleTrailStyle" fill-opacity="0" stroke="@TrailColor" stroke-linecap="@StrokeLinecap.Name" stroke-width="@StrokeWidth" d="M 50 50 m 0 47 a 47 47 0 1 1 0 -94 a 47 47 0 1 1 0 94" />
@if (SuccessPercent != 0)
{
<path class="ant-progress-circle-path" style="@_circleSuccessStyle" opacity="1" fill-opacity="0" stroke="" stroke-linecap="@StrokeLinecap.Name" stroke-width="@StrokeWidth" d="M 50 50 m 0 47 a 47 47 0 1 1 0 -94 a 47 47 0 1 1 0 94" />
}
<path class="ant-progress-circle-path" style="@_circlePathStyle" opacity="1" fill-opacity="0" stroke="" stroke-linecap="@StrokeLinecap.Name" stroke-width="@StrokeWidth" d="M 50 50 m 0 47 a 47 47 0 1 1 0 -94 a 47 47 0 1 1 0 94" />
</svg>
@if (Status == ProgressStatus.Success && !_format)
{
<span class="ant-progress-text">
<Icon Type="check-circle" Theme="@IconThemeType.Fill" />
</span>
}
else if (Status == ProgressStatus.Exception && !_format)
{
<span class="ant-progress-text">
<Icon Type="close-circle" Theme="@IconThemeType.Fill" />
</span>
}
else
{
<span title="@Format(Percent)" class="ant-progress-text">@Format(Percent)</span>
}
</div>
}
@if (ShowInfo && Type == ProgressType.Line && Steps == 0)
{
if (Status == ProgressStatus.Success)
{
<span class="ant-progress-text">
<Icon Type="check-circle" Theme="@IconThemeType.Fill" />
</span>
}
else if (Status == ProgressStatus.Exception)
{
<span class="ant-progress-text">
<Icon Type="close-circle" Theme="@IconThemeType.Fill" />
</span>
}
else
{
<span title="@Format(Percent)" class="ant-progress-text">@Format(Percent)</span>
}
}
</div>