mirror of
https://github.com/Freika/dawarich.git
synced 2026-01-09 08:47:11 -05:00
* fix: move foreman to global gems to fix startup crash (#1971) * Update exporting code to stream points data to file in batches to red… (#1980) * Update exporting code to stream points data to file in batches to reduce memory usage * Update changelog * Update changelog * Feature/maplibre frontend (#1953) * Add a plan to use MapLibre GL JS for the frontend map rendering, replacing Leaflet * Implement phase 1 * Phases 1-3 + part of 4 * Fix e2e tests * Phase 6 * Implement fog of war * Phase 7 * Next step: fix specs, phase 7 done * Use our own map tiles * Extract v2 map logic to separate manager classes * Update settings panel on v2 map * Update v2 e2e tests structure * Reimplement location search in maps v2 * Update speed routes * Implement visits and places creation in v2 * Fix last failing test * Implement visits merging * Fix a routes e2e test and simplify the routes layer styling. * Extract js to modules from maps_v2_controller.js * Implement area creation * Fix spec problem * Fix some e2e tests * Implement live mode in v2 map * Update icons and panel * Extract some styles * Remove unused file * Start adding dark theme to popups on MapLibre maps * Make popups respect dark theme * Move v2 maps to maplibre namespace * Update v2 references to maplibre * Put place, area and visit info into side panel * Update API to use safe settings config method * Fix specs * Fix method name to config in SafeSettings and update usages accordingly * Add missing public files * Add handling for real time points * Fix remembering enabled/disabled layers of the v2 map * Fix lots of e2e tests * Add settings to select map version * Use maps/v2 as main path for MapLibre maps * Update routing * Update live mode * Update maplibre controller * Update changelog * Remove some console.log statements --------- Co-authored-by: Robin Tuszik <mail@robin.gg>
152 lines
3.2 KiB
Ruby
152 lines
3.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module ApplicationHelper
|
|
def flash_alert_class(type)
|
|
case type.to_sym
|
|
when :notice, :success then 'alert-success'
|
|
when :alert, :error then 'alert-error'
|
|
when :warning then 'alert-warning'
|
|
when :info then 'alert-info'
|
|
else 'alert-info'
|
|
end
|
|
end
|
|
|
|
def flash_icon(type)
|
|
case type.to_sym
|
|
when :notice, :success then icon 'circle-check'
|
|
when :alert, :error then icon 'circle-x'
|
|
when :warning then icon 'circle-alert'
|
|
else
|
|
icon 'info'
|
|
end
|
|
end
|
|
|
|
def year_timespan(year)
|
|
start_at = DateTime.new(year).beginning_of_year.strftime('%Y-%m-%dT%H:%M')
|
|
end_at = DateTime.new(year).end_of_year.strftime('%Y-%m-%dT%H:%M')
|
|
|
|
{ start_at:, end_at: }
|
|
end
|
|
|
|
def header_colors
|
|
%w[info success warning error accent secondary primary]
|
|
end
|
|
|
|
def new_version_available?
|
|
CheckAppVersion.new.call
|
|
end
|
|
|
|
def app_theme
|
|
current_user&.theme == 'light' ? 'light' : 'dark'
|
|
end
|
|
|
|
def active_class?(link_path)
|
|
'btn-active' if current_page?(link_path)
|
|
end
|
|
|
|
def full_title(page_title = '')
|
|
base_title = 'Dawarich'
|
|
page_title.empty? ? base_title : "#{page_title} | #{base_title}"
|
|
end
|
|
|
|
def active_tab?(link_path)
|
|
'tab-active' if current_page?(link_path)
|
|
end
|
|
|
|
def active_visit_places_tab?(controller_name)
|
|
'tab-active' if current_page?(controller: controller_name)
|
|
end
|
|
|
|
def notification_link_color(notification)
|
|
return 'text-gray-600' if notification.read?
|
|
|
|
'text-blue-600'
|
|
end
|
|
|
|
def human_date(date)
|
|
date.strftime('%e %B %Y')
|
|
end
|
|
|
|
def human_datetime(datetime)
|
|
return unless datetime
|
|
|
|
content_tag(
|
|
:span,
|
|
datetime.strftime('%e %b %Y, %H:%M'),
|
|
class: 'tooltip',
|
|
data: { tip: datetime.iso8601 }
|
|
)
|
|
end
|
|
|
|
def human_datetime_with_seconds(datetime)
|
|
return unless datetime
|
|
|
|
content_tag(
|
|
:span,
|
|
datetime.strftime('%e %b %Y, %H:%M:%S'),
|
|
class: 'tooltip',
|
|
data: { tip: datetime.iso8601 }
|
|
)
|
|
end
|
|
|
|
def speed_text_color(speed)
|
|
return 'text-default' if speed.to_i >= 0
|
|
|
|
'text-red-500'
|
|
end
|
|
|
|
def point_speed(speed)
|
|
return speed if speed.to_i <= 0
|
|
|
|
speed * 3.6
|
|
end
|
|
|
|
def days_left(active_until)
|
|
return unless active_until
|
|
|
|
time_words = distance_of_time_in_words(Time.zone.now, active_until)
|
|
|
|
content_tag(
|
|
:span,
|
|
time_words,
|
|
class: 'tooltip',
|
|
data: { tip: "Expires on #{active_until.iso8601}" }
|
|
)
|
|
end
|
|
|
|
def onboarding_modal_showable?(user)
|
|
user.trial_state?
|
|
end
|
|
|
|
def trial_button_class(user)
|
|
case (user.active_until.to_date - Time.current.to_date).to_i
|
|
when 5..8
|
|
'btn-info'
|
|
when 2...5
|
|
'btn-warning'
|
|
when 0...2
|
|
'btn-error'
|
|
else
|
|
'btn-success'
|
|
end
|
|
end
|
|
|
|
def oauth_provider_name(provider)
|
|
return OIDC_PROVIDER_NAME if provider == :openid_connect
|
|
|
|
OmniAuth::Utils.camelize(provider)
|
|
end
|
|
|
|
def email_password_registration_enabled?
|
|
return true unless DawarichSettings.self_hosted?
|
|
|
|
ALLOW_EMAIL_PASSWORD_REGISTRATION
|
|
end
|
|
|
|
def preferred_map_path
|
|
return map_v1_path unless user_signed_in?
|
|
|
|
preferred_version = current_user.safe_settings.maps&.dig('preferred_version')
|
|
preferred_version == 'v2' ? map_v2_path : map_v1_path
|
|
end
|
|
end
|