120 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| - content_for :page_title do
 | |
|   = t('admin.dashboard.title')
 | |
| 
 | |
| - content_for :heading_actions do
 | |
|   = date_range(@time_period)
 | |
| 
 | |
| - unless @system_checks.empty?
 | |
|   .flash-message-stack
 | |
|     - @system_checks.each do |message|
 | |
|       .flash-message{ class: message.critical ? 'alert' : 'warning' }
 | |
|         = t("admin.system_checks.#{message.key}.message_html", value: message.value ? content_tag(:strong, message.value) : nil)
 | |
|         - if message.action
 | |
|           = link_to t("admin.system_checks.#{message.key}.action"), message.action
 | |
| 
 | |
| .dashboard
 | |
|   .dashboard__item
 | |
|     = react_admin_component :counter,
 | |
|                             end_at: @time_period.last,
 | |
|                             href: admin_accounts_path(origin: 'local'),
 | |
|                             label: t('admin.dashboard.new_users'),
 | |
|                             measure: 'new_users',
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :counter,
 | |
|                             end_at: @time_period.last,
 | |
|                             href: admin_accounts_path(origin: 'local'),
 | |
|                             label: t('admin.dashboard.active_users'),
 | |
|                             measure: 'active_users',
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :counter,
 | |
|                             end_at: @time_period.last,
 | |
|                             label: t('admin.dashboard.interactions'),
 | |
|                             measure: 'interactions',
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :counter,
 | |
|                             end_at: @time_period.last,
 | |
|                             href: admin_reports_path,
 | |
|                             label: t('admin.dashboard.opened_reports'),
 | |
|                             measure: 'opened_reports',
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :counter,
 | |
|                             end_at: @time_period.last,
 | |
|                             href: admin_reports_path(resolved: '1'),
 | |
|                             label: t('admin.dashboard.resolved_reports'),
 | |
|                             measure: 'resolved_reports',
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = link_to admin_reports_path, class: 'dashboard__quick-access' do
 | |
|       %span= t('admin.dashboard.pending_reports_html', count: @pending_reports_count.value)
 | |
|       = material_symbol 'chevron_right'
 | |
| 
 | |
|     = link_to admin_accounts_path(status: 'pending'), class: 'dashboard__quick-access' do
 | |
|       %span= t('admin.dashboard.pending_users_html', count: @pending_users_count.value)
 | |
|       = material_symbol 'chevron_right'
 | |
| 
 | |
|     = link_to admin_trends_tags_path(status: 'pending_review'), class: 'dashboard__quick-access' do
 | |
|       %span= t('admin.dashboard.pending_tags_html', count: @pending_tags_count.value)
 | |
|       = material_symbol 'chevron_right'
 | |
| 
 | |
|     = link_to admin_disputes_appeals_path(status: 'pending'), class: 'dashboard__quick-access' do
 | |
|       %span= t('admin.dashboard.pending_appeals_html', count: @pending_appeals_count.value)
 | |
|       = material_symbol 'chevron_right'
 | |
|   .dashboard__item
 | |
|     = react_admin_component :dimension,
 | |
|                             dimension: 'sources',
 | |
|                             end_at: @time_period.last,
 | |
|                             label: t('admin.dashboard.sources'),
 | |
|                             limit: 8,
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :dimension,
 | |
|                             dimension: 'languages',
 | |
|                             end_at: @time_period.last,
 | |
|                             label: t('admin.dashboard.top_languages'),
 | |
|                             limit: 8,
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :dimension,
 | |
|                             dimension: 'servers',
 | |
|                             end_at: @time_period.last,
 | |
|                             label: t('admin.dashboard.top_servers'),
 | |
|                             limit: 8,
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item.dashboard__item--span-double-column
 | |
|     = react_admin_component :retention,
 | |
|                             end_at: @time_period.last,
 | |
|                             frequency: 'month',
 | |
|                             start_at: @time_period.last - 6.months
 | |
| 
 | |
|   .dashboard__item.dashboard__item--span-double-row
 | |
|     = react_admin_component :trends,
 | |
|                             limit: 7
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :dimension,
 | |
|                             dimension: 'software_versions',
 | |
|                             end_at: @time_period.last,
 | |
|                             label: t('admin.dashboard.software'),
 | |
|                             limit: 4,
 | |
|                             start_at: @time_period.first
 | |
| 
 | |
|   .dashboard__item
 | |
|     = react_admin_component :dimension,
 | |
|                             dimension: 'space_usage',
 | |
|                             end_at: @time_period.last,
 | |
|                             label: t('admin.dashboard.space'),
 | |
|                             limit: 3,
 | |
|                             start_at: @time_period.first
 |