initial commit for space module
This commit is contained in:
commit
9e84182a8b
|
@ -0,0 +1,8 @@
|
||||||
|
.bundle/
|
||||||
|
log/*.log
|
||||||
|
pkg/
|
||||||
|
test/dummy/db/*.sqlite3
|
||||||
|
test/dummy/db/*.sqlite3-journal
|
||||||
|
test/dummy/log/*.log
|
||||||
|
test/dummy/tmp/
|
||||||
|
test/dummy/.sass-cache
|
|
@ -0,0 +1,14 @@
|
||||||
|
source "https://rubygems.org"
|
||||||
|
|
||||||
|
# Declare your gem's dependencies in space.gemspec.
|
||||||
|
# Bundler will treat runtime dependencies like base dependencies, and
|
||||||
|
# development dependencies will be added by default to the :development group.
|
||||||
|
gemspec
|
||||||
|
|
||||||
|
# Declare any dependencies that are still in development here instead of in
|
||||||
|
# your gemspec. These might include edge Rails or gems from your path or
|
||||||
|
# Git. Remember to move these dependencies to your gemspec before releasing
|
||||||
|
# your gem to rubygems.org.
|
||||||
|
|
||||||
|
# To use debugger
|
||||||
|
# gem 'debugger'
|
|
@ -0,0 +1,20 @@
|
||||||
|
Copyright 2015 YOURNAME
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
@ -0,0 +1,3 @@
|
||||||
|
= Space
|
||||||
|
|
||||||
|
This project rocks and uses MIT-LICENSE.
|
|
@ -0,0 +1,34 @@
|
||||||
|
begin
|
||||||
|
require 'bundler/setup'
|
||||||
|
rescue LoadError
|
||||||
|
puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
|
||||||
|
end
|
||||||
|
|
||||||
|
require 'rdoc/task'
|
||||||
|
|
||||||
|
RDoc::Task.new(:rdoc) do |rdoc|
|
||||||
|
rdoc.rdoc_dir = 'rdoc'
|
||||||
|
rdoc.title = 'Space'
|
||||||
|
rdoc.options << '--line-numbers'
|
||||||
|
rdoc.rdoc_files.include('README.rdoc')
|
||||||
|
rdoc.rdoc_files.include('lib/**/*.rb')
|
||||||
|
end
|
||||||
|
|
||||||
|
APP_RAKEFILE = File.expand_path("../test/dummy/Rakefile", __FILE__)
|
||||||
|
load 'rails/tasks/engine.rake'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Bundler::GemHelper.install_tasks
|
||||||
|
|
||||||
|
require 'rake/testtask'
|
||||||
|
|
||||||
|
Rake::TestTask.new(:test) do |t|
|
||||||
|
t.libs << 'lib'
|
||||||
|
t.libs << 'test'
|
||||||
|
t.pattern = 'test/**/*_test.rb'
|
||||||
|
t.verbose = false
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
task default: :test
|
|
@ -0,0 +1,124 @@
|
||||||
|
/*
|
||||||
|
A simple jQuery function that can add listeners on attribute change.
|
||||||
|
http://meetselva.github.io/attrchange/
|
||||||
|
|
||||||
|
About License:
|
||||||
|
Copyright (C) 2013-2014 Selvakumar Arumugam
|
||||||
|
You may use attrchange plugin under the terms of the MIT Licese.
|
||||||
|
https://github.com/meetselva/attrchange/blob/master/MIT-License.txt
|
||||||
|
*/
|
||||||
|
(function($) {
|
||||||
|
function isDOMAttrModifiedSupported() {
|
||||||
|
var p = document.createElement('p');
|
||||||
|
var flag = false;
|
||||||
|
|
||||||
|
if (p.addEventListener) {
|
||||||
|
p.addEventListener('DOMAttrModified', function() {
|
||||||
|
flag = true
|
||||||
|
}, false);
|
||||||
|
} else if (p.attachEvent) {
|
||||||
|
p.attachEvent('onDOMAttrModified', function() {
|
||||||
|
flag = true
|
||||||
|
});
|
||||||
|
} else { return false; }
|
||||||
|
p.setAttribute('id', 'target');
|
||||||
|
return flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
function checkAttributes(chkAttr, e) {
|
||||||
|
if (chkAttr) {
|
||||||
|
var attributes = this.data('attr-old-value');
|
||||||
|
|
||||||
|
if (e.attributeName.indexOf('style') >= 0) {
|
||||||
|
if (!attributes['style'])
|
||||||
|
attributes['style'] = {}; //initialize
|
||||||
|
var keys = e.attributeName.split('.');
|
||||||
|
e.attributeName = keys[0];
|
||||||
|
e.oldValue = attributes['style'][keys[1]]; //old value
|
||||||
|
e.newValue = keys[1] + ':'
|
||||||
|
+ this.prop("style")[$.camelCase(keys[1])]; //new value
|
||||||
|
attributes['style'][keys[1]] = e.newValue;
|
||||||
|
} else {
|
||||||
|
e.oldValue = attributes[e.attributeName];
|
||||||
|
e.newValue = this.attr(e.attributeName);
|
||||||
|
attributes[e.attributeName] = e.newValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.data('attr-old-value', attributes); //update the old value object
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//initialize Mutation Observer
|
||||||
|
var MutationObserver = window.MutationObserver
|
||||||
|
|| window.WebKitMutationObserver;
|
||||||
|
|
||||||
|
$.fn.attrchange = function(a, b) {
|
||||||
|
if (typeof a == 'object') {//core
|
||||||
|
var cfg = {
|
||||||
|
trackValues : false,
|
||||||
|
callback : $.noop
|
||||||
|
};
|
||||||
|
//backward compatibility
|
||||||
|
if (typeof a === "function") { cfg.callback = a; } else { $.extend(cfg, a); }
|
||||||
|
|
||||||
|
if (cfg.trackValues) { //get attributes old value
|
||||||
|
this.each(function(i, el) {
|
||||||
|
var attributes = {};
|
||||||
|
for ( var attr, i = 0, attrs = el.attributes, l = attrs.length; i < l; i++) {
|
||||||
|
attr = attrs.item(i);
|
||||||
|
attributes[attr.nodeName] = attr.value;
|
||||||
|
}
|
||||||
|
$(this).data('attr-old-value', attributes);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (MutationObserver) { //Modern Browsers supporting MutationObserver
|
||||||
|
var mOptions = {
|
||||||
|
subtree : false,
|
||||||
|
attributes : true,
|
||||||
|
attributeOldValue : cfg.trackValues
|
||||||
|
};
|
||||||
|
var observer = new MutationObserver(function(mutations) {
|
||||||
|
mutations.forEach(function(e) {
|
||||||
|
var _this = e.target;
|
||||||
|
//get new value if trackValues is true
|
||||||
|
if (cfg.trackValues) {
|
||||||
|
e.newValue = $(_this).attr(e.attributeName);
|
||||||
|
}
|
||||||
|
if ($(_this).data('attrchange-status') === 'connected') { //execute if connected
|
||||||
|
cfg.callback.call(_this, e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
return this.data('attrchange-method', 'Mutation Observer').data('attrchange-status', 'connected')
|
||||||
|
.data('attrchange-obs', observer).each(function() {
|
||||||
|
observer.observe(this, mOptions);
|
||||||
|
});
|
||||||
|
} else if (isDOMAttrModifiedSupported()) { //Opera
|
||||||
|
//Good old Mutation Events
|
||||||
|
return this.data('attrchange-method', 'DOMAttrModified').data('attrchange-status', 'connected').on('DOMAttrModified', function(event) {
|
||||||
|
if (event.originalEvent) { event = event.originalEvent; }//jQuery normalization is not required
|
||||||
|
event.attributeName = event.attrName; //property names to be consistent with MutationObserver
|
||||||
|
event.oldValue = event.prevValue; //property names to be consistent with MutationObserver
|
||||||
|
if ($(this).data('attrchange-status') === 'connected') { //disconnected logically
|
||||||
|
cfg.callback.call(this, event);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if ('onpropertychange' in document.body) { //works only in IE
|
||||||
|
return this.data('attrchange-method', 'propertychange').data('attrchange-status', 'connected').on('propertychange', function(e) {
|
||||||
|
e.attributeName = window.event.propertyName;
|
||||||
|
//to set the attr old value
|
||||||
|
checkAttributes.call($(this), cfg.trackValues, e);
|
||||||
|
if ($(this).data('attrchange-status') === 'connected') { //disconnected logically
|
||||||
|
cfg.callback.call(this, e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
} else if (typeof a == 'string' && $.fn.attrchange.hasOwnProperty('extensions') &&
|
||||||
|
$.fn.attrchange['extensions'].hasOwnProperty(a)) { //extensions/options
|
||||||
|
return $.fn.attrchange['extensions'][a].call(this, b);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})(jQuery);
|
|
@ -0,0 +1,13 @@
|
||||||
|
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
||||||
|
// listed below.
|
||||||
|
//
|
||||||
|
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
||||||
|
// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
|
||||||
|
//
|
||||||
|
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
||||||
|
// compiled file.
|
||||||
|
//
|
||||||
|
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
||||||
|
// about supported directives.
|
||||||
|
//
|
||||||
|
//= require_tree .
|
|
@ -0,0 +1,157 @@
|
||||||
|
ul.building-showcase{
|
||||||
|
list-style: outside none none;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0 0 10px;
|
||||||
|
|
||||||
|
.building{
|
||||||
|
background: #ffffff none repeat scroll 0 0;
|
||||||
|
box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
|
||||||
|
float: left;
|
||||||
|
margin: 5px;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 5px;
|
||||||
|
position: relative;
|
||||||
|
transition-property: left, right, top;
|
||||||
|
width: 200px;
|
||||||
|
height: 250px;
|
||||||
|
|
||||||
|
.shade {
|
||||||
|
background-color: #000000;
|
||||||
|
bottom: 0;
|
||||||
|
content: "";
|
||||||
|
display: block;
|
||||||
|
left: 0;
|
||||||
|
margin: 5px;
|
||||||
|
opacity: 0.4;
|
||||||
|
position: absolute;
|
||||||
|
right: 0;
|
||||||
|
top: 0;
|
||||||
|
width: 200px;
|
||||||
|
height: 250px;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
bottom: 0;
|
||||||
|
color: #f2f2f2;
|
||||||
|
font-family: "Playfair Display SC",sans-serif;
|
||||||
|
font-size: 30px;
|
||||||
|
letter-spacing: -0.5px;
|
||||||
|
line-height: 28px;
|
||||||
|
margin: 0;
|
||||||
|
opacity: 1;
|
||||||
|
padding: 10px;
|
||||||
|
position: absolute;
|
||||||
|
text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.4);
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
img {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.apartments-area {
|
||||||
|
list-style: outside none none;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0 0 10px;
|
||||||
|
|
||||||
|
.apartment {
|
||||||
|
background: #ffffff none repeat scroll 0 0;
|
||||||
|
box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
|
||||||
|
float: left;
|
||||||
|
margin: 10px;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 5px;
|
||||||
|
position: relative;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
padding-bottom: 0;
|
||||||
|
transition-property: left, right, top;
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
text-align: center;
|
||||||
|
|
||||||
|
.apartment-img {
|
||||||
|
background-color: #F1F1F1;
|
||||||
|
width: 100%;
|
||||||
|
height: 125px;
|
||||||
|
overflow: hidden;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
height: 145px;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
a{
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
p{
|
||||||
|
font-size: 18px;
|
||||||
|
font-family: "Playfair Display SC",sans-serif;
|
||||||
|
color : #000;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ul#layout-canvas {
|
||||||
|
background-color: #fff;
|
||||||
|
border: 2px solid #eee;
|
||||||
|
list-style: outside none none;
|
||||||
|
li.apartment-draggable {
|
||||||
|
max-width: 200px;
|
||||||
|
position: relative;
|
||||||
|
float: left;
|
||||||
|
cursor: move;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#full-layout-canvas {
|
||||||
|
background-color: #fff;
|
||||||
|
border: 2px solid #eee;
|
||||||
|
text-align: center;
|
||||||
|
position: relative;
|
||||||
|
|
||||||
|
.image-cover {
|
||||||
|
position: absolute;
|
||||||
|
left: 50%;
|
||||||
|
top: 50%;
|
||||||
|
height: 100%;
|
||||||
|
margin: auto;
|
||||||
|
overflow: hidden;
|
||||||
|
transform: translate(-50%, -50%);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.selection-box{
|
||||||
|
position: absolute;
|
||||||
|
width: 2px;
|
||||||
|
height: 2px;
|
||||||
|
background-color: rgba(0, 0, 0, .4);
|
||||||
|
}
|
||||||
|
|
||||||
|
.make-box-permanent{
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
|
||||||
|
.selection-box-form {
|
||||||
|
color: #fff;
|
||||||
|
|
||||||
|
.form-unit-title{
|
||||||
|
margin: 5px;
|
||||||
|
input {
|
||||||
|
width : 90%;
|
||||||
|
}
|
||||||
|
select {
|
||||||
|
width: 90%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,80 @@
|
||||||
|
class Admin::SpacesController < OrbitAdminController
|
||||||
|
|
||||||
|
def index
|
||||||
|
@buildings = Building.all
|
||||||
|
end
|
||||||
|
|
||||||
|
def new
|
||||||
|
@building = Building.new
|
||||||
|
end
|
||||||
|
|
||||||
|
def create
|
||||||
|
building = Building.new(building_params)
|
||||||
|
building.save
|
||||||
|
redirect_to admin_spaces_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def floors
|
||||||
|
uid = params[:space_id].split("-").last
|
||||||
|
@building = Building.find_by(:uid => uid) rescue nil
|
||||||
|
@table_fields = [:title, :action]
|
||||||
|
end
|
||||||
|
|
||||||
|
def add_floor
|
||||||
|
building = Building.find(params[:building_id])
|
||||||
|
floor = Floor.new(floor_params)
|
||||||
|
floor.building = building
|
||||||
|
floor.save
|
||||||
|
redirect_to "/admin/spaces/#{building.to_param}/floors"
|
||||||
|
end
|
||||||
|
|
||||||
|
def update_floor
|
||||||
|
floor = Floor.find(params[:floor_id]) rescue nil
|
||||||
|
floor.update_attributes(floor_params)
|
||||||
|
floor.save
|
||||||
|
redirect_to "/admin/spaces/#{floor.building.to_param}/floors"
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
def floor_layout
|
||||||
|
@floor = Floor.find_by(:uid => params[:floor_id].split("-").last)
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete_floor
|
||||||
|
floor = Floor.find_by(:uid => params[:floor_id].split("-").last)
|
||||||
|
floor.destroy
|
||||||
|
render :json => {"success" => true}.to_json
|
||||||
|
end
|
||||||
|
|
||||||
|
def add_floor_unit
|
||||||
|
@floor_unit = FloorUnit.new
|
||||||
|
@floor = Floor.find_by(:uid => params[:floor_id].split("-").last)
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_floor_unit
|
||||||
|
floor_unit = FloorUnit.new(floor_unit_params)
|
||||||
|
floor_unit.save
|
||||||
|
respond_to do |format|
|
||||||
|
format.html {redirect_to "/admin/spaces/#{floor_unit.floor.building.to_param}/#{floor_unit.floor.to_param}/units"}
|
||||||
|
format.js {render :json => {"success" => true, "unit" => {"id" => floor_unit.id.to_s, "title" => floor_unit.title}}.to_json}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def units
|
||||||
|
@floor = Floor.find_by(:uid => params[:floor_id].split("-").last)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def floor_params
|
||||||
|
params.require(:floor).permit!
|
||||||
|
end
|
||||||
|
|
||||||
|
def building_params
|
||||||
|
params.require(:building).permit!
|
||||||
|
end
|
||||||
|
|
||||||
|
def floor_unit_params
|
||||||
|
params.require(:floor_unit).permit!
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
module Space
|
||||||
|
module ApplicationHelper
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,10 @@
|
||||||
|
class Building
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
include Slug
|
||||||
|
|
||||||
|
field :title, as: :slug_title, localize: true
|
||||||
|
mount_uploader :image, ImageUploader
|
||||||
|
|
||||||
|
has_many :floors, :dependent => :destroy
|
||||||
|
end
|
|
@ -0,0 +1,13 @@
|
||||||
|
class Floor
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
include Slug
|
||||||
|
|
||||||
|
field :title, as: :slug_title
|
||||||
|
field :layout
|
||||||
|
|
||||||
|
mount_uploader :layout_image, ImageUploader
|
||||||
|
|
||||||
|
belongs_to :building
|
||||||
|
has_many :floor_units, :dependent => :destroy
|
||||||
|
end
|
|
@ -0,0 +1,11 @@
|
||||||
|
class FloorUnit
|
||||||
|
include Mongoid::Document
|
||||||
|
include Mongoid::Timestamps
|
||||||
|
|
||||||
|
field :title
|
||||||
|
|
||||||
|
belongs_to :floor
|
||||||
|
|
||||||
|
mount_uploader :layout, ImageUploader
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,7 @@
|
||||||
|
<li class="building">
|
||||||
|
<a href="/admin/spaces/<%= building.to_param %>/floors">
|
||||||
|
<img src="<%= building.image.thumb.url %>" />
|
||||||
|
<div class="shade"></div>
|
||||||
|
<p><%= building.title %></p>
|
||||||
|
</a>
|
||||||
|
</li>
|
|
@ -0,0 +1,10 @@
|
||||||
|
<tr>
|
||||||
|
<td><a href="/admin/spaces/<%= floor.building.to_param %>/<%= floor.to_param %>/units"><%= floor.title %></a></td>
|
||||||
|
<td>
|
||||||
|
<% if !floor.floor_units.blank? %>
|
||||||
|
<a href="/admin/spaces/floor/<%= floor.to_param %>/layout" class="btn btn-info">Floor Layout</a>
|
||||||
|
<% end %>
|
||||||
|
<a href="#" data-values='{"id" : "<%= floor.id.to_s %>", "title" : "<%= floor.title %>", "layout" : "<%= floor.layout_image.url == "" ? "" : floor.layout_image.url %>"}' class="btn btn-warning edit-floor-btns">Edit Floor</a>
|
||||||
|
<a href="/admin/spaces/floor/<%= floor.to_param %>/delete" class="btn btn-danger floor-delete-btns"><i class="icons-trash"></i></a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
|
@ -0,0 +1,8 @@
|
||||||
|
<li class="apartment">
|
||||||
|
<a href="#">
|
||||||
|
<div class="apartment-img">
|
||||||
|
<img src="<%= floor_unit.layout.thumb.url.nil? ? "" : floor_unit.layout.thumb.url %>" >
|
||||||
|
</div>
|
||||||
|
<p><%= floor_unit.title %></p>
|
||||||
|
</a>
|
||||||
|
</li>
|
|
@ -0,0 +1,62 @@
|
||||||
|
<% content_for :page_specific_css do %>
|
||||||
|
<%= stylesheet_link_tag "lib/main-forms" %>
|
||||||
|
<%= stylesheet_link_tag "lib/fileupload" %>
|
||||||
|
<%= stylesheet_link_tag "lib/main-list" %>
|
||||||
|
<% end %>
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "lib/bootstrap-fileupload" %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<!-- Input Area -->
|
||||||
|
<div class="input-area">
|
||||||
|
<!-- Module -->
|
||||||
|
<div class="tab-content">
|
||||||
|
|
||||||
|
<!-- Basic Module -->
|
||||||
|
<div class="tab-pane fade in active" id="basic">
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<%= f.label :title, :class => "control-label muted" %>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_field :title, placeholder: t("space.floor_unit_name") %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- Detailed layout image Upload -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t("space.detailed_layout") %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<div class="fileupload fileupload-new clearfix <%= 'fileupload-edit' if @floor_unit.layout.file %>" data-provides="fileupload">
|
||||||
|
<div class="fileupload-new thumbnail pull-left">
|
||||||
|
<% if @floor_unit.layout.file %>
|
||||||
|
<%= image_tag @floor_unit.layout %>
|
||||||
|
<% else %>
|
||||||
|
<img src="http://www.placehold.it/150x100/EFEFEF/AAAAAA" />
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<div class="fileupload-preview fileupload-exists thumbnail pull-left"></div>
|
||||||
|
<span class="btn btn-file">
|
||||||
|
<span class="fileupload-new"><%= t(:select_image) %></span>
|
||||||
|
<span class="fileupload-exists"><%= t(:change) %></span>
|
||||||
|
<%= f.file_field :layout %>
|
||||||
|
</span>
|
||||||
|
<a href="#" class="btn fileupload-exists" data-dismiss="fileupload"><%= t(:cancel) %></a>
|
||||||
|
<div class="controls" data-toggle="buttons-checkbox">
|
||||||
|
<label class="checkbox inline btn btn-danger fileupload-remove">
|
||||||
|
<%= f.check_box :remove_layout %><%= t(:remove) %>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Form Actions -->
|
||||||
|
<div class="form-actions">
|
||||||
|
<%= f.hidden_field :floor_id, value: @floor.id %>
|
||||||
|
<%= f.submit t('submit'), class: 'btn btn-primary' %>
|
||||||
|
<%= link_to t('cancel'), "/admin/spaces/#{@floor.building.to_param}/#{@floor.to_param}/units", :class=>"btn" %>
|
||||||
|
</div>
|
|
@ -0,0 +1,66 @@
|
||||||
|
<% content_for :page_specific_css do %>
|
||||||
|
<%= stylesheet_link_tag "lib/main-forms" %>
|
||||||
|
<%= stylesheet_link_tag "lib/fileupload" %>
|
||||||
|
<%= stylesheet_link_tag "lib/main-list" %>
|
||||||
|
<% end %>
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "lib/bootstrap-fileupload" %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<!-- Input Area -->
|
||||||
|
<div class="input-area">
|
||||||
|
<!-- Module -->
|
||||||
|
<div class="tab-content">
|
||||||
|
|
||||||
|
<!-- Basic Module -->
|
||||||
|
<div class="tab-pane fade in active" id="basic">
|
||||||
|
|
||||||
|
<% @site_in_use_locales.each do |locale| %>
|
||||||
|
<%= f.fields_for :title_translations do |f| %>
|
||||||
|
<div class="control-group">
|
||||||
|
<%= f.label :title.to_s + " (" + locale.to_s + ")", :class => "control-label muted" %>
|
||||||
|
<div class="controls">
|
||||||
|
<%= f.text_field locale, placeholder: t("space.building_name") %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
<% end %>
|
||||||
|
<!-- Images Upload -->
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label muted"><%= t(:image) %></label>
|
||||||
|
<div class="controls">
|
||||||
|
<div class="fileupload fileupload-new clearfix <%= 'fileupload-edit' if @building.image.file %>" data-provides="fileupload">
|
||||||
|
<div class="fileupload-new thumbnail pull-left">
|
||||||
|
<% if @building.image.file %>
|
||||||
|
<%= image_tag @building.image %>
|
||||||
|
<% else %>
|
||||||
|
<img src="http://www.placehold.it/50x50/EFEFEF/AAAAAA" />
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
<div class="fileupload-preview fileupload-exists thumbnail pull-left"></div>
|
||||||
|
<span class="btn btn-file">
|
||||||
|
<span class="fileupload-new"><%= t(:select_image) %></span>
|
||||||
|
<span class="fileupload-exists"><%= t(:change) %></span>
|
||||||
|
<%= f.file_field :image %>
|
||||||
|
</span>
|
||||||
|
<a href="#" class="btn fileupload-exists" data-dismiss="fileupload"><%= t(:cancel) %></a>
|
||||||
|
<div class="controls" data-toggle="buttons-checkbox">
|
||||||
|
<label class="checkbox inline btn btn-danger fileupload-remove">
|
||||||
|
<%= f.check_box :remove_image %><%= t(:remove) %>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Form Actions -->
|
||||||
|
<div class="form-actions">
|
||||||
|
<%= f.submit t('submit'), class: 'btn btn-primary' %>
|
||||||
|
<%= link_to t('cancel'), admin_spaces_path, :class=>"btn" %>
|
||||||
|
</div>
|
|
@ -0,0 +1,5 @@
|
||||||
|
<%= form_for @floor_unit, url: "/admin/space/create_floor_unit", html: {class: "form-horizontal main-forms"} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render :partial => "floor_unit_form", locals: {f: f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,166 @@
|
||||||
|
<% content_for :page_specific_css do %>
|
||||||
|
<%= stylesheet_link_tag "https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css" %>
|
||||||
|
<%= stylesheet_link_tag "space" %>
|
||||||
|
<% end %>
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "attrchange" %>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div id="full-layout-canvas">
|
||||||
|
<img id="layout-image" src="<%= @floor.layout_image.url %>" />
|
||||||
|
<div class="image-cover"></div>
|
||||||
|
</div>
|
||||||
|
<script type="text/javascript">
|
||||||
|
var canvas = $("#full-layout-canvas"),
|
||||||
|
layoutImage = $("#layout-image"),
|
||||||
|
cover = canvas.find(".image-cover"),
|
||||||
|
dragAreaCount = 0,
|
||||||
|
windowHeight = ($(window).height() - (36 + 46 + 75)) + "px",
|
||||||
|
floorUnits = <%= @floor.floor_units.collect{|unit| {"id" => unit.id.to_s, "title" => unit.title}}.to_json.html_safe %>,
|
||||||
|
formDisplay = false,
|
||||||
|
floor = <%= {"id" => @floor.id.to_s, "title" => @floor.title}.to_json.html_safe %>;
|
||||||
|
canvas.height(windowHeight);
|
||||||
|
layoutImage.height(windowHeight);
|
||||||
|
layoutImage.on("load",function(){
|
||||||
|
cover.width(layoutImage.width());
|
||||||
|
// cover.css("left",((layoutImage.position().left * 100) / canvas.width()) + "%");
|
||||||
|
})
|
||||||
|
|
||||||
|
var dragBoxes = [],
|
||||||
|
offsetX = 0,
|
||||||
|
offsetY = 0,
|
||||||
|
diffX = 0,
|
||||||
|
diffY = 0,
|
||||||
|
currentDragBox = null,
|
||||||
|
isDragging = false;
|
||||||
|
cover.on("mousedown",function(e){
|
||||||
|
if($(".selection-box.hover").length == 0 && !formDisplay){
|
||||||
|
if(currentDragBox != null){
|
||||||
|
currentDragBox.remove();
|
||||||
|
currentDragBox = null;
|
||||||
|
$(".make-box-permanent").remove();
|
||||||
|
}
|
||||||
|
var dragBox = $("<div class='selection-box'></div>"),
|
||||||
|
xpercent = ((e.offsetX * 100) / cover.width()) + "%",
|
||||||
|
ypercent = ((e.offsetY * 100) / cover.height()) + "%";
|
||||||
|
dragBox.css({
|
||||||
|
"left" : xpercent,
|
||||||
|
"top" : ypercent
|
||||||
|
})
|
||||||
|
offsetX = e.offsetX;
|
||||||
|
offsetY = e.offsetY;
|
||||||
|
isDragging = true;
|
||||||
|
currentDragBox = dragBox;
|
||||||
|
cover.append(dragBox);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
cover.on("mousemove",function(e){
|
||||||
|
if(isDragging){
|
||||||
|
diffX = e.offsetX - offsetX;
|
||||||
|
diffY = e.offsetY - offsetY;
|
||||||
|
currentDragBox.css({
|
||||||
|
width : diffX + "px",
|
||||||
|
height : diffY + "px"
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
cover.on("mouseup",function(){
|
||||||
|
if(isDragging){
|
||||||
|
isDragging = false;
|
||||||
|
if(currentDragBox.width() > 20 && currentDragBox.height() > 20){
|
||||||
|
var offset = currentDragBox.offset(),
|
||||||
|
btn = $("<button class='make-box-permanent btn btn-primary btn-small'><i class='fa fa-check'></i> Ok</button>");
|
||||||
|
btn.on("click",selectAreaOkBtnHandler);
|
||||||
|
currentDragBox.append(btn);
|
||||||
|
currentDragBox.hover(function(){
|
||||||
|
$(this).addClass("hover");
|
||||||
|
},function(){
|
||||||
|
$(this).removeClass("hover");
|
||||||
|
})
|
||||||
|
}else{
|
||||||
|
currentDragBox.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
var selectAreaOkBtnHandler = function(event){
|
||||||
|
$(this).remove();
|
||||||
|
var deleteBtn = $("<button class='btn btn-small btn-danger selection-box-delete-btn'><i class='fa fa-times'></i> Delete</button>");
|
||||||
|
deleteBtn.on("click",function(ev){});
|
||||||
|
currentDragBox.append(deleteBtn)
|
||||||
|
currentDragBox.append(makeNewForm(currentDragBox));
|
||||||
|
dragBoxes.push(currentDragBox);
|
||||||
|
dragAreaCount++;
|
||||||
|
currentDragBox = null;
|
||||||
|
event.stopPropagation();
|
||||||
|
}
|
||||||
|
|
||||||
|
var makeNewForm = function(box){
|
||||||
|
formDisplay = true;
|
||||||
|
var formWrapper = $("<div class='selection-form-wrapper' />"),
|
||||||
|
form = $("<form class='selection-box-form form-horizontal' />"),
|
||||||
|
field = "<div class='control-group'> <label calss='control-label muted' for='floor_unit_title'>Unit name : </label><img src='/assets/preloader.gif' style='width:50px; height:50px;display:none;' /><div class='form-unit-title'><input id='floor_unit_title' type='text' name='floor_unit[title]' placeholder='New unit title' /><select style='display:none;'>";
|
||||||
|
|
||||||
|
for(index in floorUnits){
|
||||||
|
var unit = floorUnits[index];
|
||||||
|
field += "<option value='" + unit.id + "'>" + unit.title + "</option>";
|
||||||
|
}
|
||||||
|
|
||||||
|
field += "</select></div></div>";
|
||||||
|
var checkbox = $("<div class='control-group'><div><input type='checkbox' id='toggle-select-text' /> Select existing units</div></div>"),
|
||||||
|
type = "new";
|
||||||
|
checkbox.find("input[type=checkbox]").on("click",function(){
|
||||||
|
if($(this).is(":checked")){
|
||||||
|
form.find("select").show();
|
||||||
|
form.find("input[type=text]").hide();
|
||||||
|
type = "existing";
|
||||||
|
}else{
|
||||||
|
form.find("select").hide();
|
||||||
|
form.find("input[type=text]").show();
|
||||||
|
type = "new";
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
var submitBtn = $("<div class='control-group'><div><button class='btn btn-small btn-primary'>Save</button></div>");
|
||||||
|
submitBtn.find("button").on("click",function(){
|
||||||
|
if(type == "existing"){
|
||||||
|
box.attr("data-unit-id",form.find("select").val());
|
||||||
|
formDisplay = false;
|
||||||
|
formWrapper.remove();
|
||||||
|
}else if(type == "new"){
|
||||||
|
var input = form.find("input[type=text]");
|
||||||
|
if(input.val() != ""){
|
||||||
|
form.find("img").show();
|
||||||
|
input.hide();
|
||||||
|
form.find("select").hide();
|
||||||
|
$.ajax({
|
||||||
|
url : "/admin/space/create_floor_unit",
|
||||||
|
data : {"floor_unit[title]" : input.val(), "floor_unit[floor_id]" : floor.id},
|
||||||
|
type : "post",
|
||||||
|
dataType : "json"
|
||||||
|
}).done(function(data){
|
||||||
|
box.attr("data-unit-id",data.unit.id);
|
||||||
|
formDisplay = false;
|
||||||
|
formWrapper.remove();
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
form.append(field);
|
||||||
|
form.append(checkbox);
|
||||||
|
form.append(submitBtn);
|
||||||
|
formWrapper.append(form);
|
||||||
|
return formWrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,95 @@
|
||||||
|
<% content_for :page_specific_javascript do %>
|
||||||
|
<%= javascript_include_tag "lib/jquery.form" %>
|
||||||
|
<%= javascript_include_tag "validator" %>
|
||||||
|
<% end %>
|
||||||
|
<table class="table main-list">
|
||||||
|
<thead>
|
||||||
|
<tr class="sort-header">
|
||||||
|
<% @table_fields.each do |f| %>
|
||||||
|
<%= thead(f) %>
|
||||||
|
<% end %>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody id="floor-list-table">
|
||||||
|
<%= render :partial => "floor", :collection => @building.floors %>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<div class="bottomnav clearfix">
|
||||||
|
<div class="action pull-right">
|
||||||
|
<a href="#" id="add-floor" class="btn btn-primary"><%= t("space.add_floor") %></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="add-floor-modal" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
||||||
|
<h3 id="myModalLabel"><%= t("spacd.add_floor") %></h3>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<form action="/admin/space/add_floor" method="post" id="add-floor-form" class="form-horizontal main-forms" enctype='multipart/form-data'>
|
||||||
|
<%= tag(:input, :type => "hidden", :name => request_forgery_protection_token.to_s, :value => form_authenticity_token) %>
|
||||||
|
<div class="control-group">
|
||||||
|
<label for="floor-name-text-box" class="control-label muted">Floor Name</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" placeholder="Floor1" id="floor-name-text-box" name="floor[title]" data-fv-validation="required;" data-fv-messages="Cannot be empty;" />
|
||||||
|
<input type="hidden" name="building_id" value="<%= @building.id.to_s %>" />
|
||||||
|
<input type="hidden" name="floor_id" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label for="floor-name-text-box" class="control-label muted">Floor Layout</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="file" placeholder="Floor1" id="floor-name-text-box" name="floor[layout_image]" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn btn-primary" id="add-floor-save-btn">Save</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<script type="text/javascript">
|
||||||
|
var addFloorForm = new FormValidator($("#add-floor-form"));
|
||||||
|
$("#add-floor-save-btn").on("click",function() {
|
||||||
|
if(addFloorForm.isFormValidated()){
|
||||||
|
addFloorForm.form.submit();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
$("#add-floor-modal").on("hidden",function(){
|
||||||
|
addFloorForm.reset();
|
||||||
|
})
|
||||||
|
|
||||||
|
$("body").on("click",".edit-floor-btns", function(){
|
||||||
|
var el = $(this),
|
||||||
|
data = el.data("values");
|
||||||
|
$("#floor-name-text-box").val(data.title);
|
||||||
|
$("input[name=floor_id]").val(data.id);
|
||||||
|
addFloorForm.form.attr("action","/admin/space/update_floor");
|
||||||
|
$("#add-floor-modal").modal("show");
|
||||||
|
return false;
|
||||||
|
})
|
||||||
|
|
||||||
|
$("#add-floor").on("click",function(){
|
||||||
|
addFloorForm.form.attr("action","/admin/space/add_floor");
|
||||||
|
$("#add-floor-modal").modal("show");
|
||||||
|
})
|
||||||
|
|
||||||
|
$("body").on("click",".floor-delete-btns", function(){
|
||||||
|
var el = $(this);
|
||||||
|
if(confirm("Are you sure?")){
|
||||||
|
$.ajax({
|
||||||
|
url : el.attr("href"),
|
||||||
|
type : "delete",
|
||||||
|
dataType : "json"
|
||||||
|
}).done(function(){
|
||||||
|
el.parent().parent().slideUp(function(){
|
||||||
|
$(this).remove();
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
})
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
<% content_for :page_specific_css do %>
|
||||||
|
<%= stylesheet_link_tag "space" %>
|
||||||
|
<% end %>
|
||||||
|
<ul class="building-showcase clearfix">
|
||||||
|
<%= render :partial => "building", :collection => @buildings %>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<div class="bottomnav clearfix">
|
||||||
|
<div class="action pull-right">
|
||||||
|
<%= link_to t("space.add_building"), new_admin_space_path, :class => "btn btn-primary" %>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,5 @@
|
||||||
|
<%= form_for @building, url: admin_spaces_path, html: {class: "form-horizontal main-forms"} do |f| %>
|
||||||
|
<fieldset>
|
||||||
|
<%= render :partial => "form", locals: {f: f} %>
|
||||||
|
</fieldset>
|
||||||
|
<% end %>
|
|
@ -0,0 +1,11 @@
|
||||||
|
<% content_for :page_specific_css do %>
|
||||||
|
<%= stylesheet_link_tag "space" %>
|
||||||
|
<% end %>
|
||||||
|
<ul class="apartments-area">
|
||||||
|
<%= render :partial => "floor_unit", :collection => @floor.floor_units %>
|
||||||
|
</ul>
|
||||||
|
<div class="bottomnav clearfix">
|
||||||
|
<div class="action pull-right">
|
||||||
|
<a href="/admin/spaces/floor/<%= @floor.to_param %>/add_floor_unit" id="add-floor" class="btn btn-primary" data-toggle="modal"><%= t("space.add_floor_unit") %></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,12 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
# This command will automatically be run when you run "rails" with Rails 4 gems installed from the root of your application.
|
||||||
|
|
||||||
|
ENGINE_ROOT = File.expand_path('../..', __FILE__)
|
||||||
|
ENGINE_PATH = File.expand_path('../../lib/space/engine', __FILE__)
|
||||||
|
|
||||||
|
# Set up gems listed in the Gemfile.
|
||||||
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
|
||||||
|
require 'bundler/setup' if File.exist?(ENV['BUNDLE_GEMFILE'])
|
||||||
|
|
||||||
|
require 'rails/all'
|
||||||
|
require 'rails/engine/commands'
|
|
@ -0,0 +1,12 @@
|
||||||
|
en:
|
||||||
|
space:
|
||||||
|
space: Space
|
||||||
|
buildings: Buildings
|
||||||
|
add_buildings: Add Building
|
||||||
|
building_name: Building Name
|
||||||
|
add_floor: Add Floor
|
||||||
|
add_floor_unit: Add Unit
|
||||||
|
simple_layout: Simple Layout
|
||||||
|
detailed_layout: Detailed Layout
|
||||||
|
floor_unit_name: Unit Name
|
||||||
|
save_layout: Save Layout
|
|
@ -0,0 +1,12 @@
|
||||||
|
zh_tw:
|
||||||
|
space:
|
||||||
|
space: Space
|
||||||
|
buildings: Buildings
|
||||||
|
add_buildings: Add Building
|
||||||
|
building_name: Building Name
|
||||||
|
add_floor: Add Floor
|
||||||
|
add_floor_unit: Add Unit
|
||||||
|
simple_layout: Simple Layout
|
||||||
|
detailed_layout: Detailed Layout
|
||||||
|
floor_unit_name: Unit Name
|
||||||
|
save_layout: Save Layout
|
|
@ -0,0 +1,20 @@
|
||||||
|
Rails.application.routes.draw do
|
||||||
|
|
||||||
|
locales = Site.first.in_use_locales rescue I18n.available_locales
|
||||||
|
|
||||||
|
scope "(:locale)", locale: Regexp.new(locales.join("|")) do
|
||||||
|
namespace :admin do
|
||||||
|
post "space/add_floor", to: 'spaces#add_floor'
|
||||||
|
post "space/update_floor", to: 'spaces#update_floor'
|
||||||
|
post "space/create_floor_unit", to: 'spaces#create_floor_unit'
|
||||||
|
get "spaces/:building_id/:floor_id/units", to: 'spaces#units'
|
||||||
|
get "spaces/floor/:floor_id/add_floor_unit", to: 'spaces#add_floor_unit'
|
||||||
|
get "spaces/floor/:floor_id/layout", to: 'spaces#floor_layout'
|
||||||
|
delete "spaces/floor/:floor_id/delete", to: 'spaces#delete_floor'
|
||||||
|
resources :spaces do
|
||||||
|
get "floors"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
require "space/engine"
|
||||||
|
|
||||||
|
module Space
|
||||||
|
end
|
|
@ -0,0 +1,23 @@
|
||||||
|
module Space
|
||||||
|
class Engine < ::Rails::Engine
|
||||||
|
initializer "space" do
|
||||||
|
OrbitApp.registration "Space", :type => "ModuleApp" do
|
||||||
|
module_label "space.space"
|
||||||
|
base_url File.expand_path File.dirname(__FILE__)
|
||||||
|
frontend_enabled
|
||||||
|
side_bar do
|
||||||
|
head_label_i18n 'space.space', icon_class: "icons-leaf"
|
||||||
|
available_for "users"
|
||||||
|
active_for_controllers (['admin/spaces'])
|
||||||
|
head_link_path "admin_spaces_path"
|
||||||
|
|
||||||
|
context_link 'space.buildings',
|
||||||
|
:link_path=>"admin_spaces_path" ,
|
||||||
|
:priority=>1,
|
||||||
|
:active_for_action=>{'admin/spaces'=>'index'},
|
||||||
|
:available_for => 'users'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,3 @@
|
||||||
|
module Space
|
||||||
|
VERSION = "0.0.1"
|
||||||
|
end
|
|
@ -0,0 +1,4 @@
|
||||||
|
# desc "Explaining what the task does"
|
||||||
|
# task :space do
|
||||||
|
# # Task goes here
|
||||||
|
# end
|
|
@ -0,0 +1,19 @@
|
||||||
|
$:.push File.expand_path("../lib", __FILE__)
|
||||||
|
|
||||||
|
# Maintain your gem's version:
|
||||||
|
require "space/version"
|
||||||
|
|
||||||
|
# Describe your gem and declare its dependencies:
|
||||||
|
Gem::Specification.new do |s|
|
||||||
|
s.name = "space"
|
||||||
|
s.version = Space::VERSION
|
||||||
|
s.authors = ["Harry Bomrah"]
|
||||||
|
s.email = ["harry@rulingcom.com"]
|
||||||
|
s.homepage = "http://www.rulingcom.com"
|
||||||
|
s.summary = "Construction layout module."
|
||||||
|
s.description = "Construction layout module."
|
||||||
|
s.license = "MIT"
|
||||||
|
|
||||||
|
s.files = Dir["{app,config,db,lib}/**/*", "MIT-LICENSE", "Rakefile", "README.rdoc"]
|
||||||
|
s.test_files = Dir["test/**/*"]
|
||||||
|
end
|
|
@ -0,0 +1,28 @@
|
||||||
|
== README
|
||||||
|
|
||||||
|
This README would normally document whatever steps are necessary to get the
|
||||||
|
application up and running.
|
||||||
|
|
||||||
|
Things you may want to cover:
|
||||||
|
|
||||||
|
* Ruby version
|
||||||
|
|
||||||
|
* System dependencies
|
||||||
|
|
||||||
|
* Configuration
|
||||||
|
|
||||||
|
* Database creation
|
||||||
|
|
||||||
|
* Database initialization
|
||||||
|
|
||||||
|
* How to run the test suite
|
||||||
|
|
||||||
|
* Services (job queues, cache servers, search engines, etc.)
|
||||||
|
|
||||||
|
* Deployment instructions
|
||||||
|
|
||||||
|
* ...
|
||||||
|
|
||||||
|
|
||||||
|
Please feel free to use a different markup language if you do not plan to run
|
||||||
|
<tt>rake doc:app</tt>.
|
|
@ -0,0 +1,6 @@
|
||||||
|
# Add your own tasks in files placed in lib/tasks ending in .rake,
|
||||||
|
# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
|
||||||
|
|
||||||
|
require File.expand_path('../config/application', __FILE__)
|
||||||
|
|
||||||
|
Rails.application.load_tasks
|
|
@ -0,0 +1,13 @@
|
||||||
|
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
||||||
|
// listed below.
|
||||||
|
//
|
||||||
|
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
||||||
|
// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
|
||||||
|
//
|
||||||
|
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
||||||
|
// compiled file.
|
||||||
|
//
|
||||||
|
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
||||||
|
// about supported directives.
|
||||||
|
//
|
||||||
|
//= require_tree .
|
|
@ -0,0 +1,15 @@
|
||||||
|
/*
|
||||||
|
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
||||||
|
* listed below.
|
||||||
|
*
|
||||||
|
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
||||||
|
* or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
|
||||||
|
*
|
||||||
|
* You're free to add application-wide styles to this file and they'll appear at the bottom of the
|
||||||
|
* compiled file so the styles you add here take precedence over styles defined in any styles
|
||||||
|
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
||||||
|
* file per style scope.
|
||||||
|
*
|
||||||
|
*= require_tree .
|
||||||
|
*= require_self
|
||||||
|
*/
|
|
@ -0,0 +1,5 @@
|
||||||
|
class ApplicationController < ActionController::Base
|
||||||
|
# Prevent CSRF attacks by raising an exception.
|
||||||
|
# For APIs, you may want to use :null_session instead.
|
||||||
|
protect_from_forgery with: :exception
|
||||||
|
end
|
|
@ -0,0 +1,2 @@
|
||||||
|
module ApplicationHelper
|
||||||
|
end
|
|
@ -0,0 +1,14 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Dummy</title>
|
||||||
|
<%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track' => true %>
|
||||||
|
<%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
|
||||||
|
<%= csrf_meta_tags %>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<%= yield %>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,3 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
|
||||||
|
load Gem.bin_path('bundler', 'bundle')
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
APP_PATH = File.expand_path('../../config/application', __FILE__)
|
||||||
|
require_relative '../config/boot'
|
||||||
|
require 'rails/commands'
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
require_relative '../config/boot'
|
||||||
|
require 'rake'
|
||||||
|
Rake.application.run
|
|
@ -0,0 +1,4 @@
|
||||||
|
# This file is used by Rack-based servers to start the application.
|
||||||
|
|
||||||
|
require ::File.expand_path('../config/environment', __FILE__)
|
||||||
|
run Rails.application
|
|
@ -0,0 +1,23 @@
|
||||||
|
require File.expand_path('../boot', __FILE__)
|
||||||
|
|
||||||
|
require 'rails/all'
|
||||||
|
|
||||||
|
Bundler.require(*Rails.groups)
|
||||||
|
require "space"
|
||||||
|
|
||||||
|
module Dummy
|
||||||
|
class Application < Rails::Application
|
||||||
|
# Settings in config/environments/* take precedence over those specified here.
|
||||||
|
# Application configuration should go into files in config/initializers
|
||||||
|
# -- all .rb files in that directory are automatically loaded.
|
||||||
|
|
||||||
|
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
||||||
|
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
||||||
|
# config.time_zone = 'Central Time (US & Canada)'
|
||||||
|
|
||||||
|
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
||||||
|
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
||||||
|
# config.i18n.default_locale = :de
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
# Set up gems listed in the Gemfile.
|
||||||
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../../../Gemfile', __FILE__)
|
||||||
|
|
||||||
|
require 'bundler/setup' if File.exist?(ENV['BUNDLE_GEMFILE'])
|
||||||
|
$LOAD_PATH.unshift File.expand_path('../../../../lib', __FILE__)
|
|
@ -0,0 +1,25 @@
|
||||||
|
# SQLite version 3.x
|
||||||
|
# gem install sqlite3
|
||||||
|
#
|
||||||
|
# Ensure the SQLite 3 gem is defined in your Gemfile
|
||||||
|
# gem 'sqlite3'
|
||||||
|
#
|
||||||
|
default: &default
|
||||||
|
adapter: sqlite3
|
||||||
|
pool: 5
|
||||||
|
timeout: 5000
|
||||||
|
|
||||||
|
development:
|
||||||
|
<<: *default
|
||||||
|
database: db/development.sqlite3
|
||||||
|
|
||||||
|
# Warning: The database defined as "test" will be erased and
|
||||||
|
# re-generated from your development database when you run "rake".
|
||||||
|
# Do not set this db to the same as development or production.
|
||||||
|
test:
|
||||||
|
<<: *default
|
||||||
|
database: db/test.sqlite3
|
||||||
|
|
||||||
|
production:
|
||||||
|
<<: *default
|
||||||
|
database: db/production.sqlite3
|
|
@ -0,0 +1,5 @@
|
||||||
|
# Load the Rails application.
|
||||||
|
require File.expand_path('../application', __FILE__)
|
||||||
|
|
||||||
|
# Initialize the Rails application.
|
||||||
|
Rails.application.initialize!
|
|
@ -0,0 +1,37 @@
|
||||||
|
Rails.application.configure do
|
||||||
|
# Settings specified here will take precedence over those in config/application.rb.
|
||||||
|
|
||||||
|
# In the development environment your application's code is reloaded on
|
||||||
|
# every request. This slows down response time but is perfect for development
|
||||||
|
# since you don't have to restart the web server when you make code changes.
|
||||||
|
config.cache_classes = false
|
||||||
|
|
||||||
|
# Do not eager load code on boot.
|
||||||
|
config.eager_load = false
|
||||||
|
|
||||||
|
# Show full error reports and disable caching.
|
||||||
|
config.consider_all_requests_local = true
|
||||||
|
config.action_controller.perform_caching = false
|
||||||
|
|
||||||
|
# Don't care if the mailer can't send.
|
||||||
|
config.action_mailer.raise_delivery_errors = false
|
||||||
|
|
||||||
|
# Print deprecation notices to the Rails logger.
|
||||||
|
config.active_support.deprecation = :log
|
||||||
|
|
||||||
|
# Raise an error on page load if there are pending migrations.
|
||||||
|
config.active_record.migration_error = :page_load
|
||||||
|
|
||||||
|
# Debug mode disables concatenation and preprocessing of assets.
|
||||||
|
# This option may cause significant delays in view rendering with a large
|
||||||
|
# number of complex assets.
|
||||||
|
config.assets.debug = true
|
||||||
|
|
||||||
|
# Adds additional error checking when serving assets at runtime.
|
||||||
|
# Checks for improperly declared sprockets dependencies.
|
||||||
|
# Raises helpful error messages.
|
||||||
|
config.assets.raise_runtime_errors = true
|
||||||
|
|
||||||
|
# Raises error for missing translations
|
||||||
|
# config.action_view.raise_on_missing_translations = true
|
||||||
|
end
|
|
@ -0,0 +1,78 @@
|
||||||
|
Rails.application.configure do
|
||||||
|
# Settings specified here will take precedence over those in config/application.rb.
|
||||||
|
|
||||||
|
# Code is not reloaded between requests.
|
||||||
|
config.cache_classes = true
|
||||||
|
|
||||||
|
# Eager load code on boot. This eager loads most of Rails and
|
||||||
|
# your application in memory, allowing both threaded web servers
|
||||||
|
# and those relying on copy on write to perform better.
|
||||||
|
# Rake tasks automatically ignore this option for performance.
|
||||||
|
config.eager_load = true
|
||||||
|
|
||||||
|
# Full error reports are disabled and caching is turned on.
|
||||||
|
config.consider_all_requests_local = false
|
||||||
|
config.action_controller.perform_caching = true
|
||||||
|
|
||||||
|
# Enable Rack::Cache to put a simple HTTP cache in front of your application
|
||||||
|
# Add `rack-cache` to your Gemfile before enabling this.
|
||||||
|
# For large-scale production use, consider using a caching reverse proxy like nginx, varnish or squid.
|
||||||
|
# config.action_dispatch.rack_cache = true
|
||||||
|
|
||||||
|
# Disable Rails's static asset server (Apache or nginx will already do this).
|
||||||
|
config.serve_static_assets = false
|
||||||
|
|
||||||
|
# Compress JavaScripts and CSS.
|
||||||
|
config.assets.js_compressor = :uglifier
|
||||||
|
# config.assets.css_compressor = :sass
|
||||||
|
|
||||||
|
# Do not fallback to assets pipeline if a precompiled asset is missed.
|
||||||
|
config.assets.compile = false
|
||||||
|
|
||||||
|
# Generate digests for assets URLs.
|
||||||
|
config.assets.digest = true
|
||||||
|
|
||||||
|
# `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb
|
||||||
|
|
||||||
|
# Specifies the header that your server uses for sending files.
|
||||||
|
# config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
|
||||||
|
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
|
||||||
|
|
||||||
|
# Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
|
||||||
|
# config.force_ssl = true
|
||||||
|
|
||||||
|
# Set to :debug to see everything in the log.
|
||||||
|
config.log_level = :info
|
||||||
|
|
||||||
|
# Prepend all log lines with the following tags.
|
||||||
|
# config.log_tags = [ :subdomain, :uuid ]
|
||||||
|
|
||||||
|
# Use a different logger for distributed setups.
|
||||||
|
# config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
|
||||||
|
|
||||||
|
# Use a different cache store in production.
|
||||||
|
# config.cache_store = :mem_cache_store
|
||||||
|
|
||||||
|
# Enable serving of images, stylesheets, and JavaScripts from an asset server.
|
||||||
|
# config.action_controller.asset_host = "http://assets.example.com"
|
||||||
|
|
||||||
|
# Ignore bad email addresses and do not raise email delivery errors.
|
||||||
|
# Set this to true and configure the email server for immediate delivery to raise delivery errors.
|
||||||
|
# config.action_mailer.raise_delivery_errors = false
|
||||||
|
|
||||||
|
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
||||||
|
# the I18n.default_locale when a translation cannot be found).
|
||||||
|
config.i18n.fallbacks = true
|
||||||
|
|
||||||
|
# Send deprecation notices to registered listeners.
|
||||||
|
config.active_support.deprecation = :notify
|
||||||
|
|
||||||
|
# Disable automatic flushing of the log to improve performance.
|
||||||
|
# config.autoflush_log = false
|
||||||
|
|
||||||
|
# Use default logging formatter so that PID and timestamp are not suppressed.
|
||||||
|
config.log_formatter = ::Logger::Formatter.new
|
||||||
|
|
||||||
|
# Do not dump schema after migrations.
|
||||||
|
config.active_record.dump_schema_after_migration = false
|
||||||
|
end
|
|
@ -0,0 +1,39 @@
|
||||||
|
Rails.application.configure do
|
||||||
|
# Settings specified here will take precedence over those in config/application.rb.
|
||||||
|
|
||||||
|
# The test environment is used exclusively to run your application's
|
||||||
|
# test suite. You never need to work with it otherwise. Remember that
|
||||||
|
# your test database is "scratch space" for the test suite and is wiped
|
||||||
|
# and recreated between test runs. Don't rely on the data there!
|
||||||
|
config.cache_classes = true
|
||||||
|
|
||||||
|
# Do not eager load code on boot. This avoids loading your whole application
|
||||||
|
# just for the purpose of running a single test. If you are using a tool that
|
||||||
|
# preloads Rails for running tests, you may have to set it to true.
|
||||||
|
config.eager_load = false
|
||||||
|
|
||||||
|
# Configure static asset server for tests with Cache-Control for performance.
|
||||||
|
config.serve_static_assets = true
|
||||||
|
config.static_cache_control = 'public, max-age=3600'
|
||||||
|
|
||||||
|
# Show full error reports and disable caching.
|
||||||
|
config.consider_all_requests_local = true
|
||||||
|
config.action_controller.perform_caching = false
|
||||||
|
|
||||||
|
# Raise exceptions instead of rendering exception templates.
|
||||||
|
config.action_dispatch.show_exceptions = false
|
||||||
|
|
||||||
|
# Disable request forgery protection in test environment.
|
||||||
|
config.action_controller.allow_forgery_protection = false
|
||||||
|
|
||||||
|
# Tell Action Mailer not to deliver emails to the real world.
|
||||||
|
# The :test delivery method accumulates sent emails in the
|
||||||
|
# ActionMailer::Base.deliveries array.
|
||||||
|
config.action_mailer.delivery_method = :test
|
||||||
|
|
||||||
|
# Print deprecation notices to the stderr.
|
||||||
|
config.active_support.deprecation = :stderr
|
||||||
|
|
||||||
|
# Raises error for missing translations
|
||||||
|
# config.action_view.raise_on_missing_translations = true
|
||||||
|
end
|
|
@ -0,0 +1,8 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Version of your assets, change this if you want to expire all your assets.
|
||||||
|
Rails.application.config.assets.version = '1.0'
|
||||||
|
|
||||||
|
# Precompile additional assets.
|
||||||
|
# application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
|
||||||
|
# Rails.application.config.assets.precompile += %w( search.js )
|
|
@ -0,0 +1,7 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
|
||||||
|
# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
|
||||||
|
|
||||||
|
# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
|
||||||
|
# Rails.backtrace_cleaner.remove_silencers!
|
|
@ -0,0 +1,3 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
Rails.application.config.action_dispatch.cookies_serializer = :json
|
|
@ -0,0 +1,4 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Configure sensitive parameters which will be filtered from the log file.
|
||||||
|
Rails.application.config.filter_parameters += [:password]
|
|
@ -0,0 +1,16 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Add new inflection rules using the following format. Inflections
|
||||||
|
# are locale specific, and you may define rules for as many different
|
||||||
|
# locales as you wish. All of these examples are active by default:
|
||||||
|
# ActiveSupport::Inflector.inflections(:en) do |inflect|
|
||||||
|
# inflect.plural /^(ox)$/i, '\1en'
|
||||||
|
# inflect.singular /^(ox)en/i, '\1'
|
||||||
|
# inflect.irregular 'person', 'people'
|
||||||
|
# inflect.uncountable %w( fish sheep )
|
||||||
|
# end
|
||||||
|
|
||||||
|
# These inflection rules are supported but not enabled by default:
|
||||||
|
# ActiveSupport::Inflector.inflections(:en) do |inflect|
|
||||||
|
# inflect.acronym 'RESTful'
|
||||||
|
# end
|
|
@ -0,0 +1,4 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Add new mime types for use in respond_to blocks:
|
||||||
|
# Mime::Type.register "text/richtext", :rtf
|
|
@ -0,0 +1,3 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
Rails.application.config.session_store :cookie_store, key: '_dummy_session'
|
|
@ -0,0 +1,14 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# This file contains settings for ActionController::ParamsWrapper which
|
||||||
|
# is enabled by default.
|
||||||
|
|
||||||
|
# Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
|
||||||
|
ActiveSupport.on_load(:action_controller) do
|
||||||
|
wrap_parameters format: [:json] if respond_to?(:wrap_parameters)
|
||||||
|
end
|
||||||
|
|
||||||
|
# To enable root element in JSON for ActiveRecord objects.
|
||||||
|
# ActiveSupport.on_load(:active_record) do
|
||||||
|
# self.include_root_in_json = true
|
||||||
|
# end
|
|
@ -0,0 +1,23 @@
|
||||||
|
# Files in the config/locales directory are used for internationalization
|
||||||
|
# and are automatically loaded by Rails. If you want to use locales other
|
||||||
|
# than English, add the necessary files in this directory.
|
||||||
|
#
|
||||||
|
# To use the locales, use `I18n.t`:
|
||||||
|
#
|
||||||
|
# I18n.t 'hello'
|
||||||
|
#
|
||||||
|
# In views, this is aliased to just `t`:
|
||||||
|
#
|
||||||
|
# <%= t('hello') %>
|
||||||
|
#
|
||||||
|
# To use a different locale, set it with `I18n.locale`:
|
||||||
|
#
|
||||||
|
# I18n.locale = :es
|
||||||
|
#
|
||||||
|
# This would use the information in config/locales/es.yml.
|
||||||
|
#
|
||||||
|
# To learn more, please read the Rails Internationalization guide
|
||||||
|
# available at http://guides.rubyonrails.org/i18n.html.
|
||||||
|
|
||||||
|
en:
|
||||||
|
hello: "Hello world"
|
|
@ -0,0 +1,4 @@
|
||||||
|
Rails.application.routes.draw do
|
||||||
|
|
||||||
|
mount Space::Engine => "/space"
|
||||||
|
end
|
|
@ -0,0 +1,22 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
|
||||||
|
# Your secret key is used for verifying the integrity of signed cookies.
|
||||||
|
# If you change this key, all old signed cookies will become invalid!
|
||||||
|
|
||||||
|
# Make sure the secret is at least 30 characters and all random,
|
||||||
|
# no regular words or you'll be exposed to dictionary attacks.
|
||||||
|
# You can use `rake secret` to generate a secure secret key.
|
||||||
|
|
||||||
|
# Make sure the secrets in this file are kept private
|
||||||
|
# if you're sharing your code publicly.
|
||||||
|
|
||||||
|
development:
|
||||||
|
secret_key_base: d102322462c532ee79cc1e54f99cd5cffb1f81475901bd4e10c1a2c69737e901ea19488a46c4d650a45fff2f93b6756a4f7733a2966cc7aa6be387cefcec36ac
|
||||||
|
|
||||||
|
test:
|
||||||
|
secret_key_base: a7a4771e48902b5d4d8a99c038147bb4b264da4e9efd8de4efce48abec1f42f2dd8e1a962b1dabeb3239f74d34d0a52e25e389e2e58506468d5d7a5d575abaf9
|
||||||
|
|
||||||
|
# Do not keep production secrets in the repository,
|
||||||
|
# instead read values from the environment.
|
||||||
|
production:
|
||||||
|
secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>
|
|
@ -0,0 +1,67 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>The page you were looking for doesn't exist (404)</title>
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #EFEFEF;
|
||||||
|
color: #2E2F30;
|
||||||
|
text-align: center;
|
||||||
|
font-family: arial, sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog {
|
||||||
|
width: 95%;
|
||||||
|
max-width: 33em;
|
||||||
|
margin: 4em auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > div {
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #BBB;
|
||||||
|
border-top: #B00100 solid 4px;
|
||||||
|
border-top-left-radius: 9px;
|
||||||
|
border-top-right-radius: 9px;
|
||||||
|
background-color: white;
|
||||||
|
padding: 7px 12% 0;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 100%;
|
||||||
|
color: #730E15;
|
||||||
|
line-height: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > p {
|
||||||
|
margin: 0 0 1em;
|
||||||
|
padding: 1em;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #999;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-top-color: #DADADA;
|
||||||
|
color: #666;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<!-- This file lives in public/404.html -->
|
||||||
|
<div class="dialog">
|
||||||
|
<div>
|
||||||
|
<h1>The page you were looking for doesn't exist.</h1>
|
||||||
|
<p>You may have mistyped the address or the page may have moved.</p>
|
||||||
|
</div>
|
||||||
|
<p>If you are the application owner check the logs for more information.</p>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,67 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>The change you wanted was rejected (422)</title>
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #EFEFEF;
|
||||||
|
color: #2E2F30;
|
||||||
|
text-align: center;
|
||||||
|
font-family: arial, sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog {
|
||||||
|
width: 95%;
|
||||||
|
max-width: 33em;
|
||||||
|
margin: 4em auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > div {
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #BBB;
|
||||||
|
border-top: #B00100 solid 4px;
|
||||||
|
border-top-left-radius: 9px;
|
||||||
|
border-top-right-radius: 9px;
|
||||||
|
background-color: white;
|
||||||
|
padding: 7px 12% 0;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 100%;
|
||||||
|
color: #730E15;
|
||||||
|
line-height: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > p {
|
||||||
|
margin: 0 0 1em;
|
||||||
|
padding: 1em;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #999;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-top-color: #DADADA;
|
||||||
|
color: #666;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<!-- This file lives in public/422.html -->
|
||||||
|
<div class="dialog">
|
||||||
|
<div>
|
||||||
|
<h1>The change you wanted was rejected.</h1>
|
||||||
|
<p>Maybe you tried to change something you didn't have access to.</p>
|
||||||
|
</div>
|
||||||
|
<p>If you are the application owner check the logs for more information.</p>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,66 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>We're sorry, but something went wrong (500)</title>
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #EFEFEF;
|
||||||
|
color: #2E2F30;
|
||||||
|
text-align: center;
|
||||||
|
font-family: arial, sans-serif;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog {
|
||||||
|
width: 95%;
|
||||||
|
max-width: 33em;
|
||||||
|
margin: 4em auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > div {
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #BBB;
|
||||||
|
border-top: #B00100 solid 4px;
|
||||||
|
border-top-left-radius: 9px;
|
||||||
|
border-top-right-radius: 9px;
|
||||||
|
background-color: white;
|
||||||
|
padding: 7px 12% 0;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 100%;
|
||||||
|
color: #730E15;
|
||||||
|
line-height: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.dialog > p {
|
||||||
|
margin: 0 0 1em;
|
||||||
|
padding: 1em;
|
||||||
|
background-color: #F7F7F7;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-right-color: #999;
|
||||||
|
border-left-color: #999;
|
||||||
|
border-bottom-color: #999;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-top-color: #DADADA;
|
||||||
|
color: #666;
|
||||||
|
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<!-- This file lives in public/500.html -->
|
||||||
|
<div class="dialog">
|
||||||
|
<div>
|
||||||
|
<h1>We're sorry, but something went wrong.</h1>
|
||||||
|
</div>
|
||||||
|
<p>If you are the application owner check the logs for more information.</p>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,10 @@
|
||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class NavigationTest < ActionDispatch::IntegrationTest
|
||||||
|
fixtures :all
|
||||||
|
|
||||||
|
# test "the truth" do
|
||||||
|
# assert true
|
||||||
|
# end
|
||||||
|
end
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class SpaceTest < ActiveSupport::TestCase
|
||||||
|
test "truth" do
|
||||||
|
assert_kind_of Module, Space
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,19 @@
|
||||||
|
# Configure Rails Environment
|
||||||
|
ENV["RAILS_ENV"] = "test"
|
||||||
|
|
||||||
|
require File.expand_path("../../test/dummy/config/environment.rb", __FILE__)
|
||||||
|
ActiveRecord::Migrator.migrations_paths = [File.expand_path("../../test/dummy/db/migrate", __FILE__)]
|
||||||
|
ActiveRecord::Migrator.migrations_paths << File.expand_path('../../db/migrate', __FILE__)
|
||||||
|
require "rails/test_help"
|
||||||
|
|
||||||
|
# Filter out Minitest backtrace while allowing backtrace from other libraries
|
||||||
|
# to be shown.
|
||||||
|
Minitest.backtrace_filter = Minitest::BacktraceFilter.new
|
||||||
|
|
||||||
|
# Load support files
|
||||||
|
Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
|
||||||
|
|
||||||
|
# Load fixtures from the engine
|
||||||
|
if ActiveSupport::TestCase.method_defined?(:fixture_path=)
|
||||||
|
ActiveSupport::TestCase.fixture_path = File.expand_path("../fixtures", __FILE__)
|
||||||
|
end
|
Loading…
Reference in New Issue