phcmembers 11.0.0 → 12.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/MIT-LICENSE +20 -20
- data/README.md +45 -45
- data/Rakefile +33 -33
- data/app/assets/config/phcmembers_manifest.js +2 -2
- data/app/assets/javascripts/phcmembers/application.js +2 -2
- data/app/assets/stylesheets/phcmembers/application.scss +2 -2
- data/app/controllers/phcmembers/api/directories_controller.rb +18 -18
- data/app/controllers/phcmembers/application_controller.rb +17 -17
- data/app/controllers/phcmembers/directory/categories_controller.rb +68 -68
- data/app/controllers/phcmembers/directory/categorylistings_controller.rb +21 -21
- data/app/controllers/phcmembers/member/addresses_controller.rb +75 -75
- data/app/controllers/phcmembers/member/listings_controller.rb +77 -77
- data/app/controllers/phcmembers/member/profiles_controller.rb +68 -68
- data/app/controllers/phcmembers/modules/dashboards_controller.rb +14 -14
- data/app/helpers/phcmembers/application_helper.rb +14 -14
- data/app/jobs/phcmembers/application_job.rb +4 -4
- data/app/mailers/phcmembers/application_mailer.rb +8 -8
- data/app/models/phcmembers/application_record.rb +5 -5
- data/app/models/phcmembers/connections.rb +7 -7
- data/app/models/phcmembers/directory.rb +7 -7
- data/app/models/phcmembers/directory/category.rb +29 -19
- data/app/models/phcmembers/directory/categorylisting.rb +12 -18
- data/app/models/phcmembers/member.rb +7 -7
- data/app/models/phcmembers/member/address.rb +45 -17
- data/app/models/phcmembers/member/listing.rb +66 -26
- data/app/models/phcmembers/member/profile.rb +49 -49
- data/app/models/phcmembers/versions_address.rb +5 -0
- data/app/models/phcmembers/versions_category.rb +5 -0
- data/app/models/phcmembers/versions_category_listing.rb +5 -0
- data/app/models/phcmembers/versions_listing.rb +5 -0
- data/app/models/phcmembers/versions_profile.rb +5 -0
- data/app/views/layouts/phcmembers/application.html.erb +56 -56
- data/app/views/layouts/phcmembers/components/backend/footer/_footer.html.erb +4 -4
- data/app/views/layouts/phcmembers/components/backend/navigation/_navigation.html.erb +60 -60
- data/app/views/layouts/phcmembers/components/backend/topbar/_topbar.html.erb +5 -5
- data/app/views/layouts/phcmembers/components/backend/topbar/_topbar_links.html.erb +0 -0
- data/app/views/layouts/phcmembers/directory/directory_all.html.erb +56 -56
- data/app/views/layouts/phcmembers/members/members_all.html.erb +56 -56
- data/app/views/phcmembers/directory/categories/_form.html.erb +15 -15
- data/app/views/phcmembers/directory/categories/components/_category_audits.html.erb +14 -14
- data/app/views/phcmembers/directory/categories/components/_category_list.html.erb +7 -7
- data/app/views/phcmembers/directory/categories/components/_category_main.html.erb +31 -31
- data/app/views/phcmembers/directory/categories/edit.html.erb +38 -38
- data/app/views/phcmembers/directory/categories/index.html.erb +47 -47
- data/app/views/phcmembers/directory/categories/new.html.erb +36 -36
- data/app/views/phcmembers/directory/categories/show.html.erb +27 -27
- data/app/views/phcmembers/directory/categorylistings/index.html.erb +63 -63
- data/app/views/phcmembers/directory/categorylistings/show.html.erb +4 -4
- data/app/views/phcmembers/member/addresses/_form.html.erb +44 -44
- data/app/views/phcmembers/member/addresses/components/_address_address.html.erb +29 -29
- data/app/views/phcmembers/member/addresses/components/_address_audits.html.erb +12 -12
- data/app/views/phcmembers/member/addresses/components/_address_main.html.erb +31 -31
- data/app/views/phcmembers/member/addresses/edit.html.erb +40 -40
- data/app/views/phcmembers/member/addresses/index.html.erb +74 -74
- data/app/views/phcmembers/member/addresses/new.html.erb +40 -40
- data/app/views/phcmembers/member/addresses/show.html.erb +27 -27
- data/app/views/phcmembers/member/listings/_form.html.erb +68 -68
- data/app/views/phcmembers/member/listings/components/_listing_address.html.erb +48 -48
- data/app/views/phcmembers/member/listings/components/_listing_audits.html.erb +14 -14
- data/app/views/phcmembers/member/listings/components/_listing_main.html.erb +31 -31
- data/app/views/phcmembers/member/listings/edit.html.erb +40 -40
- data/app/views/phcmembers/member/listings/index.html.erb +76 -76
- data/app/views/phcmembers/member/listings/new.html.erb +40 -40
- data/app/views/phcmembers/member/listings/show.html.erb +27 -27
- data/app/views/phcmembers/member/profiles/_form.html.erb +36 -36
- data/app/views/phcmembers/member/profiles/components/_profile_main.html.erb +44 -44
- data/app/views/phcmembers/member/profiles/components/_profile_sidebar.html.erb +28 -28
- data/app/views/phcmembers/member/profiles/edit.html.erb +39 -39
- data/app/views/phcmembers/member/profiles/index.html.erb +68 -68
- data/app/views/phcmembers/member/profiles/new.html.erb +39 -39
- data/app/views/phcmembers/member/profiles/show.html.erb +31 -31
- data/app/views/phcmembers/modules/dashboards/index.html.erb +66 -66
- data/config/initializers/friendly_id.rb +92 -92
- data/config/initializers/paper_trail.rb +1 -0
- data/config/locales/en.yml +9 -9
- data/config/routes.rb +36 -36
- data/db/migrate/20160724220339_create_phcmembers_member_profiles.rb +23 -23
- data/db/migrate/20160725153306_create_phcmembers_member_addresses.rb +26 -26
- data/db/migrate/20160725182257_create_phcmembers_directory_categories.rb +18 -18
- data/db/migrate/20160727024006_create_phcmembers_member_listings.rb +30 -30
- data/db/migrate/20160727042756_create_phcmembers_directory_categorylistings.rb +19 -19
- data/db/migrate/20170509002355_create_phcmembers_friendly_id_slugs.rb +15 -0
- data/db/migrate/20170517064030_create_phcmembers_versions_profiles.rb +12 -0
- data/db/migrate/20170517064049_create_phcmembers_versions_listings.rb +12 -0
- data/db/migrate/20170517064114_create_phcmembers_versions_addresses.rb +12 -0
- data/db/migrate/20170517064208_create_phcmembers_versions_categorylistings.rb +12 -0
- data/db/migrate/20170517064427_create_phcmembers_versions_categories.rb +12 -0
- data/lib/phcmembers.rb +4 -4
- data/lib/phcmembers/engine.rb +73 -73
- data/lib/phcmembers/version.rb +3 -3
- data/lib/tasks/phcmembers_tasks.rake +4 -4
- metadata +59 -7
- data/db/migrate/20160707154842_create_versions.rb +0 -80
- data/db/migrate/20170509002355_create_friendly_id_slugs.rb +0 -15
@@ -1,80 +0,0 @@
|
|
1
|
-
# This migration creates the `versions` table, the only schema PT requires.
|
2
|
-
# All other migrations PT provides are optional.
|
3
|
-
class CreateVersions < ActiveRecord::Migration[5.1]
|
4
|
-
# Class names of MySQL adapters.
|
5
|
-
# - `MysqlAdapter` - Used by gems: `mysql`, `activerecord-jdbcmysql-adapter`.
|
6
|
-
# - `Mysql2Adapter` - Used by `mysql2` gem.
|
7
|
-
MYSQL_ADAPTERS = [
|
8
|
-
"ActiveRecord::ConnectionAdapters::MysqlAdapter",
|
9
|
-
"ActiveRecord::ConnectionAdapters::Mysql2Adapter"
|
10
|
-
].freeze
|
11
|
-
|
12
|
-
# The largest text column available in all supported RDBMS is
|
13
|
-
# 1024^3 - 1 bytes, roughly one gibibyte. We specify a size
|
14
|
-
# so that MySQL will use `longtext` instead of `text`. Otherwise,
|
15
|
-
# when serializing very large objects, `text` might not be big enough.
|
16
|
-
TEXT_BYTES = 1_073_741_823
|
17
|
-
|
18
|
-
def change
|
19
|
-
create_table :versions, versions_table_options do |t|
|
20
|
-
t.string :item_type, item_type_options
|
21
|
-
t.integer :item_id, null: false
|
22
|
-
t.string :event, null: false
|
23
|
-
t.string :whodunnit
|
24
|
-
t.text :object, limit: TEXT_BYTES
|
25
|
-
|
26
|
-
# Known issue in MySQL: fractional second precision
|
27
|
-
# -------------------------------------------------
|
28
|
-
#
|
29
|
-
# MySQL timestamp columns do not support fractional seconds unless
|
30
|
-
# defined with "fractional seconds precision". MySQL users should manually
|
31
|
-
# add fractional seconds precision to this migration, specifically, to
|
32
|
-
# the `created_at` column.
|
33
|
-
# (https://dev.mysql.com/doc/refman/5.6/en/fractional-seconds.html)
|
34
|
-
#
|
35
|
-
# MySQL users should also upgrade to rails 4.2, which is the first
|
36
|
-
# version of ActiveRecord with support for fractional seconds in MySQL.
|
37
|
-
# (https://github.com/rails/rails/pull/14359)
|
38
|
-
#
|
39
|
-
t.datetime :created_at
|
40
|
-
end
|
41
|
-
add_index :versions, [:item_type, :item_id]
|
42
|
-
end
|
43
|
-
|
44
|
-
private
|
45
|
-
|
46
|
-
# MySQL 5.6 utf8mb4 limit is 191 chars for keys used in indexes.
|
47
|
-
# See https://github.com/airblade/paper_trail/issues/651
|
48
|
-
def item_type_options
|
49
|
-
opt = { null: false }
|
50
|
-
opt[:limit] = 191 if mysql?
|
51
|
-
opt
|
52
|
-
end
|
53
|
-
|
54
|
-
def mysql?
|
55
|
-
MYSQL_ADAPTERS.include?(connection.class.name)
|
56
|
-
end
|
57
|
-
|
58
|
-
# Even modern versions of MySQL still use `latin1` as the default character
|
59
|
-
# encoding. Many users are not aware of this, and run into trouble when they
|
60
|
-
# try to use PaperTrail in apps that otherwise tend to use UTF-8. Postgres, by
|
61
|
-
# comparison, uses UTF-8 except in the unusual case where the OS is configured
|
62
|
-
# with a custom locale.
|
63
|
-
#
|
64
|
-
# - https://dev.mysql.com/doc/refman/5.7/en/charset-applications.html
|
65
|
-
# - http://www.postgresql.org/docs/9.4/static/multibyte.html
|
66
|
-
#
|
67
|
-
# Furthermore, MySQL's original implementation of UTF-8 was flawed, and had
|
68
|
-
# to be fixed later by introducing a new charset, `utf8mb4`.
|
69
|
-
#
|
70
|
-
# - https://mathiasbynens.be/notes/mysql-utf8mb4
|
71
|
-
# - https://dev.mysql.com/doc/refman/5.5/en/charset-unicode-utf8mb4.html
|
72
|
-
#
|
73
|
-
def versions_table_options
|
74
|
-
if mysql?
|
75
|
-
{ options: "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci" }
|
76
|
-
else
|
77
|
-
{}
|
78
|
-
end
|
79
|
-
end
|
80
|
-
end
|
@@ -1,15 +0,0 @@
|
|
1
|
-
class CreateFriendlyIdSlugs < ActiveRecord::Migration[5.1]
|
2
|
-
def change
|
3
|
-
create_table :friendly_id_slugs do |t|
|
4
|
-
t.string :slug, :null => false
|
5
|
-
t.integer :sluggable_id, :null => false
|
6
|
-
t.string :sluggable_type, :limit => 50
|
7
|
-
t.string :scope
|
8
|
-
t.datetime :created_at
|
9
|
-
end
|
10
|
-
add_index :friendly_id_slugs, :sluggable_id
|
11
|
-
add_index :friendly_id_slugs, [:slug, :sluggable_type], length: { slug: 140, sluggable_type: 50 }
|
12
|
-
add_index :friendly_id_slugs, [:slug, :sluggable_type, :scope], length: { slug: 70, sluggable_type: 50, scope: 70 }, unique: true
|
13
|
-
add_index :friendly_id_slugs, :sluggable_type
|
14
|
-
end
|
15
|
-
end
|