Organisation can now be organised in kinds, and easily modified by moderators
This commit is contained in:
parent
ef7df97949
commit
0333a1ad68
2
Gemfile
2
Gemfile
@ -57,7 +57,7 @@ gem 'i18n-active_record',
|
|||||||
gem 'http_accept_language'
|
gem 'http_accept_language'
|
||||||
|
|
||||||
# A superb font to use as icons
|
# A superb font to use as icons
|
||||||
gem 'font-awesome-rails'
|
gem 'font-awesome-sass'
|
||||||
# Validate mails submitted
|
# Validate mails submitted
|
||||||
gem 'email_validator'
|
gem 'email_validator'
|
||||||
# Email address obfuscation
|
# Email address obfuscation
|
||||||
|
@ -146,8 +146,8 @@ GEM
|
|||||||
multipart-post (>= 1.2, < 3)
|
multipart-post (>= 1.2, < 3)
|
||||||
fastercsv (1.5.5)
|
fastercsv (1.5.5)
|
||||||
ffi (1.9.6)
|
ffi (1.9.6)
|
||||||
font-awesome-rails (4.3.0.0)
|
font-awesome-sass (4.3.1)
|
||||||
railties (>= 3.2, < 5.0)
|
sass (~> 3.2)
|
||||||
formatador (0.2.5)
|
formatador (0.2.5)
|
||||||
formtastic (3.1.3)
|
formtastic (3.1.3)
|
||||||
actionpack (>= 3.2.13)
|
actionpack (>= 3.2.13)
|
||||||
@ -426,7 +426,7 @@ DEPENDENCIES
|
|||||||
devise-i18n
|
devise-i18n
|
||||||
differ
|
differ
|
||||||
email_validator
|
email_validator
|
||||||
font-awesome-rails
|
font-awesome-sass
|
||||||
geocoder
|
geocoder
|
||||||
guard-brakeman
|
guard-brakeman
|
||||||
guard-bundler
|
guard-bundler
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
// Mixins
|
|
||||||
// --------------------------
|
|
||||||
|
|
||||||
@mixin fa-icon-rotate($degrees, $rotation) {
|
|
||||||
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation});
|
|
||||||
-webkit-transform: rotate($degrees);
|
|
||||||
-moz-transform: rotate($degrees);
|
|
||||||
-ms-transform: rotate($degrees);
|
|
||||||
-o-transform: rotate($degrees);
|
|
||||||
transform: rotate($degrees);
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin fa-icon-flip($horiz, $vert, $rotation) {
|
|
||||||
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation});
|
|
||||||
-webkit-transform: scale($horiz, $vert);
|
|
||||||
-moz-transform: scale($horiz, $vert);
|
|
||||||
-ms-transform: scale($horiz, $vert);
|
|
||||||
-o-transform: scale($horiz, $vert);
|
|
||||||
transform: scale($horiz, $vert);
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin fa-icon-base() {
|
|
||||||
&:before {
|
|
||||||
display: inline-block;
|
|
||||||
font-family: FontAwesome;
|
|
||||||
font-style: normal;
|
|
||||||
font-weight: normal;
|
|
||||||
line-height: 1;
|
|
||||||
-webkit-font-smoothing: antialiased;
|
|
||||||
-moz-osx-font-smoothing: grayscale;
|
|
||||||
margin-right: 5px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin fa-icon($icon-char) {
|
|
||||||
@include fa-icon-base();
|
|
||||||
&:before {
|
|
||||||
@if($icon-char != null) {
|
|
||||||
content: $icon-char;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,4 +1,5 @@
|
|||||||
@import compass
|
@import compass
|
||||||
|
@import font-awesome-sprockets
|
||||||
@import font-awesome
|
@import font-awesome
|
||||||
|
|
||||||
*
|
*
|
||||||
@ -134,6 +135,28 @@ main, body.mce-content-body
|
|||||||
min-height: 100%
|
min-height: 100%
|
||||||
font-family: Palatino, 'URW Palladio L', 'dejavu serif', georgia, serif
|
font-family: Palatino, 'URW Palladio L', 'dejavu serif', georgia, serif
|
||||||
|
|
||||||
|
aside
|
||||||
|
float: right
|
||||||
|
width: 16em
|
||||||
|
border: 1px solid #96CFFF
|
||||||
|
margin: 0 1.2em
|
||||||
|
padding: 5px
|
||||||
|
font-size: 0.7em
|
||||||
|
margin-right: -4em
|
||||||
|
background-color: #D6ECFF
|
||||||
|
+box-shadow(4px 4px 1em gray)
|
||||||
|
+border-radius(10px)
|
||||||
|
h1
|
||||||
|
font-weight: normal
|
||||||
|
border-bottom: 1px black solid
|
||||||
|
padding-bottom: 0.3em
|
||||||
|
h2
|
||||||
|
margin: 0
|
||||||
|
font-size: larger
|
||||||
|
a
|
||||||
|
padding: 0.5em 0
|
||||||
|
display: block
|
||||||
|
|
||||||
iframe
|
iframe
|
||||||
border: none
|
border: none
|
||||||
max-width: 100%
|
max-width: 100%
|
||||||
|
@ -14,17 +14,22 @@
|
|||||||
*= require_tree .
|
*= require_tree .
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@import 'awesome_mixins'
|
@import font-awesome-sprockets
|
||||||
|
@import font-awesome
|
||||||
|
|
||||||
body.application
|
body.application
|
||||||
&.infos h4
|
&.infos h4
|
||||||
text-align: left
|
text-align: left
|
||||||
|
|
||||||
&.infos main h2:first-child
|
&.infos, &.contact, &.rules
|
||||||
+fa-icon('')
|
main h2:first-child:before
|
||||||
|
+fa-icon()
|
||||||
|
margin-right: 0.4em
|
||||||
|
&.infos main h2:first-child:before
|
||||||
|
content: $fa-var-info
|
||||||
|
|
||||||
&.contact main h2:first-child
|
&.contact main h2:first-child:before
|
||||||
+fa-icon('')
|
content: $fa-var-envelope
|
||||||
|
|
||||||
&.rules main h2:first-child
|
&.rules main h2:first-child:before
|
||||||
+fa-icon('')
|
content: $fa-var-gavel
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
@import compass
|
@import compass
|
||||||
@import awesome_mixins
|
|
||||||
|
|
||||||
header.calendar-header
|
header.calendar-header
|
||||||
font-size: 1.5em
|
font-size: 1.5em
|
||||||
@ -116,28 +115,6 @@ body.events.show main
|
|||||||
h2
|
h2
|
||||||
margin-top: 1em
|
margin-top: 1em
|
||||||
|
|
||||||
aside#orga-list
|
|
||||||
float: right
|
|
||||||
width: 16em
|
|
||||||
border: 1px solid #96CFFF
|
|
||||||
margin: 0 1.2em
|
|
||||||
padding: 5px
|
|
||||||
font-size: 0.7em
|
|
||||||
margin-right: -4em
|
|
||||||
background-color: #D6ECFF
|
|
||||||
+box-shadow(4px 4px 1em gray)
|
|
||||||
+border-radius(10px)
|
|
||||||
h1
|
|
||||||
font-weight: normal
|
|
||||||
border-bottom: 1px black solid
|
|
||||||
padding-bottom: 0.3em
|
|
||||||
h2
|
|
||||||
margin: 0
|
|
||||||
font-size: larger
|
|
||||||
a
|
|
||||||
padding: 0.5em 0
|
|
||||||
display: block
|
|
||||||
|
|
||||||
#advises
|
#advises
|
||||||
border: 1px solid #FFB578
|
border: 1px solid #FFB578
|
||||||
padding-left: 10px
|
padding-left: 10px
|
||||||
@ -150,80 +127,6 @@ aside#orga-list
|
|||||||
a
|
a
|
||||||
color: #8F4900
|
color: #8F4900
|
||||||
|
|
||||||
.events form, .moderations form
|
|
||||||
.field, .actions
|
|
||||||
max-width: 70em
|
|
||||||
text-align: left
|
|
||||||
margin-left: auto
|
|
||||||
margin-right: auto
|
|
||||||
*
|
|
||||||
vertical-align: middle
|
|
||||||
.helper p
|
|
||||||
color: gray
|
|
||||||
margin: 0
|
|
||||||
font-style: italic
|
|
||||||
margin-left: 8em
|
|
||||||
padding-left: 0.4em
|
|
||||||
label
|
|
||||||
width: 8em
|
|
||||||
+inline-block()
|
|
||||||
input, select, .select2-container ul
|
|
||||||
+border-top-left-radius(0)
|
|
||||||
+border-bottom-left-radius(0)
|
|
||||||
input[type=radio] + label
|
|
||||||
width: 20em
|
|
||||||
&:after
|
|
||||||
content: ''
|
|
||||||
|
|
||||||
input[type=text], input[type=url], input[type=email],
|
|
||||||
.select2-container, .select2-container ul, .mce-tinymce
|
|
||||||
min-width: 22em
|
|
||||||
|
|
||||||
.mce-tinymce
|
|
||||||
font-size: inherit
|
|
||||||
font-family: inherit
|
|
||||||
+inline-block()
|
|
||||||
+border-radius(0.4em)
|
|
||||||
+border-top-left-radius(0)
|
|
||||||
+border-bottom-left-radius(0)
|
|
||||||
.mce-container-body
|
|
||||||
.mce-panel.mce-first
|
|
||||||
+border-top-right-radius(0.4em)
|
|
||||||
.mce-panel.mce-last
|
|
||||||
+border-bottom-right-radius(0.4em)
|
|
||||||
|
|
||||||
.field label:before
|
|
||||||
color: gray
|
|
||||||
.field.title label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.start_time label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.end_time label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.description label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.address label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.city label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.region label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.locality label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.contact label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.submitter label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.url label
|
|
||||||
+fa-icon('')
|
|
||||||
.field.tags label
|
|
||||||
+fa-icon('')
|
|
||||||
|
|
||||||
.actions
|
|
||||||
text-align: center
|
|
||||||
input
|
|
||||||
font-size: x-large
|
|
||||||
|
|
||||||
.description, body.mce-content-body
|
.description, body.mce-content-body
|
||||||
img
|
img
|
||||||
margin-left: 1%
|
margin-left: 1%
|
||||||
|
97
app/assets/stylesheets/form.css.sass
Normal file
97
app/assets/stylesheets/form.css.sass
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
@import compass
|
||||||
|
@import font-awesome-sprockets
|
||||||
|
@import font-awesome
|
||||||
|
|
||||||
|
.events form, .moderations form, .orgas form
|
||||||
|
.field, .actions
|
||||||
|
max-width: 70em
|
||||||
|
text-align: left
|
||||||
|
margin-left: auto
|
||||||
|
margin-right: auto
|
||||||
|
.helper p
|
||||||
|
color: gray
|
||||||
|
margin: 0
|
||||||
|
font-style: italic
|
||||||
|
margin-left: 8em
|
||||||
|
padding-left: 0.4em
|
||||||
|
label
|
||||||
|
width: 8em
|
||||||
|
+inline-block()
|
||||||
|
input, select, .select2-container ul
|
||||||
|
+border-top-left-radius(0)
|
||||||
|
+border-bottom-left-radius(0)
|
||||||
|
input[type=radio] + label
|
||||||
|
width: 20em
|
||||||
|
&:after
|
||||||
|
content: ''
|
||||||
|
|
||||||
|
input[type=text], input[type=url], input[type=email],
|
||||||
|
.select2-container, .select2-container ul, .mce-tinymce
|
||||||
|
min-width: 22em
|
||||||
|
|
||||||
|
.mce-tinymce
|
||||||
|
font-size: inherit
|
||||||
|
font-family: inherit
|
||||||
|
+inline-block()
|
||||||
|
+border-radius(0.4em)
|
||||||
|
+border-top-left-radius(0)
|
||||||
|
+border-bottom-left-radius(0)
|
||||||
|
.mce-container-body
|
||||||
|
.mce-panel.mce-first
|
||||||
|
+border-top-right-radius(0.4em)
|
||||||
|
.mce-panel.mce-last
|
||||||
|
+border-bottom-right-radius(0.4em)
|
||||||
|
|
||||||
|
.field label:before
|
||||||
|
color: gray
|
||||||
|
margin-right: 0.4em
|
||||||
|
+fa-icon()
|
||||||
|
.field.title label:before
|
||||||
|
content: $fa-var-newspaper-o
|
||||||
|
.field.start_time label:before
|
||||||
|
content: $fa-var-toggle-on
|
||||||
|
.field.end_time label:before
|
||||||
|
content: $fa-var-toggle-off
|
||||||
|
.field.description label:before
|
||||||
|
content: $fa-var-pencil-square-o
|
||||||
|
.field.address label:before
|
||||||
|
content: $fa-var-map-marker
|
||||||
|
.field.city label:before
|
||||||
|
content: $fa-var-compress
|
||||||
|
.field.region label:before
|
||||||
|
content: $fa-var-shield
|
||||||
|
.field.locality > label:before
|
||||||
|
content: $fa-var-expand
|
||||||
|
.field.contact label:before
|
||||||
|
content: $fa-var-envelope
|
||||||
|
.field.submitter label:before
|
||||||
|
content: $fa-var-envelope-o
|
||||||
|
.field.url label:before
|
||||||
|
content: $fa-var-external-link
|
||||||
|
.field.tags label:before
|
||||||
|
content: $fa-var-tags
|
||||||
|
|
||||||
|
.field.kind > label:before
|
||||||
|
content: $fa-var-cubes
|
||||||
|
.field.feed label:before
|
||||||
|
content: $fa-var-rss
|
||||||
|
|
||||||
|
.field .radios label
|
||||||
|
width: auto !important
|
||||||
|
margin-right: 1em
|
||||||
|
|
||||||
|
[type=radio]
|
||||||
|
display: none
|
||||||
|
[type=radio] + label:before
|
||||||
|
color: black
|
||||||
|
content: $fa-var-circle-o
|
||||||
|
font-size: larger
|
||||||
|
[type=radio]:checked + label:before
|
||||||
|
color: black
|
||||||
|
content: $fa-var-dot-circle-o
|
||||||
|
+text-shadow(0 0 1px gray)
|
||||||
|
|
||||||
|
.actions
|
||||||
|
text-align: center
|
||||||
|
input
|
||||||
|
font-size: x-large
|
@ -14,7 +14,7 @@
|
|||||||
&.event
|
&.event
|
||||||
height: 20em
|
height: 20em
|
||||||
|
|
||||||
.tags, .orgas
|
.tags
|
||||||
#map
|
#map
|
||||||
width: 40%
|
width: 40%
|
||||||
height: 60em
|
height: 60em
|
||||||
|
@ -40,7 +40,9 @@ form#orga_search
|
|||||||
span.label
|
span.label
|
||||||
display: none
|
display: none
|
||||||
|
|
||||||
body.show main
|
body.orgas.show main
|
||||||
|
fieldset.orga
|
||||||
|
min-width: 60em
|
||||||
dl, iframe, fieldset
|
dl, iframe, fieldset
|
||||||
min-width: 30em
|
min-width: 30em
|
||||||
+inline-block()
|
+inline-block()
|
||||||
|
@ -20,7 +20,7 @@ class EventsController < ApplicationController
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# GET /users/new
|
# GET /events/new
|
||||||
def new
|
def new
|
||||||
@event = Event.new start_time: Time.now.change(min: 0) + 1.day + 1.hour,
|
@event = Event.new start_time: Time.now.change(min: 0) + 1.day + 1.hour,
|
||||||
end_time: Time.now.change(min: 0) + 1.day + 2.hour
|
end_time: Time.now.change(min: 0) + 1.day + 2.hour
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# Groups life cycle
|
# Groups life cycle
|
||||||
class OrgasController < ApplicationController
|
class OrgasController < ApplicationController
|
||||||
before_action :set_orga, only: [:show]
|
before_action :authenticate_user!, only: [:new, :edit, :update, :destroy]
|
||||||
|
before_action :set_orga, except: [:index, :new, :create]
|
||||||
|
|
||||||
def index
|
def index
|
||||||
@search = Orga.search params[:q]
|
@search = Orga.search params[:q]
|
||||||
@ -8,6 +9,28 @@ class OrgasController < ApplicationController
|
|||||||
@orgas = @search.result.page params[:page]
|
@orgas = @search.result.page params[:page]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# GET /orgas/new
|
||||||
|
def new
|
||||||
|
@orga = Orga.new
|
||||||
|
end
|
||||||
|
|
||||||
|
# POST /orgas
|
||||||
|
# POST /orgas.json
|
||||||
|
def create
|
||||||
|
@orga = Orga.new orga_params
|
||||||
|
respond_to do |format|
|
||||||
|
if @orga.save # && send_creation_mails
|
||||||
|
format.html { redirect_to :root, notice: t('.ok') }
|
||||||
|
# 201 means :created
|
||||||
|
format.json { render action: 'show', status: 201, location: @orga }
|
||||||
|
else
|
||||||
|
format.html { render action: 'new' }
|
||||||
|
# 422 means :unprocessable_entity
|
||||||
|
format.json { render json: @orga.errors, status: 422 }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def show
|
def show
|
||||||
@search = Orga.search params[:q]
|
@search = Orga.search params[:q]
|
||||||
|
|
||||||
@ -15,10 +38,33 @@ class OrgasController < ApplicationController
|
|||||||
@events_past = Event.moderated.past.tag @orga.name
|
@events_past = Event.moderated.past.tag @orga.name
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# PATCH/PUT /orgas/1
|
||||||
|
# PATCH/PUT /orgas/1.json
|
||||||
|
def update
|
||||||
|
respond_to do |format|
|
||||||
|
if @orga.update(orga_params) # && send_update_mails
|
||||||
|
format.html { redirect_to @orga, notice: t('.ok') }
|
||||||
|
format.json { head :no_content }
|
||||||
|
else
|
||||||
|
format.html { render action: 'edit' }
|
||||||
|
# 422 means :unprocessable_entity
|
||||||
|
format.json { render json: @orga.errors, status: 422 }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
# Use callbacks to share common setup or constraints between actions.
|
# Use callbacks to share common setup or constraints between actions.
|
||||||
def set_orga
|
def set_orga
|
||||||
@orga = Orga.find params[:id]
|
@orga = Orga.find params[:id]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Never trust parameters from the scary internet, only allow the white list
|
||||||
|
# through
|
||||||
|
def orga_params
|
||||||
|
params.require(:orga)
|
||||||
|
.permit :lock_version, :kind_id, :name, :city, :department, :region_id,
|
||||||
|
:url, :feed, :contact, :submitter
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
4
app/models/kind.rb
Normal file
4
app/models/kind.rb
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
# Gives the possibility to organise organisations! :)
|
||||||
|
class Kind < ActiveRecord::Base
|
||||||
|
has_many :orgas
|
||||||
|
end
|
@ -1,4 +1,21 @@
|
|||||||
# Groups related to this agenda
|
# Groups related to this agenda
|
||||||
class Orga < ActiveRecord::Base
|
class Orga < ActiveRecord::Base
|
||||||
belongs_to :region
|
belongs_to :region
|
||||||
|
belongs_to :kind
|
||||||
|
|
||||||
|
validates :kind, presence: true
|
||||||
|
validates :name, presence: true
|
||||||
|
validates :region, presence: true
|
||||||
|
validates :url, format: %r{\Ahttps?:\/\/.*\..*\z}
|
||||||
|
validates :feed, allow_blank: true, format: %r{\Ahttps?:\/\/.*\..*\z}
|
||||||
|
validates :contact, allow_blank: true, email: true
|
||||||
|
validates :submitter, allow_blank: true, email: true
|
||||||
|
|
||||||
|
before_validation on: :create do
|
||||||
|
self.submission_time = DateTime.now
|
||||||
|
self.decision_time = DateTime.now
|
||||||
|
|
||||||
|
# Populate submitter using contact info if absent
|
||||||
|
self.submitter ||= contact
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
@ -43,14 +43,18 @@
|
|||||||
%option= city
|
%option= city
|
||||||
.field.region
|
.field.region
|
||||||
= f.label :region
|
= f.label :region
|
||||||
= f.select :region_id,
|
= f.collection_select :region_id, Region.all, :id, :name
|
||||||
options_from_collection_for_select(Region.all, 'id', 'name',
|
|
||||||
@event.region_id)
|
|
||||||
.field.locality
|
.field.locality
|
||||||
= f.label :locality
|
= f.label :locality
|
||||||
= f.select :locality,
|
%span.radios
|
||||||
options_for_select([[t('attributes.locality_0'), 0],
|
= f.radio_button :locality, 0
|
||||||
[t('attributes.locality_1'), 1]], @event.locality)
|
= f.label 'locality_0' do
|
||||||
|
%em.fa.fa-shield
|
||||||
|
= t 'attributes.locality_0'
|
||||||
|
= f.radio_button :locality, 1
|
||||||
|
= f.label 'locality_1' do
|
||||||
|
%em.fa.fa-globe
|
||||||
|
= t 'attributes.locality_1'
|
||||||
|
|
||||||
.field.url
|
.field.url
|
||||||
.helper
|
.helper
|
||||||
|
@ -19,6 +19,6 @@
|
|||||||
|
|
||||||
%fieldset
|
%fieldset
|
||||||
%legend
|
%legend
|
||||||
%em.fa.fa-pencil
|
%em.fa.fa-plus
|
||||||
=t '.edit'
|
=t '.edit'
|
||||||
= render 'form'
|
= render 'form'
|
||||||
|
@ -14,11 +14,14 @@
|
|||||||
%h1
|
%h1
|
||||||
%em.fa.fa-users
|
%em.fa.fa-users
|
||||||
= t '.orga-list'
|
= t '.orga-list'
|
||||||
- if @event.region
|
%ul.fa-ul
|
||||||
%ul
|
- @event.region.orgas.each do |orga|
|
||||||
- @event.region.orgas.order(department: :asc).each do |orga|
|
|
||||||
%li
|
%li
|
||||||
= link_to orga.name, orga
|
= link_to orga do
|
||||||
|
- if orga.kind
|
||||||
|
%em.fa.fa-li{ class: "fa-#{orga.kind.icon}",
|
||||||
|
title: Kind.human_attribute_name("name_#{orga.kind.name}") }
|
||||||
|
= orga.name
|
||||||
(#{orga.department})
|
(#{orga.department})
|
||||||
= link_to orga.url do
|
= link_to orga.url do
|
||||||
= image_tag orga.url + '/favicon.ico', alt: '', class: :favicon
|
= image_tag orga.url + '/favicon.ico', alt: '', class: :favicon
|
||||||
@ -84,11 +87,15 @@
|
|||||||
tags: %w(p h1 h2 h3 h4 br table tr th td ul ol li a strong b em i img),
|
tags: %w(p h1 h2 h3 h4 br table tr th td ul ol li a strong b em i img),
|
||||||
attributes: %w(href src width height style)
|
attributes: %w(href src width height style)
|
||||||
|
|
||||||
%h3= t '.infos'
|
%h3
|
||||||
|
%em.fa.fa-info-circle
|
||||||
|
= t '.infos'
|
||||||
%p
|
%p
|
||||||
|
%em.fa.fa-external-link
|
||||||
%span.label= Event.human_attribute_name :url
|
%span.label= Event.human_attribute_name :url
|
||||||
= link_to @event.url, @event.url
|
= link_to @event.url, @event.url
|
||||||
%p
|
%p
|
||||||
|
%em.fa.fa-envelope
|
||||||
%span.label= Event.human_attribute_name :contact
|
%span.label= Event.human_attribute_name :contact
|
||||||
= mail_to @event.contact, nil,
|
= mail_to @event.contact, nil,
|
||||||
encode: (request.format == 'text/html' ? :javascript : nil),
|
encode: (request.format == 'text/html' ? :javascript : nil),
|
||||||
@ -96,6 +103,7 @@
|
|||||||
|
|
||||||
- if @event.tags && @event.tags.present?
|
- if @event.tags && @event.tags.present?
|
||||||
%p.tags
|
%p.tags
|
||||||
|
%em.fa.fa-tags
|
||||||
%span.label= Event.human_attribute_name :tags
|
%span.label= Event.human_attribute_name :tags
|
||||||
- @event.tags.split.each do |tag|
|
- @event.tags.split.each do |tag|
|
||||||
= link_to tag, tag_path(tag), rel: :tag
|
= link_to tag, tag_path(tag), rel: :tag
|
||||||
|
59
app/views/orgas/_form.html.haml
Normal file
59
app/views/orgas/_form.html.haml
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
= form_for @orga do |f|
|
||||||
|
- if @orga.errors.any?
|
||||||
|
#flash_messages
|
||||||
|
- @orga.errors.full_messages.each do |msg|
|
||||||
|
%p.flash.alert= msg
|
||||||
|
|
||||||
|
.field.kind
|
||||||
|
= f.label :kind
|
||||||
|
%span.radios
|
||||||
|
- Kind.all.each do |kind|
|
||||||
|
= f.radio_button :kind_id, kind.id
|
||||||
|
= f.label "kind_id_#{kind.id}" do
|
||||||
|
%em.fa{ class: "fa-#{kind.icon}" }
|
||||||
|
= Kind.human_attribute_name "name_#{kind.name}"
|
||||||
|
.field.name
|
||||||
|
= f.label :name
|
||||||
|
= f.text_field :name, required: true
|
||||||
|
.field.city
|
||||||
|
= f.label :city
|
||||||
|
= f.text_field :city, list: :cities
|
||||||
|
%datalist#cities
|
||||||
|
- Event.group(:city).order('count(city) desc').pluck(:city).each do |city|
|
||||||
|
%option= city
|
||||||
|
.field.department
|
||||||
|
= f.label :department
|
||||||
|
= f.text_field :department
|
||||||
|
.field.region
|
||||||
|
= f.label :region
|
||||||
|
= f.collection_select :region_id, Region.all, :id, :name
|
||||||
|
|
||||||
|
.field.url
|
||||||
|
.helper
|
||||||
|
:markdown
|
||||||
|
#{t '.url_helper'}
|
||||||
|
= f.label :url
|
||||||
|
= f.url_field :url, placeholder: 'Ex: http://april.org'
|
||||||
|
.field.feed
|
||||||
|
.helper
|
||||||
|
:markdown
|
||||||
|
#{t '.feed_helper'}
|
||||||
|
= f.label :feed
|
||||||
|
= f.url_field :feed, placeholder: 'Ex: http://april.org/index.rss'
|
||||||
|
.field.contact
|
||||||
|
.helper
|
||||||
|
:markdown
|
||||||
|
#{t '.contact_helper'}
|
||||||
|
= f.label :contact
|
||||||
|
= f.email_field :contact
|
||||||
|
.field.submitter
|
||||||
|
.helper
|
||||||
|
:markdown
|
||||||
|
#{t '.submitter_helper'}
|
||||||
|
= f.label :submitter
|
||||||
|
= f.email_field :submitter
|
||||||
|
|
||||||
|
.actions
|
||||||
|
= f.button do
|
||||||
|
%em.fa.fa-check
|
||||||
|
= t '.save'
|
9
app/views/orgas/edit.html.haml
Normal file
9
app/views/orgas/edit.html.haml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
%h2
|
||||||
|
%em.fa.fa-users
|
||||||
|
= title t '.title'
|
||||||
|
|
||||||
|
%fieldset
|
||||||
|
%legend
|
||||||
|
%em.fa.fa-pencil
|
||||||
|
= t '.edit'
|
||||||
|
= render 'form'
|
@ -6,6 +6,7 @@
|
|||||||
|
|
||||||
%table.list.autopagerize_page_element
|
%table.list.autopagerize_page_element
|
||||||
%thead
|
%thead
|
||||||
|
%th= sort_link @search, :kind_name, Orga.human_attribute_name(:kind)
|
||||||
%th= sort_link @search, :name
|
%th= sort_link @search, :name
|
||||||
%th= sort_link @search, :city
|
%th= sort_link @search, :city
|
||||||
%th= sort_link @search, :department
|
%th= sort_link @search, :department
|
||||||
@ -17,9 +18,13 @@
|
|||||||
- @orgas.each do |orga|
|
- @orgas.each do |orga|
|
||||||
%tr
|
%tr
|
||||||
%td
|
%td
|
||||||
|
- if orga.kind
|
||||||
|
%em.fa{ class: "fa-#{orga.kind.icon}",
|
||||||
|
title: Kind.human_attribute_name("name_#{orga.kind.name}") }
|
||||||
|
%td
|
||||||
|
= orga.name
|
||||||
- if orga.url =~ /^http/
|
- if orga.url =~ /^http/
|
||||||
= image_tag orga.url + '/favicon.ico', alt: '', class: :favicon
|
= image_tag orga.url + '/favicon.ico', alt: '', class: :favicon
|
||||||
= orga.name
|
|
||||||
%td
|
%td
|
||||||
= orga.city
|
= orga.city
|
||||||
%td
|
%td
|
||||||
|
9
app/views/orgas/new.html.haml
Normal file
9
app/views/orgas/new.html.haml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
%h2
|
||||||
|
%em.fa.fa-users
|
||||||
|
= title t '.title'
|
||||||
|
|
||||||
|
%fieldset
|
||||||
|
%legend
|
||||||
|
%em.fa.fa-pencil
|
||||||
|
= t '.edit'
|
||||||
|
= render 'form'
|
@ -2,84 +2,97 @@
|
|||||||
|
|
||||||
= render 'search'
|
= render 'search'
|
||||||
|
|
||||||
%h2
|
|
||||||
= image_tag @orga.url + '/favicon.ico', alt: '', class: :favicon
|
|
||||||
= title @orga.name
|
|
||||||
|
|
||||||
%nav
|
%nav
|
||||||
= link_to orgas_path(q: params[:q], page: params[:page]), class: :back do
|
= link_to orgas_path(q: params[:q], page: params[:page]), class: :back do
|
||||||
%em.fa.fa-arrow-left
|
%em.fa.fa-arrow-left
|
||||||
= Orga.model_name.human.pluralize
|
= Orga.model_name.human.pluralize
|
||||||
\/
|
|
||||||
|
%fieldset.orga
|
||||||
|
%aside
|
||||||
|
%h1
|
||||||
|
%em.fa.fa-link
|
||||||
|
= t '.links'
|
||||||
|
|
||||||
|
%ul.fa-ul
|
||||||
|
%li
|
||||||
= link_to events_path tag: @orga.name do
|
= link_to events_path tag: @orga.name do
|
||||||
%em.fa.fa-calendar
|
%em.fa.fa-li.fa-calendar
|
||||||
Agenda
|
Agenda
|
||||||
\/
|
|
||||||
|
%li
|
||||||
= link_to events_path format: :rss, tag: @orga.name do
|
= link_to events_path format: :rss, tag: @orga.name do
|
||||||
%em.fa.fa-rss
|
%em.fa.fa-li.fa-rss
|
||||||
RSS
|
RSS
|
||||||
\/
|
|
||||||
|
%li
|
||||||
= link_to events_path format: :ics, tag: @orga.name do
|
= link_to events_path format: :ics, tag: @orga.name do
|
||||||
%em.fa.fa-th-list
|
%em.fa.fa-li.fa-th-list
|
||||||
iCal
|
iCal
|
||||||
\/
|
|
||||||
|
%li
|
||||||
= link_to maps_path tag: @orga.name do
|
= link_to maps_path tag: @orga.name do
|
||||||
%em.fa.fa-map-marker
|
%em.fa.fa-li.fa-map-marker
|
||||||
OpenStreetMap
|
OpenStreetMap
|
||||||
\/
|
|
||||||
|
%li
|
||||||
= link_to maps_path format: :json, tag: @orga.name do
|
= link_to maps_path format: :json, tag: @orga.name do
|
||||||
%em.fa.fa-dot-circle-o
|
%em.fa.fa-li.fa-dot-circle-o
|
||||||
GeoJSON
|
GeoJSON
|
||||||
|
|
||||||
|
- if user_signed_in?
|
||||||
|
%h1
|
||||||
|
%em.fa.fa-wrench
|
||||||
|
= t '.actions'
|
||||||
|
%h2
|
||||||
|
= link_to edit_orga_path @orga do
|
||||||
|
%em.fa.fa-lg.fa-pencil
|
||||||
|
= t '.edit'
|
||||||
|
|
||||||
|
%h2
|
||||||
|
- if @orga.kind
|
||||||
|
%em.fa{ class: "fa-#{@orga.kind.icon}",
|
||||||
|
title: Kind.human_attribute_name("name_#{@orga.kind.name}") }
|
||||||
|
= title @orga.name
|
||||||
|
= image_tag @orga.url + '/favicon.ico', alt: '', class: :favicon
|
||||||
|
|
||||||
%dl
|
%dl
|
||||||
- if @orga.city.present?
|
- if @orga.city.present?
|
||||||
%dt= Orga.human_attribute_name :city
|
%dt
|
||||||
|
%em.fa.fa-compress
|
||||||
|
= Orga.human_attribute_name :city
|
||||||
%dd= @orga.city
|
%dd= @orga.city
|
||||||
- if @orga.department.present?
|
- if @orga.department.present?
|
||||||
%dt= Orga.human_attribute_name :department
|
%dt= Orga.human_attribute_name :department
|
||||||
%dd= @orga.department
|
%dd= @orga.department
|
||||||
- if @orga.region.present?
|
- if @orga.region.present?
|
||||||
%dt= Orga.human_attribute_name :region
|
%dt
|
||||||
|
%em.fa.fa-shield
|
||||||
|
= Orga.human_attribute_name :region
|
||||||
%dd= @orga.region
|
%dd= @orga.region
|
||||||
- if @orga.url.present?
|
- if @orga.url.present?
|
||||||
%dt= Orga.human_attribute_name :url
|
%dt
|
||||||
|
%em.fa.fa-external-link
|
||||||
|
= Orga.human_attribute_name :url
|
||||||
%dd= link_to @orga.url, @orga.url
|
%dd= link_to @orga.url, @orga.url
|
||||||
|
- if @orga.feed.present?
|
||||||
%iframe{ src: @orga.url, width: '1280', height: '300', frameborder: 'none',
|
%dt
|
||||||
allowTransparency: 'true' }
|
%em.fa.fa-rss
|
||||||
|
= Orga.human_attribute_name :feed
|
||||||
- if @events_future.any? || @events_past.any?
|
%dd= link_to @orga.feed, @orga.feed
|
||||||
%fieldset
|
- if @orga.contact.present?
|
||||||
%legend
|
%dt
|
||||||
%em.fa.fa-calendar
|
%em.fa.fa-envelope
|
||||||
= Event.model_name.human.pluralize
|
= Event.human_attribute_name :contact
|
||||||
|
%dd= mail_to @orga.contact, nil,
|
||||||
|
encode: (request.format == 'text/html' ? :javascript : nil),
|
||||||
|
replace_at: ' CHEZ ', replace_dot: ' POINT '
|
||||||
|
|
||||||
- if @events_future.any?
|
- if @events_future.any?
|
||||||
%h3= raw t 'future', count: @events_future.count
|
%dt= t '.future'
|
||||||
%ul.fa-ul
|
%dd= t '.count', count: @events_future.count
|
||||||
- @events_future.order('start_time asc').each do |event|
|
|
||||||
%li
|
|
||||||
= link_to event do
|
|
||||||
- if event.locality?
|
|
||||||
%em.locality.fa-li.fa.fa-globe(title="#{Event.human_attribute_name :locality} #{t 'attributes.locality_1'}")
|
|
||||||
- else
|
|
||||||
%em.locality.fa-li.fa.fa-shield(title="#{Event.human_attribute_name :locality} #{t 'attributes.locality_0'}")
|
|
||||||
%em.city= event.city
|
|
||||||
= event.title
|
|
||||||
.date= display_date event
|
|
||||||
|
|
||||||
- if @events_past.any?
|
- if @events_past.any?
|
||||||
%h3= raw t 'past', count: @events_past.count
|
%dt= t '.past'
|
||||||
%ul.fa-ul
|
%dd= t '.count', count: @events_past.count
|
||||||
- @events_past.order('start_time desc').each do |event|
|
|
||||||
%li
|
|
||||||
= link_to event do
|
|
||||||
- if event.locality?
|
|
||||||
%em.locality.fa-li.fa.fa-globe(title="#{Event.human_attribute_name :locality} #{t 'attributes.locality_1'}")
|
|
||||||
- else
|
|
||||||
%em.locality.fa-li.fa.fa-shield(title="#{Event.human_attribute_name :locality} #{t 'attributes.locality_0'}")
|
|
||||||
%em.city= event.city
|
|
||||||
= event.title
|
|
||||||
.date= display_date event
|
|
||||||
|
|
||||||
.events#map{ data: { url: maps_path(format: :json, tag: @orga.name) } }
|
.events#map{ data: { url: maps_path(format: :json, tag: @orga.name,
|
||||||
|
future: false) } }
|
||||||
|
@ -33,10 +33,22 @@ en:
|
|||||||
inseecode: INSEE code
|
inseecode: INSEE code
|
||||||
regioncode: Region code
|
regioncode: Region code
|
||||||
orga:
|
orga:
|
||||||
region: Region
|
kind: Type
|
||||||
department: Department
|
name: Name
|
||||||
url: Web address
|
|
||||||
city: City
|
city: City
|
||||||
|
department: Department
|
||||||
|
region: Region
|
||||||
|
url: Web address
|
||||||
|
feed: Syndication
|
||||||
|
contact: Contact
|
||||||
|
submitter: Soumetteur
|
||||||
|
submission_time: En attente depuis
|
||||||
|
kind:
|
||||||
|
name_association: Association
|
||||||
|
name_enterprise: Enterprise
|
||||||
|
name_lug: LUG
|
||||||
|
name_provider: ISP
|
||||||
|
name_institution: Institution
|
||||||
event:
|
event:
|
||||||
title: Title
|
title: Title
|
||||||
start_time: Start
|
start_time: Start
|
||||||
|
@ -16,6 +16,7 @@ fr:
|
|||||||
event: Événement
|
event: Événement
|
||||||
user: Modérateur
|
user: Modérateur
|
||||||
orga: Asso
|
orga: Asso
|
||||||
|
kind: Type
|
||||||
city: Ville
|
city: Ville
|
||||||
region: Région
|
region: Région
|
||||||
admin_user: Admin
|
admin_user: Admin
|
||||||
@ -33,10 +34,22 @@ fr:
|
|||||||
inseecode: Code INSEE
|
inseecode: Code INSEE
|
||||||
regioncode: Code région
|
regioncode: Code région
|
||||||
orga:
|
orga:
|
||||||
|
kind: Type
|
||||||
|
name: Nom
|
||||||
city: Ville
|
city: Ville
|
||||||
department: Département
|
department: Département
|
||||||
region: Région
|
region: Région
|
||||||
url: Adresse web
|
url: Adresse web
|
||||||
|
feed: Syndication
|
||||||
|
contact: Contact
|
||||||
|
submitter: Soumetteur
|
||||||
|
submission_time: En attente depuis
|
||||||
|
kind:
|
||||||
|
name_association: Association
|
||||||
|
name_enterprise: Entreprise
|
||||||
|
name_lug: GUL
|
||||||
|
name_provider: FAI
|
||||||
|
name_institution: Institution
|
||||||
event:
|
event:
|
||||||
title: Titre
|
title: Titre
|
||||||
start_time: Début
|
start_time: Début
|
||||||
|
@ -9,14 +9,6 @@ en:
|
|||||||
logout: Disconnect
|
logout: Disconnect
|
||||||
staleObjectError: Sorry, your modification was rejected because someone else
|
staleObjectError: Sorry, your modification was rejected because someone else
|
||||||
already intervened
|
already intervened
|
||||||
future:
|
|
||||||
zero:
|
|
||||||
one: "<strong>In the future</strong>, %{count} event:"
|
|
||||||
other: "<strong>In the future</strong>, %{count} evens:"
|
|
||||||
past:
|
|
||||||
zero:
|
|
||||||
one: "<strong>In the past</strong>, %{count} event:"
|
|
||||||
other: "<strong>In the past</strong>, %{count} events:"
|
|
||||||
|
|
||||||
# Translatings screens
|
# Translatings screens
|
||||||
layouts:
|
layouts:
|
||||||
@ -42,7 +34,7 @@ en:
|
|||||||
calendar_in: This calendar in %{rss}, %{webcal} or %{ical}
|
calendar_in: This calendar in %{rss}, %{webcal} or %{ical}
|
||||||
nb_events: "%{count} events"
|
nb_events: "%{count} events"
|
||||||
show:
|
show:
|
||||||
orga-list: Region's associations
|
orga-list: Region's orgas
|
||||||
add_to_calendar: Add to my calendar
|
add_to_calendar: Add to my calendar
|
||||||
copy: Duplicate event
|
copy: Duplicate event
|
||||||
at: At
|
at: At
|
||||||
@ -76,7 +68,7 @@ telegraphic style.
|
|||||||
it more readable or agreable.
|
it more readable or agreable.
|
||||||
"
|
"
|
||||||
preview: Previsualisation
|
preview: Previsualisation
|
||||||
edit: Edition
|
edit: Creation
|
||||||
create:
|
create:
|
||||||
ok: Your event was added to the lists of events waiting for moderation.
|
ok: Your event was added to the lists of events waiting for moderation.
|
||||||
It will appear online as soon as a moderator validates it.
|
It will appear online as soon as a moderator validates it.
|
||||||
@ -242,6 +234,32 @@ description."
|
|||||||
search:
|
search:
|
||||||
title: Find your %{entity}!
|
title: Find your %{entity}!
|
||||||
label: Search
|
label: Search
|
||||||
|
show:
|
||||||
|
links: Links
|
||||||
|
actions: Actions
|
||||||
|
edit: Edit
|
||||||
|
future: Coming
|
||||||
|
past: In the past
|
||||||
|
count:
|
||||||
|
zero:
|
||||||
|
one: one event
|
||||||
|
other: "%{count} events"
|
||||||
|
new:
|
||||||
|
title: Organisation
|
||||||
|
edit: Creation
|
||||||
|
edit:
|
||||||
|
title: Organisation
|
||||||
|
edit: Edition
|
||||||
|
form:
|
||||||
|
url_helper: Link toe the organisation's website
|
||||||
|
feed_helper: "**Direct** link to a syndication feed, RSS or atom"
|
||||||
|
contact_helper: Contact's email address, obfuscated so that spammers
|
||||||
|
won't understand it
|
||||||
|
submitter_helper: Submitter's email address. It will only be used by the
|
||||||
|
moderators to contact the person who proposed the event, to inform her
|
||||||
|
about her acceptation or rejection. If this address is absent, the
|
||||||
|
contact's will be used
|
||||||
|
save: Save
|
||||||
|
|
||||||
devise:
|
devise:
|
||||||
sessions:
|
sessions:
|
||||||
|
@ -9,14 +9,6 @@ fr:
|
|||||||
logout: Se déconnecter
|
logout: Se déconnecter
|
||||||
staleObjectError: Désolé, votre modification est rejetée car une autre
|
staleObjectError: Désolé, votre modification est rejetée car une autre
|
||||||
personne est déjà intervenue
|
personne est déjà intervenue
|
||||||
future:
|
|
||||||
zero:
|
|
||||||
one: "<strong>Prochainement</strong>, %{count} événement:"
|
|
||||||
other: "<strong>Prochainement</strong>, %{count} événements:"
|
|
||||||
past:
|
|
||||||
zero:
|
|
||||||
one: "<strong>Dans le passé</strong>, %{count} événement:"
|
|
||||||
other: "<strong>Dans le passé</strong>, %{count} événements:"
|
|
||||||
|
|
||||||
# Traductions des écrans
|
# Traductions des écrans
|
||||||
layouts:
|
layouts:
|
||||||
@ -42,7 +34,7 @@ fr:
|
|||||||
calendar_in: Ce calendrier en %{rss}, %{webcal} ou %{ical}
|
calendar_in: Ce calendrier en %{rss}, %{webcal} ou %{ical}
|
||||||
nb_events: "%{count} événements"
|
nb_events: "%{count} événements"
|
||||||
show:
|
show:
|
||||||
orga-list: Asso de la région
|
orga-list: Orgas de la région
|
||||||
add_to_calendar: Ajouter à mon calendrier
|
add_to_calendar: Ajouter à mon calendrier
|
||||||
copy: Dupliquer événement
|
copy: Dupliquer événement
|
||||||
at: À
|
at: À
|
||||||
@ -60,14 +52,14 @@ fr:
|
|||||||
description: Description
|
description: Description
|
||||||
infos: Informations
|
infos: Informations
|
||||||
new:
|
new:
|
||||||
title: Soumettre un événement
|
title: Proposer un événement
|
||||||
subtitle: Cette page permet de soumettre un événement dans l'Agenda du
|
subtitle: Cette page permet de soumettre un événement dans l'Agenda du
|
||||||
Libre. Celui-ci n'apparaîtra pas automatiquement dans l'Agenda, il sera
|
Libre. Celui-ci n'apparaîtra pas automatiquement dans l'Agenda, il sera
|
||||||
tout d'abord validé par un modérateur. Un courrier électronique sera
|
tout d'abord validé par un modérateur. Un courrier électronique sera
|
||||||
envoyé à l'adresse e-mail du soumetteur donnée ci-dessous lorsque
|
envoyé à l'adresse e-mail du soumetteur donnée ci-dessous lorsque
|
||||||
l'événement aura été modéré.
|
l'événement aura été modéré.
|
||||||
preview: Prévisualisation
|
preview: Prévisualisation
|
||||||
edit: Édition
|
edit: Création
|
||||||
create:
|
create:
|
||||||
ok: Votre événement a bien été ajouté à la liste des événements en
|
ok: Votre événement a bien été ajouté à la liste des événements en
|
||||||
attente de modération. Il apparaîtra en ligne dès qu'un modérateur
|
attente de modération. Il apparaîtra en ligne dès qu'un modérateur
|
||||||
@ -244,6 +236,32 @@ description plus complète."
|
|||||||
search:
|
search:
|
||||||
title: Trouve ton %{entity}!
|
title: Trouve ton %{entity}!
|
||||||
label: Recherche
|
label: Recherche
|
||||||
|
show:
|
||||||
|
links: Liens
|
||||||
|
actions: Actions
|
||||||
|
edit: Éditer
|
||||||
|
future: Prochainement
|
||||||
|
past: Dans le passé
|
||||||
|
count:
|
||||||
|
zero:
|
||||||
|
one: Un événement
|
||||||
|
other: "%{count} événements"
|
||||||
|
new:
|
||||||
|
title: Organisation
|
||||||
|
edit: Création
|
||||||
|
edit:
|
||||||
|
title: Organisation
|
||||||
|
edit: Édition
|
||||||
|
form:
|
||||||
|
url_helper: Lien vers le site web de l'organisation
|
||||||
|
feed_helper: Lien **direct** vers un flux de syndication, type RSS ou atom
|
||||||
|
contact_helper: Adresse e-mail de contact, affichée de manière peu
|
||||||
|
compréhensible par les spammeurs
|
||||||
|
submitter_helper: Adresse e-mail du soumetteur de l'organisation.
|
||||||
|
Utilisée par les modérateurs pour informer de sa validation ou de son
|
||||||
|
rejet. Si cette adresse n'est pas présente, l'adresse de contact sera
|
||||||
|
utilisée
|
||||||
|
save: Envoyer
|
||||||
|
|
||||||
devise:
|
devise:
|
||||||
sessions:
|
sessions:
|
||||||
|
@ -19,7 +19,7 @@ Rails.application.routes.draw do
|
|||||||
resources :regions, only: [:index]
|
resources :regions, only: [:index]
|
||||||
resources :tags, only: [:index, :show]
|
resources :tags, only: [:index, :show]
|
||||||
resources :maps, only: [:index]
|
resources :maps, only: [:index]
|
||||||
resources :orgas, only: [:index, :show]
|
resources :orgas
|
||||||
|
|
||||||
# Manage former php pages
|
# Manage former php pages
|
||||||
get 'showevent.php', to: redirect { |_, req| "events/#{req.params[:id]}" }
|
get 'showevent.php', to: redirect { |_, req| "events/#{req.params[:id]}" }
|
||||||
|
18
db/migrate/20150215172000_create_kinds.rb
Normal file
18
db/migrate/20150215172000_create_kinds.rb
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# Setting up organisations' kinds
|
||||||
|
class CreateKinds < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
create_table :kinds do |t|
|
||||||
|
t.string :name, unique: true, null: false
|
||||||
|
t.string :icon
|
||||||
|
|
||||||
|
t.timestamps null: false
|
||||||
|
end
|
||||||
|
|
||||||
|
# Create the relevant organisation kinds
|
||||||
|
Kind.create name: 'association', icon: 'sitemap'
|
||||||
|
Kind.create name: 'enterprise', icon: 'building'
|
||||||
|
Kind.create name: 'lug', icon: 'support'
|
||||||
|
Kind.create name: 'provider', icon: 'tty'
|
||||||
|
Kind.create name: 'institution', icon: 'institution'
|
||||||
|
end
|
||||||
|
end
|
15
db/migrate/20150215172739_add_data_to_orgas.rb
Normal file
15
db/migrate/20150215172739_add_data_to_orgas.rb
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
# The relation between orga and their kind
|
||||||
|
class AddDataToOrgas < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
add_reference :orgas, :kind, index: true
|
||||||
|
add_foreign_key :orgas, :kinds
|
||||||
|
add_column :orgas, :feed, :string
|
||||||
|
add_column :orgas, :contact, :string
|
||||||
|
add_column :orgas, :submitter, :string
|
||||||
|
add_column :orgas, :moderated, :boolean, default: false
|
||||||
|
add_column :orgas, :submission_time, :datetime
|
||||||
|
add_column :orgas, :decision_time, :datetime
|
||||||
|
add_column :orgas, :secret, :string
|
||||||
|
add_column :orgas, :deleted, :boolean, default: false, null: false
|
||||||
|
end
|
||||||
|
end
|
25
db/schema.rb
25
db/schema.rb
@ -1,5 +1,4 @@
|
|||||||
# encoding: UTF-8
|
# encoding: UTF-8
|
||||||
# rubocop:disable all
|
|
||||||
# This file is auto-generated from the current state of the database. Instead
|
# This file is auto-generated from the current state of the database. Instead
|
||||||
# of editing this file, please use the migrations feature of Active Record to
|
# of editing this file, please use the migrations feature of Active Record to
|
||||||
# incrementally modify your database, and then regenerate this schema definition.
|
# incrementally modify your database, and then regenerate this schema definition.
|
||||||
@ -12,7 +11,7 @@
|
|||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(version: 20150215151059) do
|
ActiveRecord::Schema.define(version: 20150215172739) do
|
||||||
|
|
||||||
create_table "active_admin_comments", force: :cascade do |t|
|
create_table "active_admin_comments", force: :cascade do |t|
|
||||||
t.string "namespace", limit: 255
|
t.string "namespace", limit: 255
|
||||||
@ -85,6 +84,13 @@ ActiveRecord::Schema.define(version: 20150215151059) do
|
|||||||
|
|
||||||
add_index "events", ["start_time", "end_time"], name: "events_date"
|
add_index "events", ["start_time", "end_time"], name: "events_date"
|
||||||
|
|
||||||
|
create_table "kinds", force: :cascade do |t|
|
||||||
|
t.string "name", null: false
|
||||||
|
t.string "icon"
|
||||||
|
t.datetime "created_at", null: false
|
||||||
|
t.datetime "updated_at", null: false
|
||||||
|
end
|
||||||
|
|
||||||
create_table "notes", force: :cascade do |t|
|
create_table "notes", force: :cascade do |t|
|
||||||
t.text "contents", null: false
|
t.text "contents", null: false
|
||||||
t.datetime "date", null: false
|
t.datetime "date", null: false
|
||||||
@ -98,8 +104,23 @@ ActiveRecord::Schema.define(version: 20150215151059) do
|
|||||||
t.string "name", limit: 255, default: "", null: false
|
t.string "name", limit: 255, default: "", null: false
|
||||||
t.string "url", limit: 255, default: "", null: false
|
t.string "url", limit: 255, default: "", null: false
|
||||||
t.string "city", limit: 255, default: "", null: false
|
t.string "city", limit: 255, default: "", null: false
|
||||||
|
t.string "place"
|
||||||
|
t.string "address"
|
||||||
|
t.integer "orga_kind_id"
|
||||||
|
t.integer "kind_id"
|
||||||
|
t.string "feed"
|
||||||
|
t.string "contact"
|
||||||
|
t.string "submitter"
|
||||||
|
t.boolean "moderated", default: false
|
||||||
|
t.datetime "submission_time"
|
||||||
|
t.datetime "decision_time"
|
||||||
|
t.string "secret"
|
||||||
|
t.boolean "deleted", default: false, null: false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
add_index "orgas", ["kind_id"], name: "index_orgas_on_kind_id"
|
||||||
|
add_index "orgas", ["orga_kind_id"], name: "index_orgas_on_orga_kind_id"
|
||||||
|
|
||||||
create_table "regions", force: :cascade do |t|
|
create_table "regions", force: :cascade do |t|
|
||||||
t.string "name", limit: 255, default: "", null: false
|
t.string "name", limit: 255, default: "", null: false
|
||||||
end
|
end
|
||||||
|
@ -18,6 +18,12 @@ User.create login: 'admin@example.com', email: 'admin@example.com',
|
|||||||
|
|
||||||
AdminUser.create email: 'admin@example.com', password: 'password'
|
AdminUser.create email: 'admin@example.com', password: 'password'
|
||||||
|
|
||||||
|
Kind.create name: 'association', icon: 'sitemap'
|
||||||
|
Kind.create name: 'enterprise', icon: 'building'
|
||||||
|
Kind.create name: 'lug', icon: 'support'
|
||||||
|
Kind.create name: 'provider', icon: 'tty'
|
||||||
|
Kind.create name: 'institution', icon: 'institution'
|
||||||
|
|
||||||
# rubocop:disable Metrics/LineLength
|
# rubocop:disable Metrics/LineLength
|
||||||
I18n::Backend::ActiveRecord::Translation.create([
|
I18n::Backend::ActiveRecord::Translation.create([
|
||||||
{ locale: 'fr', key: 'mail_suffix', value: '[AdL] ' },
|
{ locale: 'fr', key: 'mail_suffix', value: '[AdL] ' },
|
||||||
|
@ -2,6 +2,7 @@ require 'test_helper'
|
|||||||
|
|
||||||
# Free Software groups life cycle
|
# Free Software groups life cycle
|
||||||
class OrgasControllerTest < ActionController::TestCase
|
class OrgasControllerTest < ActionController::TestCase
|
||||||
|
include Devise::TestHelpers
|
||||||
setup do
|
setup do
|
||||||
@orga = orgas :one
|
@orga = orgas :one
|
||||||
end
|
end
|
||||||
@ -11,6 +12,40 @@ class OrgasControllerTest < ActionController::TestCase
|
|||||||
assert_response :success
|
assert_response :success
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test 'should get new' do
|
||||||
|
sign_in users(:one)
|
||||||
|
get :new
|
||||||
|
assert_response :success
|
||||||
|
end
|
||||||
|
|
||||||
|
test 'should create orga' do
|
||||||
|
sign_in users(:one)
|
||||||
|
assert_difference 'Orga.count' do
|
||||||
|
post :create, orga: {
|
||||||
|
kind_id: @orga.kind_id,
|
||||||
|
name: @orga.name,
|
||||||
|
city: @orga.city,
|
||||||
|
region_id: @orga.region.id,
|
||||||
|
url: @orga.url,
|
||||||
|
feed: @orga.feed,
|
||||||
|
contact: @orga.contact
|
||||||
|
}
|
||||||
|
|
||||||
|
assert_empty assigns(:orga).errors.messages
|
||||||
|
end
|
||||||
|
|
||||||
|
assert_redirected_to :root
|
||||||
|
end
|
||||||
|
|
||||||
|
test 'should not create orga' do
|
||||||
|
sign_in users(:one)
|
||||||
|
assert_no_difference 'Orga.count' do
|
||||||
|
post :create, orga: { url: @orga.url }
|
||||||
|
|
||||||
|
assert_not_empty assigns(:orga).errors.messages
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
test 'should get show' do
|
test 'should get show' do
|
||||||
get :show, id: @orga
|
get :show, id: @orga
|
||||||
assert_response :success
|
assert_response :success
|
||||||
|
21
test/fixtures/kinds.yml
vendored
Normal file
21
test/fixtures/kinds.yml
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
|
||||||
|
|
||||||
|
one:
|
||||||
|
name: Association
|
||||||
|
icon: sitemap
|
||||||
|
|
||||||
|
two:
|
||||||
|
name: Enterprise
|
||||||
|
icon: building
|
||||||
|
|
||||||
|
lug:
|
||||||
|
name: Lug
|
||||||
|
icon: support
|
||||||
|
|
||||||
|
provider:
|
||||||
|
name: Provider
|
||||||
|
icon: tty
|
||||||
|
|
||||||
|
institution:
|
||||||
|
name: Institution
|
||||||
|
icon: institution
|
20
test/fixtures/orgas.yml
vendored
20
test/fixtures/orgas.yml
vendored
@ -1,15 +1,23 @@
|
|||||||
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
|
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
|
||||||
|
|
||||||
one:
|
one:
|
||||||
region: region_one
|
kind: lug
|
||||||
|
name: MyString
|
||||||
city: Jolie ville
|
city: Jolie ville
|
||||||
department: 1
|
department: 1
|
||||||
name: MyString
|
region: region_one
|
||||||
url: MyString
|
url: http://april.org
|
||||||
|
feed: http://april.org/index.rss
|
||||||
|
contact: test@exemple.com
|
||||||
|
submitter: test@exemple.com
|
||||||
|
|
||||||
two:
|
two:
|
||||||
region: region_two
|
kind: provider
|
||||||
|
name: MyString
|
||||||
city: Jolie ville
|
city: Jolie ville
|
||||||
department: 1
|
department: 1
|
||||||
name: MyString
|
region: region_two
|
||||||
url: MyString
|
url: http://april.org
|
||||||
|
feed: http://april.org/index.rss
|
||||||
|
contact: test@exemple.com
|
||||||
|
submitter: test@exemple.com
|
||||||
|
7
test/models/kind_test.rb
Normal file
7
test/models/kind_test.rb
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class KindTest < ActiveSupport::TestCase
|
||||||
|
# test "the truth" do
|
||||||
|
# assert true
|
||||||
|
# end
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user