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.
Files changed (236) hide show
  1. checksums.yaml +5 -5
  2. data/.gitignore +8 -0
  3. data/CODE_OF_CONDUCT.md +74 -0
  4. data/Gemfile.lock +26 -0
  5. data/LICENSE.txt +21 -0
  6. data/README.md +93 -22
  7. data/Rakefile +6 -0
  8. data/bin/keppler +6 -2
  9. data/bin/setup +2 -1
  10. data/exe/keppler +6 -0
  11. data/installer/core/.gitignore +87 -0
  12. data/installer/core/.ruby-version +1 -0
  13. data/installer/core/Gemfile +6 -4
  14. data/installer/core/README.md +86 -50
  15. data/installer/core/app/assets/images/.keep +0 -0
  16. data/installer/core/app/assets/images/admin/astronauta_keppler.svg +123 -0
  17. data/installer/core/app/assets/images/admin/avatar_keppler.svg +100 -0
  18. data/installer/core/app/assets/images/admin/image_default.png +0 -0
  19. data/installer/core/app/assets/images/app/fondo.svg +19 -0
  20. data/installer/core/app/assets/javascripts/admin/file_upload.coffee +11 -0
  21. data/installer/core/app/assets/javascripts/admin/main.coffee +23 -12
  22. data/installer/core/app/assets/javascripts/admin/preview_template.js +2 -2
  23. data/installer/core/app/assets/javascripts/admin/sidebar.js +8 -7
  24. data/installer/core/app/assets/javascripts/admin/swal.js +37 -0
  25. data/installer/core/app/assets/javascripts/admin/switch.js +6 -0
  26. data/installer/core/app/assets/javascripts/admin/tooltips.coffee +3 -0
  27. data/installer/core/app/assets/javascripts/errors/application.js.coffee +1 -0
  28. data/installer/core/app/assets/javascripts/errors/errors.js +113 -0
  29. data/installer/core/app/assets/javascripts/keppler_ga_dashboard/view-selector2.js +1 -1
  30. data/installer/core/app/assets/javascripts/vue_admin/index.js +34 -9
  31. data/installer/core/app/assets/stylesheets/admin/application.scss +4 -14
  32. data/installer/core/app/assets/stylesheets/admin/components/navigation/_navbar.scss +4 -5
  33. data/installer/core/app/assets/stylesheets/admin/components/navigation/_sidebar.scss +26 -17
  34. data/installer/core/app/assets/stylesheets/admin/pages/_appearance.scss +5 -0
  35. data/installer/core/app/assets/stylesheets/admin/pages/_customize.scss +21 -0
  36. data/installer/core/app/assets/stylesheets/admin/pages/_datepicker.scss +1088 -0
  37. data/installer/core/app/assets/stylesheets/admin/pages/_files.scss +26 -9
  38. data/installer/core/app/assets/stylesheets/admin/pages/_form.scss +19 -6
  39. data/installer/core/app/assets/stylesheets/admin/pages/_index.scss +4 -8
  40. data/installer/core/app/assets/stylesheets/admin/pages/_listing.scss +5 -0
  41. data/installer/core/app/assets/stylesheets/admin/pages/_navbar.scss +9 -2
  42. data/installer/core/app/assets/stylesheets/admin/pages/_roles.scss +6 -0
  43. data/installer/core/app/assets/stylesheets/admin/pages/_search.scss +24 -28
  44. data/installer/core/app/assets/stylesheets/admin/pages/_sidebar.scss +1 -1
  45. data/installer/core/app/assets/stylesheets/admin/pages/_switchs.scss +135 -39
  46. data/installer/core/app/assets/stylesheets/admin/pages/_timepicker.scss +16 -0
  47. data/installer/core/app/assets/stylesheets/admin/pages/_user.scss +6 -0
  48. data/installer/core/app/assets/stylesheets/admin/utils/_base.scss +6 -1
  49. data/installer/core/app/assets/stylesheets/admin/utils/_theme.scss +24 -11
  50. data/installer/core/app/assets/stylesheets/admin/utils/_variables.scss +1 -1
  51. data/installer/core/app/assets/stylesheets/app/pages/_front.sass +70 -56
  52. data/installer/core/app/assets/stylesheets/errors/errors.scss +161 -120
  53. data/installer/core/app/assets/stylesheets/vendor/admin-lte/_skin-blue.scss +1 -1
  54. data/installer/core/app/controllers/admin/admin_controller.rb +1 -1
  55. data/installer/core/app/controllers/admin/customizes_controller.rb +6 -8
  56. data/installer/core/app/controllers/admin/meta_tags_controller.rb +14 -18
  57. data/installer/core/app/controllers/admin/roles_controller.rb +176 -0
  58. data/installer/core/app/controllers/admin/scripts_controller.rb +14 -33
  59. data/installer/core/app/controllers/admin/settings_controller.rb +26 -27
  60. data/installer/core/app/controllers/admin/users_controller.rb +35 -29
  61. data/installer/core/app/controllers/app/app_controller.rb +27 -4
  62. data/installer/core/app/controllers/application_controller.rb +39 -1
  63. data/installer/core/app/controllers/concerns/.keep +0 -0
  64. data/installer/core/app/helpers/admin_helper.rb +5 -0
  65. data/installer/core/app/helpers/application_helper.rb +9 -0
  66. data/installer/core/app/helpers/roles_helper.rb +2 -0
  67. data/installer/core/app/inputs/file_material_input.rb +4 -2
  68. data/installer/core/app/inputs/keppler_boolean_input.rb +74 -0
  69. data/installer/core/app/inputs/keppler_file_input.rb +70 -0
  70. data/installer/core/app/mailers/.keep +0 -0
  71. data/installer/core/app/mailers/application_mailer.rb +13 -13
  72. data/installer/core/app/models/.keep +0 -0
  73. data/installer/core/app/models/appearance.rb +2 -0
  74. data/installer/core/app/models/application_record.rb +3 -0
  75. data/installer/core/app/models/concerns/.keep +0 -0
  76. data/installer/core/app/models/concerns/downloadable.rb +13 -0
  77. data/installer/core/app/models/concerns/sortable.rb +9 -0
  78. data/installer/core/app/models/concerns/uploadable.rb +10 -0
  79. data/installer/core/app/models/customize.rb +8 -6
  80. data/installer/core/app/models/front.rb +3 -0
  81. data/installer/core/app/models/google_analytics_setting.rb +2 -0
  82. data/installer/core/app/models/meta_tag.rb +27 -14
  83. data/installer/core/app/models/permission.rb +3 -0
  84. data/installer/core/app/models/role.rb +62 -5
  85. data/installer/core/app/models/script.rb +6 -15
  86. data/installer/core/app/models/setting.rb +2 -0
  87. data/installer/core/app/models/smtp_setting.rb +2 -0
  88. data/installer/core/app/models/social_account.rb +2 -0
  89. data/installer/core/app/models/user.rb +17 -1
  90. data/installer/core/app/policies/application_policy.rb +4 -4
  91. data/installer/core/app/policies/controller_policy.rb +15 -11
  92. data/installer/core/app/policies/role_policy.rb +25 -0
  93. data/installer/core/app/policies/user_policy.rb +1 -1
  94. data/installer/core/app/uploaders/attachment_uploader.rb +18 -1
  95. data/installer/core/app/views/admin/customizes/_description.html.haml +4 -4
  96. data/installer/core/app/views/admin/customizes/_form.html.haml +4 -4
  97. data/installer/core/app/views/admin/customizes/_listing.html.haml +1 -1
  98. data/installer/core/app/views/admin/customizes/_switch_default_template.html.haml +8 -13
  99. data/installer/core/app/views/admin/customizes/_switch_template.html.haml +8 -11
  100. data/installer/core/app/views/admin/customizes/index.html.haml +9 -9
  101. data/installer/core/app/views/admin/layouts/_head.html.haml +3 -3
  102. data/installer/core/app/views/admin/layouts/_keppler_boolean_script.haml +12 -0
  103. data/installer/core/app/views/admin/layouts/_navigation.html.haml +17 -16
  104. data/installer/core/app/views/admin/layouts/_sidebar.html.haml +27 -36
  105. data/installer/core/app/views/admin/layouts/application.html.haml +1 -0
  106. data/installer/core/app/views/admin/layouts/index/remote_messages.js.haml +6 -6
  107. data/installer/core/app/views/admin/meta_tags/_index_show.html.haml +2 -2
  108. data/installer/core/app/views/admin/meta_tags/_listing.html.haml +6 -6
  109. data/installer/core/app/views/admin/meta_tags/index.html.haml +15 -29
  110. data/installer/core/app/views/admin/meta_tags/show.html.haml +7 -8
  111. data/installer/core/app/views/admin/roles/_description.html.haml +13 -0
  112. data/installer/core/app/views/admin/roles/_form.html.haml +27 -0
  113. data/installer/core/app/views/admin/roles/_index_show.html.haml +24 -0
  114. data/installer/core/app/views/admin/roles/_listing.html.haml +46 -0
  115. data/installer/core/app/views/admin/roles/_switch.html.haml +20 -0
  116. data/installer/core/app/views/admin/roles/add_permissions.html.haml +60 -0
  117. data/installer/core/app/views/admin/roles/create_permissions.html.haml +0 -0
  118. data/installer/core/app/views/admin/roles/create_permissions.js.erb +1 -0
  119. data/installer/core/app/views/admin/roles/edit.html.haml +1 -0
  120. data/installer/core/app/views/admin/roles/index.html.haml +80 -0
  121. data/installer/core/app/views/admin/roles/new.html.haml +1 -0
  122. data/installer/core/app/views/admin/roles/reload.js.haml +5 -0
  123. data/installer/core/app/views/admin/roles/show.html.haml +32 -0
  124. data/installer/core/app/views/admin/roles/show.js.haml +4 -0
  125. data/installer/core/app/views/admin/roles/show_description.js.erb +2 -0
  126. data/installer/core/app/views/admin/scripts/_index_show.html.haml +2 -2
  127. data/installer/core/app/views/admin/scripts/_listing.html.haml +13 -13
  128. data/installer/core/app/views/admin/scripts/index.html.haml +12 -26
  129. data/installer/core/app/views/admin/scripts/show.html.haml +4 -4
  130. data/installer/core/app/views/admin/settings/components/_preview.html.haml +1 -1
  131. data/installer/core/app/views/admin/settings/fields/_appearance.html.haml +25 -17
  132. data/installer/core/app/views/admin/settings/fields/_basic_information.html.haml +13 -7
  133. data/installer/core/app/views/admin/settings/fields/_email_setting.html.haml +16 -16
  134. data/installer/core/app/views/admin/settings/fields/_google_analytics_setting.html.haml +1 -1
  135. data/installer/core/app/views/admin/settings/fields/_social_accounts.html.haml +39 -39
  136. data/installer/core/app/views/admin/users/_form.html.haml +18 -25
  137. data/installer/core/app/views/admin/users/_index_show.html.haml +2 -2
  138. data/installer/core/app/views/admin/users/_listing.html.haml +6 -6
  139. data/installer/core/app/views/admin/users/delete_avatar.js.haml +3 -0
  140. data/installer/core/app/views/admin/users/filter_by_role.js.erb +9 -0
  141. data/installer/core/app/views/admin/users/index.html.haml +22 -22
  142. data/installer/core/app/views/admin/users/show.html.haml +10 -12
  143. data/installer/core/app/views/app/front/index.html.haml +137 -87
  144. data/installer/core/app/views/app/layouts/_footer.html.haml +2 -2
  145. data/installer/core/app/views/app/layouts/_head.html.haml +4 -12
  146. data/installer/core/app/views/app/layouts/_meta_tags.html.haml +38 -6
  147. data/installer/core/app/views/app/layouts/application.html.haml +8 -8
  148. data/installer/core/app/views/devise/sessions/new.html.haml +32 -28
  149. data/installer/core/app/views/errors/internal_server_error.html.haml +50 -7
  150. data/installer/core/app/views/errors/not_authorized.html.haml +75 -6
  151. data/installer/core/app/views/errors/not_found.html.haml +101 -7
  152. data/installer/core/app/views/errors/unprocessable.html.haml +50 -7
  153. data/installer/core/bin/update +31 -0
  154. data/installer/core/bin/yarn +11 -0
  155. data/installer/core/config/application.rb +1 -1
  156. data/installer/core/config/environments/production.rb +1 -1
  157. data/installer/core/config/initializers/carrierwave.rb +12 -0
  158. data/installer/core/config/initializers/mime_types.rb +2 -2
  159. data/installer/core/config/initializers/simple_form_bootstrap.rb +20 -1
  160. data/installer/core/config/initializers/simple_form_components.rb +61 -0
  161. data/installer/core/config/locales/en.yml +29 -6
  162. data/installer/core/config/locales/es.yml +32 -5
  163. data/installer/core/config/locales/simple_form.en.yml +1 -0
  164. data/installer/core/config/locales/simple_form.es.yml +3 -2
  165. data/installer/core/config/menu.yml +34 -8
  166. data/installer/core/config/permissions.yml +21 -0
  167. data/installer/core/config/routes.rb +56 -14
  168. data/installer/core/db/migrate/20140812210925_rolify_create_roles.rb +2 -0
  169. data/installer/core/db/migrate/20160128131802_create_scripts.rb +1 -0
  170. data/installer/core/db/migrate/20180503174351_create_permissions.rb +11 -0
  171. data/installer/core/db/seeds.rb +12 -6
  172. data/installer/core/lib/generators/keppler_front/templates/views/template.html.haml +222 -177
  173. data/installer/core/lib/generators/keppler_relation/keppler_relation_generator.rb +1 -1
  174. data/installer/core/lib/generators/keppler_scaffold/keppler_scaffold_generator.rb +57 -40
  175. data/installer/core/lib/generators/keppler_scaffold/templates/controllers/controller.rb +29 -30
  176. data/installer/core/lib/generators/keppler_scaffold/templates/models/model.rb +14 -20
  177. data/installer/core/lib/generators/keppler_scaffold/templates/views/_form.html.haml +24 -35
  178. data/installer/core/lib/generators/keppler_scaffold/templates/views/_index_show.html.haml +12 -11
  179. data/installer/core/lib/generators/keppler_scaffold/templates/views/_listing.html.haml +7 -7
  180. data/installer/core/lib/generators/keppler_scaffold/templates/views/index.html.haml +17 -33
  181. data/installer/core/lib/generators/keppler_scaffold/templates/views/show.html.haml +23 -24
  182. data/installer/core/plugins/keppler_ga_dashboard/app/assets/images/keppler_ga_dashboard/.keep +0 -0
  183. data/installer/core/plugins/keppler_ga_dashboard/config/permissions.yml +4 -0
  184. data/installer/core/plugins/keppler_ga_dashboard/keppler_ga_dashboard.gemspec +1 -1
  185. data/installer/core/test/controllers/.keep +0 -0
  186. data/installer/core/test/controllers/roles_controller_test.rb +48 -0
  187. data/installer/core/test/fixtures/.keep +0 -0
  188. data/installer/core/test/fixtures/permissions.yml +9 -0
  189. data/installer/core/test/helpers/.keep +0 -0
  190. data/installer/core/test/integration/.keep +0 -0
  191. data/installer/core/test/mailers/.keep +0 -0
  192. data/installer/core/test/models/.keep +0 -0
  193. data/installer/core/test/models/permission_test.rb +7 -0
  194. data/installer/core/test/system/roles_test.rb +43 -0
  195. data/installer/core/vendor/assets/javascripts/.keep +0 -0
  196. data/installer/core/vendor/assets/stylesheets/.keep +0 -0
  197. data/installer/plugins/concerns/commons.rb +47 -0
  198. data/installer/plugins/concerns/destroy_multiple.rb +33 -0
  199. data/installer/plugins/concerns/history.rb +24 -0
  200. data/installer/plugins/config/locales/en.yml +104 -0
  201. data/installer/plugins/config/locales/es.yml +139 -0
  202. data/installer/plugins/config/menu.yml +12 -0
  203. data/installer/plugins/config/permissions.yml +1 -0
  204. data/installer/plugins/generators/keppler_scaffold/keppler_scaffold_generator.rb +203 -0
  205. data/installer/plugins/generators/keppler_scaffold/templates/controllers/controller.rb +171 -0
  206. data/installer/plugins/generators/keppler_scaffold/templates/models/model.rb +41 -0
  207. data/installer/plugins/generators/keppler_scaffold/templates/policies/policy.rb +11 -0
  208. data/installer/plugins/generators/keppler_scaffold/templates/views/_description.html.haml +13 -0
  209. data/installer/plugins/generators/keppler_scaffold/templates/views/_form.html.haml +49 -0
  210. data/installer/plugins/generators/keppler_scaffold/templates/views/_index_show.html.haml +26 -0
  211. data/installer/plugins/generators/keppler_scaffold/templates/views/_listing.html.haml +65 -0
  212. data/installer/plugins/generators/keppler_scaffold/templates/views/edit.html.haml +1 -0
  213. data/installer/plugins/generators/keppler_scaffold/templates/views/index.html.haml +97 -0
  214. data/installer/plugins/generators/keppler_scaffold/templates/views/new.html.haml +1 -0
  215. data/installer/plugins/generators/keppler_scaffold/templates/views/reload.js.haml +5 -0
  216. data/installer/plugins/generators/keppler_scaffold/templates/views/show.html.haml +66 -0
  217. data/installer/plugins/generators/keppler_scaffold/templates/views/show.js.haml +4 -0
  218. data/installer/plugins/install.rb +156 -0
  219. data/installer/plugins/layouts/_navigation.html.haml +47 -0
  220. data/installer/plugins/layouts/application.html.haml +24 -0
  221. data/keppler.gemspec +35 -0
  222. data/lib/keppler.rb +0 -1
  223. data/lib/keppler/add.rb +13 -0
  224. data/lib/keppler/cli.rb +134 -5
  225. data/lib/keppler/delete.rb +13 -0
  226. data/lib/keppler/version.rb +1 -1
  227. metadata +117 -23
  228. data/installer/core/app/assets/images/admin/space.png +0 -0
  229. data/installer/core/app/assets/stylesheets/admin/pages/_header.scss +0 -34
  230. data/installer/core/app/assets/stylesheets/admin/pages/_pageslide.scss +0 -125
  231. data/installer/core/db/schema.rb +0 -172
  232. data/installer/lib/conf.rb +0 -31
  233. data/installer/lib/scaffold.rb +0 -10
  234. data/installer/run.sh +0 -17
  235. data/installer/scripts/bin.sh +0 -61
  236. 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,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
+ });