faalis 1.0.0.alpha1 → 1.0.0.alpha2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +11 -10
- data/Rakefile +6 -2
- data/app/assets/javascripts/faalis/angular-manifest.js +3 -0
- data/app/assets/javascripts/faalis/application.js +0 -1
- data/app/assets/javascripts/faalis/dashboard/app.js +20 -6
- data/app/assets/javascripts/faalis/dashboard/application.js.erb +5 -1
- data/app/assets/javascripts/faalis/dashboard/controllers/group.js.coffee +42 -0
- data/app/assets/javascripts/faalis/dashboard/functions.js.erb +20 -0
- data/app/assets/javascripts/faalis/dashboard/init.js +1 -1
- data/app/assets/javascripts/faalis/dashboard/lib/button.js.coffee +17 -0
- data/app/assets/javascripts/faalis/dashboard/lib/controllers.js.coffee +11 -0
- data/app/assets/javascripts/faalis/dashboard/lib/controllers/base_controller.js.coffee +14 -0
- data/app/assets/javascripts/faalis/dashboard/lib/controllers/generic_add_controller.js.coffee +33 -0
- data/app/assets/javascripts/faalis/dashboard/lib/controllers/generic_index_controller.js.coffee +85 -0
- data/app/assets/javascripts/faalis/dashboard/lib/fields/base.js.coffee +6 -0
- data/app/assets/javascripts/faalis/dashboard/lib/fields/has_many_field.js.coffee +4 -0
- data/app/assets/javascripts/faalis/dashboard/lib/fields/string_field.js.coffee +2 -0
- data/app/assets/javascripts/faalis/dashboard/lib/resource.js.coffee +147 -0
- data/app/assets/javascripts/faalis/dashboard/modules/auth/auth.js +5 -3
- data/app/assets/javascripts/faalis/dashboard/modules/auth/profile.js +6 -5
- data/app/assets/javascripts/faalis/dashboard/modules/auth/user.js +12 -10
- data/app/assets/javascripts/faalis/dashboard/modules/conversations.js +2 -1
- data/app/assets/javascripts/faalis/dashboard/modules/fields/#image.js# +43 -0
- data/app/assets/javascripts/faalis/dashboard/modules/fields/date.js +51 -0
- data/app/assets/javascripts/faalis/dashboard/modules/fields/datetime.js +26 -15
- data/app/assets/javascripts/faalis/dashboard/modules/fields/fields.js +3 -1
- data/app/assets/javascripts/faalis/dashboard/modules/fields/file.js +43 -0
- data/app/assets/javascripts/faalis/dashboard/modules/fields/image.js +33 -46
- data/app/assets/javascripts/faalis/dashboard/modules/fields/relation.js +7 -4
- data/app/assets/javascripts/faalis/dashboard/modules/fields/tag.js +5 -11
- data/app/assets/javascripts/faalis/dashboard/modules/fields/time.js +34 -122
- data/app/assets/javascripts/faalis/dashboard/modules/logs.js +5 -4
- data/app/assets/javascripts/faalis/dashboard/modules/permissions.js.coffee +38 -0
- data/app/assets/javascripts/faalis/dashboard/resources/group_resource.js.coffee +8 -0
- data/app/assets/javascripts/faalis/dashboard/resources/permission_resource.js.coffee +6 -0
- data/app/assets/javascripts/faalis/dashboard/services/api.js.coffee +73 -0
- data/app/assets/javascripts/faalis/dashboard/services/resource_factory.js.coffee +48 -0
- data/app/assets/javascripts/faalis/dashboard/services/user.js.coffee +4 -0
- data/app/assets/javascripts/faalis/dashboard/variables.js.erb +5 -0
- data/app/assets/javascripts/faalis/{locales → locale}/en.json +0 -0
- data/app/assets/javascripts/faalis/{locales → locale}/fa.json +0 -0
- data/app/assets/javascripts/faalis/{locales → locale}/translations.fa.js +0 -0
- data/app/controllers/faalis/api/v1/groups_controller.rb +53 -57
- data/app/controllers/faalis/api/v1/permissions_controller.rb +29 -12
- data/app/controllers/faalis/api_controller.rb +19 -12
- data/app/controllers/faalis/application_controller.rb +8 -7
- data/app/controllers/faalis/dashboard_controller.rb +5 -11
- data/app/models/faalis/{user → concerns/user}/auth_definitions.rb +6 -1
- data/app/models/faalis/{user → concerns/user}/mongoid_fields.rb +8 -2
- data/app/models/faalis/concerns/user/permission.rb +24 -0
- data/app/models/faalis/concerns/user/user_roles.rb +20 -0
- data/app/models/faalis/group.rb +13 -15
- data/app/models/faalis/permission.rb +15 -1
- data/app/models/faalis/user.rb +44 -20
- data/app/policies/faalis/admin_only_policy.rb +66 -0
- data/app/policies/faalis/application_policy.rb +40 -0
- data/app/policies/faalis/group_policy.rb +8 -0
- data/app/policies/faalis/user_policy.rb +9 -0
- data/app/views/{angularjs_templates → angular}/auth/groups/details.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/groups/index.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/groups/new.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/index.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/profile/edit.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/users/details.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/users/index.html +0 -0
- data/app/views/{angularjs_templates → angular}/auth/users/new.html +0 -0
- data/app/views/{angularjs_templates → angular}/conversations/details.html +0 -0
- data/app/views/{angularjs_templates → angular}/conversations/index.html +0 -0
- data/app/views/{angularjs_templates → angular}/conversations/new.html +0 -0
- data/app/views/{angularjs_templates → angular}/conversations/show.html +0 -0
- data/app/views/{angularjs_templates → angular}/conversations/show_details.html +0 -0
- data/app/views/angular/faalis/views/generic_add_view.html.slim +5 -0
- data/app/views/{angularjs_templates → angular}/fields/boolean/boolean.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/control-combo/control-list.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/datetime/datetime.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/datetime/time.html +0 -0
- data/app/views/angular/fields/file/file.html.slim +0 -0
- data/app/views/{angularjs_templates → angular}/fields/float/float.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/image/image.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/integer/integer.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/relation/relation.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/string/string.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/tag/tag.html +0 -0
- data/app/views/{angularjs_templates → angular}/fields/text/text.html +0 -0
- data/app/views/{angularjs_templates → angular}/filter/index.html +0 -0
- data/app/views/{angularjs_templates → angular}/index.html +0 -0
- data/app/views/{angularjs_templates → angular}/locale/fa.po +0 -0
- data/app/views/{angularjs_templates → angular}/locale/templates.pot +0 -0
- data/app/views/{angularjs_templates → angular}/logs/index.html +0 -0
- data/app/views/angular/modules.html +0 -0
- data/app/views/{angularjs_templates → angular}/nav.html.erb +0 -0
- data/app/views/faalis/api/v1/groups/index.json.jbuilder +1 -1
- data/app/views/faalis/api/v1/permissions/index.json.jbuilder +1 -1
- data/app/views/faalis/dashboard/index.html.erb +1 -1
- data/app/views/layouts/faalis/application.html.erb +1 -1
- data/config/routes.rb +1 -7
- data/config/spring.rb +1 -0
- data/db/migrate/20131013091000_devise_create_faalis_users.rb +4 -4
- data/db/migrate/20131020124701_create_faalis_groups.rb +3 -0
- data/db/migrate/20131021170923_create_faalis_permissions.rb +2 -0
- data/db/seeds.rb +15 -13
- data/lib/faalis.rb +2 -2
- data/lib/faalis/concerns/authorizable.rb +1 -0
- data/lib/faalis/engine.rb +15 -16
- data/lib/faalis/{extensions.rb → extension.rb} +1 -1
- data/lib/faalis/{extensions → extension}/base.rb +0 -0
- data/lib/faalis/fake_assets.rb +2 -0
- data/lib/faalis/generators/concerns.rb +1 -1
- data/lib/faalis/generators/concerns/angular.rb +1 -1
- data/lib/faalis/generators/concerns/bulk.rb +1 -2
- data/lib/faalis/generators/concerns/input_file.rb +49 -0
- data/lib/faalis/generators/concerns/resource_fields.rb +4 -0
- data/lib/faalis/generators/concerns/tabs.rb +1 -1
- data/lib/faalis/generators/dashboard_scaffold.rb +3 -1
- data/lib/faalis/i18n.rb +1 -0
- data/lib/faalis/route.rb +26 -9
- data/lib/faalis/version.rb +1 -1
- data/lib/faalis_application.rb +442 -0
- data/lib/generators/faalis/install_generator.rb +4 -2
- data/lib/generators/faalis/js/list_view_generator.rb +3 -22
- data/lib/generators/faalis/scaffold_generator.rb +7 -10
- data/lib/generators/faalis/templates/README +0 -7
- data/lib/generators/faalis/templates/angularjs/module.js.erb +4 -1
- data/lib/generators/faalis/templates/api/controller.rb.erb +18 -21
- data/lib/generators/faalis/templates/application.js +14 -1
- data/lib/generators/faalis/templates/faalis.rb +3 -1
- data/lib/generators/faalis/templates/i18n/Gruntfile.js.erb +2 -2
- data/lib/generators/faalis/templates/js/list_view/partials/add_controller.js.erb +3 -3
- data/lib/generators/faalis/views_generator.rb +1 -1
- data/lib/tasks/docs.rake +6 -0
- data/lib/tasks/faalis_tasks.rake +1 -0
- data/lib/tasks/grunt/Gruntfile.js +3 -3
- data/spec/dummy/app/controllers/api_controller.rb +5 -0
- data/spec/dummy/config/initializers/faalis.rb +3 -3
- data/spec/dummy/db/development.sqlite3 +0 -0
- data/spec/dummy/db/migrate/20150121060012_create_application_models.model_discovery_engine.rb +10 -0
- data/spec/dummy/db/schema.rb +71 -0
- data/spec/dummy/db/test.sqlite3 +0 -0
- data/spec/dummy/log/development.log +544 -0
- data/spec/dummy/log/test.log +12354 -0
- data/spec/factories/faalis/groups.rb +31 -0
- data/spec/factories/faalis/permissions.rb +16 -0
- data/spec/factories/faalis/users.rb +23 -0
- data/spec/models/faalis/group_spec.rb +32 -0
- data/spec/models/faalis/permission_spec.rb +15 -0
- data/spec/models/faalis/user_spec.rb +100 -0
- data/spec/policies/faalis/admin_only_policy_spec.rb +39 -0
- data/spec/policies/faalis/application_policy_spec.rb +49 -0
- data/spec/spec_helper.rb +26 -5
- data/spec/support/factory_girl.rb +3 -0
- metadata +225 -102
- data/app/assets/javascripts/faalis/dashboard/modules/auth/group.js +0 -155
- data/app/assets/javascripts/faalis/dashboard/modules/permissions.js +0 -52
- data/app/controllers/faalis/#api_controller.rb# +0 -51
- data/app/controllers/faalis/#dashboard_controller.rb# +0 -65
- data/app/models/ability.rb +0 -40
- data/app/models/faalis/user/permission.rb +0 -21
- data/app/views/angularjs_templates/modules.html +0 -17
- data/db/migrate/20140617124019_faalis_groups_users.rb +0 -4
- data/lib/faalis/generators/concerns/json_input.rb +0 -41
- data/lib/faalis/generators/fields/#relation.rb# +0 -61
- data/lib/faalis/patches/models.rb +0 -7
@@ -57,8 +57,10 @@ module Faalis
|
|
57
57
|
end
|
58
58
|
|
59
59
|
def install_routes
|
60
|
-
route '
|
61
|
-
route '
|
60
|
+
route 'end'
|
61
|
+
route ' # Define your API routes here . . .'
|
62
|
+
route 'Faalis::Routes.define_api_routes do'
|
63
|
+
route "mount Faalis::Engine => '/'"
|
62
64
|
end
|
63
65
|
|
64
66
|
def patch_application_controller
|
@@ -1,22 +1,3 @@
|
|
1
|
-
# -----------------------------------------------------------------------------
|
2
|
-
# Faalis - Basic website skel engine
|
3
|
-
# Copyright (C) 2012-2013 Yellowen
|
4
|
-
#
|
5
|
-
# This program is free software; you can redistribute it and/or modify
|
6
|
-
# it under the terms of the GNU General Public License as published by
|
7
|
-
# the Free Software Foundation; either version 2 of the License, or
|
8
|
-
# (at your option) any later version.
|
9
|
-
#
|
10
|
-
# This program is distributed in the hope that it will be useful,
|
11
|
-
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
12
|
-
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
13
|
-
# GNU General Public License for more details.
|
14
|
-
#
|
15
|
-
# You should have received a copy of the GNU General Public License along
|
16
|
-
# with this program; if not, write to the Free Software Foundation, Inc.,
|
17
|
-
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
18
|
-
# -----------------------------------------------------------------------------
|
19
|
-
|
20
1
|
module Faalis
|
21
2
|
module Generators
|
22
3
|
module Js
|
@@ -44,11 +25,11 @@ module Faalis
|
|
44
25
|
def create_template
|
45
26
|
unless options[:only_controller]
|
46
27
|
unless options[:only_specs]
|
47
|
-
template "js/list_view/index.html.erb", "app/views/
|
28
|
+
template "js/list_view/index.html.erb", "app/views/angular/#{resource.underscore}/index.html"
|
48
29
|
unless options[:no_new_template]
|
49
|
-
template "js/list_view/new.html.erb", "app/views/
|
30
|
+
template "js/list_view/new.html.erb", "app/views/angular/#{resource.underscore}/new.html"
|
50
31
|
end
|
51
|
-
template "js/list_view/details.html.erb", "app/views/
|
32
|
+
template "js/list_view/details.html.erb", "app/views/angular/#{resource.underscore}/details.html"
|
52
33
|
end
|
53
34
|
end
|
54
35
|
|
@@ -24,7 +24,7 @@ module Faalis
|
|
24
24
|
include Faalis::Generators::Concerns::RequireFields
|
25
25
|
include Faalis::Generators::Concerns::Parent
|
26
26
|
include Faalis::Generators::Concerns::Child
|
27
|
-
include Faalis::Generators::Concerns::
|
27
|
+
include Faalis::Generators::Concerns::InputFile
|
28
28
|
include Faalis::Generators::Concerns::ResourceName
|
29
29
|
include Faalis::Generators::Concerns::ResourceFields
|
30
30
|
include Faalis::Generators::Concerns::Globalize
|
@@ -75,21 +75,20 @@ module Faalis
|
|
75
75
|
result = []
|
76
76
|
all_fields = []
|
77
77
|
relations = "\n"
|
78
|
-
|
79
78
|
fields.each do |name, type, to|
|
80
79
|
case type
|
81
80
|
when 'belongs_to'
|
82
81
|
type_ = 'integer'
|
83
82
|
if to.singularize != name
|
84
83
|
relations << " belongs_to :#{name.singularize},
|
85
|
-
:class_name => \"#{to.singularize.
|
84
|
+
:class_name => \"#{to.singularize.camelize}\"\n"
|
86
85
|
else
|
87
86
|
relations << " belongs_to :#{to.singularize}\n"
|
88
87
|
end
|
89
88
|
name_ = "#{name.singularize}_id"
|
90
89
|
result << [name_, type_]
|
91
90
|
|
92
|
-
when 'text', 'integer', 'string', 'boolean', 'datetime', 'date', 'float'
|
91
|
+
when 'text', 'integer', 'string', 'boolean', 'datetime', 'time', 'date', 'float'
|
93
92
|
result << [name, type]
|
94
93
|
|
95
94
|
when 'image'
|
@@ -97,7 +96,7 @@ module Faalis
|
|
97
96
|
relations << " has_attached_file :#{name}\n"
|
98
97
|
relations << " validates_attachment_content_type :#{name},
|
99
98
|
content_type: %w(image/jpeg image/jpg image/png),
|
100
|
-
less_than: 1.megabytes
|
99
|
+
less_than: 1.megabytes\n"
|
101
100
|
# TODO: Run this generator just once for all images
|
102
101
|
`rails generate paperclip #{resource_data['name']} #{name}`
|
103
102
|
when 'tag'
|
@@ -108,11 +107,10 @@ module Faalis
|
|
108
107
|
when 'in'
|
109
108
|
result << [name, 'string']
|
110
109
|
|
111
|
-
when '
|
112
|
-
relations << " has_and_belongs_to_many :#{to}\n"
|
110
|
+
when 'has_and_belongs_to_many'
|
111
|
+
relations << " has_and_belongs_to_many :#{to.pluralize}\n"
|
113
112
|
say_status 'warn', "There is a many to many relation between #{resource_data['name']} and #{to},
|
114
113
|
You should create it manually in model files"
|
115
|
-
|
116
114
|
end
|
117
115
|
end
|
118
116
|
|
@@ -161,8 +159,7 @@ module Faalis
|
|
161
159
|
|
162
160
|
#Invoke Faalis list view generator
|
163
161
|
def create_list_view
|
164
|
-
|
165
|
-
|
162
|
+
invoke 'faalis:js:list_view', [input_file]
|
166
163
|
end
|
167
164
|
|
168
165
|
def create_globalize_migration
|
@@ -32,10 +32,3 @@ Steps to finish up installation:
|
|
32
32
|
|
33
33
|
6. Make sure you take a look and configured conf/initializer/fast_gettext.rb
|
34
34
|
7. Make sure you take a look and configured conf/initializer/formtastic.rb
|
35
|
-
8. Add your resources to routes.rb like this:
|
36
|
-
|
37
|
-
namespace :api, :defaults => {:format => :json} do
|
38
|
-
namespace :v1 do
|
39
|
-
resources :resource
|
40
|
-
end
|
41
|
-
end
|
@@ -100,7 +100,8 @@ var <%= resource.pluralize %> = angular.module("<%= resource %>", ["ListView", "
|
|
100
100
|
},
|
101
101
|
route: "#<% if parent? %>/<%= options[:parent] %>/" + <%= options[:parent] %>_id + "<% end %>/<%= resource_url %>/new"
|
102
102
|
|
103
|
-
}
|
103
|
+
},
|
104
|
+
<% unless options[:no_bulk] %>
|
104
105
|
{
|
105
106
|
title: gettext("Bulk Edit"),
|
106
107
|
icon: "fa fa-edit",
|
@@ -114,6 +115,7 @@ var <%= resource.pluralize %> = angular.module("<%= resource %>", ["ListView", "
|
|
114
115
|
},
|
115
116
|
|
116
117
|
},<% end %>
|
118
|
+
<% unless options[:no_duplicate] %>
|
117
119
|
{
|
118
120
|
title: gettext("Duplicate"),
|
119
121
|
icon: "fa fa-files-o",
|
@@ -135,6 +137,7 @@ var <%= resource.pluralize %> = angular.module("<%= resource %>", ["ListView", "
|
|
135
137
|
}
|
136
138
|
}
|
137
139
|
}
|
140
|
+
<% end %>
|
138
141
|
|
139
142
|
];<% unless options[:no_bulk] %>
|
140
143
|
|
@@ -1,20 +1,18 @@
|
|
1
1
|
class API::V1::<%= resource.pluralize %>Controller < APIController
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
<% all_parents.each do |p| %>load_and_authorize_resource :<%= p.singularize %>, :through => :<%= prev.singularize %>, :except => [:destory]<% prev = p %>
|
7
|
-
<% end %>load_and_authorize_resource :through => :<%= prev.singularize %>, :except => [:destory]<% if model_specified? %>, :class => "<%= model %>"<% end %>
|
8
|
-
<% else %>
|
9
|
-
load_and_authorize_resource :except => [:destory]<% if model_specified? %>, :class => "<%= model %>"<% end %>
|
10
|
-
<% end %>
|
11
|
-
# GET /api/v1/<%= resource.pluralize.underscore %>
|
2
|
+
<% if allowed_fields_provided? %>allow_query_on <%= allowed_fields %><% end %>
|
3
|
+
after_action :verify_authorized, :except => :index
|
4
|
+
|
5
|
+
# GET /api/v1/<%= resource.pluralize.underscore %>
|
12
6
|
def index
|
7
|
+
@<%= resource.pluralize.underscore %> = <%= resource.camelize %>.all
|
8
|
+
authorize @<%= resource.pluralize.underscore %>
|
13
9
|
respond_with(@<%= resource.pluralize.underscore %>)
|
14
10
|
end
|
15
11
|
|
16
12
|
def create
|
17
|
-
|
13
|
+
authorize <%= resource.camelize %>, :create?
|
14
|
+
@<%= resource.underscore %> = <%= resource.camelize %>.new(resource_params)
|
15
|
+
<% fields.each do |name, type| %><% if type == "has_many" %>
|
18
16
|
<%= name.underscore %> = <%= name.singularize.camelize %>.where({:id => params[:<%= resource.underscore %>][:<%= name %>]})
|
19
17
|
@<%= resource.underscore %>.<%= name.underscore %> = <%= name.underscore %><% end %><% end %>
|
20
18
|
if @<%= resource.underscore %>.save
|
@@ -27,11 +25,15 @@ class API::V1::<%= resource.pluralize %>Controller < APIController
|
|
27
25
|
end
|
28
26
|
|
29
27
|
def show
|
28
|
+
@<%= resource.underscore %> = <%= resource.camelize %>.find(params[:id])
|
29
|
+
authorize @<%= resource.underscore %>
|
30
30
|
respond_with(@<%= resource.underscore %>)
|
31
31
|
end
|
32
32
|
|
33
33
|
def update
|
34
|
-
|
34
|
+
@<%= resource.underscore %> = <%= resource.camelize %>.find(params[:id])
|
35
|
+
authorize @<%= resource.underscore %>, :update?
|
36
|
+
<% fields.each do |name, type| %><% if type == "has_many" %>
|
35
37
|
<%= name.underscore %> = <%= name.singularize.camelize %>.where({:id => params[:<%= resource.underscore %>][:<%= name %>]})
|
36
38
|
@<%= resource.underscore %>.<%= name.underscore %> = <%= name.underscore %><% end %><% end %>
|
37
39
|
|
@@ -39,25 +41,20 @@ class API::V1::<%= resource.pluralize %>Controller < APIController
|
|
39
41
|
respond_with(@<%= resource.underscore %>)
|
40
42
|
else
|
41
43
|
respond_to do |format|
|
42
|
-
|
44
|
+
format.json { render :json => {:fields => @<%= resource.underscore %>.errors}, :status => :unprocessable_entity }
|
43
45
|
end
|
44
46
|
end
|
45
47
|
end
|
46
48
|
|
47
49
|
def destroy
|
48
50
|
ids = params[:id].split(",")
|
49
|
-
@<%= resource.pluralize.underscore %> =
|
50
|
-
authorize! :destroy, @<%= resource.pluralize.underscore %>
|
51
|
-
@<%= resource.pluralize.underscore %>.destroy_all
|
52
|
-
end
|
51
|
+
@<%= resource.pluralize.underscore %> = <%= resource.camelize%>.where(:id => ids)
|
53
52
|
|
54
|
-
|
55
|
-
@<%= resource.underscore
|
56
|
-
<% if parent? %>@<%= resource.underscore %>.<%= parents.last.singularize %> = <%= parents.last.singularize.camelize %>.find(params[:<%= parents.last.singularize %>_id])<% end %>
|
53
|
+
authorize @<%= resource.pluralize.underscore %>
|
54
|
+
@<%= resource.pluralize.underscore %>.destroy_all
|
57
55
|
end
|
58
56
|
|
59
57
|
def resource_params
|
60
58
|
params.require(:<%= resource.underscore %>).permit(:id<%= fields_as_params(:relations => true) %>)
|
61
59
|
end
|
62
|
-
|
63
60
|
end
|
@@ -10,6 +10,19 @@
|
|
10
10
|
// Read Sprockets README (https://github.com/sstephenson/sprockets#sprockets-directives) for details
|
11
11
|
// about supported directives.
|
12
12
|
//
|
13
|
+
/// From Faalis -----------------------------
|
13
14
|
//= require faalis/angular-manifest
|
14
|
-
|
15
|
+
|
16
|
+
|
17
|
+
/// From Dashstrap
|
18
|
+
//= require jquery-ui
|
19
|
+
///= require jquery-ui/tooltip
|
20
|
+
//= require ui-bootstrap
|
21
|
+
//= require dashstrap/application
|
22
|
+
|
23
|
+
//= require AdminLTE/app
|
24
|
+
//= require AdminLTE/dashboard
|
25
|
+
|
26
|
+
/// Faalis dashboard main application --------
|
15
27
|
//= require_tree ./modules
|
28
|
+
//= require faalis/dashboard/application
|
@@ -3,8 +3,10 @@ Faalis::Engine.setup do |config|
|
|
3
3
|
# Default value is the rails logger
|
4
4
|
# config.logger = Logger.new(STDOUT)
|
5
5
|
|
6
|
+
config.orm = 'active_record'
|
7
|
+
|
6
8
|
# Add your models which want to manage their permissions
|
7
|
-
config.models_with_permission = []
|
9
|
+
config.models_with_permission = ['Faalis::Permissions::Auth']
|
8
10
|
|
9
11
|
# Url prefix for dashboard section. default is '/dashboard'
|
10
12
|
# config.dashboard_namespace = :dashboard
|
@@ -3,8 +3,8 @@ module.exports = function (grunt) {
|
|
3
3
|
nggettext_extract: {
|
4
4
|
pot: {
|
5
5
|
files: {
|
6
|
-
'app/assets/locales/templates.pot': ['app/views/
|
7
|
-
'app/views/
|
6
|
+
'app/assets/locales/templates.pot': ['app/views/angular/**/*.html',
|
7
|
+
'app/views/angular/**/*.html.erb',
|
8
8
|
'app/assets/javascripts/**/*.js',
|
9
9
|
'app/assets/javascripts/**/*.js',
|
10
10
|
'app/assets/javascripts/**/*.coffee',
|
@@ -16,14 +16,14 @@
|
|
16
16
|
<% fields.each do |name, type, to| %><% if ["belongs_to", "in", "has_many"].include? type %>
|
17
17
|
$scope.<%= name %>_data = {
|
18
18
|
type: '<%= type %>',<% if type == "in" %>
|
19
|
-
choices:
|
19
|
+
choices: [<% to.each do |choice| %>{name: "<%= choice.underscore %>", title: "<%= choice.humanize %>"},<% end %>].sortBy(),
|
20
20
|
<% else %>
|
21
21
|
to: '<%= type.to %>',<% end %>
|
22
22
|
name: '<%= name %>'
|
23
23
|
};<% end %><% end %>
|
24
|
-
<% fields.each do |name, type, to| %><% if type == "in" %>$scope.<%= name %>_choices =
|
24
|
+
<% fields.each do |name, type, to| %><% if type == "in" %>$scope.<%= name %>_choices = [<% to.each do |choice| %>
|
25
25
|
{name: "<%= choice.underscore %>", title: "<%= choice.humanize %>"},<% end %>
|
26
|
-
], "title");<% end %><% end %>
|
26
|
+
].sortBy(), "title");<% end %><% end %>
|
27
27
|
if( "id" in $routeParams ){
|
28
28
|
$scope.obj_id = $routeParams.id;
|
29
29
|
$scope.editing = true;
|
@@ -27,7 +27,7 @@ module Faalis
|
|
27
27
|
def copy_views_file
|
28
28
|
directory "views/faalis", "app/views/faalis"
|
29
29
|
directory "views/layouts/faalis", "app/views/layouts/faalis"
|
30
|
-
directory "views/
|
30
|
+
directory "views/angular", "app/views/layouts/faalis"
|
31
31
|
|
32
32
|
end
|
33
33
|
|
data/lib/tasks/docs.rake
ADDED
data/lib/tasks/faalis_tasks.rake
CHANGED
@@ -3,8 +3,8 @@ module.exports = function (grunt) {
|
|
3
3
|
nggettext_extract: {
|
4
4
|
pot: {
|
5
5
|
files: {
|
6
|
-
'app/assets/
|
7
|
-
'app/views/
|
6
|
+
'app/assets/locales/templates.pot': ['app/views/angular/**/*.html',
|
7
|
+
'app/views/angular/**/*.html.erb',
|
8
8
|
'app/assets/javascripts/**/*.js',
|
9
9
|
'app/assets/javascripts/**/*.js',
|
10
10
|
'app/assets/javascripts/**/*.coffee',
|
@@ -18,7 +18,7 @@ module.exports = function (grunt) {
|
|
18
18
|
module: "Dashboard"
|
19
19
|
},
|
20
20
|
files: {
|
21
|
-
'app/assets/javascripts/faalis/
|
21
|
+
'app/assets/javascripts/faalis/locale/translations.fa.js': ['app/assets/locale/*.fa.pot']
|
22
22
|
}
|
23
23
|
}
|
24
24
|
}
|
@@ -4,9 +4,9 @@ Faalis::Engine.setup do |config|
|
|
4
4
|
# config.logger = Logger.new(STDOUT)
|
5
5
|
|
6
6
|
# Add your models which want to manage their permissions
|
7
|
-
config.models_with_permission = ["Permissions::Settings",
|
8
|
-
|
9
|
-
|
7
|
+
#config.models_with_permission = ["Permissions::Settings",
|
8
|
+
# "Permissions::Theme",
|
9
|
+
# "Faalis::Permissions::Auth"]
|
10
10
|
|
11
11
|
# Url prefix for dashboard section. default is '/dashboard'
|
12
12
|
# config.dashboard_namespace = :dashboard
|
Binary file
|
@@ -0,0 +1,71 @@
|
|
1
|
+
# encoding: UTF-8
|
2
|
+
# This file is auto-generated from the current state of the database. Instead
|
3
|
+
# of editing this file, please use the migrations feature of Active Record to
|
4
|
+
# incrementally modify your database, and then regenerate this schema definition.
|
5
|
+
#
|
6
|
+
# Note that this schema.rb definition is the authoritative source for your
|
7
|
+
# database schema. If you need to create the application database on another
|
8
|
+
# system, you should be using db:schema:load, not running all the migrations
|
9
|
+
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
10
|
+
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
11
|
+
#
|
12
|
+
# It's strongly recommended that you check this file into your version control system.
|
13
|
+
|
14
|
+
ActiveRecord::Schema.define(version: 20150121060012) do
|
15
|
+
|
16
|
+
create_table "application_models", force: :cascade do |t|
|
17
|
+
t.string "model"
|
18
|
+
t.datetime "created_at"
|
19
|
+
t.datetime "updated_at"
|
20
|
+
end
|
21
|
+
|
22
|
+
create_table "faalis_groups", force: :cascade do |t|
|
23
|
+
t.string "name"
|
24
|
+
t.string "role"
|
25
|
+
t.datetime "created_at"
|
26
|
+
t.datetime "updated_at"
|
27
|
+
end
|
28
|
+
|
29
|
+
create_table "faalis_groups_permissions", force: :cascade do |t|
|
30
|
+
t.integer "permission_id"
|
31
|
+
t.integer "group_id"
|
32
|
+
end
|
33
|
+
|
34
|
+
create_table "faalis_groups_users", force: :cascade do |t|
|
35
|
+
t.integer "user_id"
|
36
|
+
t.integer "group_id"
|
37
|
+
end
|
38
|
+
|
39
|
+
create_table "faalis_permissions", force: :cascade do |t|
|
40
|
+
t.string "model"
|
41
|
+
t.string "permission_type"
|
42
|
+
t.datetime "created_at"
|
43
|
+
t.datetime "updated_at"
|
44
|
+
end
|
45
|
+
|
46
|
+
create_table "faalis_users", force: :cascade do |t|
|
47
|
+
t.string "email", default: "", null: false
|
48
|
+
t.string "encrypted_password", default: "", null: false
|
49
|
+
t.string "reset_password_token"
|
50
|
+
t.datetime "reset_password_sent_at"
|
51
|
+
t.datetime "remember_created_at"
|
52
|
+
t.integer "sign_in_count", default: 0
|
53
|
+
t.datetime "current_sign_in_at"
|
54
|
+
t.datetime "last_sign_in_at"
|
55
|
+
t.string "current_sign_in_ip"
|
56
|
+
t.string "last_sign_in_ip"
|
57
|
+
t.string "first_name"
|
58
|
+
t.string "last_name"
|
59
|
+
t.integer "group_id", default: 2
|
60
|
+
t.integer "failed_attempts", default: 0
|
61
|
+
t.string "unlock_token"
|
62
|
+
t.datetime "locked_at"
|
63
|
+
t.datetime "created_at"
|
64
|
+
t.datetime "updated_at"
|
65
|
+
end
|
66
|
+
|
67
|
+
add_index "faalis_users", ["email"], name: "index_faalis_users_on_email", unique: true
|
68
|
+
add_index "faalis_users", ["reset_password_token"], name: "index_faalis_users_on_reset_password_token", unique: true
|
69
|
+
add_index "faalis_users", ["unlock_token"], name: "index_faalis_users_on_unlock_token", unique: true
|
70
|
+
|
71
|
+
end
|
Binary file
|