karafka-web 0.6.2 → 0.7.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/.github/workflows/ci.yml +13 -4
- data/CHANGELOG.md +114 -6
- data/Gemfile +1 -0
- data/Gemfile.lock +27 -24
- data/README.md +2 -0
- data/bin/rspecs +6 -0
- data/certs/cert_chain.pem +21 -21
- data/docker-compose.yml +22 -0
- data/karafka-web.gemspec +3 -3
- data/lib/karafka/web/app.rb +6 -2
- data/lib/karafka/web/cli.rb +51 -47
- data/lib/karafka/web/config.rb +31 -9
- data/lib/karafka/web/contracts/base.rb +32 -0
- data/lib/karafka/web/contracts/config.rb +63 -0
- data/lib/karafka/web/deserializer.rb +10 -1
- data/lib/karafka/web/errors.rb +29 -7
- data/lib/karafka/web/installer.rb +58 -148
- data/lib/karafka/web/management/base.rb +34 -0
- data/lib/karafka/web/management/clean_boot_file.rb +31 -0
- data/lib/karafka/web/management/create_initial_states.rb +101 -0
- data/lib/karafka/web/management/create_topics.rb +127 -0
- data/lib/karafka/web/management/delete_topics.rb +28 -0
- data/lib/karafka/web/management/enable.rb +82 -0
- data/lib/karafka/web/management/extend_boot_file.rb +37 -0
- data/lib/karafka/web/processing/consumer.rb +73 -17
- data/lib/karafka/web/processing/consumers/aggregators/base.rb +56 -0
- data/lib/karafka/web/processing/consumers/aggregators/metrics.rb +154 -0
- data/lib/karafka/web/processing/consumers/aggregators/state.rb +180 -0
- data/lib/karafka/web/processing/consumers/contracts/aggregated_stats.rb +32 -0
- data/lib/karafka/web/processing/consumers/contracts/metrics.rb +53 -0
- data/lib/karafka/web/processing/consumers/contracts/process.rb +19 -0
- data/lib/karafka/web/processing/consumers/contracts/state.rb +49 -0
- data/lib/karafka/web/processing/consumers/contracts/topic_stats.rb +21 -0
- data/lib/karafka/web/processing/consumers/metrics.rb +29 -0
- data/lib/karafka/web/processing/consumers/schema_manager.rb +56 -0
- data/lib/karafka/web/processing/consumers/state.rb +6 -9
- data/lib/karafka/web/processing/time_series_tracker.rb +130 -0
- data/lib/karafka/web/tracking/consumers/contracts/consumer_group.rb +2 -2
- data/lib/karafka/web/tracking/consumers/contracts/job.rb +2 -1
- data/lib/karafka/web/tracking/consumers/contracts/partition.rb +14 -1
- data/lib/karafka/web/tracking/consumers/contracts/report.rb +10 -8
- data/lib/karafka/web/tracking/consumers/contracts/subscription_group.rb +2 -2
- data/lib/karafka/web/tracking/consumers/contracts/topic.rb +2 -2
- data/lib/karafka/web/tracking/consumers/listeners/processing.rb +6 -2
- data/lib/karafka/web/tracking/consumers/listeners/statistics.rb +15 -1
- data/lib/karafka/web/tracking/consumers/reporter.rb +14 -6
- data/lib/karafka/web/tracking/consumers/sampler.rb +80 -39
- data/lib/karafka/web/tracking/contracts/error.rb +2 -1
- data/lib/karafka/web/ui/app.rb +20 -10
- data/lib/karafka/web/ui/base.rb +50 -4
- data/lib/karafka/web/ui/controllers/base.rb +11 -0
- data/lib/karafka/web/ui/controllers/become_pro.rb +1 -1
- data/lib/karafka/web/ui/controllers/cluster.rb +7 -4
- data/lib/karafka/web/ui/controllers/consumers.rb +1 -1
- data/lib/karafka/web/ui/controllers/dashboard.rb +32 -0
- data/lib/karafka/web/ui/controllers/jobs.rb +1 -1
- data/lib/karafka/web/ui/controllers/requests/params.rb +18 -0
- data/lib/karafka/web/ui/controllers/responses/redirect.rb +29 -0
- data/lib/karafka/web/ui/helpers/application_helper.rb +57 -14
- data/lib/karafka/web/ui/helpers/paths_helper.rb +48 -0
- data/lib/karafka/web/ui/lib/hash_proxy.rb +18 -6
- data/lib/karafka/web/ui/lib/paginations/watermark_offsets_based.rb +75 -0
- data/lib/karafka/web/ui/lib/ttl_cache.rb +8 -0
- data/lib/karafka/web/ui/models/consumers_metrics.rb +46 -0
- data/lib/karafka/web/ui/models/{state.rb → consumers_state.rb} +6 -2
- data/lib/karafka/web/ui/models/health.rb +37 -7
- data/lib/karafka/web/ui/models/message.rb +11 -3
- data/lib/karafka/web/ui/models/metrics/aggregated.rb +196 -0
- data/lib/karafka/web/ui/models/metrics/charts/aggregated.rb +50 -0
- data/lib/karafka/web/ui/models/metrics/charts/topics.rb +109 -0
- data/lib/karafka/web/ui/models/metrics/topics.rb +101 -0
- data/lib/karafka/web/ui/models/partition.rb +27 -0
- data/lib/karafka/web/ui/models/process.rb +12 -1
- data/lib/karafka/web/ui/models/status.rb +107 -21
- data/lib/karafka/web/ui/models/visibility_filter.rb +33 -0
- data/lib/karafka/web/ui/pro/app.rb +80 -20
- data/lib/karafka/web/ui/pro/controllers/cluster.rb +11 -0
- data/lib/karafka/web/ui/pro/controllers/consumers.rb +10 -6
- data/lib/karafka/web/ui/pro/controllers/dashboard.rb +54 -0
- data/lib/karafka/web/ui/pro/controllers/errors.rb +3 -0
- data/lib/karafka/web/ui/pro/controllers/explorer.rb +94 -9
- data/lib/karafka/web/ui/pro/controllers/health.rb +10 -2
- data/lib/karafka/web/ui/pro/controllers/messages.rb +62 -0
- data/lib/karafka/web/ui/pro/controllers/routing.rb +44 -0
- data/lib/karafka/web/ui/pro/views/consumers/_breadcrumbs.erb +7 -1
- data/lib/karafka/web/ui/pro/views/consumers/_consumer.erb +1 -1
- data/lib/karafka/web/ui/pro/views/consumers/_counters.erb +7 -5
- data/lib/karafka/web/ui/pro/views/consumers/consumer/_job.erb +3 -3
- data/lib/karafka/web/ui/pro/views/consumers/consumer/_metrics.erb +5 -4
- data/lib/karafka/web/ui/pro/views/consumers/consumer/_partition.erb +13 -4
- data/lib/karafka/web/ui/pro/views/consumers/consumer/_subscription_group.erb +3 -2
- data/lib/karafka/web/ui/pro/views/consumers/consumer/_tabs.erb +7 -0
- data/lib/karafka/web/ui/pro/views/consumers/details.erb +21 -0
- data/lib/karafka/web/ui/pro/views/consumers/index.erb +4 -2
- data/lib/karafka/web/ui/pro/views/dashboard/_ranges_selector.erb +39 -0
- data/lib/karafka/web/ui/pro/views/dashboard/index.erb +82 -0
- data/lib/karafka/web/ui/pro/views/dlq/_topic.erb +1 -1
- data/lib/karafka/web/ui/pro/views/errors/_error.erb +1 -1
- data/lib/karafka/web/ui/pro/views/errors/index.erb +1 -1
- data/lib/karafka/web/ui/pro/views/errors/partition.erb +1 -1
- data/lib/karafka/web/ui/pro/views/errors/show.erb +1 -1
- data/lib/karafka/web/ui/pro/views/explorer/_breadcrumbs.erb +6 -4
- data/lib/karafka/web/ui/pro/views/explorer/_filtered.erb +16 -0
- data/lib/karafka/web/ui/pro/views/explorer/_message.erb +6 -2
- data/lib/karafka/web/ui/pro/views/explorer/_no_topics.erb +7 -0
- data/lib/karafka/web/ui/pro/views/explorer/_partition_option.erb +2 -2
- data/lib/karafka/web/ui/pro/views/explorer/_topic.erb +1 -1
- data/lib/karafka/web/ui/pro/views/explorer/index.erb +12 -8
- data/lib/karafka/web/ui/pro/views/explorer/messages/_headers.erb +15 -0
- data/lib/karafka/web/ui/pro/views/explorer/messages/_key.erb +12 -0
- data/lib/karafka/web/ui/pro/views/explorer/partition/_details.erb +35 -0
- data/lib/karafka/web/ui/pro/views/explorer/partition.erb +5 -3
- data/lib/karafka/web/ui/pro/views/explorer/show.erb +48 -5
- data/lib/karafka/web/ui/pro/views/explorer/topic/_details.erb +23 -0
- data/lib/karafka/web/ui/pro/views/explorer/topic.erb +14 -12
- data/lib/karafka/web/ui/pro/views/health/_breadcrumbs.erb +16 -0
- data/lib/karafka/web/ui/pro/views/health/_no_data.erb +9 -0
- data/lib/karafka/web/ui/pro/views/health/_partition.erb +17 -15
- data/lib/karafka/web/ui/pro/views/health/_partition_offset.erb +40 -0
- data/lib/karafka/web/ui/pro/views/health/_tabs.erb +27 -0
- data/lib/karafka/web/ui/pro/views/health/offsets.erb +71 -0
- data/lib/karafka/web/ui/pro/views/health/overview.erb +68 -0
- data/lib/karafka/web/ui/pro/views/jobs/_job.erb +6 -3
- data/lib/karafka/web/ui/pro/views/jobs/index.erb +4 -1
- data/lib/karafka/web/ui/pro/views/routing/_consumer_group.erb +37 -0
- data/lib/karafka/web/ui/pro/views/routing/_detail.erb +25 -0
- data/lib/karafka/web/ui/pro/views/routing/_topic.erb +23 -0
- data/lib/karafka/web/ui/pro/views/routing/index.erb +10 -0
- data/lib/karafka/web/ui/pro/views/routing/show.erb +26 -0
- data/lib/karafka/web/ui/pro/views/shared/_navigation.erb +6 -9
- data/lib/karafka/web/ui/public/images/logo-gray.svg +28 -0
- data/lib/karafka/web/ui/public/javascripts/application.js +30 -0
- data/lib/karafka/web/ui/public/javascripts/chart.min.js +14 -0
- data/lib/karafka/web/ui/public/javascripts/charts.js +330 -0
- data/lib/karafka/web/ui/public/javascripts/datepicker.js +6 -0
- data/lib/karafka/web/ui/public/javascripts/live_poll.js +39 -12
- data/lib/karafka/web/ui/public/javascripts/offset_datetime.js +74 -0
- data/lib/karafka/web/ui/public/javascripts/tabs.js +59 -0
- data/lib/karafka/web/ui/public/stylesheets/application.css +11 -0
- data/lib/karafka/web/ui/public/stylesheets/datepicker.min.css +12 -0
- data/lib/karafka/web/ui/views/cluster/_no_partitions.erb +3 -0
- data/lib/karafka/web/ui/views/cluster/_partition.erb +20 -22
- data/lib/karafka/web/ui/views/cluster/index.erb +6 -1
- data/lib/karafka/web/ui/views/consumers/_consumer.erb +1 -1
- data/lib/karafka/web/ui/views/consumers/_counters.erb +6 -4
- data/lib/karafka/web/ui/views/consumers/_summary.erb +3 -3
- data/lib/karafka/web/ui/views/consumers/index.erb +3 -1
- data/lib/karafka/web/ui/views/dashboard/_feature_pro.erb +3 -0
- data/lib/karafka/web/ui/views/dashboard/_not_enough_data.erb +15 -0
- data/lib/karafka/web/ui/views/dashboard/_ranges_selector.erb +23 -0
- data/lib/karafka/web/ui/views/dashboard/index.erb +95 -0
- data/lib/karafka/web/ui/views/errors/_detail.erb +12 -0
- data/lib/karafka/web/ui/views/errors/_error.erb +1 -1
- data/lib/karafka/web/ui/views/errors/show.erb +1 -1
- data/lib/karafka/web/ui/views/jobs/index.erb +3 -1
- data/lib/karafka/web/ui/views/layout.erb +10 -3
- data/lib/karafka/web/ui/views/routing/_consumer_group.erb +8 -6
- data/lib/karafka/web/ui/views/routing/_detail.erb +2 -2
- data/lib/karafka/web/ui/views/routing/_topic.erb +1 -1
- data/lib/karafka/web/ui/views/routing/show.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_brand.erb +2 -2
- data/lib/karafka/web/ui/views/shared/_chart.erb +14 -0
- data/lib/karafka/web/ui/views/shared/_content.erb +2 -2
- data/lib/karafka/web/ui/views/shared/_feature_pro.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_flashes.erb +9 -0
- data/lib/karafka/web/ui/views/shared/_footer.erb +22 -0
- data/lib/karafka/web/ui/views/shared/_header.erb +15 -9
- data/lib/karafka/web/ui/views/shared/_live_poll.erb +7 -0
- data/lib/karafka/web/ui/views/shared/_navigation.erb +5 -8
- data/lib/karafka/web/ui/views/shared/_no_paginated_data.erb +9 -0
- data/lib/karafka/web/ui/views/shared/_pagination.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_tab_nav.erb +7 -0
- data/lib/karafka/web/ui/views/shared/exceptions/not_found.erb +34 -32
- data/lib/karafka/web/ui/views/shared/exceptions/pro_only.erb +45 -43
- data/lib/karafka/web/ui/views/status/failures/_consumers_reports_schema_state.erb +15 -0
- data/lib/karafka/web/ui/views/status/failures/_enabled.erb +8 -0
- data/lib/karafka/web/ui/views/status/failures/_initial_consumers_metrics.erb +11 -0
- data/lib/karafka/web/ui/views/status/failures/{_initial_state.erb → _initial_consumers_state.erb} +3 -3
- data/lib/karafka/web/ui/views/status/failures/_partitions.erb +14 -6
- data/lib/karafka/web/ui/views/status/info/_components.erb +21 -1
- data/lib/karafka/web/ui/views/status/show.erb +62 -5
- data/lib/karafka/web/ui/views/status/successes/_enabled.erb +1 -0
- data/lib/karafka/web/ui/views/status/warnings/_replication.erb +19 -0
- data/lib/karafka/web/version.rb +1 -1
- data/lib/karafka/web.rb +11 -0
- data.tar.gz.sig +0 -0
- metadata +109 -39
- metadata.gz.sig +0 -0
- data/lib/karafka/web/processing/consumers/aggregator.rb +0 -130
- data/lib/karafka/web/tracking/contracts/base.rb +0 -34
- data/lib/karafka/web/ui/pro/views/explorer/_encryption_enabled.erb +0 -18
- data/lib/karafka/web/ui/pro/views/explorer/partition/_watermark_offsets.erb +0 -10
- data/lib/karafka/web/ui/pro/views/explorer/topic/_partitions.erb +0 -11
- data/lib/karafka/web/ui/pro/views/health/index.erb +0 -60
- /data/lib/karafka/web/ui/pro/views/explorer/{_detail.erb → messages/_detail.erb} +0 -0
@@ -0,0 +1,68 @@
|
|
1
|
+
<%== view_title('Consumers groups overview') %>
|
2
|
+
|
3
|
+
<% if @stats.empty? %>
|
4
|
+
<%== partial 'health/no_data' %>
|
5
|
+
<% else %>
|
6
|
+
<%== partial 'health/tabs' %>
|
7
|
+
<% end %>
|
8
|
+
|
9
|
+
<% @stats.each_with_index do |(cg_name, details), index| %>
|
10
|
+
<div class="container mb-5">
|
11
|
+
<div class="row mb-4">
|
12
|
+
<div class="col-sm-8">
|
13
|
+
<h4 class="mb-4"><%= cg_name %></h4>
|
14
|
+
</div>
|
15
|
+
|
16
|
+
<div class="col-sm-4">
|
17
|
+
<span class="float-end">
|
18
|
+
Last rebalance:
|
19
|
+
<span class="badge bg-secondary">
|
20
|
+
<%== relative_time(details[:rebalanced_at]) %>
|
21
|
+
</span>
|
22
|
+
</span>
|
23
|
+
</div>
|
24
|
+
</div>
|
25
|
+
|
26
|
+
<div class="row mb-3">
|
27
|
+
<div class="col-sm-12">
|
28
|
+
<% topics = details[:topics].sort_by(&:first) %>
|
29
|
+
<% topics.each_with_index do |(topic_name, partitions), index| %>
|
30
|
+
<table class="processes bg-white table table-hover table-bordered table-striped align-middle <%= (index+1 < topics.size) ? 'mb-5' : 'mb-3' %>">
|
31
|
+
<thead>
|
32
|
+
<tr class="align-middle">
|
33
|
+
<th colspan="100">
|
34
|
+
<h5 class="mb-0"><%= topic_name %></h4>
|
35
|
+
</th>
|
36
|
+
</tr>
|
37
|
+
<tr class="align-middle">
|
38
|
+
<th>Partition</th>
|
39
|
+
<th>Lag stored</th>
|
40
|
+
<th>Lag stored trend</th>
|
41
|
+
<th>Committed offset</th>
|
42
|
+
<th>Stored offset</th>
|
43
|
+
<th>Fetch state</th>
|
44
|
+
<th>Poll state</th>
|
45
|
+
<th>LSO state</th>
|
46
|
+
<th>Process name</th>
|
47
|
+
</tr>
|
48
|
+
</thead>
|
49
|
+
<tbody>
|
50
|
+
<% partitions.sort_by(&:first).each do |partition_id, details| %>
|
51
|
+
<%==
|
52
|
+
partial(
|
53
|
+
'health/partition',
|
54
|
+
locals: {
|
55
|
+
topic_name: topic_name,
|
56
|
+
partition_id: partition_id,
|
57
|
+
details: details
|
58
|
+
}
|
59
|
+
)
|
60
|
+
%>
|
61
|
+
<% end %>
|
62
|
+
</tbody>
|
63
|
+
</table>
|
64
|
+
<% end %>
|
65
|
+
</div>
|
66
|
+
</div>
|
67
|
+
</div>
|
68
|
+
<% end %>
|
@@ -22,13 +22,16 @@
|
|
22
22
|
<code>#<%= job.type %></code>
|
23
23
|
</td>
|
24
24
|
<td>
|
25
|
-
|
25
|
+
<%= job.messages %>
|
26
26
|
</td>
|
27
27
|
<td>
|
28
|
-
<%== offset_with_label job.
|
28
|
+
<%== offset_with_label job.topic, job.partition, job.first_offset, explore: true %>
|
29
29
|
</td>
|
30
30
|
<td>
|
31
|
-
<%== offset_with_label job.
|
31
|
+
<%== offset_with_label job.topic, job.partition, job.last_offset, explore: true %>
|
32
|
+
</td>
|
33
|
+
<td>
|
34
|
+
<%== offset_with_label job.topic, job.partition, job.committed_offset %>
|
32
35
|
</td>
|
33
36
|
<td>
|
34
37
|
<%== relative_time job.started_at %>
|
@@ -1,7 +1,9 @@
|
|
1
1
|
<%== view_title('Running jobs', hr: true) %>
|
2
2
|
|
3
|
-
<% if @jobs.empty? %>
|
3
|
+
<% if @jobs.empty? && params.current_page <= 1 %>
|
4
4
|
<%== partial 'jobs/no_jobs' %>
|
5
|
+
<% elsif @jobs.empty? %>
|
6
|
+
<%== partial 'shared/no_paginated_data' %>
|
5
7
|
<% else %>
|
6
8
|
<div class="container">
|
7
9
|
<div class="row mb-5">
|
@@ -13,6 +15,7 @@
|
|
13
15
|
<th>Topic</th>
|
14
16
|
<th>Consumer</th>
|
15
17
|
<th>Type</th>
|
18
|
+
<th>Messages</th>
|
16
19
|
<th>First offset</th>
|
17
20
|
<th>Last offset</th>
|
18
21
|
<th>Committed offset</th>
|
@@ -0,0 +1,37 @@
|
|
1
|
+
<div class="row mb-4">
|
2
|
+
<div class="col-sm-12">
|
3
|
+
<h4 class="mb-2">
|
4
|
+
<%= consumer_group.id %>
|
5
|
+
</h4>
|
6
|
+
<hr/>
|
7
|
+
</div>
|
8
|
+
</div>
|
9
|
+
|
10
|
+
<div class="row mb-5">
|
11
|
+
<div class="col-sm-12">
|
12
|
+
<table class="processes bg-white table table-hover table-bordered table-striped mb-0 align-middle">
|
13
|
+
<thead>
|
14
|
+
<tr class="align-middle">
|
15
|
+
<th>Subscription group</th>
|
16
|
+
<th>Topic</th>
|
17
|
+
<th>Type</th>
|
18
|
+
<th>Active</th>
|
19
|
+
<th></th>
|
20
|
+
</tr>
|
21
|
+
</thead>
|
22
|
+
<tbody>
|
23
|
+
<% consumer_group.topics.each do |topic| %>
|
24
|
+
<%==
|
25
|
+
partial(
|
26
|
+
'routing/topic',
|
27
|
+
locals: {
|
28
|
+
subscription_group: topic.subscription_group,
|
29
|
+
topic: topic
|
30
|
+
}
|
31
|
+
)
|
32
|
+
%>
|
33
|
+
<% end %>
|
34
|
+
</tbody>
|
35
|
+
</table>
|
36
|
+
</div>
|
37
|
+
</div>
|
@@ -0,0 +1,25 @@
|
|
1
|
+
<% if v.is_a?(Hash) || v.respond_to?(:to_h) %>
|
2
|
+
<% v.to_h.each do |k2, v2| %>
|
3
|
+
<tr>
|
4
|
+
<td>
|
5
|
+
<%= "#{k}.#{k2}" %>
|
6
|
+
</td>
|
7
|
+
<td>
|
8
|
+
<% if %w[sasl ssl].any? { |scope| k2.to_s.include?(scope) } %>
|
9
|
+
***
|
10
|
+
<% else %>
|
11
|
+
<%= v2 %>
|
12
|
+
<% end %>
|
13
|
+
</td>
|
14
|
+
</tr>
|
15
|
+
<% end %>
|
16
|
+
<% else %>
|
17
|
+
<tr>
|
18
|
+
<td>
|
19
|
+
<%= k %>
|
20
|
+
</td>
|
21
|
+
<td>
|
22
|
+
<%= object_value_to_s(v) %>
|
23
|
+
</td>
|
24
|
+
</tr>
|
25
|
+
<% end %>
|
@@ -0,0 +1,23 @@
|
|
1
|
+
<tr>
|
2
|
+
<td>
|
3
|
+
<%= subscription_group %>
|
4
|
+
</td>
|
5
|
+
<td>
|
6
|
+
<%= topic.name %>
|
7
|
+
</td>
|
8
|
+
<td>
|
9
|
+
<span class="badge bg-secondary">
|
10
|
+
<%= topic.patterns.type %>
|
11
|
+
</span>
|
12
|
+
</td>
|
13
|
+
<td>
|
14
|
+
<span class="badge bg-<%= topic.active? ? 'success' : 'warning text-dark' %>">
|
15
|
+
<%= topic.active? %>
|
16
|
+
</span>
|
17
|
+
</td>
|
18
|
+
<td class="text-center">
|
19
|
+
<a href="<%= root_path('routing', topic.id) %>" class="btn btn-sm btn-secondary text-white">
|
20
|
+
Details
|
21
|
+
</a>
|
22
|
+
</td>
|
23
|
+
</tr>
|
@@ -0,0 +1,26 @@
|
|
1
|
+
<%==
|
2
|
+
title = [@topic.consumer_group.name, @topic.subscription_group, @topic.name].join(': ')
|
3
|
+
view_title(title, hr: true)
|
4
|
+
%>
|
5
|
+
|
6
|
+
<div class="container">
|
7
|
+
<div class="row mb-5">
|
8
|
+
<div class="col-sm-12">
|
9
|
+
<table class="processes bg-white table table-hover table-bordered table-striped mb-0 align-middle">
|
10
|
+
<tbody>
|
11
|
+
<% flat_hash(@topic.to_h).each do |k, v| %>
|
12
|
+
<%==
|
13
|
+
partial(
|
14
|
+
'routing/detail',
|
15
|
+
locals: {
|
16
|
+
k: k,
|
17
|
+
v: v
|
18
|
+
}
|
19
|
+
)
|
20
|
+
%>
|
21
|
+
<% end %>
|
22
|
+
</tbody>
|
23
|
+
</table>
|
24
|
+
</div>
|
25
|
+
</div>
|
26
|
+
</div>
|
@@ -4,6 +4,11 @@
|
|
4
4
|
|
5
5
|
<div class="collapse navbar-collapse" id="navbarNav">
|
6
6
|
<ul class="navbar-nav">
|
7
|
+
<li class="nav-item ms-3">
|
8
|
+
<a class="nav-link <%= nav_class(start_with: '/dashboard') %>" href="<%= root_path('dashboard') %>">
|
9
|
+
Dashboard
|
10
|
+
</a>
|
11
|
+
</li>
|
7
12
|
<li class="nav-item ms-3">
|
8
13
|
<a class="nav-link <%= nav_class(start_with: '/consumers') %>" href="<%= root_path('consumers') %>">
|
9
14
|
Consumers
|
@@ -16,7 +21,7 @@
|
|
16
21
|
</li>
|
17
22
|
|
18
23
|
<li class="nav-item ms-3">
|
19
|
-
<a class="nav-link <%= nav_class(start_with: '/health') %>" href="<%= root_path('health') %>">
|
24
|
+
<a class="nav-link <%= nav_class(start_with: '/health') %>" href="<%= root_path('health/overview') %>">
|
20
25
|
Health
|
21
26
|
</a>
|
22
27
|
</li>
|
@@ -52,11 +57,3 @@
|
|
52
57
|
</li>
|
53
58
|
</ul>
|
54
59
|
</div>
|
55
|
-
|
56
|
-
<ul class="nav navbar-nav navbar-right">
|
57
|
-
<li>
|
58
|
-
<span class="btn btn-secondary btn-sm" id="live-poll" data-on="Live polling" data-off="Live poll">
|
59
|
-
Live poll
|
60
|
-
</a>
|
61
|
-
</li>
|
62
|
-
</ul>
|
@@ -0,0 +1,28 @@
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
2
|
+
<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
3
|
+
<svg xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 646.99998 136.1" xml:space="preserve" sodipodi:docname="logo.svg" width="647" height="136.10001" inkscape:version="0.92.5 (2060ec1f9f, 2020-04-08)"><metadata id="metadata45"><rdf:RDF><cc:Work rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage"/></cc:Work></rdf:RDF></metadata><defs id="defs43"/><sodipodi:namedview pagecolor="#6c757d" bordercolor="#666666" borderopacity="1" objecttolerance="10" gridtolerance="10" guidetolerance="10" inkscape:pageopacity="0" inkscape:pageshadow="2" inkscape:window-width="1920" inkscape:window-height="1016" id="namedview41" showgrid="false" inkscape:zoom="1.3391547" inkscape:cx="198.39874" inkscape:cy="89.619887" inkscape:window-x="0" inkscape:window-y="27" inkscape:window-maximized="1" inkscape:current-layer="g22"/>
|
4
|
+
<style type="text/css" id="style2">
|
5
|
+
.st0{fill:#FFFFFF;}
|
6
|
+
.st1{fill:none;stroke:#0B0C1B;stroke-width:5.7629;stroke-miterlimit:10;}
|
7
|
+
.st2{fill:#BC2C40;}
|
8
|
+
.st3{fill:none;stroke:#0B0C1B;stroke-width:4.6103;stroke-linejoin:round;stroke-miterlimit:10;}
|
9
|
+
</style>
|
10
|
+
|
11
|
+
|
12
|
+
<g id="g22" transform="translate(-183.3,-50.9)">
|
13
|
+
<path d="m 217.7,151.7 -9.3,11.1 v 22.4 H 183.3 V 52.6 h 25.1 v 76.7 l 30.1,-37.1 h 29 l -33,39.2 36.2,53.7 h -30.1 z" id="path8" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
14
|
+
<path d="m 314.6,90.4 c 7.3,0 15.4,2 24.4,9.5 v -7.7 h 23.6 v 64.5 c 0,10.9 1.4,18.3 5,27.6 l -24,1.8 c -1.6,-3.8 -2.5,-8.4 -3.2,-12.2 -7.7,8.6 -18.3,13.1 -28.3,13.1 -18.5,0 -36.9,-16.3 -36.9,-48.4 0,-32.1 20.1,-48.2 39.4,-48.2 z m 5.4,75.1 c 5.9,0 12.4,-3 17.6,-8.1 v -38.5 c -5.9,-5 -11.3,-7 -16.5,-7 -11.1,0 -20.2,8.8 -20.2,26.7 -0.1,18.4 8.9,26.9 19.1,26.9 z" id="path10" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
15
|
+
<path d="m 389.7,92.2 h 23.6 v 24.6 c 5.6,-12.7 17.2,-23.3 32.8,-26.9 l 4.5,24.9 c -14.5,2.3 -27.6,13.9 -35.8,24.3 v 46.1 h -25.1 z" id="path12" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
16
|
+
<path d="m 497.2,90.4 c 7.3,0 15.4,2 24.4,9.5 v -7.7 h 23.6 v 64.5 c 0,10.9 1.4,18.3 5,27.6 l -24,1.8 c -1.6,-3.8 -2.5,-8.4 -3.2,-12.2 -7.7,8.6 -18.3,13.1 -28.3,13.1 -18.5,0 -36.9,-16.3 -36.9,-48.4 -0.1,-32.1 20,-48.2 39.4,-48.2 z m 5.3,75.1 c 5.9,0 12.4,-3 17.6,-8.1 v -38.5 c -5.9,-5 -11.3,-7 -16.5,-7 -11.1,0 -20.2,8.8 -20.2,26.7 0,18.4 8.9,26.9 19.1,26.9 z" id="path14" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
17
|
+
<path d="M 578.7,113.7 H 564.2 V 92.2 h 14.5 v -9.1 c 0,-18.6 9.5,-32.2 28.8,-32.2 5.7,0 12.4,1.1 20.1,3.6 l -4.8,21 c -4.1,-1.4 -7.2,-2 -9.9,-2 -6.6,0 -9.1,4.3 -9.1,10.6 v 8.2 h 23.8 v 21.5 h -23.8 v 71.5 h -25.1 z" id="path16" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
18
|
+
<path d="m 680.4,151.7 -9.3,11.1 v 22.4 H 646 V 52.6 h 25.1 v 76.7 l 30.1,-37.1 h 29 l -33,39.2 36.2,53.7 h -30.1 z" id="path18" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
19
|
+
<path d="m 777.3,90.4 c 7.3,0 15.4,2 24.4,9.5 v -7.7 h 23.6 v 64.5 c 0,10.9 1.4,18.3 5,27.6 l -24,1.8 c -1.6,-3.8 -2.5,-8.4 -3.2,-12.2 -7.7,8.6 -18.3,13.1 -28.3,13.1 -18.5,0 -36.9,-16.3 -36.9,-48.4 0,-32.1 20.1,-48.2 39.4,-48.2 z m 5.4,75.1 c 5.9,0 12.4,-3 17.6,-8.1 v -38.5 c -5.9,-5 -11.3,-7 -16.5,-7 -11.1,0 -20.2,8.8 -20.2,26.7 0,18.4 8.9,26.9 19.1,26.9 z" id="path20" inkscape:connector-curvature="0" style="fill:#6c757d;fill-opacity:1"/>
|
20
|
+
</g>
|
21
|
+
|
22
|
+
|
23
|
+
|
24
|
+
|
25
|
+
|
26
|
+
|
27
|
+
|
28
|
+
<style xmlns="" id="autoconsent-prehide"/></svg>
|
@@ -1,3 +1,4 @@
|
|
1
|
+
// Nicer display of time distance from a given event
|
1
2
|
function updateTimeAgo() {
|
2
3
|
var selection = document.querySelectorAll('time');
|
3
4
|
|
@@ -7,11 +8,15 @@ function updateTimeAgo() {
|
|
7
8
|
}
|
8
9
|
}
|
9
10
|
|
11
|
+
// To prevent from flickering, the UI is initially hidden and visible when all the JS components
|
12
|
+
// are fully initialized
|
10
13
|
function displayUi() {
|
11
14
|
var content = document.getElementById('content');
|
12
15
|
content.style.display = 'inherit';
|
13
16
|
}
|
14
17
|
|
18
|
+
// When using explorer, we can select the desired partition. This code redirects without having
|
19
|
+
// to press a button after a select
|
15
20
|
function redirectToPartition() {
|
16
21
|
var selector = document.getElementById('current-partition');
|
17
22
|
|
@@ -22,6 +27,27 @@ function redirectToPartition() {
|
|
22
27
|
});
|
23
28
|
}
|
24
29
|
|
30
|
+
// Binds to links and forms to make sure action is what user wants
|
31
|
+
function bindActionsConfirmations() {
|
32
|
+
var elements = document.getElementsByClassName('confirm-action')
|
33
|
+
var confirmation = 'Are you sure?'
|
34
|
+
|
35
|
+
for (var i = 0; i < elements.length; i++) {
|
36
|
+
let element = elements[i]
|
37
|
+
let action = 'click'
|
38
|
+
|
39
|
+
if (element.nodeName === 'FORM') {
|
40
|
+
action = 'submit'
|
41
|
+
}
|
42
|
+
|
43
|
+
element.addEventListener(action, function(event) {
|
44
|
+
if (!window.confirm(confirmation)) {
|
45
|
+
event.preventDefault();
|
46
|
+
}
|
47
|
+
})
|
48
|
+
}
|
49
|
+
}
|
50
|
+
|
25
51
|
function addListeners() {
|
26
52
|
bindPollingButtonClick();
|
27
53
|
setLivePollButton();
|
@@ -30,6 +56,10 @@ function addListeners() {
|
|
30
56
|
hljs.highlightAll();
|
31
57
|
updateTimeAgo();
|
32
58
|
redirectToPartition();
|
59
|
+
manageTabs();
|
60
|
+
manageCharts();
|
61
|
+
bindActionsConfirmations();
|
62
|
+
loadOffsetLookupDatePicker();
|
33
63
|
displayUi();
|
34
64
|
}
|
35
65
|
|