mirror of
https://github.com/discourse/discourse.git
synced 2024-12-16 10:58:23 +08:00
0431942f3d
This new iteration of select-kit focuses on following best principales and disallowing mutations inside select-kit components. A best effort has been made to avoid breaking changes, however if you content was a flat array, eg: ["foo", "bar"] You will need to set valueProperty=null and nameProperty=null on the component. Also almost every component should have an `onChange` handler now to decide what to do with the updated data. **select-kit will not mutate your data by itself anymore**
199 lines
5.9 KiB
Handlebars
199 lines
5.9 KiB
Handlebars
{{#if isEnabled}}
|
|
{{#conditional-loading-section isLoading=isLoading}}
|
|
{{#if showHeader}}
|
|
<div class="header">
|
|
{{#if showTitle}}
|
|
<ul class="breadcrumb">
|
|
{{#if showAllReportsLink}}
|
|
<li class="item all-reports">
|
|
{{#link-to "admin.dashboardReports" class="report-url"}}
|
|
{{i18n "admin.dashboard.all_reports"}}
|
|
{{/link-to}}
|
|
</li>
|
|
|
|
{{#unless showNotFoundError}}
|
|
<li class="item separator">|</li>
|
|
{{/unless}}
|
|
{{/if}}
|
|
|
|
{{#unless showNotFoundError}}
|
|
<li class="item report">
|
|
<a href="{{model.reportUrl}}" class="report-url">
|
|
{{model.title}}
|
|
</a>
|
|
|
|
{{#if model.description}}
|
|
<span class="info" data-tooltip="{{model.description}}">
|
|
{{d-icon "question-circle"}}
|
|
</span>
|
|
{{/if}}
|
|
</li>
|
|
{{/unless}}
|
|
</ul>
|
|
{{/if}}
|
|
|
|
{{#if shouldDisplayTrend}}
|
|
<div class="trend {{model.trend}}">
|
|
<span class="value" title="{{model.trendTitle}}">
|
|
{{#if model.average}}
|
|
{{number model.currentAverage}}{{#if model.percent}}%{{/if}}
|
|
{{else}}
|
|
{{number model.currentTotal noTitle="true"}}{{#if model.percent}}%{{/if}}
|
|
{{/if}}
|
|
|
|
{{#if model.trendIcon}}
|
|
{{d-icon model.trendIcon class="icon"}}
|
|
{{/if}}
|
|
</span>
|
|
</div>
|
|
{{/if}}
|
|
</div>
|
|
{{/if}}
|
|
|
|
<div class="body">
|
|
<div class="main">
|
|
{{#unless showError}}
|
|
{{#if hasData}}
|
|
{{#if currentMode}}
|
|
{{component modeComponent model=model options=options}}
|
|
|
|
{{#if model.relatedReport}}
|
|
{{admin-report showFilteringUI=false dataSourceName=model.relatedReport.type}}
|
|
{{/if}}
|
|
{{/if}}
|
|
{{else}}
|
|
{{#if rateLimitationString}}
|
|
<div class="alert alert-error report-alert rate-limited">
|
|
{{d-icon "thermometer-three-quarters"}}
|
|
<span>{{rateLimitationString}}</span>
|
|
</div>
|
|
{{else}}
|
|
<div class="alert alert-info report-alert no-data">
|
|
{{d-icon "chart-pie"}}
|
|
{{#if model.reportUrl}}
|
|
<a href="{{model.reportUrl}}" class="report-url">
|
|
<span>
|
|
{{#if model.title}}
|
|
{{model.title}} —
|
|
{{/if}}
|
|
{{i18n "admin.dashboard.reports.no_data"}}
|
|
</span>
|
|
</a>
|
|
{{else}}
|
|
<span>{{i18n "admin.dashboard.reports.no_data"}}</span>
|
|
{{/if}}
|
|
</div>
|
|
{{/if}}
|
|
{{/if}}
|
|
{{else}}
|
|
{{#if showTimeoutError}}
|
|
<div class="alert alert-error report-alert timeout">
|
|
{{d-icon "exclamation-triangle"}}
|
|
<span>{{i18n "admin.dashboard.timeout_error"}}</span>
|
|
</div>
|
|
{{/if}}
|
|
|
|
{{#if showExceptionError}}
|
|
<div class="alert alert-error report-alert exception">
|
|
{{d-icon "exclamation-triangle"}}
|
|
<span>{{i18n "admin.dashboard.exception_error"}}</span>
|
|
</div>
|
|
{{/if}}
|
|
|
|
{{#if showNotFoundError}}
|
|
<div class="alert alert-error report-alert not-found">
|
|
{{d-icon "exclamation-triangle"}}
|
|
<span>{{i18n "admin.dashboard.not_found_error"}}</span>
|
|
</div>
|
|
{{/if}}
|
|
{{/unless}}
|
|
</div>
|
|
|
|
{{#if showFilteringUI}}
|
|
<div class="filters">
|
|
{{#if showModes}}
|
|
<div class="modes">
|
|
{{#each displayedModes as |displayedMode|}}
|
|
{{d-button
|
|
action=(action "changeMode")
|
|
actionParam=displayedMode.mode
|
|
class=displayedMode.cssClass
|
|
icon=displayedMode.icon}}
|
|
{{/each}}
|
|
</div>
|
|
{{/if}}
|
|
|
|
{{#if showDatesOptions}}
|
|
<div class="control">
|
|
<span class="label">
|
|
{{i18n 'admin.dashboard.reports.start_date'}}
|
|
</span>
|
|
|
|
<div class="input">
|
|
{{date-input
|
|
date=startDate
|
|
onChange=(action "onChangeStartDate")
|
|
}}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="control">
|
|
<span class="label">
|
|
{{i18n 'admin.dashboard.reports.end_date'}}
|
|
</span>
|
|
|
|
<div class="input">
|
|
{{date-input
|
|
date=endDate
|
|
onChange=(action "onChangeEndDate")
|
|
}}
|
|
</div>
|
|
</div>
|
|
{{/if}}
|
|
|
|
{{#each model.available_filters as |filter|}}
|
|
<div class="control">
|
|
<span class="label">
|
|
{{i18n (concat "admin.dashboard.reports.filters." filter.id ".label")}}
|
|
</span>
|
|
|
|
<div class="input">
|
|
{{component
|
|
(concat "report-filters/" filter.id)
|
|
filter=filter
|
|
applyFilter=(action "applyFilter")}}
|
|
</div>
|
|
</div>
|
|
{{/each}}
|
|
|
|
<div class="control">
|
|
<div class="input">
|
|
{{d-button
|
|
class="btn-default export-csv-btn"
|
|
action=(action "exportCsv")
|
|
label="admin.export_csv.button_text"
|
|
icon="download"}}
|
|
</div>
|
|
</div>
|
|
|
|
{{#if showRefresh}}
|
|
<div class="control">
|
|
<div class="input">
|
|
{{d-button
|
|
class="refresh-report-btn btn-primary"
|
|
action=(action "refreshReport")
|
|
label="admin.dashboard.reports.refresh_report"
|
|
icon="sync"}}
|
|
</div>
|
|
</div>
|
|
{{/if}}
|
|
</div>
|
|
{{/if}}
|
|
</div>
|
|
{{/conditional-loading-section}}
|
|
{{else}}
|
|
<div class="alert alert-info">
|
|
{{{disabledLabel}}}
|
|
</div>
|
|
{{/if}}
|