aboutsummaryrefslogtreecommitdiffstats
path: root/app/views
diff options
context:
space:
mode:
authorAlban Peignier2018-05-10 22:17:03 +0200
committerGitHub2018-05-10 22:17:03 +0200
commit764aa8a93bd3e25a83b3db70892ca06304edaa9c (patch)
treeb681730cec81ee6b721e8148f3fbcab691c3689b /app/views
parent093599f1c2e75ba2a4e3e9e8a6aa2cf665919886 (diff)
parent3364755e26c5a4a54a6de6080bf1177ee03c7183 (diff)
downloadchouette-core-764aa8a93bd3e25a83b3db70892ca06304edaa9c.tar.bz2
Merge pull request #555 from af83/6923-consolidated-offer
Display consolidated offer. Fixes #6923
Diffstat (limited to 'app/views')
-rw-r--r--app/views/referential_vehicle_journeys/_consolidated.html.slim33
-rw-r--r--app/views/referential_vehicle_journeys/_consolidated_line.html.slim119
-rw-r--r--app/views/referential_vehicle_journeys/_filters.html.slim14
-rw-r--r--app/views/referential_vehicle_journeys/_list.html.slim49
-rw-r--r--app/views/referential_vehicle_journeys/index.html.slim52
5 files changed, 217 insertions, 50 deletions
diff --git a/app/views/referential_vehicle_journeys/_consolidated.html.slim b/app/views/referential_vehicle_journeys/_consolidated.html.slim
new file mode 100644
index 000000000..e2de526bc
--- /dev/null
+++ b/app/views/referential_vehicle_journeys/_consolidated.html.slim
@@ -0,0 +1,33 @@
+.row.consolidated-view
+ - @consolidated.lines.each do |line|
+ = render partial: "consolidated_line", object: line
+ .col-md-12
+ = new_pagination @consolidated.paginated_lines, 'pull-right'
+
+coffee:
+ $('a.toggle-timetables').click (e)->
+ e.preventDefault()
+ $(e.target).toggleClass 'active'
+ $(e.target).parents('.table').find('.detailed-timetables').toggleClass 'hidden'
+
+ $('a.toggle-purchase-windows').click (e)->
+ e.preventDefault()
+ $(e.target).toggleClass 'active'
+ $(e.target).parents('.table').find('.detailed-purchase-windows').toggleClass 'hidden'
+
+ $('.route').find('.vehicle-journeys').each (i, e)->
+ $e = $(e)
+ $e.removeClass 'hidden'
+ e.setAttribute 'data-original-height', $e.height()
+ $e.height 0
+
+ $('a.toggle-route').click (e)->
+ e.preventDefault()
+ $(e.currentTarget).toggleClass 'active'
+ tab = $(e.currentTarget).parents('.route').find('.vehicle-journeys')
+ if tab.hasClass 'open'
+ tab.removeClass 'open'
+ tab.height 0
+ else
+ tab.addClass 'open'
+ tab.height tab.attr('data-original-height')
diff --git a/app/views/referential_vehicle_journeys/_consolidated_line.html.slim b/app/views/referential_vehicle_journeys/_consolidated_line.html.slim
new file mode 100644
index 000000000..d4c756d38
--- /dev/null
+++ b/app/views/referential_vehicle_journeys/_consolidated_line.html.slim
@@ -0,0 +1,119 @@
+.line.col-md-12
+ .head
+ span
+ = Chouette::Line.ts
+ |  
+ strong= consolidated_line.name
+ .routes
+ - consolidated_line.routes.each do |route|
+ .route
+ .head class="#{route.highlighted? ? 'highlighted' : ''}"
+ = link_to '#', class: 'toggle-route' do
+ span.sb.sb-route
+ |  
+ = Chouette::Route.ts
+ |  
+ strong= route.name
+ .pull-right
+ = route.highlighted_count
+ |  
+ = Chouette::VehicleJourney.t
+ |  
+ span.fa.fa-angle-up
+ .table.table-2entries.vehicle-journeys.hidden
+ .t2e-head.w20
+ .th
+ div
+ strong= Chouette::VehicleJourney.tmf(:id)
+ div= Chouette::VehicleJourney.tmf(:name)
+ div= Chouette::VehicleJourney.tmf(:journey_pattern_id)
+ div
+ = link_to '#', class: 'toggle-purchase-windows detailed-timetables-bt' do
+ span.fa.fa-angle-up
+ = Chouette::PurchaseWindow.t
+ .detailed-purchase-windows.hidden
+ - route.purchase_windows.uniq.each do |tt|
+ div
+ p
+ = link_to [@referential, tt] do
+ span.fa.fa-calendar style={color: (tt.color ? tt.color : '#4B4B4B')}
+ |  
+ = tt.name
+
+ p= tt.bounding_dates.split(' ').join(' > ')
+ div
+ = link_to '#', class: 'toggle-timetables detailed-timetables-bt' do
+ span.fa.fa-angle-up
+ = Chouette::TimeTable.t
+
+ .detailed-timetables.hidden
+ - route.time_tables.uniq.each do |tt|
+ div
+ p
+ = link_to [@referential, tt] do
+ span.fa.fa-calendar style={color: (tt.color ? tt.color : '#4B4B4B')}
+ |  
+ = tt.display_day_types
+
+ p= tt.bounding_dates.split(' ').join(' > ')
+ - prev_sp = nil
+ - route.stop_points.each do |sp|
+ ruby:
+ headline = vehicle_journey_stop_headline prev_sp, sp
+ prev_sp = sp
+ .td class="#{sp.highlighted? ? 'highlighted' : ''}"
+ div title="#{sp.stop_area.city_name ? "#{sp.stop_area.city_name} (#{sp.stop_area.zip_code})" : ''}" data-headline=headline class=(headline.present? ? 'headlined' : '')
+ span
+ = sp.name
+ - if sp.stop_area.time_zone_formatted_offset
+ span.small
+ |  
+ = "(#{sp.stop_area.time_zone_formatted_offset})"
+ .t2e-item-list.w80
+ div
+ - route.vehicle_journeys.each do |journey|
+ .t2e-item class="#{journey.highlighted? ? 'highlighted' : ''}"
+ .th
+ div
+ strong= link_to journey.id, [@referential, journey.route.line, journey.route, :vehicle_journeys]
+ div
+ = link_to journey.published_journey_name, [@referential, journey.route.line, journey.route, :vehicle_journeys], title: journey.published_journey_name
+ div= journey.journey_pattern.get_objectid.short_id
+ div
+ - journey.purchase_windows[0..3].each do |tt|
+ span.vj_tt
+ = link_to [@referential, tt], target: :blank do
+ span.fa.fa-calendar style="color: #{tt.color ? tt.color : '#4B4B4B'}"
+ - if journey.purchase_windows.size > 3
+ span.vj_tt = "+ #{journey.purchase_windows.size - 3}"
+ .detailed-purchase-windows.hidden
+ - route.purchase_windows.uniq.each do |tt|
+ div class=(journey.has_purchase_window?(tt) ? 'active' : 'inactive')
+ div
+ - journey.time_tables[0..3].each do |tt|
+ span.vj_tt
+ = link_to [@referential, tt], target: :blank do
+ span.fa.fa-calendar style="color: #{tt.color ? tt.color : '#4B4B4B'}"
+ - if journey.time_tables.size > 3
+ span.vj_tt = "+ #{journey.time_tables.size - 3}"
+ .detailed-timetables.hidden
+ - route.time_tables.uniq.each do |tt|
+ div class=(journey.has_time_table?(tt) ? 'active' : 'inactive')
+
+ - prev_sp = nil
+ - route.stop_points.each do |sp|
+ ruby:
+ headline = vehicle_journey_stop_headline prev_sp, sp
+ prev_sp = sp
+ vjas = journey.vehicle_journey_at_stops.where(stop_point_id: sp.id).last
+ .td class="#{vjas && sp.highlighted? ? 'highlighted' : ''} #{vjas.nil? ? 'disabled' : ''} #{headline.present? ? 'headlined' : ''}"
+ div title="#{sp.stop_area.city_name ? "#{sp.stop_area.city_name} (#{sp.stop_area.zip_code})" : ''}" data-headline=headline class=(headline.present? ? 'headlined' : '')
+ - if vjas.present?
+ - if vjas.departure_time == vjas.arrival_time
+ = vjas.departure_time.l(format: "%H:%M")
+ - else
+ = vjas.arrival_time.l(format: "%H:%M")
+ |  - 
+ = vjas.departure_time.l(format: "%H:%M")
+ - else
+ | 00:00
diff --git a/app/views/referential_vehicle_journeys/_filters.html.slim b/app/views/referential_vehicle_journeys/_filters.html.slim
index a6e289b97..31053c5ba 100644
--- a/app/views/referential_vehicle_journeys/_filters.html.slim
+++ b/app/views/referential_vehicle_journeys/_filters.html.slim
@@ -1,10 +1,20 @@
= search_form_for @q, url: referential_vehicle_journeys_path(@referential), html: {method: :get}, class: 'form form-filter' do |f|
- .ffg-row
+ input type="hidden" name="display" value=params[:display]
+ .ffg-row.w85
.input-group.search_bar
= f.search_field :published_journey_name_or_objectid_cont, placeholder: t('.published_journey_name_or_objectid'), class: 'form-control'
span.input-group-btn
button.btn.btn-default#search-btn type='submit'
span.fa.fa-search
+ .ffg-row.w15
+ - if has_feature?(:consolidated_offers)
+ .form-group
+ .btn-group
+ = link_to referential_vehicle_journeys_path(@referential, q: params[:q], display: :list), class: 'btn btn-default ' + (params[:display] != "consolidated" ? 'active' : '') do
+ span.fa.fa-align-justify
+ = link_to referential_vehicle_journeys_path(@referential, q: params[:q], display: :consolidated), class: 'btn btn-default ' + (params[:display] == "consolidated" ? 'active' : '') do
+ span.fa.fa-th-large
+
.ffg-row
.form-group.per-page-select
= I18n.t("simple_form.per_page")
@@ -73,5 +83,5 @@
.actions
- = link_to t('actions.erase'), referential_vehicle_journeys_path(@referential), class: 'btn btn-link'
+ = link_to t('actions.erase'), referential_vehicle_journeys_path(@referential, display: params[:display]), class: 'btn btn-link'
= f.submit t('actions.filter'), class: 'btn btn-default'
diff --git a/app/views/referential_vehicle_journeys/_list.html.slim b/app/views/referential_vehicle_journeys/_list.html.slim
new file mode 100644
index 000000000..74f8238f8
--- /dev/null
+++ b/app/views/referential_vehicle_journeys/_list.html.slim
@@ -0,0 +1,49 @@
+.row
+ .col-lg-12
+ .select_table
+ = table_builder_2 @vehicle_journeys,
+ [ \
+ TableBuilderHelper::Column.new( \
+ name: t('objectid'), \
+ attribute: Proc.new { |n| n.get_objectid.short_id }, \
+ sortable: false \
+ ), \
+ TableBuilderHelper::Column.new( \
+ key: :published_journey_name, \
+ attribute: 'published_journey_name', \
+ link_to: lambda do |vehicle_journey| \
+ vehicle_journey.published_journey_name ? referential_line_route_vehicle_journeys_path(@referential, vehicle_journey.route.line, vehicle_journey.route) : '' \
+ end, \
+ sortable: true \
+ ), \
+ TableBuilderHelper::Column.new( \
+ key: :line, \
+ attribute: Proc.new {|v| v.route.line.name}, \
+ sortable: true \
+ ), \
+ TableBuilderHelper::Column.new( \
+ key: :route, \
+ attribute: Proc.new {|v| v.route.name}, \
+ sortable: true \
+ ), \
+ TableBuilderHelper::Column.new( \
+ key: :departure_time, \
+ attribute: Proc.new {|v| v.vehicle_journey_at_stops.first&.departure_local }, \
+ sortable: true \
+ ), \
+ [@starting_stop, @ending_stop].compact.map{|stop| \
+ TableBuilderHelper::Column.new( \
+ attribute: Proc.new {|v| v.vehicle_journey_at_stops.where("stop_points.stop_area_id" => stop.id).last&.arrival_local }, \
+ sortable: false, \
+ name: stop.name \
+ )\
+ }, \
+ TableBuilderHelper::Column.new( \
+ key: :arrival_time, \
+ attribute: Proc.new {|v| v.vehicle_journey_at_stops.last&.arrival_local }, \
+ sortable: true, \
+ ), \
+ ].flatten.compact,
+ cls: 'table has-filter has-search'
+
+ = new_pagination @vehicle_journeys, 'pull-right'
diff --git a/app/views/referential_vehicle_journeys/index.html.slim b/app/views/referential_vehicle_journeys/index.html.slim
index 00f63cb65..d1d1dae07 100644
--- a/app/views/referential_vehicle_journeys/index.html.slim
+++ b/app/views/referential_vehicle_journeys/index.html.slim
@@ -9,55 +9,11 @@
= render 'filters'
- if @vehicle_journeys.present?
- .row
- .col-lg-12
- .select_table
- = table_builder_2 @vehicle_journeys,
- [ \
- TableBuilderHelper::Column.new( \
- name: t('objectid'), \
- attribute: Proc.new { |n| n.get_objectid.short_id }, \
- sortable: false \
- ), \
- TableBuilderHelper::Column.new( \
- key: :published_journey_name, \
- attribute: 'published_journey_name', \
- link_to: lambda do |vehicle_journey| \
- vehicle_journey.published_journey_name ? referential_line_route_vehicle_journeys_path(@referential, vehicle_journey.route.line, vehicle_journey.route) : '' \
- end, \
- sortable: true \
- ), \
- TableBuilderHelper::Column.new( \
- key: :line, \
- attribute: Proc.new {|v| v.route.line.name}, \
- sortable: true \
- ), \
- TableBuilderHelper::Column.new( \
- key: :route, \
- attribute: Proc.new {|v| v.route.name}, \
- sortable: true \
- ), \
- TableBuilderHelper::Column.new( \
- key: :departure_time, \
- attribute: Proc.new {|v| v.vehicle_journey_at_stops.first&.departure_local }, \
- sortable: true \
- ), \
- [@starting_stop, @ending_stop].compact.map{|stop| \
- TableBuilderHelper::Column.new( \
- attribute: Proc.new {|v| v.vehicle_journey_at_stops.where("stop_points.stop_area_id" => stop.id).last&.arrival_local }, \
- sortable: false, \
- name: stop.name \
- )\
- }, \
- TableBuilderHelper::Column.new( \
- key: :arrival_time, \
- attribute: Proc.new {|v| v.vehicle_journey_at_stops.last&.arrival_local }, \
- sortable: true, \
- ), \
- ].flatten.compact,
- cls: 'table has-filter has-search'
+ - if params[:display] == "consolidated" && has_feature?(:consolidated_offers)
+ = render partial: "consolidated"
+ - else
+ = render partial: "list"
- = new_pagination @vehicle_journeys, 'pull-right'
- unless @vehicle_journeys.any?
.row.mt-xs