app port from old version
This commit is contained in:
parent
cb7e47a466
commit
f8c03d6f5c
2
Gemfile
2
Gemfile
@ -33,5 +33,7 @@ group :development, :test do
|
||||
gem 'guard'
|
||||
gem 'guard-rubocop'
|
||||
gem 'guard-minitest'
|
||||
gem 'guard-livereload'
|
||||
gem 'rack-livereload'
|
||||
gem 'minitest-reporters'
|
||||
end
|
||||
|
12
Gemfile.lock
12
Gemfile.lock
@ -59,6 +59,9 @@ GEM
|
||||
columnize (0.9.0)
|
||||
daemons (1.2.3)
|
||||
debug_inspector (0.0.2)
|
||||
em-websocket (0.5.1)
|
||||
eventmachine (>= 0.12.9)
|
||||
http_parser.rb (~> 0.6.0)
|
||||
erubis (2.7.0)
|
||||
eventmachine (1.0.8)
|
||||
execjs (2.6.0)
|
||||
@ -76,6 +79,10 @@ GEM
|
||||
shellany (~> 0.0)
|
||||
thor (>= 0.18.1)
|
||||
guard-compat (1.2.1)
|
||||
guard-livereload (2.4.0)
|
||||
em-websocket (~> 0.5)
|
||||
guard (~> 2.8)
|
||||
multi_json (~> 1.8)
|
||||
guard-minitest (2.4.4)
|
||||
guard-compat (~> 1.2)
|
||||
minitest (>= 3.0)
|
||||
@ -95,6 +102,7 @@ GEM
|
||||
haml (~> 4.0.0)
|
||||
nokogiri (~> 1.6.0)
|
||||
ruby_parser (~> 3.5)
|
||||
http_parser.rb (0.6.0)
|
||||
i18n (0.7.0)
|
||||
jquery-rails (4.0.5)
|
||||
rails-dom-testing (~> 1.0)
|
||||
@ -140,6 +148,8 @@ GEM
|
||||
pry-rails (0.3.4)
|
||||
pry (>= 0.9.10)
|
||||
rack (1.6.4)
|
||||
rack-livereload (0.3.16)
|
||||
rack
|
||||
rack-test (0.6.3)
|
||||
rack (>= 1.0)
|
||||
rails (4.2.4)
|
||||
@ -231,6 +241,7 @@ DEPENDENCIES
|
||||
bcrypt (~> 3.1.7)
|
||||
binding_of_caller
|
||||
guard
|
||||
guard-livereload
|
||||
guard-minitest
|
||||
guard-rubocop
|
||||
haml-rails (~> 0.9)
|
||||
@ -240,6 +251,7 @@ DEPENDENCIES
|
||||
mysql2 (~> 0.3.20)
|
||||
pry-byebug
|
||||
pry-rails
|
||||
rack-livereload
|
||||
rails (~> 4.2.4)
|
||||
responders (~> 2.1.0)
|
||||
rubocop
|
||||
|
12
Guardfile
12
Guardfile
@ -27,3 +27,15 @@ guard :minitest do
|
||||
watch(%r{^app/(.*/)?([^/]+)\.rb$}) { |m| "test/#{m[1]}#{m[2]}_test.rb" }
|
||||
watch(%r{^lib/(.*/)?([^/]+)\.rb$}) { |m| "test/lib/#{m[1]}#{m[2]}_test.rb" }
|
||||
end
|
||||
|
||||
guard 'livereload' do
|
||||
watch(%r{app/views/.+\.(erb|haml|slim)$})
|
||||
watch(%r{app/helpers/.+\.rb})
|
||||
watch(%r{public/.+\.(css|js|html)})
|
||||
watch(%r{config/locales/.+\.yml})
|
||||
|
||||
# Rails Assets Pipeline
|
||||
watch(%r{(app|vendor)(/assets/\w+/(.+\.(css|js|html|png|jpg))).*}) do |m|
|
||||
"/assets/#{m[3]}"
|
||||
end
|
||||
end
|
||||
|
@ -2,4 +2,6 @@ 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
|
||||
|
||||
respond_to :html, :json
|
||||
end
|
||||
|
@ -1,2 +1,6 @@
|
||||
class ChildrenController < ApplicationController
|
||||
def index
|
||||
@children = Child.all.order(:last_name, :first_name)
|
||||
respond_with @children
|
||||
end
|
||||
end
|
||||
|
@ -1,2 +1,6 @@
|
||||
class StaffController < ApplicationController
|
||||
def index
|
||||
@staff = Person.staff
|
||||
respond_with @staff
|
||||
end
|
||||
end
|
||||
|
@ -1,2 +1,6 @@
|
||||
class UsersController < ApplicationController
|
||||
def index
|
||||
@users = Person.admins
|
||||
respond_with @users
|
||||
end
|
||||
end
|
||||
|
11
app/models/child.rb
Normal file
11
app/models/child.rb
Normal file
@ -0,0 +1,11 @@
|
||||
class Child < ActiveRecord::Base
|
||||
has_many :parenthoods
|
||||
has_many :parents, through: :parenthoods, source: :person
|
||||
|
||||
validates :first_name, presence: true
|
||||
validates :last_name, presence: true
|
||||
|
||||
def name
|
||||
"#{first_name} #{last_name}"
|
||||
end
|
||||
end
|
4
app/models/parenthood.rb
Normal file
4
app/models/parenthood.rb
Normal file
@ -0,0 +1,4 @@
|
||||
class Parenthood < ActiveRecord::Base
|
||||
belongs_to :person
|
||||
belongs_to :child
|
||||
end
|
25
app/models/person.rb
Normal file
25
app/models/person.rb
Normal file
@ -0,0 +1,25 @@
|
||||
class Person < ActiveRecord::Base
|
||||
has_many :parenthoods
|
||||
has_many :children, through: :parenthoods
|
||||
|
||||
validates :first_name, presence: true
|
||||
validates :last_name, presence: true
|
||||
|
||||
scope :with_name, lambda { |name|
|
||||
where("concat(first_name, ' ', last_name) RLIKE ?", name)
|
||||
}
|
||||
|
||||
scope :just_parents, lambda {
|
||||
joins(:children)
|
||||
.order(:first_name)
|
||||
.uniq
|
||||
}
|
||||
|
||||
scope :staff, -> { where(staff: true) }
|
||||
|
||||
scope :admins, -> { where(admin: true) }
|
||||
|
||||
def name
|
||||
"#{first_name} #{last_name}"
|
||||
end
|
||||
end
|
8
app/views/children/index.haml
Normal file
8
app/views/children/index.haml
Normal file
@ -0,0 +1,8 @@
|
||||
%h1 Children
|
||||
|
||||
- @children.each do |child|
|
||||
%ul
|
||||
%li= child.name
|
||||
%ul
|
||||
- child.parents.each do |parent|
|
||||
%li #{parent.name}: #{number_to_phone parent.phone}
|
11
app/views/parents/index.haml
Normal file
11
app/views/parents/index.haml
Normal file
@ -0,0 +1,11 @@
|
||||
%h1 Parents
|
||||
|
||||
- @parents.each do |parent|
|
||||
%ul
|
||||
%li= parent.name
|
||||
%li= number_to_phone parent.phone
|
||||
%li= mail_to parent.email
|
||||
%li Children:
|
||||
%ul
|
||||
- parent.children.each do |child|
|
||||
%li= child.name
|
4
app/views/staff/index.haml
Normal file
4
app/views/staff/index.haml
Normal file
@ -0,0 +1,4 @@
|
||||
%h1 Staff
|
||||
%ul
|
||||
- @staff.each do |staff|
|
||||
%li= staff.name
|
5
app/views/users/index.haml
Normal file
5
app/views/users/index.haml
Normal file
@ -0,0 +1,5 @@
|
||||
%h1 Users
|
||||
|
||||
%ul
|
||||
- @users.each do |user|
|
||||
%li= user.name
|
@ -1,4 +1,4 @@
|
||||
a--
|
||||
---
|
||||
default: &default
|
||||
adapter: mysql2
|
||||
encoding: utf8
|
||||
|
@ -38,4 +38,7 @@ Rails.application.configure do
|
||||
|
||||
# Raises error for missing translations
|
||||
# config.action_view.raise_on_missing_translations = true
|
||||
|
||||
# Add Rack::LiveReload to the bottom of the middleware stack with the default options.
|
||||
config.middleware.insert_after ActionDispatch::Static, Rack::LiveReload
|
||||
end
|
||||
|
50
db/schema.rb
Normal file
50
db/schema.rb
Normal file
@ -0,0 +1,50 @@
|
||||
# encoding: UTF-8
|
||||
# This file is auto-generated from the current state of the database. Instead
|
||||
# of editing this file, please use the migrations feature of Active Record to
|
||||
# incrementally modify your database, and then regenerate this schema definition.
|
||||
#
|
||||
# Note that this schema.rb definition is the authoritative source for your
|
||||
# database schema. If you need to create the application database on another
|
||||
# system, you should be using db:schema:load, not running all the migrations
|
||||
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
||||
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
||||
#
|
||||
# It's strongly recommended that you check this file into your version control system.
|
||||
|
||||
ActiveRecord::Schema.define(version: 20150913220116) do
|
||||
|
||||
create_table "children", force: :cascade do |t|
|
||||
t.string "first_name", limit: 255
|
||||
t.string "last_name", limit: 255
|
||||
end
|
||||
|
||||
create_table "pages", force: :cascade do |t|
|
||||
t.integer "user_id", limit: 4
|
||||
t.integer "person_id", limit: 4
|
||||
t.string "phone", limit: 255
|
||||
t.string "to", limit: 255
|
||||
t.string "message", limit: 255
|
||||
t.string "status", limit: 255
|
||||
t.datetime "created_at", null: false
|
||||
t.datetime "updated_at", null: false
|
||||
end
|
||||
|
||||
create_table "parenthoods", force: :cascade do |t|
|
||||
t.integer "person_id", limit: 4
|
||||
t.integer "child_id", limit: 4
|
||||
end
|
||||
|
||||
add_index "parenthoods", ["person_id", "child_id"], name: "parentship", using: :btree
|
||||
|
||||
create_table "people", force: :cascade do |t|
|
||||
t.string "first_name", limit: 255
|
||||
t.string "last_name", limit: 255
|
||||
t.string "phone", limit: 255
|
||||
t.string "email", limit: 255
|
||||
t.boolean "admin"
|
||||
t.boolean "staff"
|
||||
end
|
||||
|
||||
add_index "people", ["phone"], name: "index_people_on_phone", using: :btree
|
||||
|
||||
end
|
@ -2,7 +2,7 @@ require 'test_helper'
|
||||
|
||||
class ParentsControllerTest < ActionController::TestCase
|
||||
def test_parents
|
||||
xhr :get, :index
|
||||
get :index
|
||||
assert response.ok?
|
||||
end
|
||||
end
|
||||
|
@ -1,7 +1,7 @@
|
||||
require File.expand_path '../../test_helper.rb', __FILE__
|
||||
require 'test_helper'
|
||||
|
||||
class SecretsTest < ActiveSupport::TestCase
|
||||
def test_sanity
|
||||
assert Secrets
|
||||
end
|
||||
# def test_sanity
|
||||
# assert Secrets
|
||||
# end
|
||||
end
|
||||
|
Loading…
x
Reference in New Issue
Block a user