keppler 2.0.2 → 2.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/.gitignore +8 -0
- data/CODE_OF_CONDUCT.md +74 -0
- data/Gemfile.lock +26 -0
- data/LICENSE.txt +21 -0
- data/README.md +93 -22
- data/Rakefile +6 -0
- data/bin/keppler +6 -2
- data/bin/setup +2 -1
- data/exe/keppler +6 -0
- data/installer/core/.gitignore +87 -0
- data/installer/core/.ruby-version +1 -0
- data/installer/core/Gemfile +6 -4
- data/installer/core/README.md +86 -50
- data/installer/core/app/assets/images/.keep +0 -0
- data/installer/core/app/assets/images/admin/astronauta_keppler.svg +123 -0
- data/installer/core/app/assets/images/admin/avatar_keppler.svg +100 -0
- data/installer/core/app/assets/images/admin/image_default.png +0 -0
- data/installer/core/app/assets/images/app/fondo.svg +19 -0
- data/installer/core/app/assets/javascripts/admin/file_upload.coffee +11 -0
- data/installer/core/app/assets/javascripts/admin/main.coffee +23 -12
- data/installer/core/app/assets/javascripts/admin/preview_template.js +2 -2
- data/installer/core/app/assets/javascripts/admin/sidebar.js +8 -7
- data/installer/core/app/assets/javascripts/admin/swal.js +37 -0
- data/installer/core/app/assets/javascripts/admin/switch.js +6 -0
- data/installer/core/app/assets/javascripts/admin/tooltips.coffee +3 -0
- data/installer/core/app/assets/javascripts/errors/application.js.coffee +1 -0
- data/installer/core/app/assets/javascripts/errors/errors.js +113 -0
- data/installer/core/app/assets/javascripts/keppler_ga_dashboard/view-selector2.js +1 -1
- data/installer/core/app/assets/javascripts/vue_admin/index.js +34 -9
- data/installer/core/app/assets/stylesheets/admin/application.scss +4 -14
- data/installer/core/app/assets/stylesheets/admin/components/navigation/_navbar.scss +4 -5
- data/installer/core/app/assets/stylesheets/admin/components/navigation/_sidebar.scss +26 -17
- data/installer/core/app/assets/stylesheets/admin/pages/_appearance.scss +5 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_customize.scss +21 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_datepicker.scss +1088 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_files.scss +26 -9
- data/installer/core/app/assets/stylesheets/admin/pages/_form.scss +19 -6
- data/installer/core/app/assets/stylesheets/admin/pages/_index.scss +4 -8
- data/installer/core/app/assets/stylesheets/admin/pages/_listing.scss +5 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_navbar.scss +9 -2
- data/installer/core/app/assets/stylesheets/admin/pages/_roles.scss +6 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_search.scss +24 -28
- data/installer/core/app/assets/stylesheets/admin/pages/_sidebar.scss +1 -1
- data/installer/core/app/assets/stylesheets/admin/pages/_switchs.scss +135 -39
- data/installer/core/app/assets/stylesheets/admin/pages/_timepicker.scss +16 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_user.scss +6 -0
- data/installer/core/app/assets/stylesheets/admin/utils/_base.scss +6 -1
- data/installer/core/app/assets/stylesheets/admin/utils/_theme.scss +24 -11
- data/installer/core/app/assets/stylesheets/admin/utils/_variables.scss +1 -1
- data/installer/core/app/assets/stylesheets/app/pages/_front.sass +70 -56
- data/installer/core/app/assets/stylesheets/errors/errors.scss +161 -120
- data/installer/core/app/assets/stylesheets/vendor/admin-lte/_skin-blue.scss +1 -1
- data/installer/core/app/controllers/admin/admin_controller.rb +1 -1
- data/installer/core/app/controllers/admin/customizes_controller.rb +6 -8
- data/installer/core/app/controllers/admin/meta_tags_controller.rb +14 -18
- data/installer/core/app/controllers/admin/roles_controller.rb +176 -0
- data/installer/core/app/controllers/admin/scripts_controller.rb +14 -33
- data/installer/core/app/controllers/admin/settings_controller.rb +26 -27
- data/installer/core/app/controllers/admin/users_controller.rb +35 -29
- data/installer/core/app/controllers/app/app_controller.rb +27 -4
- data/installer/core/app/controllers/application_controller.rb +39 -1
- data/installer/core/app/controllers/concerns/.keep +0 -0
- data/installer/core/app/helpers/admin_helper.rb +5 -0
- data/installer/core/app/helpers/application_helper.rb +9 -0
- data/installer/core/app/helpers/roles_helper.rb +2 -0
- data/installer/core/app/inputs/file_material_input.rb +4 -2
- data/installer/core/app/inputs/keppler_boolean_input.rb +74 -0
- data/installer/core/app/inputs/keppler_file_input.rb +70 -0
- data/installer/core/app/mailers/.keep +0 -0
- data/installer/core/app/mailers/application_mailer.rb +13 -13
- data/installer/core/app/models/.keep +0 -0
- data/installer/core/app/models/appearance.rb +2 -0
- data/installer/core/app/models/application_record.rb +3 -0
- data/installer/core/app/models/concerns/.keep +0 -0
- data/installer/core/app/models/concerns/downloadable.rb +13 -0
- data/installer/core/app/models/concerns/sortable.rb +9 -0
- data/installer/core/app/models/concerns/uploadable.rb +10 -0
- data/installer/core/app/models/customize.rb +8 -6
- data/installer/core/app/models/front.rb +3 -0
- data/installer/core/app/models/google_analytics_setting.rb +2 -0
- data/installer/core/app/models/meta_tag.rb +27 -14
- data/installer/core/app/models/permission.rb +3 -0
- data/installer/core/app/models/role.rb +62 -5
- data/installer/core/app/models/script.rb +6 -15
- data/installer/core/app/models/setting.rb +2 -0
- data/installer/core/app/models/smtp_setting.rb +2 -0
- data/installer/core/app/models/social_account.rb +2 -0
- data/installer/core/app/models/user.rb +17 -1
- data/installer/core/app/policies/application_policy.rb +4 -4
- data/installer/core/app/policies/controller_policy.rb +15 -11
- data/installer/core/app/policies/role_policy.rb +25 -0
- data/installer/core/app/policies/user_policy.rb +1 -1
- data/installer/core/app/uploaders/attachment_uploader.rb +18 -1
- data/installer/core/app/views/admin/customizes/_description.html.haml +4 -4
- data/installer/core/app/views/admin/customizes/_form.html.haml +4 -4
- data/installer/core/app/views/admin/customizes/_listing.html.haml +1 -1
- data/installer/core/app/views/admin/customizes/_switch_default_template.html.haml +8 -13
- data/installer/core/app/views/admin/customizes/_switch_template.html.haml +8 -11
- data/installer/core/app/views/admin/customizes/index.html.haml +9 -9
- data/installer/core/app/views/admin/layouts/_head.html.haml +3 -3
- data/installer/core/app/views/admin/layouts/_keppler_boolean_script.haml +12 -0
- data/installer/core/app/views/admin/layouts/_navigation.html.haml +17 -16
- data/installer/core/app/views/admin/layouts/_sidebar.html.haml +27 -36
- data/installer/core/app/views/admin/layouts/application.html.haml +1 -0
- data/installer/core/app/views/admin/layouts/index/remote_messages.js.haml +6 -6
- data/installer/core/app/views/admin/meta_tags/_index_show.html.haml +2 -2
- data/installer/core/app/views/admin/meta_tags/_listing.html.haml +6 -6
- data/installer/core/app/views/admin/meta_tags/index.html.haml +15 -29
- data/installer/core/app/views/admin/meta_tags/show.html.haml +7 -8
- data/installer/core/app/views/admin/roles/_description.html.haml +13 -0
- data/installer/core/app/views/admin/roles/_form.html.haml +27 -0
- data/installer/core/app/views/admin/roles/_index_show.html.haml +24 -0
- data/installer/core/app/views/admin/roles/_listing.html.haml +46 -0
- data/installer/core/app/views/admin/roles/_switch.html.haml +20 -0
- data/installer/core/app/views/admin/roles/add_permissions.html.haml +60 -0
- data/installer/core/app/views/admin/roles/create_permissions.html.haml +0 -0
- data/installer/core/app/views/admin/roles/create_permissions.js.erb +1 -0
- data/installer/core/app/views/admin/roles/edit.html.haml +1 -0
- data/installer/core/app/views/admin/roles/index.html.haml +80 -0
- data/installer/core/app/views/admin/roles/new.html.haml +1 -0
- data/installer/core/app/views/admin/roles/reload.js.haml +5 -0
- data/installer/core/app/views/admin/roles/show.html.haml +32 -0
- data/installer/core/app/views/admin/roles/show.js.haml +4 -0
- data/installer/core/app/views/admin/roles/show_description.js.erb +2 -0
- data/installer/core/app/views/admin/scripts/_index_show.html.haml +2 -2
- data/installer/core/app/views/admin/scripts/_listing.html.haml +13 -13
- data/installer/core/app/views/admin/scripts/index.html.haml +12 -26
- data/installer/core/app/views/admin/scripts/show.html.haml +4 -4
- data/installer/core/app/views/admin/settings/components/_preview.html.haml +1 -1
- data/installer/core/app/views/admin/settings/fields/_appearance.html.haml +25 -17
- data/installer/core/app/views/admin/settings/fields/_basic_information.html.haml +13 -7
- data/installer/core/app/views/admin/settings/fields/_email_setting.html.haml +16 -16
- data/installer/core/app/views/admin/settings/fields/_google_analytics_setting.html.haml +1 -1
- data/installer/core/app/views/admin/settings/fields/_social_accounts.html.haml +39 -39
- data/installer/core/app/views/admin/users/_form.html.haml +18 -25
- data/installer/core/app/views/admin/users/_index_show.html.haml +2 -2
- data/installer/core/app/views/admin/users/_listing.html.haml +6 -6
- data/installer/core/app/views/admin/users/delete_avatar.js.haml +3 -0
- data/installer/core/app/views/admin/users/filter_by_role.js.erb +9 -0
- data/installer/core/app/views/admin/users/index.html.haml +22 -22
- data/installer/core/app/views/admin/users/show.html.haml +10 -12
- data/installer/core/app/views/app/front/index.html.haml +137 -87
- data/installer/core/app/views/app/layouts/_footer.html.haml +2 -2
- data/installer/core/app/views/app/layouts/_head.html.haml +4 -12
- data/installer/core/app/views/app/layouts/_meta_tags.html.haml +38 -6
- data/installer/core/app/views/app/layouts/application.html.haml +8 -8
- data/installer/core/app/views/devise/sessions/new.html.haml +32 -28
- data/installer/core/app/views/errors/internal_server_error.html.haml +50 -7
- data/installer/core/app/views/errors/not_authorized.html.haml +75 -6
- data/installer/core/app/views/errors/not_found.html.haml +101 -7
- data/installer/core/app/views/errors/unprocessable.html.haml +50 -7
- data/installer/core/bin/update +31 -0
- data/installer/core/bin/yarn +11 -0
- data/installer/core/config/application.rb +1 -1
- data/installer/core/config/environments/production.rb +1 -1
- data/installer/core/config/initializers/carrierwave.rb +12 -0
- data/installer/core/config/initializers/mime_types.rb +2 -2
- data/installer/core/config/initializers/simple_form_bootstrap.rb +20 -1
- data/installer/core/config/initializers/simple_form_components.rb +61 -0
- data/installer/core/config/locales/en.yml +29 -6
- data/installer/core/config/locales/es.yml +32 -5
- data/installer/core/config/locales/simple_form.en.yml +1 -0
- data/installer/core/config/locales/simple_form.es.yml +3 -2
- data/installer/core/config/menu.yml +34 -8
- data/installer/core/config/permissions.yml +21 -0
- data/installer/core/config/routes.rb +56 -14
- data/installer/core/db/migrate/20140812210925_rolify_create_roles.rb +2 -0
- data/installer/core/db/migrate/20160128131802_create_scripts.rb +1 -0
- data/installer/core/db/migrate/20180503174351_create_permissions.rb +11 -0
- data/installer/core/db/seeds.rb +12 -6
- data/installer/core/lib/generators/keppler_front/templates/views/template.html.haml +222 -177
- data/installer/core/lib/generators/keppler_relation/keppler_relation_generator.rb +1 -1
- data/installer/core/lib/generators/keppler_scaffold/keppler_scaffold_generator.rb +57 -40
- data/installer/core/lib/generators/keppler_scaffold/templates/controllers/controller.rb +29 -30
- data/installer/core/lib/generators/keppler_scaffold/templates/models/model.rb +14 -20
- data/installer/core/lib/generators/keppler_scaffold/templates/views/_form.html.haml +24 -35
- data/installer/core/lib/generators/keppler_scaffold/templates/views/_index_show.html.haml +12 -11
- data/installer/core/lib/generators/keppler_scaffold/templates/views/_listing.html.haml +7 -7
- data/installer/core/lib/generators/keppler_scaffold/templates/views/index.html.haml +17 -33
- data/installer/core/lib/generators/keppler_scaffold/templates/views/show.html.haml +23 -24
- data/installer/core/plugins/keppler_ga_dashboard/app/assets/images/keppler_ga_dashboard/.keep +0 -0
- data/installer/core/plugins/keppler_ga_dashboard/config/permissions.yml +4 -0
- data/installer/core/plugins/keppler_ga_dashboard/keppler_ga_dashboard.gemspec +1 -1
- data/installer/core/test/controllers/.keep +0 -0
- data/installer/core/test/controllers/roles_controller_test.rb +48 -0
- data/installer/core/test/fixtures/.keep +0 -0
- data/installer/core/test/fixtures/permissions.yml +9 -0
- data/installer/core/test/helpers/.keep +0 -0
- data/installer/core/test/integration/.keep +0 -0
- data/installer/core/test/mailers/.keep +0 -0
- data/installer/core/test/models/.keep +0 -0
- data/installer/core/test/models/permission_test.rb +7 -0
- data/installer/core/test/system/roles_test.rb +43 -0
- data/installer/core/vendor/assets/javascripts/.keep +0 -0
- data/installer/core/vendor/assets/stylesheets/.keep +0 -0
- data/installer/plugins/concerns/commons.rb +47 -0
- data/installer/plugins/concerns/destroy_multiple.rb +33 -0
- data/installer/plugins/concerns/history.rb +24 -0
- data/installer/plugins/config/locales/en.yml +104 -0
- data/installer/plugins/config/locales/es.yml +139 -0
- data/installer/plugins/config/menu.yml +12 -0
- data/installer/plugins/config/permissions.yml +1 -0
- data/installer/plugins/generators/keppler_scaffold/keppler_scaffold_generator.rb +203 -0
- data/installer/plugins/generators/keppler_scaffold/templates/controllers/controller.rb +171 -0
- data/installer/plugins/generators/keppler_scaffold/templates/models/model.rb +41 -0
- data/installer/plugins/generators/keppler_scaffold/templates/policies/policy.rb +11 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/_description.html.haml +13 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/_form.html.haml +49 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/_index_show.html.haml +26 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/_listing.html.haml +65 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/edit.html.haml +1 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/index.html.haml +97 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/new.html.haml +1 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/reload.js.haml +5 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/show.html.haml +66 -0
- data/installer/plugins/generators/keppler_scaffold/templates/views/show.js.haml +4 -0
- data/installer/plugins/install.rb +156 -0
- data/installer/plugins/layouts/_navigation.html.haml +47 -0
- data/installer/plugins/layouts/application.html.haml +24 -0
- data/keppler.gemspec +35 -0
- data/lib/keppler.rb +0 -1
- data/lib/keppler/add.rb +13 -0
- data/lib/keppler/cli.rb +134 -5
- data/lib/keppler/delete.rb +13 -0
- data/lib/keppler/version.rb +1 -1
- metadata +117 -23
- data/installer/core/app/assets/images/admin/space.png +0 -0
- data/installer/core/app/assets/stylesheets/admin/pages/_header.scss +0 -34
- data/installer/core/app/assets/stylesheets/admin/pages/_pageslide.scss +0 -125
- data/installer/core/db/schema.rb +0 -172
- data/installer/lib/conf.rb +0 -31
- data/installer/lib/scaffold.rb +0 -10
- data/installer/run.sh +0 -17
- data/installer/scripts/bin.sh +0 -61
- data/lib/keppler/cli/generate.rb +0 -19
@@ -0,0 +1,171 @@
|
|
1
|
+
<% if namespaced? -%>
|
2
|
+
require_dependency "<%= namespaced_path %>/application_controller"
|
3
|
+
<% end -%>
|
4
|
+
<% module_namespacing do -%>
|
5
|
+
module Admin
|
6
|
+
# <%= controller_class_name %>Controller
|
7
|
+
class <%= controller_class_name %>Controller < ApplicationController
|
8
|
+
layout '<%= namespaced_path %>/admin/layouts/application'
|
9
|
+
before_action :set_<%= singular_table_name %>, only: [:show, :edit, :update, :destroy]
|
10
|
+
before_action :show_history, only: [:index]
|
11
|
+
before_action :set_attachments
|
12
|
+
before_action :authorization
|
13
|
+
include <%= namespaced_path.split('_').map(&:capitalize).join('') %>::Concerns::Commons
|
14
|
+
include <%= namespaced_path.split('_').map(&:capitalize).join('') %>::Concerns::History
|
15
|
+
include <%= namespaced_path.split('_').map(&:capitalize).join('') %>::Concerns::DestroyMultiple
|
16
|
+
|
17
|
+
|
18
|
+
# GET <%= route_url %>
|
19
|
+
def index
|
20
|
+
@q = <%= class_name %>.ransack(params[:q])
|
21
|
+
<%= plural_table_name %> = @q.result(distinct: true)
|
22
|
+
@objects = <%= plural_table_name %>.page(@current_page).order(position: :asc)
|
23
|
+
@total = <%= plural_table_name %>.size
|
24
|
+
@<%= plural_table_name %> = @objects.all
|
25
|
+
if !@objects.first_page? && @objects.size.zero?
|
26
|
+
redirect_to <%= plural_table_name %>_path(page: @current_page.to_i.pred, search: @query)
|
27
|
+
end
|
28
|
+
respond_to do |format|
|
29
|
+
format.html
|
30
|
+
format.xls { send_data(@<%= plural_table_name %>.to_xls) }
|
31
|
+
format.json { render :json => @objects }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# GET <%= route_url %>/1
|
36
|
+
def show
|
37
|
+
end
|
38
|
+
|
39
|
+
# GET <%= route_url %>/new
|
40
|
+
def new
|
41
|
+
@<%= singular_table_name %> = <%= orm_class.build(class_name) %>
|
42
|
+
end
|
43
|
+
|
44
|
+
# GET <%= route_url %>/1/edit
|
45
|
+
def edit
|
46
|
+
end
|
47
|
+
|
48
|
+
# POST <%= route_url %>
|
49
|
+
def create
|
50
|
+
@<%= singular_table_name %> = <%= orm_class.build(class_name, "#{singular_table_name}_params") %>
|
51
|
+
|
52
|
+
if @<%= orm_instance.save %>
|
53
|
+
redirect(@<%= singular_table_name %>, params)
|
54
|
+
else
|
55
|
+
render :new
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
# PATCH/PUT <%= route_url %>/1
|
60
|
+
def update
|
61
|
+
if @<%= orm_instance.update("#{singular_table_name}_params") %>
|
62
|
+
redirect(@<%= singular_table_name %>, params)
|
63
|
+
else
|
64
|
+
render :edit
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
def clone
|
69
|
+
@<%= singular_table_name %> = <%= class_name %>.clone_record params[:<%=singular_table_name%>_id]
|
70
|
+
|
71
|
+
if @<%= singular_table_name %>.save
|
72
|
+
redirect_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= index_helper %>_path
|
73
|
+
else
|
74
|
+
render :new
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
# DELETE <%= route_url %>/1
|
79
|
+
def destroy
|
80
|
+
@<%= orm_instance.destroy %>
|
81
|
+
redirect_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= index_helper %>_path, notice: actions_messages(@<%= singular_table_name %>)
|
82
|
+
end
|
83
|
+
|
84
|
+
def destroy_multiple
|
85
|
+
<%= class_name %>.destroy redefine_ids(params[:multiple_ids])
|
86
|
+
redirect_to(
|
87
|
+
admin_<%= index_helper %>_path(page: @current_page, search: @query),
|
88
|
+
notice: actions_messages(<%= orm_class.build(class_name) %>)
|
89
|
+
)
|
90
|
+
end
|
91
|
+
|
92
|
+
def upload
|
93
|
+
<%= class_name %>.upload(params[:file])
|
94
|
+
redirect_to(
|
95
|
+
admin_<%= index_helper %>_path(page: @current_page, search: @query),
|
96
|
+
notice: actions_messages(<%= orm_class.build(class_name) %>)
|
97
|
+
)
|
98
|
+
end
|
99
|
+
|
100
|
+
def download
|
101
|
+
@<%= plural_table_name %> = <%= class_name %>.all
|
102
|
+
respond_to do |format|
|
103
|
+
format.html
|
104
|
+
format.xls { send_data(@<%= plural_table_name %>.to_xls) }
|
105
|
+
format.json { render json: @<%= plural_table_name %> }
|
106
|
+
end
|
107
|
+
end
|
108
|
+
|
109
|
+
def reload
|
110
|
+
@q = <%= class_name %>.ransack(params[:q])
|
111
|
+
<%= plural_table_name %> = @q.result(distinct: true)
|
112
|
+
@objects = <%= plural_table_name %>.page(@current_page).order(position: :desc)
|
113
|
+
end
|
114
|
+
|
115
|
+
def sort
|
116
|
+
<%= class_name %>.sorter(params[:row])
|
117
|
+
@q = <%= class_name %>.ransack(params[:q])
|
118
|
+
<%= plural_table_name %> = @q.result(distinct: true)
|
119
|
+
@objects = <%= plural_table_name %>.page(@current_page)
|
120
|
+
render :index
|
121
|
+
end
|
122
|
+
|
123
|
+
private
|
124
|
+
|
125
|
+
def authorization
|
126
|
+
authorize <%= class_name %>
|
127
|
+
end
|
128
|
+
|
129
|
+
def set_attachments
|
130
|
+
@attachments = ['logo', 'brand', 'photo', 'avatar', 'cover', 'image',
|
131
|
+
'picture', 'banner', 'attachment', 'pic', 'file']
|
132
|
+
end
|
133
|
+
|
134
|
+
# Use callbacks to share common setup or constraints between actions.
|
135
|
+
def set_<%= singular_table_name %>
|
136
|
+
@<%= singular_table_name %> = <%= orm_class.find(class_name, "params[:id]") %>
|
137
|
+
end
|
138
|
+
|
139
|
+
# Only allow a trusted parameter "white list" through.
|
140
|
+
def <%= "#{singular_table_name}_params" %>
|
141
|
+
<%- if attributes_names.empty? -%>
|
142
|
+
params[:<%= singular_table_name %>]
|
143
|
+
<%- else -%>
|
144
|
+
params.require(:<%= singular_table_name %>).permit(<%= attributes_names.map { |name| ":#{name}" }.join(', ') %>)
|
145
|
+
<%- end -%>
|
146
|
+
end
|
147
|
+
|
148
|
+
def show_history
|
149
|
+
get_history(<%= singular_table_name.camelcase %>)
|
150
|
+
end
|
151
|
+
|
152
|
+
def get_history(model)
|
153
|
+
@activities = PublicActivity::Activity.where(
|
154
|
+
trackable_type: model.to_s
|
155
|
+
).order('created_at desc').limit(50)
|
156
|
+
end
|
157
|
+
|
158
|
+
# Get submit key to redirect, only [:create, :update]
|
159
|
+
def redirect(object, commit)
|
160
|
+
if commit.key?('_save')
|
161
|
+
redirect_to([:admin, :<%= namespaced_path.split('_').drop(1).join('_') %>, object], notice: actions_messages(object))
|
162
|
+
elsif commit.key?('_add_other')
|
163
|
+
redirect_to(
|
164
|
+
send("new_admin_<%= namespaced_path.split('_').drop(1).join('_') %>_#{underscore(object)}_path"),
|
165
|
+
notice: actions_messages(object)
|
166
|
+
)
|
167
|
+
end
|
168
|
+
end
|
169
|
+
end
|
170
|
+
end
|
171
|
+
<% end -%>
|
@@ -0,0 +1,41 @@
|
|
1
|
+
# <%= class_name %> Model
|
2
|
+
<% module_namespacing do -%>
|
3
|
+
class <%= class_name %> < ActiveRecord::Base
|
4
|
+
include ActivityHistory
|
5
|
+
include CloneRecord
|
6
|
+
require 'csv'
|
7
|
+
<%- attributes_names.each do |attribute| -%>
|
8
|
+
<%- if @attachments.include?(attribute) -%>
|
9
|
+
mount_uploader :<%=attribute%>, AttachmentUploader
|
10
|
+
<%- end -%>
|
11
|
+
<%- end -%>
|
12
|
+
acts_as_list
|
13
|
+
# Fields for the search form in the navbar
|
14
|
+
def self.search_field
|
15
|
+
fields = <%= attributes_names.map { |name| name } %>
|
16
|
+
build_query(fields, :or, :cont)
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.upload(file)
|
20
|
+
CSV.foreach(file.path, headers: true) do |row|
|
21
|
+
begin
|
22
|
+
self.create! row.to_hash
|
23
|
+
rescue => err
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.sorter(params)
|
29
|
+
params.each_with_index do |id, idx|
|
30
|
+
self.find(id).update(position: idx.to_i+1)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
# Funcion para armar el query de ransack
|
35
|
+
def self.build_query(fields, operator, conf)
|
36
|
+
query = fields.join("_#{operator}_")
|
37
|
+
query << "_#{conf}"
|
38
|
+
query.to_sym
|
39
|
+
end
|
40
|
+
end
|
41
|
+
<% end -%>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
<% module_namespacing do -%>
|
2
|
+
# Policy for <%= controller_class_name.singularize %> model
|
3
|
+
class <%= controller_class_name.singularize %>Policy < ControllerPolicy
|
4
|
+
attr_reader :user, :objects
|
5
|
+
|
6
|
+
def initialize(user, objects)
|
7
|
+
@user = user
|
8
|
+
@objects = objects
|
9
|
+
end
|
10
|
+
end
|
11
|
+
<% end -%>
|
@@ -0,0 +1,13 @@
|
|
1
|
+
%aside.control-sidebar.control-sidebar-light
|
2
|
+
.tab-content
|
3
|
+
%p.control-sidebar-heading
|
4
|
+
= @activities.empty? ? t('keppler.messages.no_events') : t("keppler.titles.history")
|
5
|
+
%ul.timeline
|
6
|
+
- @activities.each do |activity|
|
7
|
+
- if activity.trackable_type.eql? "Session"
|
8
|
+
%li
|
9
|
+
= render partial: "public_activity/session/#{activity.key.split(".").second}", locals: { activity: activity, method: "id" }
|
10
|
+
- else
|
11
|
+
%li
|
12
|
+
= render partial: "public_activity/layout/#{activity.key.split(".").second}", locals: { activity: activity, method: "id" }
|
13
|
+
.control-sidebar-bg
|
@@ -0,0 +1,49 @@
|
|
1
|
+
= simple_form_for [:admin, :<%= namespaced_path.split('_').drop(1).join('_') %>, @<%= singular_table_name %>] do |f|
|
2
|
+
.container
|
3
|
+
.row
|
4
|
+
.col-lg-2
|
5
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= plural_table_name %>_path, class: "", "data-position" => "bottom", "data-tooltip" => t("keppler.actions.back") do
|
6
|
+
.arrow-back.btn.btn-default
|
7
|
+
%i.fa.fa-angle-left
|
8
|
+
= t('keppler.actions.back')
|
9
|
+
|
10
|
+
.row
|
11
|
+
.col-lg-12
|
12
|
+
.box.slice-box
|
13
|
+
.box-header.with-border
|
14
|
+
%h3.box-title= t("keppler.modules.#{action_name.underscore}")
|
15
|
+
.box-tools.pull-right
|
16
|
+
%a.btn.btn-box-tool{"data-widget" => "collapse", :type => "button"}
|
17
|
+
%i.fa.fa-minus
|
18
|
+
.box-body
|
19
|
+
%table.table.table-bordered
|
20
|
+
%tbody
|
21
|
+
.form-padding
|
22
|
+
<%- attributes.each do |attribute| -%>
|
23
|
+
.col-xs-12
|
24
|
+
<%- if @attachments.include?(attribute.name) -%>
|
25
|
+
= f.input :<%= attribute.name %>, as: :keppler_file, label: false
|
26
|
+
<%- elsif attribute.reference? -%>
|
27
|
+
= f.association :<%= attribute.name %>, include_blank: false
|
28
|
+
<%- elsif attribute.type.to_s == 'text' -%>
|
29
|
+
= f.input :<%= attribute.name %>, input_html: { ckeditor: { toolbar: 'mini' } }
|
30
|
+
<%- elsif %[position deleted_at].include?(attribute.name.to_s) || attribute.type.to_s == 'timestamp' -%>
|
31
|
+
= f.input :<%= attribute.name %>, as: :hidden
|
32
|
+
<%- elsif attribute.type.to_s == 'date' -%>
|
33
|
+
= f.input :<%= attribute.name %>, as: :string, input_html: { class: 'datepicker' }
|
34
|
+
<%- elsif attribute.type.to_s == 'boolean' -%>
|
35
|
+
= f.input :<%= attribute.name %>, as: :keppler_boolean
|
36
|
+
<%- elsif %w[integer float decimal].include?(attribute.type.to_s) -%>
|
37
|
+
= f.input :<%= attribute.name %>, input_html: { min: 0 }
|
38
|
+
<%- elsif attribute.type.to_s == 'binary' -%>
|
39
|
+
= f.input :<%= attribute.name %>, as: :string
|
40
|
+
<%- elsif attribute.name.to_s == "position" || attribute.name.to_s == "deleted_at" -%>
|
41
|
+
= f.<%= attribute.reference? ? :association : :input %> :<%= attribute.name %>, as: :hidden
|
42
|
+
<%- else -%>
|
43
|
+
= f.input :<%= attribute.name %>
|
44
|
+
<%- end -%>
|
45
|
+
<%- end -%>
|
46
|
+
.col-xs-12
|
47
|
+
.pull-right
|
48
|
+
= f.button :submit, t('keppler.actions.save'), name: '_save', class: 'btn-primary'
|
49
|
+
= f.button :submit, t('keppler.actions.save_and_add_another'), name: '_add_other'
|
@@ -0,0 +1,26 @@
|
|
1
|
+
.tab-content
|
2
|
+
%h6.actions
|
3
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).update?
|
4
|
+
= link_to edit_admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(@<%= singular_table_name %>), title: t("keppler.actions.edit"), class: 'pull-left' do
|
5
|
+
%i.icon-pencil
|
6
|
+
%span= t('keppler.actions.edit')
|
7
|
+
%a#close-index-show.pull-right
|
8
|
+
%i.icon-close
|
9
|
+
%h3.control-sidebar-heading
|
10
|
+
= t("keppler.modules.#{controller_path.underscore}")
|
11
|
+
%ul.timeline
|
12
|
+
- @<%= singular_table_name %>.as_json(only: <%= attributes.map{|attr| attr.name} %>).each do |attribute, value|
|
13
|
+
-unless attribute.eql?('position') || attribute.eql?('deleted_at')
|
14
|
+
%li.list-row
|
15
|
+
.timeline-item
|
16
|
+
%h6.timeline-header.no-border
|
17
|
+
%small
|
18
|
+
%strong.display-value= t("activerecord.attributes.#{attribute}")
|
19
|
+
- if @attachments.include?(attribute)
|
20
|
+
.display-label= image_tag value.url if value.url
|
21
|
+
- else
|
22
|
+
%p.display-label= value.blank? ? '-----------' : value
|
23
|
+
|
24
|
+
:coffee
|
25
|
+
$('#close-index-show').click ->
|
26
|
+
$('#index-show').css 'right', -$('#index-show').outerWidth()
|
@@ -0,0 +1,65 @@
|
|
1
|
+
- objects.each do |<%= singular_table_name %>|
|
2
|
+
%tr{ id: "row-#{<%= singular_table_name %>.id}" }
|
3
|
+
%td.item-check{ style: 'width: 10%' }
|
4
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).destroy_multiple?
|
5
|
+
.checkbox
|
6
|
+
%label{ for: "checkbox-#{<%= singular_table_name %>.id}" }
|
7
|
+
%input{ type:"checkbox", id: "checkbox-#{<%= singular_table_name %>.id}", 'checklist-model' => 'check', 'checklist-value' => "#{<%= singular_table_name %>.id}", '@click' => "listDelete(#{<%= singular_table_name %>.id})"}
|
8
|
+
%span.cr
|
9
|
+
%i.cr-icon.glyphicon.glyphicon-ok
|
10
|
+
<%- attributes.each do |attribute| -%>
|
11
|
+
<%- if @attachments.include?(attribute.name) -%>
|
12
|
+
%td
|
13
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(<%= singular_table_name %>, search: @query), remote: true, class: 'show-row' do
|
14
|
+
%span
|
15
|
+
- unless <%= singular_table_name %>.<%= attribute.name %>.url.blank?
|
16
|
+
= image_tag <%= singular_table_name %>.<%= attribute.name %>.url
|
17
|
+
<%- end -%>
|
18
|
+
<%- end -%>
|
19
|
+
<%- attributes.each_with_index do |attribute, index| -%>
|
20
|
+
<%- if index < 6 -%>
|
21
|
+
<%- unless attribute.type.to_s.eql?('text') || attribute.name.eql?('position') || attribute.name.eql?('deleted_at') -%>
|
22
|
+
<%- unless @attachments.include?(attribute.name) -%>
|
23
|
+
<%- if index < 2 -%>
|
24
|
+
%td.hidden-xs
|
25
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(<%= singular_table_name %>, search: @query), remote: true, class: 'show-row' do
|
26
|
+
%span
|
27
|
+
= <%= singular_table_name %>.<%= attribute.name %>
|
28
|
+
<%- else -%>
|
29
|
+
%td.hidden-xs.hidden-sm
|
30
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(<%= singular_table_name %>, search: @query), remote: true, class: 'show-row' do
|
31
|
+
%span
|
32
|
+
= <%= singular_table_name %>.<%= attribute.name %>
|
33
|
+
<%- end -%>
|
34
|
+
<%- end -%>
|
35
|
+
<%- end -%>
|
36
|
+
<%- end -%>
|
37
|
+
<%- end -%>
|
38
|
+
%td{ style: 'width: 15px;padding-right:15px;' }
|
39
|
+
%a.action-btn.pull-right{:id => "menu-#{<%= singular_table_name %>.id}", "aria-expanded" => "false", "aria-haspopup" => "true", "data-toggle" => "dropdown"}
|
40
|
+
%i.icon-options-vertical
|
41
|
+
%ul.actions.dropdown-menu{"aria-labelledby" => "menu-#{<%= singular_table_name %>.id}" }
|
42
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).index?
|
43
|
+
%li
|
44
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(<%= singular_table_name %>), class: 'new-menu', title: t('keppler.actions.show') do
|
45
|
+
%i.icon-eye
|
46
|
+
= t('keppler.actions.show')
|
47
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).update?
|
48
|
+
%li
|
49
|
+
= link_to edit_admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(<%= singular_table_name %>), class: 'new-menu', title: t('keppler.actions.edit') do
|
50
|
+
%i.icon-pencil
|
51
|
+
= t('keppler.actions.edit')
|
52
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).clone?
|
53
|
+
%li
|
54
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_clone_path(<%= singular_table_name %>), class: 'new-menu', title: t('keppler.actions.clone') do
|
55
|
+
%i.icon-docs
|
56
|
+
= t('keppler.actions.clone')
|
57
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).destroy?
|
58
|
+
%li
|
59
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path(<%= singular_table_name %>), class: 'new-menu', title: t('keppler.actions.delete'), method: :delete, data: { confirm: t("keppler.messages.data_confirm") } do
|
60
|
+
%i.icon-trash
|
61
|
+
= t('keppler.actions.delete')
|
62
|
+
|
63
|
+
%td{:style => 'width: 5%;'}
|
64
|
+
%a.drop{:href=>"#"}
|
65
|
+
%i.icon-cursor-move
|
@@ -0,0 +1 @@
|
|
1
|
+
= render 'form'
|
@@ -0,0 +1,97 @@
|
|
1
|
+
#index-container{ :controller => "<%= plural_table_name %>" }
|
2
|
+
.container
|
3
|
+
.row
|
4
|
+
.listing.col-lg-12.col-xs-12
|
5
|
+
%section.content-header.index-header
|
6
|
+
%h1{ style: 'display: inline-block' }
|
7
|
+
= t("keppler.modules.#{controller_path.underscore}")
|
8
|
+
= entries(@total, @objects)
|
9
|
+
.toolbar
|
10
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).download?
|
11
|
+
.toolbar-item
|
12
|
+
= link_to admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_download_path(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>, :format => :xls), class: "tool-btn", title: t('keppler.actions.download_records') do
|
13
|
+
%i.icon-cloud-download
|
14
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).upload?
|
15
|
+
.toolbar-item
|
16
|
+
= link_to "", class: "tool-btn", title: t('keppler.actions.upload_records'), id: "<%= singular_table_name %>" do
|
17
|
+
%i.icon-cloud-upload
|
18
|
+
.toolbar-item
|
19
|
+
= link_to reload_admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= plural_table_name %>_path, class: "tool-btn", remote: true do
|
20
|
+
%i.icon-reload
|
21
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).destroy_multiple?
|
22
|
+
.toolbar-item
|
23
|
+
.checkbox
|
24
|
+
%label{ for: 'checkbox-all' }
|
25
|
+
%input{ type: 'checkbox', id: 'checkbox-all', ':disabled' => 'checkItems ? disabled : ""', '@click' => 'selectAll()' }
|
26
|
+
%span.cr
|
27
|
+
%i.cr-icon.glyphicon.glyphicon-ok
|
28
|
+
.toolbar-item
|
29
|
+
%a.tool-btn{"data-confirm" => "¿Estás seguro?", "data-method" => "delete", "v-bind:href" => "link", :rel => "nofollow", ":class" => "{disabled: !checks}" }
|
30
|
+
%i.icon-trash
|
31
|
+
.hide
|
32
|
+
= form_tag admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_upload_path(@objects), id: "upload_form_<%= plural_table_name %>", multipart: true, method: :post do
|
33
|
+
= file_field_tag :file, id: "upload_file_<%= singular_table_name %>"
|
34
|
+
%ol.breadcrumb
|
35
|
+
%li
|
36
|
+
%a{ href: '#' }
|
37
|
+
%i.icon-directions
|
38
|
+
= t("keppler.modules.#{action_name.underscore}")
|
39
|
+
|
40
|
+
.box.slice-box
|
41
|
+
.box-body.no-padding
|
42
|
+
|
43
|
+
%table.table
|
44
|
+
%thead
|
45
|
+
- if @objects.size.zero?
|
46
|
+
%tr
|
47
|
+
%th{style: 'text-align: center;'}
|
48
|
+
%h6= t('keppler.messages.not_found_records', model: t("keppler.models.pluralize.<%= plural_table_name %>"))
|
49
|
+
- else
|
50
|
+
%tr
|
51
|
+
%th
|
52
|
+
<%- attributes.each do |attribute| -%>
|
53
|
+
<%- if @attachments.include?(attribute.name) -%>
|
54
|
+
%th= t('activerecord.attributes.<%= attribute.name %>')
|
55
|
+
<%- end -%>
|
56
|
+
<%- end -%>
|
57
|
+
<%- attributes.each_with_index do |attribute, index| -%>
|
58
|
+
<%- if index < 6 -%>
|
59
|
+
<%- unless attribute.type.to_s == 'text' || attribute.name.eql?('position') || attribute.name.eql?('deleted_at') -%>
|
60
|
+
<%- unless @attachments.include?(attribute.name) -%>
|
61
|
+
<%- if index < 2 -%>
|
62
|
+
%th.hidden-xs= t('activerecord.attributes.<%= attribute.name %>')
|
63
|
+
<%- else -%>
|
64
|
+
%th.hidden-xs.hidden-sm= t('activerecord.attributes.<%= attribute.name %>')
|
65
|
+
<%- end -%>
|
66
|
+
<%- end -%>
|
67
|
+
<%- end -%>
|
68
|
+
<%- end -%>
|
69
|
+
<%- end -%>
|
70
|
+
%th.center Menu
|
71
|
+
%th
|
72
|
+
%tbody#objects-container
|
73
|
+
= render 'admin/layouts/listing_preloader'
|
74
|
+
= render 'listing', objects: @objects
|
75
|
+
%center#paginator-module
|
76
|
+
= paginate @objects, window: 1
|
77
|
+
%aside.control-sidebar
|
78
|
+
= render "description"
|
79
|
+
%aside#index-show.control-sidebar
|
80
|
+
|
81
|
+
.mixed-btn
|
82
|
+
- if can?(<%= namespaced_path.split('_').map(&:capitalize).join('') %>::<%= singular_table_name.camelcase %>).create?
|
83
|
+
= link_to new_admin_<%= namespaced_path.split('_').drop(1).join('_') %>_<%= singular_table_name %>_path, class: "btn-float" do
|
84
|
+
+
|
85
|
+
|
86
|
+
:javascript
|
87
|
+
$(document).ready(function(){
|
88
|
+
$('#<%= singular_table_name %>').click(function() {
|
89
|
+
$('#upload_file_<%= singular_table_name %>').click()
|
90
|
+
$('#upload_file_<%= singular_table_name %>').change(function() {
|
91
|
+
$('.waiting').css('display', 'block')
|
92
|
+
$('#upload_form_<%= singular_table_name %>').submit()
|
93
|
+
})
|
94
|
+
});
|
95
|
+
|
96
|
+
renderImg();
|
97
|
+
});
|