1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-11 00:52:29 +01:00
fab-manager/db/seeds.rb

532 lines
30 KiB
Ruby
Raw Normal View History

2019-03-26 10:06:29 +01:00
# frozen_string_literal: true
2016-03-23 18:39:41 +01:00
2019-03-26 10:06:29 +01:00
if StatisticIndex.count.zero?
2016-03-23 18:39:41 +01:00
StatisticIndex.create!([
2019-03-26 10:06:29 +01:00
{ id: 1, es_type_key: 'subscription', label: I18n.t('statistics.subscriptions') },
{ id: 2, es_type_key: 'machine', label: I18n.t('statistics.machines_hours') },
{ id: 3, es_type_key: 'training', label: I18n.t('statistics.trainings') },
{ id: 4, es_type_key: 'event', label: I18n.t('statistics.events') },
{ id: 5, es_type_key: 'account', label: I18n.t('statistics.registrations'), ca: false },
{ id: 6, es_type_key: 'project', label: I18n.t('statistics.projects'), ca: false },
{ id: 7, es_type_key: 'user', label: I18n.t('statistics.users'), table: false, ca: false }
])
2016-03-23 18:39:41 +01:00
connection = ActiveRecord::Base.connection
2019-03-26 10:06:29 +01:00
connection.execute("SELECT setval('statistic_indices_id_seq', 7);") if connection.instance_values['config'][:adapter] == 'postgresql'
2016-03-23 18:39:41 +01:00
end
2019-03-26 10:06:29 +01:00
if StatisticField.count.zero?
2016-03-23 18:39:41 +01:00
StatisticField.create!([
2019-03-26 10:06:29 +01:00
# available data_types : index, number, date, text, list
{ key: 'trainingId', label: I18n.t('statistics.training_id'), statistic_index_id: 3, data_type: 'index' },
{ key: 'trainingDate', label: I18n.t('statistics.training_date'), statistic_index_id: 3, data_type: 'date' },
{ key: 'eventId', label: I18n.t('statistics.event_id'), statistic_index_id: 4, data_type: 'index' },
{ key: 'eventDate', label: I18n.t('statistics.event_date'), statistic_index_id: 4, data_type: 'date' },
{ key: 'themes', label: I18n.t('statistics.themes'), statistic_index_id: 6, data_type: 'list' },
{ key: 'components', label: I18n.t('statistics.components'), statistic_index_id: 6, data_type: 'list' },
{ key: 'machines', label: I18n.t('statistics.machines'), statistic_index_id: 6, data_type: 'list' },
{ key: 'name', label: I18n.t('statistics.event_name'), statistic_index_id: 4, data_type: 'text' },
{ key: 'userId', label: I18n.t('statistics.user_id'), statistic_index_id: 7, data_type: 'index' },
{ key: 'eventTheme', label: I18n.t('statistics.event_theme'), statistic_index_id: 4, data_type: 'text' },
{ key: 'ageRange', label: I18n.t('statistics.age_range'), statistic_index_id: 4, data_type: 'text' }
])
2016-03-23 18:39:41 +01:00
end
unless StatisticField.find_by(key:'groupName').try(:label)
field = StatisticField.find_or_initialize_by(key: 'groupName')
field.label = 'Groupe'
field.statistic_index_id = 1
field.data_type = 'text'
field.save!
end
2019-03-26 10:06:29 +01:00
if StatisticType.count.zero?
2016-03-23 18:39:41 +01:00
StatisticType.create!([
2019-03-26 10:06:29 +01:00
{ statistic_index_id: 2, key: 'booking', label: I18n.t('statistics.bookings'), graph: true, simple: true },
{ statistic_index_id: 2, key: 'hour', label: I18n.t('statistics.hours_number'), graph: true, simple: false },
{ statistic_index_id: 3, key: 'booking', label: I18n.t('statistics.bookings'), graph: false, simple: true },
{ statistic_index_id: 3, key: 'hour', label: I18n.t('statistics.hours_number'), graph: false, simple: false },
{ statistic_index_id: 4, key: 'booking', label: I18n.t('statistics.tickets_number'), graph: false,
simple: false },
{ statistic_index_id: 4, key: 'hour', label: I18n.t('statistics.hours_number'), graph: false, simple: false },
{ statistic_index_id: 5, key: 'member', label: I18n.t('statistics.users'), graph: true, simple: true },
{ statistic_index_id: 6, key: 'project', label: I18n.t('statistics.projects'), graph: false, simple: true },
{ statistic_index_id: 7, key: 'revenue', label: I18n.t('statistics.revenue'), graph: false, simple: false }
])
end
if StatisticSubType.count.zero?
2016-03-23 18:39:41 +01:00
StatisticSubType.create!([
2019-03-26 10:06:29 +01:00
{ key: 'created', label: I18n.t('statistics.account_creation'),
statistic_types: StatisticIndex.find_by(es_type_key: 'account').statistic_types },
{ key: 'published', label:I18n.t('statistics.project_publication'),
statistic_types: StatisticIndex.find_by(es_type_key: 'project').statistic_types }
])
2016-03-23 18:39:41 +01:00
end
2019-03-26 10:06:29 +01:00
if StatisticGraph.count.zero?
2016-03-23 18:39:41 +01:00
StatisticGraph.create!([
2019-03-26 10:06:29 +01:00
{ statistic_index_id: 1, chart_type: 'stackedAreaChart', limit: 0 },
{ statistic_index_id: 2, chart_type: 'stackedAreaChart', limit: 0 },
{ statistic_index_id: 3, chart_type: 'discreteBarChart', limit: 10 },
{ statistic_index_id: 4, chart_type: 'discreteBarChart', limit: 10 },
{ statistic_index_id: 5, chart_type: 'lineChart', limit: 0 },
{ statistic_index_id: 7, chart_type: 'discreteBarChart', limit: 10 }
])
2016-03-23 18:39:41 +01:00
end
2015-05-05 03:10:25 +02:00
2019-03-26 10:06:29 +01:00
if Group.count.zero?
2015-05-05 03:10:25 +02:00
Group.create!([
2019-03-26 10:06:29 +01:00
{ name: 'standard, association', slug: 'standard' },
{ name: "étudiant, - de 25 ans, enseignant, demandeur d'emploi", slug: 'student' },
{ name: 'artisan, commerçant, chercheur, auto-entrepreneur', slug: 'merchant' },
{ name: 'PME, PMI, SARL, SA', slug: 'business' }
])
2015-05-05 03:10:25 +02:00
end
2019-03-26 10:06:29 +01:00
Group.create! name: I18n.t('group.admins'), slug: 'admins' unless Group.find_by(slug: 'admins')
2017-08-30 14:57:06 +02:00
# Create the default admin if none exists yet
2019-03-26 10:06:29 +01:00
if Role.where(name: 'admin').joins(:users).count.zero?
admin = User.new(username: 'admin', email: ENV['ADMIN_EMAIL'], password: ENV['ADMIN_PASSWORD'],
password_confirmation: Rails.application.secrets.admin_password, group_id: Group.find_by(slug: 'admins').id,
profile_attributes: { first_name: 'admin', last_name: 'admin', gender: true, phone: '0123456789', birthday: Time.now })
admin.add_role 'admin'
admin.save!
2015-05-05 03:10:25 +02:00
end
2019-03-26 10:06:29 +01:00
if Component.count.zero?
2015-05-05 03:10:25 +02:00
Component.create!([
2019-03-26 10:06:29 +01:00
{ name: 'Silicone' },
{ name: 'Vinyle' },
{ name: 'Bois Contre plaqué' },
{ name: 'Bois Medium' },
{ name: 'Plexi / PMMA' },
{ name: 'Flex' },
{ name: 'Vinyle' },
{ name: 'Parafine' },
{ name: 'Fibre de verre' },
{ name: 'Résine' }
])
end
if Licence.count.zero?
2015-05-05 03:10:25 +02:00
Licence.create!([
2019-03-26 10:06:29 +01:00
{ name: 'Attribution (BY)', description: 'Le titulaire des droits autorise toute exploitation de lœuvre, y compris à' \
' des fins commerciales, ainsi que la création dœuvres dérivées, dont la distribution est également autorisé sans ' \
'restriction, à condition de lattribuer à son lauteur en citant son nom. Cette licence est recommandée pour la ' \
'diffusion et lutilisation maximale des œuvres.' },
{ name: 'Attribution + Pas de modification (BY ND)', description: 'Le titulaire des droits autorise toute utilisation' \
' de lœuvre originale (y compris à des fins commerciales), mais nautorise pas la création dœuvres dérivées.' },
{ name: "Attribution + Pas d'Utilisation Commerciale + Pas de Modification (BY NC ND)", description: 'Le titulaire ' \
'des droits autorise lutilisation de lœuvre originale à des fins non commerciales, mais nautorise pas la ' \
'création dœuvres dérivés.' },
{ name: "Attribution + Pas d'Utilisation Commerciale (BY NC)", description: 'Le titulaire des droits autorise ' \
'lexploitation de lœuvre, ainsi que la création dœuvres dérivées, à condition quil ne sagisse pas dune ' \
'utilisation commerciale (les utilisations commerciales restant soumises à son autorisation).' },
{ name: "Attribution + Pas d'Utilisation Commerciale + Partage dans les mêmes conditions (BY NC SA)", description:
'Le titulaire des droits autorise lexploitation de lœuvre originale à des fins non commerciales, ainsi que la ' \
'création dœuvres dérivées, à condition quelles soient distribuées sous une licence identique à celle qui régit ' \
'lœuvre originale.' },
{ name: 'Attribution + Partage dans les mêmes conditions (BY SA)', description: 'Le titulaire des droits autorise ' \
'toute utilisation de lœuvre originale (y compris à des fins commerciales) ainsi que la création dœuvres dérivées' \
', à condition quelles soient distribuées sous une licence identique à celle qui régit lœuvre originale. Cette' \
'licence est souvent comparée aux licences « copyleft » des logiciels libres. Cest la licence utilisée par ' \
'Wikipedia.' }
])
end
if Theme.count.zero?
2015-05-05 03:10:25 +02:00
Theme.create!([
2019-03-26 10:06:29 +01:00
{ name: 'Vie quotidienne' },
{ name: 'Robotique' },
{ name: 'Arduine' },
{ name: 'Capteurs' },
{ name: 'Musique' },
{ name: 'Sport' },
{ name: 'Autre' }
])
2016-03-23 18:39:41 +01:00
end
2019-03-26 10:06:29 +01:00
if Training.count.zero?
2016-03-23 18:39:41 +01:00
Training.create!([
2019-03-26 10:06:29 +01:00
{ name: 'Formation Imprimante 3D', description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do ' \
'eiusmod tempor incididunt ut labore et dolore magna aliqua.' },
{ name: 'Formation Laser / Vinyle', description: 'Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris' \
' nisi ut aliquip ex ea commodo consequat.' },
{ name: 'Formation Petite fraiseuse numerique', description: 'Duis aute irure dolor in reprehenderit in voluptate ' \
'velit esse cillum dolore eu fugiat nulla pariatur.' },
{ name: 'Formation Shopbot Grande Fraiseuse', description: 'Excepteur sint occaecat cupidatat non proident, sunt in ' \
'culpa qui officia deserunt mollit anim id est laborum.' },
{ name: 'Formation logiciel 2D', description: 'Sed ut perspiciatis unde omnis iste natus error sit voluptatem ' \
'accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi ' \
'architecto beatae vitae dicta sunt explicabo.' }
])
2016-03-23 18:39:41 +01:00
TrainingsPricing.all.each do |p|
2017-02-13 14:38:28 +01:00
p.update_columns(amount: (rand * 50 + 5).floor * 100)
2016-03-23 18:39:41 +01:00
end
2015-05-05 03:10:25 +02:00
end
2019-03-26 10:06:29 +01:00
if Machine.count.zero?
2015-05-05 03:10:25 +02:00
Machine.create!([
2019-03-26 10:06:29 +01:00
{ name: 'Découpeuse laser', description: "Préparation à l'utilisation de l'EPILOG Legend 36EXT\r\nInformations" \
" générales \r\n Pour la découpe, il suffit d'apporter votre fichier vectorisé type illustrator, svg ou dxf" \
" avec des \"lignes de coupe\" d'une épaisseur inférieur à 0,01 mm et la machine s'occupera du reste!\r\n La " \
'gravure est basée sur le spectre noir et blanc. Les nuances sont obtenues par différentes profondeurs de gravure ' \
"correspondant aux niveaux de gris de votre image. Il suffit pour cela d'apporter une image scannée ou un fichier " \
"photo en noir et blanc pour pouvoir reproduire celle-ci sur votre support! \r\nQuels types de matériaux pouvons " \
"nous graver/découper?\r\n Du bois au tissu, du plexiglass au cuir, cette machine permet de découper et graver " \
"la plupart des matériaux sauf les métaux. La gravure est néanmoins possible sur les métaux recouverts d'une couche" \
" de peinture ou les aluminiums anodisés. \r\n Concernant l'épaisseur des matériaux découpés, il est " \
"préférable de ne pas dépasser 5 mm pour le bois et 6 mm pour le plexiglass.\r\n", spec: "Puissance: 40W\r\nSurface" \
" de travail: 914x609 mm \r\nEpaisseur maximale de la matière: 305mm\r\nSource laser: tube laser type CO2\r\n" \
'Contrôles de vitesse et de puissance: ces deux paramètres sont ajustables en fonction du matériau (de 1% à 100%) .' \
"\r\n", slug: 'decoupeuse-laser' },
{ name: 'Découpeuse vinyle', description: "Préparation à l'utilisation de la Roland CAMM-1 GX24\r\nInformations " \
"générales \r\n Envie de réaliser un tee shirt personnalisé ? Un sticker à l'effigie votre groupe " \
"préféré ? Un masque pour la réalisation d'un circuit imprimé? Pour cela, il suffit simplement de venir avec votre" \
" fichier vectorisé (ne pas oublier de vectoriser les textes) type illustrator svg ou dxf.\r\n \r\nMatériaux " \
"utilisés:\r\n Cette machine permet de découper principalement du vinyle,vinyle réfléchissant, flex.\r\n",
spec: "Largeurs de support acceptées: de 50 mm à 700 mm\r\nVitesse de découpe: 50 cm/sec\r\nRésolution mécanique: " \
"0,0125 mm/pas\r\n", slug: 'decoupeuse-vinyle' },
{ name: 'Shopbot / Grande fraiseuse', description: "La fraiseuse numérique ShopBot PRS standard\r\nInformations " \
"générales\r\nCette machine est un fraiseuse 3 axes idéale pour l'usinage de pièces de grandes dimensions. De la " \
"réalisation d'une chaise ou d'un meuble jusqu'à la construction d'une maison ou d'un assemblage immense, le " \
"ShopBot ouvre de nombreuses portes à votre imagination! \r\nMatériaux usinables\r\nLes principaux matériaux " \
"usinables sont le bois, le plastique, le laiton et bien d'autres.\r\nCette machine n'usine pas les métaux.\r\n",
spec: "Surface maximale de travail: 2440x1220x150 (Z) mm\r\nLogiciel utilisé: Partworks 2D & 3D\r\nRésolution " \
"mécanique: 0,015 mm\r\nPrécision de la position: +/- 0,127mm\r\nFormats acceptés: DXF, STL \r\n",
slug: 'shopbot-grande-fraiseuse' },
{ name: 'Imprimante 3D', description: "L'utimaker est une imprimante 3D low cost utilisant une technologie FFF " \
"(Fused Filament Fabrication) avec extrusion thermoplastique.\r\nC'est une machine idéale pour réaliser rapidement " \
"des prototypes 3D dans des couleurs différentes.\r\n", spec: "Surface maximale de travail: 210x210x220mm \r\n" \
"Résolution méchanique: 0,02 mm \r\nPrécision de position: +/- 0,05 \r\nLogiciel utilisé: Cura\r\nFormats de " \
"fichier acceptés: STL \r\nMatériaux utilisés: PLA (en stock).", slug: 'imprimante-3d' },
{ name: 'Petite Fraiseuse', description: "La fraiseuse numérique Roland Modela MDX-20\r\nInformations générales" \
"\r\nCette machine est utilisée pour l'usinage et le scannage 3D de précision. Elle permet principalement d'usiner" \
' des circuits imprimés et des moules de petite taille. Le faible diamètre des fraises utilisées (Ø 0,3 mm à Ø 6mm' \
") induit que certains temps d'usinages peuvent êtres long (> 12h), c'est pourquoi cette fraiseuse peut être " \
"laissée en autonomie toute une nuit afin d'obtenir le plus précis des usinages au FabLab.\r\nMatériaux usinables:" \
"\r\nLes principaux matériaux usinables sont le bois, plâtre, résine, cire usinable, cuivre.\r\n",
spec: "Taille du plateau X/Y : 220 mm x 160 mm\r\nVolume maximal de travail: 203,2 mm (X), 152,4 mm (Y), 60,5 mm " \
"(Z)\r\nPrécision usinage: 0,00625 mm\r\nPrécision scannage: réglable de 0,05 à 5 mm (axes X,Y) et 0,025 mm (axe Z)" \
"\r\nVitesse d'analyse (scannage): 4-15 mm/sec\r\n \r\n \r\nLogiciel utilisé pour le fraisage: Roland Modela player" \
" 4 \r\nLogiciel utilisé pour l'usinage de circuits imprimés: Cad.py (linux)\r\nFormats acceptés: STL,PNG 3D\r\n" \
"Format d'exportation des données scannées: DXF, VRML, STL, 3DMF, IGES, Grayscale, Point Group et BMP\r\n",
slug: 'petite-fraiseuse' },
])
2016-03-23 18:39:41 +01:00
Price.all.each do |p|
2019-03-26 10:06:29 +01:00
p.update_columns(amount: (rand * 50 + 5).floor * 100)
2016-03-23 18:39:41 +01:00
end
2015-05-05 03:10:25 +02:00
end
2016-03-23 18:39:41 +01:00
2019-03-25 17:14:26 +01:00
if Category.count.zero?
Category.create!(
[
{ name: 'Stage' },
{ name: 'Atelier' }
]
)
2016-03-23 18:39:41 +01:00
end
unless Setting.find_by(name: 'about_body').try(:value)
setting = Setting.find_or_initialize_by(name: 'about_body')
2019-03-25 17:14:26 +01:00
setting.value = '<p>La Fabrique du <a href=\"http://fab-manager.com\" target=\"_blank\">Fab-manager</a> est un' \
' atelier de fabrication numérique où lon peut utiliser des machines de découpe, des imprimantes 3D,… permettant' \
' de travailler sur des matériaux variés : plastique, bois, carton, vinyle, … afin de créer toute sorte dobjet grâce' \
' à la conception assistée par ordinateur ou à lélectronique. Mais le Fab Lab est aussi un lieu déchange de' \
' compétences technique. </p>' \
' <p>La Fabrique du <a href=\"http://fab-manager.com\" target=\"_blank\">Fab-manager</a> est un espace' \
' permanent : ouvert à tous, il offre la possibilité de réaliser des objets soi-même, de partager ses' \
' compétences et dapprendre au contact des médiateurs du Fab Lab et des autres usagers. </p>' \
'<p>La formation au Fab Lab sappuie sur des projets et le partage de connaissances : vous devez prendre' \
2017-02-13 14:38:28 +01:00
' part à la capitalisation des connaissances et à linstruction des autres utilisateurs.</p>'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'about_title').try(:value)
setting = Setting.find_or_initialize_by(name: 'about_title')
2019-03-25 17:14:26 +01:00
setting.value = 'Imaginer, Fabriquer, <br>Partager à la Fabrique <br> du Fab-manager'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'about_contacts').try(:value)
setting = Setting.find_or_initialize_by(name: 'about_contacts')
2019-03-25 17:14:26 +01:00
setting.value = '<dl>' \
'<dt>Manager Fab Lab :</dt>' \
2019-03-26 10:06:29 +01:00
'<dd>contact@fab-manager.com</dd>' \
'<dt>Responsable médiation :</dt>' \
'<dd>contact@fab-manager.com</dd>' \
'<dt>Animateur scientifique :</dt>' \
'<dd>lcontact@fab-manager.com</dd>' \
'</dl>' \
2019-03-25 17:14:26 +01:00
'<br><br>' \
"<p><a href='http://fab-manager.com'>Visitez le site de Fab-manager</a></p>"
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'twitter_name').try(:value)
setting = Setting.find_or_initialize_by(name: 'twitter_name')
2019-03-25 17:15:19 +01:00
setting.value = 'fab_manager'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'machine_explications_alert').try(:value)
setting = Setting.find_or_initialize_by(name: 'machine_explications_alert')
2019-03-26 10:06:29 +01:00
setting.value = "Tout achat d'heure machine est définitif. Aucune" \
' annulation ne pourra être effectuée, néanmoins au plus tard 24h avant le créneau fixé, vous pouvez en' \
" modifier la date et l'horaire à votre convenance et en fonction du calendrier proposé. Passé ce délais," \
2017-02-13 14:38:28 +01:00
' aucun changement ne pourra être effectué.'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'training_explications_alert').try(:value)
setting = Setting.find_or_initialize_by(name: 'training_explications_alert')
2019-03-26 10:06:29 +01:00
setting.value = 'Toute réservation de formation est définitive.' \
' Aucune annulation ne pourra être effectuée, néanmoins au plus tard 24h avant le créneau fixé, vous pouvez' \
" en modifier la date et l'horaire à votre convenance et en fonction du calendrier proposé. Passé ce délais," \
2017-02-13 14:38:28 +01:00
' aucun changement ne pourra être effectué.'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'subscription_explications_alert').try(:value)
setting = Setting.find_or_initialize_by(name: 'subscription_explications_alert')
2019-03-26 10:06:29 +01:00
setting.value = '<p><b>Règle sur la date de début des abonnements</b><br></p><ul><li>' \
' <span style=\"font-size: 1.6rem; line-height: 2.4rem;\">Si vous êtes un nouvel utilisateur - i.e aucune ' \
" formation d'enregistrée sur le site - votre abonnement débutera à la date de réservation de votre première " \
' formation.</span><br></li><li><span style=\"font-size: 1.6rem; line-height: 2.4rem;\">Si vous avez déjà une ' \
" formation ou plus de validée, votre abonnement débutera à la date de votre achat d'abonnement.</span></li>" \
" </ul><p>Merci de bien prendre ses informations en compte, et merci de votre compréhension. L'équipe du Fab Lab.<br>" \
2017-02-13 14:38:28 +01:00
' </p><p></p>'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_logo').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_logo')
2019-03-26 10:06:29 +01:00
setting.value = 'iVBORw0KGgoAAAANSUhEUgAAAG0AAABZCAYAAAA0E6rtAAAACXBIWXMAAAsTAAALEwEAmpwYAAA57WlUWHRYTUw6Y29tLmFkb2JlLnhtc' \
'AAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4KPHg6eG1wbWV0YSB4bWxuczp4PS' \
'JhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxMzggNzkuMTU5ODI0LCAyMDE2LzA5LzE0LTAxOjA5OjA' \
'xICAgICAgICAiPgogICA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMi' \
'PgogICAgICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgICAgICAgICB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb' \
'20veGFwLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgICAgICAgIC' \
'AgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0' \
'iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20v' \
'eGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmL' \
'zEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcm' \
'VhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgMjAxNyAoV2luZG93cyk8L3htcDpDcmVhdG9yVG9vbD4KICAgICAgICAgPHhtcDpDcmV' \
'hdGVEYXRlPjIwMTctMDEtMDNUMTE6MTg6MTgrMDE6MDA8L3htcDpDcmVhdGVEYXRlPgogICAgICAgICA8eG1wOk1vZGlmeURhdGU'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_reference').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_reference')
2017-02-13 14:38:28 +01:00
setting.value = 'YYMMmmmX[/VL]R[/A]'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_code-active').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_code-active')
2017-02-13 14:38:28 +01:00
setting.value = 'true'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_code-value').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_code-value')
2017-02-13 14:38:28 +01:00
setting.value = 'INMEDFABLAB'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_order-nb').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_order-nb')
2017-02-13 14:38:28 +01:00
setting.value = 'nnnnnn-MM-YY'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_VAT-active').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_VAT-active')
2017-02-13 14:38:28 +01:00
setting.value = 'false'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_VAT-rate').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_VAT-rate')
2017-02-13 14:38:28 +01:00
setting.value = '20.0'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'invoice_text').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_text')
setting.value = "Notre association n'est pas assujettie à la TVA"
setting.save
end
unless Setting.find_by(name: 'invoice_legals').try(:value)
setting = Setting.find_or_initialize_by(name: 'invoice_legals')
2019-03-25 17:14:26 +01:00
setting.value = 'La fabrique<br/>' \
'68 rue Louise Michel 38100 GRENOBLE France<br/>' \
'Tél. : +33 1 23 45 67 98<br/>' \
'Fax. : +33 1 23 45 67 98<br/>' \
'SIRET : 237 082 474 00006 - APE 913 E'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'booking_window_start').try(:value)
setting = Setting.find_or_initialize_by(name: 'booking_window_start')
2017-02-13 14:38:28 +01:00
setting.value = '1970-01-01 08:00:00'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'booking_window_end').try(:value)
setting = Setting.find_or_initialize_by(name: 'booking_window_end')
2017-02-13 14:38:28 +01:00
setting.value = '1970-01-01 23:59:59'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'booking_move_enable').try(:value)
setting = Setting.find_or_initialize_by(name: 'booking_move_enable')
setting.value = 'true'
setting.save
end
unless Setting.find_by(name: 'booking_move_delay').try(:value)
setting = Setting.find_or_initialize_by(name: 'booking_move_delay')
setting.value = '24'
setting.save
end
unless Setting.find_by(name: 'booking_cancel_enable').try(:value)
setting = Setting.find_or_initialize_by(name: 'booking_cancel_enable')
setting.value = 'false'
setting.save
end
unless Setting.find_by(name: 'booking_cancel_delay').try(:value)
setting = Setting.find_or_initialize_by(name: 'booking_cancel_delay')
setting.value = '24'
setting.save
end
unless Setting.find_by(name: 'main_color').try(:value)
setting = Setting.find_or_initialize_by(name: 'main_color')
setting.value = '#cb1117'
setting.save
end
unless Setting.find_by(name: 'secondary_color').try(:value)
setting = Setting.find_or_initialize_by(name: 'secondary_color')
setting.value = '#ffdd00'
setting.save
end
Stylesheet.build_sheet!
unless Setting.find_by(name: 'training_information_message').try(:value)
setting = Setting.find_or_initialize_by(name: 'training_information_message')
setting.value = "Avant de réserver une formation, nous vous conseillons de consulter nos offres d'abonnement qui"+
2017-02-13 14:38:28 +01:00
' proposent des conditions avantageuses sur le prix des formations et les heures machines.'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'fablab_name').try(:value)
setting = Setting.find_or_initialize_by(name: 'fablab_name')
2019-03-25 17:14:26 +01:00
setting.value = 'Fabrique'
2016-03-23 18:39:41 +01:00
setting.save
end
unless Setting.find_by(name: 'name_genre').try(:value)
setting = Setting.find_or_initialize_by(name: 'name_genre')
2019-03-25 17:14:26 +01:00
setting.value = 'female'
2016-03-23 18:39:41 +01:00
setting.save
end
unless DatabaseProvider.count > 0
db_provider = DatabaseProvider.new
db_provider.save
unless AuthProvider.find_by(providable_type: DatabaseProvider.name)
provider = AuthProvider.new
provider.name = 'Fablab'
provider.providable = db_provider
provider.status = 'active'
provider.save
end
2015-05-05 03:10:25 +02:00
end
unless Setting.find_by(name: 'reminder_enable').try(:value)
setting = Setting.find_or_initialize_by(name: 'reminder_enable')
setting.value = 'true'
setting.save
end
unless Setting.find_by(name: 'reminder_delay').try(:value)
setting = Setting.find_or_initialize_by(name: 'reminder_delay')
setting.value = '24'
setting.save
end
unless Setting.find_by(name: 'visibility_yearly').try(:value)
setting = Setting.find_or_initialize_by(name: 'visibility_yearly')
setting.value = '3'
setting.save
end
unless Setting.find_by(name: 'visibility_others').try(:value)
setting = Setting.find_or_initialize_by(name: 'visibility_others')
setting.value = '1'
setting.save
end
unless Setting.find_by(name: 'display_name_enable').try(:value)
setting = Setting.find_or_initialize_by(name: 'display_name_enable')
setting.value = 'false'
setting.save
end
unless Setting.find_by(name: 'machines_sort_by').try(:value)
setting = Setting.find_or_initialize_by(name: 'machines_sort_by')
setting.value = 'default'
setting.save
end
2019-03-26 10:06:29 +01:00
if StatisticCustomAggregation.count.zero?
# available reservations hours for machines
machine_hours = StatisticType.find_by(key: 'hour', statistic_index_id: 2)
2019-03-26 10:06:29 +01:00
available_hours = StatisticCustomAggregation.new(
statistic_type_id: machine_hours.id,
es_index: 'fablab',
es_type: 'availabilities',
field: 'available_hours',
query: '{"size":0, "aggregations":{"%{aggs_name}":{"sum":{"field":"bookable_hours"}}}, "query":{"bool":{"must":[{"range":' \
'{"start_at":{"gte":"%{start_date}", "lte":"%{end_date}"}}}, {"match":{"available_type":"machines"}}]}}}'
)
available_hours.save!
# available training tickets
training_bookings = StatisticType.find_by(key: 'booking', statistic_index_id: 3)
2019-03-26 10:06:29 +01:00
available_tickets = StatisticCustomAggregation.new(
statistic_type_id: training_bookings.id,
es_index: 'fablab',
es_type: 'availabilities',
field: 'available_tickets',
query: '{"size":0, "aggregations":{"%{aggs_name}":{"sum":{"field":"nb_total_places"}}}, "query":{"bool":{"must":[{"range":' \
'{"start_at":{"gte":"%{start_date}", "lte":"%{end_date}"}}}, {"match":{"available_type":"training"}}]}}}'
)
available_tickets.save!
2017-02-13 14:38:28 +01:00
end
unless StatisticIndex.find_by(es_type_key: 'space')
2019-03-26 10:06:29 +01:00
index = StatisticIndex.create!(es_type_key: 'space', label: I18n.t('statistics.spaces'))
2017-02-13 14:38:28 +01:00
StatisticType.create!([
2019-03-26 10:06:29 +01:00
{ statistic_index_id: index.id, key: 'booking', label: I18n.t('statistics.bookings'),
graph: true, simple: true },
{ statistic_index_id: index.id, key: 'hour', label: I18n.t('statistics.hours_number'),
graph: true, simple: false }
])
2019-03-25 17:14:26 +01:00
end