Toolbar.razor 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. @using FastReport.Web.Toolbar
  2. <div class="fr-toolbar fr-@WebReport.ID-toolbar">
  3. @if (WebReport.Toolbar.ShowRefreshButton && !WebReport.Report.IsLoadPrepared)
  4. {
  5. <div class="fr-toolbar-item fr-toolbar-pointer fr-@WebReport.ID-toolbar-item fr-webreport-pointer" @onclick="Reload" title="@Localization.reloadTxt">
  6. <img src="_content/FastReport.Web/Resources/reload.svg" />
  7. </div>
  8. }
  9. @if (WebReport.Toolbar.Exports.Show)
  10. {
  11. <ExportsMenu WebReport="WebReport" OpenModalDialog="OpenModalDialog" />
  12. }
  13. @if (WebReport.Toolbar.ShowPrint)
  14. {
  15. <div class="fr-toolbar-item fr-@WebReport.ID-toolbar-item" title="@Localization.printTxt">
  16. <img src="_content/FastReport.Web/Resources/print.svg" />
  17. <div class="fr-toolbar-dropdown-content fr-@WebReport.ID-toolbar-dropdown-content">
  18. @if (WebReport.Toolbar.PrintInHtml)
  19. {
  20. <a target="_blank" @onclick="async () => await PrintReportAsync(PrintTypes.HTML)">@Localization.printFromBrowserTxt</a>
  21. }
  22. @if (WebReport.Toolbar.PrintInPdf)
  23. {
  24. <a target="_blank" @onclick="async () => await PrintReportAsync(PrintTypes.PDF)">@Localization.printFromPdf</a>
  25. }
  26. </div>
  27. </div>
  28. }
  29. @if (WebReport.Toolbar.ShowZoomButton)
  30. {
  31. <div class="fr-toolbar-item fr-@WebReport.ID-toolbar-item">
  32. <img src="_content/FastReport.Web/Resources/magnifier.svg" title="@Localization.zoomTxt" />
  33. <div class="fr-toolbar-dropdown-content fr-@WebReport.ID-toolbar-dropdown-content">
  34. @foreach (int zoom in zoomList)
  35. {
  36. @if (currentZoom != zoom)
  37. {
  38. <a @onclick="@(() => Zoom(zoom))">
  39. @zoom%
  40. </a>
  41. }
  42. @if (currentZoom == zoom)
  43. {
  44. <a @onclick="@(() => Zoom(zoom))" class="fr-webreport-zoom-selected">
  45. @zoom%
  46. </a>
  47. }
  48. }
  49. </div>
  50. </div>
  51. }
  52. @*@if (currentZoom != zoom)
  53. {
  54. <a @onclick="@(() => Zoom(zoom))" @zoom%></a>
  55. }
  56. @if (currentZoom == zoom)
  57. {
  58. <a class="fr-webreport-zoom-selected">@zoom%</a>
  59. }*@
  60. <div class="fr-toolbar-item fr-toolbar-narrow fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-narrow @(isFirstPage ? $"fr-webreport-toolbar-notbutton fr-webreport-disabled": $"fr-webreport-pointer" )"
  61. @onclick="GotoFirst"
  62. Title="@Localization.firstPageTxt">
  63. <img src="_content/FastReport.Web/Resources/angle-double-left.svg" />
  64. </div>
  65. <div class="fr-toolbar-item fr-toolbar-narrow fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-narrow @(isFirstPage ? $"fr-webreport-toolbar-notbutton fr-webreport-disabled": $"fr-webreport-pointer" )"
  66. @onclick="GotoPrevious"
  67. Title="@Localization.previousPageTxt">
  68. <img src="_content/FastReport.Web/Resources/angle-left.svg" />
  69. </div>
  70. <div class="fr-toolbar-item fr-toolbar-notbutton fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-notbutton @(isSinglePage ? "fr-webreport-disabled" : "")" style="margin-right: 2px;">
  71. <input class="fr-@WebReport.ID-current-page-input"
  72. type="text"
  73. @bind="InputValue"
  74. readonly="@isSinglePage"
  75. title="@Localization.currentPageTxt" />
  76. </div>
  77. <div class="fr-toolbar-item fr-toolbar-notbutton fr-toolbar-slash fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-notbutton fr-@WebReport.ID-toolbar-slash @(isSinglePage ? "fr-webreport-disabled" : "")" style="margin: 0;">
  78. <img src="_content/FastReport.Web/Resources/slash.svg" />
  79. </div>
  80. <div class="fr-toolbar-item fr-toolbar-notbutton fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-notbutton @(isSinglePage ? "fr-webreport-disabled" : "")" style="margin-left: 2px;">
  81. <input type="text" value="@WebReport.TotalPages" readonly="readonly" title="@Localization.totalPagesTxt" />
  82. </div>
  83. <div class="fr-toolbar-item fr-toolbar-narrow fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-narrow @(isLastPage ? $"fr-webreport-toolbar-notbutton fr-webreport-disabled" : $"fr-webreport-pointer")"
  84. @onclick="GotoNext"
  85. title="@Localization.nextPageTxt">
  86. <img src="_content/FastReport.Web/Resources/angle-right.svg" />
  87. </div>
  88. <div class="fr-toolbar-item fr-toolbar-narrow fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-narrow @(isLastPage ? $"fr-webreport-toolbar-notbutton fr-webreport-disabled" : $"fr-webreport-pointer")"
  89. @onclick="GotoLast"
  90. title="@Localization.lastPageTxt">
  91. <img src="_content/FastReport.Web/Resources/angle-double-right.svg" />
  92. </div>
  93. @if (WebReport.Toolbar.Elements != null)
  94. {
  95. @foreach (var element in WebReport.Toolbar.Elements.Where(element => element.Enabled))
  96. {
  97. switch (element)
  98. {
  99. case ToolbarButton toolbarButton:
  100. <div class="fr-toolbar-item fr-toolbar-pointer fr-@WebReport.ID-toolbar-item fr-webreport-pointer @toolbarButton.ElementClasses" @onclick="() => InvokeAction(toolbarButton.OnClickAction as ElementClickAction)" style="@toolbarButton.ElementCustomStyle" title="@toolbarButton.Title">
  101. <img src="@toolbarButton.Image.RenderedImage" alt=""/>
  102. </div>
  103. break;
  104. case ToolbarSelect toolbarSelect:
  105. {
  106. <div class="fr-toolbar-item fr-@WebReport.ID-toolbar-item @toolbarSelect.ElementClasses" title="@toolbarSelect.Title" style="@toolbarSelect.ElementCustomStyle">
  107. <img src="@toolbarSelect.Image.RenderedImage" alt=""/>
  108. <div class="fr-toolbar-dropdown-content fr-@WebReport.ID-toolbar-dropdown-content">
  109. @foreach (var item in toolbarSelect.Items.Where(element => element.Enabled))
  110. {
  111. <a @onclick="() => InvokeAction(item.OnClickAction as ElementClickAction)">@item.Title</a>
  112. }
  113. </div>
  114. </div>
  115. break;
  116. }
  117. case ToolbarInput toolbarInput:
  118. <div class="fr-toolbar-item fr-toolbar-notbutton fr-@WebReport.ID-toolbar-item fr-webreport-toolbar-notbutton @toolbarInput.ElementClasses" style="@toolbarInput.ElementCustomStyle">
  119. <input style="@toolbarInput.InputCustomStyle" type="@toolbarInput.InputType" value="@toolbarInput.InputDefaultValue" title="@toolbarInput.Title" @onchange="(e) => InvokeInputAction(e.Value.ToString(), toolbarInput.OnChangeAction as ElementChangeAction)"/>
  120. </div>
  121. break;
  122. }
  123. }
  124. }
  125. </div>
  126. @if (WebReport.Tabs.Count > 1)
  127. {
  128. <Tabs WebReport="WebReport" />
  129. }
  130. @code {
  131. [Parameter]
  132. public WebReport WebReport { get; set; }
  133. [Parameter]
  134. public Action PageChanged { get; set; }
  135. [Parameter]
  136. public Action OpenModalDialog { get; set; }
  137. protected override void OnParametersSet()
  138. {
  139. Localization = new ToolbarLocalization(WebReport.Res);
  140. currentZoom = WebReport.Zoom * 100;
  141. isFirstPage = WebReport.CurrentPageIndex == 0;
  142. isLastPage = WebReport.CurrentPageIndex >= WebReport.TotalPages - 1;
  143. isSinglePage = WebReport.SinglePage || WebReport.TotalPages < 2;
  144. }
  145. }