binda 0.0.7 → 0.1.0

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 (301) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +850 -18
  3. data/Rakefile +1 -13
  4. data/app/assets/javascripts/binda/application.js +23 -0
  5. data/app/assets/javascripts/binda/components/bootstrap.js +9 -0
  6. data/app/assets/javascripts/binda/components/field_group_editor.js +18 -0
  7. data/app/assets/javascripts/binda/components/fileupload.js +182 -0
  8. data/app/assets/javascripts/binda/components/form_item.js +91 -23
  9. data/app/assets/javascripts/binda/components/form_item_choice.js +15 -8
  10. data/app/assets/javascripts/binda/components/form_item_editor.js +6 -6
  11. data/app/assets/javascripts/binda/components/form_item_image.js +23 -0
  12. data/app/assets/javascripts/binda/components/form_item_repeater.js +70 -23
  13. data/app/assets/javascripts/binda/components/login-shader.js +193 -0
  14. data/app/assets/javascripts/binda/components/login_form.js +116 -0
  15. data/app/assets/javascripts/binda/components/radio-toggle.js +18 -0
  16. data/app/assets/javascripts/binda/components/select2.js +22 -0
  17. data/app/assets/javascripts/binda/components/sortable.js +53 -8
  18. data/app/assets/javascripts/binda/dist/binda.bundle.js +914 -107
  19. data/app/assets/javascripts/binda/index.js +26 -3
  20. data/app/assets/stylesheets/binda/application.scss +6 -0
  21. data/app/assets/stylesheets/binda/components/assets_manager.scss +46 -36
  22. data/app/assets/stylesheets/binda/components/b-btn.scss +114 -0
  23. data/app/assets/stylesheets/binda/components/button.scss +4 -1
  24. data/app/assets/stylesheets/binda/components/fileupload.scss +134 -0
  25. data/app/assets/stylesheets/binda/components/form_item.scss +233 -168
  26. data/app/assets/stylesheets/binda/components/form_item_image.scss +0 -0
  27. data/app/assets/stylesheets/binda/components/form_item_video.scss +25 -0
  28. data/app/assets/stylesheets/binda/components/main_container.scss +3 -0
  29. data/app/assets/stylesheets/binda/components/main_content.scss +1 -2
  30. data/app/assets/stylesheets/binda/components/main_header.scss +21 -20
  31. data/app/assets/stylesheets/binda/components/main_sidebar.scss +121 -0
  32. data/app/assets/stylesheets/binda/components/main_table.scss +84 -28
  33. data/app/assets/stylesheets/binda/components/popup_warning.scss +71 -0
  34. data/app/assets/stylesheets/binda/components/select2.scss +126 -0
  35. data/app/assets/stylesheets/binda/components/sortable.scss +83 -56
  36. data/app/assets/stylesheets/binda/components/standard-form.scss +228 -0
  37. data/app/assets/stylesheets/binda/components/texts.scss +6 -0
  38. data/app/assets/stylesheets/binda/controllers/components_index.scss +3 -0
  39. data/app/assets/stylesheets/binda/controllers/users_sessions_new.scss +309 -0
  40. data/app/assets/stylesheets/binda/index.scss +16 -8
  41. data/app/assets/stylesheets/binda/settings/bootstrap_overrides.scss +0 -0
  42. data/app/assets/stylesheets/binda/settings/buttons.scss +36 -0
  43. data/app/assets/stylesheets/binda/settings/common.scss +36 -79
  44. data/app/assets/stylesheets/binda/settings/fonts.scss +88 -31
  45. data/app/assets/stylesheets/binda/settings/tiny_mce_overrides.scss +82 -0
  46. data/app/assets/stylesheets/binda/settings/variables.scss +36 -31
  47. data/app/controllers/binda/application_controller.rb +0 -2
  48. data/app/controllers/binda/assets_controller.rb +1 -1
  49. data/app/controllers/binda/boards_controller.rb +15 -4
  50. data/app/controllers/binda/components_controller.rb +30 -15
  51. data/app/controllers/binda/field_groups_controller.rb +19 -4
  52. data/app/controllers/binda/images_controller.rb +68 -0
  53. data/app/controllers/binda/repeaters_controller.rb +3 -12
  54. data/app/controllers/binda/structures_controller.rb +8 -1
  55. data/app/controllers/binda/videos_controller.rb +68 -0
  56. data/app/controllers/concerns/binda/fieldable_helpers.rb +113 -28
  57. data/app/controllers/concerns/binda/maintenance_helpers.rb +34 -0
  58. data/app/helpers/binda/components_helper.rb +26 -2
  59. data/app/helpers/binda/field_groups_helper.rb +16 -0
  60. data/app/helpers/binda/structures_helper.rb +6 -0
  61. data/app/models/binda/asset.rb +0 -4
  62. data/app/models/binda/b.rb +5 -0
  63. data/app/models/binda/board.rb +1 -18
  64. data/app/models/binda/choice.rb +48 -12
  65. data/app/models/binda/component.rb +20 -0
  66. data/app/models/binda/field_group.rb +2 -2
  67. data/app/models/binda/field_setting.rb +61 -28
  68. data/app/models/binda/gallery.rb +0 -2
  69. data/app/models/binda/image.rb +7 -0
  70. data/app/models/binda/relation.rb +79 -0
  71. data/app/models/binda/relation_link.rb +11 -0
  72. data/app/models/binda/repeater.rb +1 -1
  73. data/app/models/binda/selection.rb +0 -9
  74. data/app/models/binda/structure.rb +41 -39
  75. data/app/models/binda/video.rb +7 -0
  76. data/app/models/concerns/binda/default_helpers.rb +186 -0
  77. data/app/models/concerns/binda/fieldable_associations.rb +276 -30
  78. data/app/uploaders/binda/{asset → image}/image_uploader.rb +27 -9
  79. data/app/uploaders/binda/video/video_uploader.rb +51 -0
  80. data/app/views/binda/boards/edit.html.erb +6 -1
  81. data/app/views/binda/categories/_form.html.erb +41 -40
  82. data/app/views/binda/categories/edit.html.erb +1 -1
  83. data/app/views/binda/categories/index.html.erb +16 -13
  84. data/app/views/binda/components/edit.html.erb +6 -3
  85. data/app/views/binda/components/index.html.erb +69 -28
  86. data/app/views/binda/components/new.html.erb +1 -1
  87. data/app/views/binda/components/sort_index.html.erb +46 -0
  88. data/app/views/binda/field_groups/_form_body.html.erb +65 -44
  89. data/app/views/binda/field_groups/_form_item.html.erb +66 -23
  90. data/app/views/binda/field_groups/_form_item_choice.erb +34 -15
  91. data/app/views/binda/field_groups/_form_section.html.erb +6 -10
  92. data/app/views/binda/field_groups/_form_section_repeater.html.erb +3 -3
  93. data/app/views/binda/field_groups/edit.html.erb +1 -1
  94. data/app/views/binda/field_settings/_form_body.html.erb +5 -5
  95. data/app/views/binda/field_settings/edit.html.erb +1 -1
  96. data/app/views/binda/fieldable/_form_body.html.erb +93 -79
  97. data/app/views/binda/fieldable/_form_item_date.html.erb +14 -14
  98. data/app/views/binda/fieldable/_form_item_image.html.erb +35 -0
  99. data/app/views/binda/fieldable/_form_item_new_repeater.html.erb +12 -5
  100. data/app/views/binda/fieldable/_form_item_relation.html.erb +44 -0
  101. data/app/views/binda/fieldable/_form_item_repeater.html.erb +80 -58
  102. data/app/views/binda/fieldable/_form_item_selections.html.erb +109 -87
  103. data/app/views/binda/fieldable/_form_item_string.html.erb +19 -17
  104. data/app/views/binda/fieldable/_form_item_text.html.erb +19 -16
  105. data/app/views/binda/fieldable/_form_item_video.html.erb +32 -0
  106. data/app/views/binda/fieldable/_form_section.html.erb +27 -5
  107. data/app/views/binda/fieldable/_form_section_repeater.html.erb +30 -10
  108. data/app/views/binda/fieldable/_form_sidebar.html.erb +44 -20
  109. data/app/views/binda/manage/users/_form_body.html.erb +42 -37
  110. data/app/views/binda/manage/users/edit.html.erb +1 -1
  111. data/app/views/binda/manage/users/index.html.erb +21 -21
  112. data/app/views/binda/structures/_form_body.html.erb +54 -60
  113. data/app/views/binda/structures/_form_section.html.erb +32 -18
  114. data/app/views/binda/structures/_form_sidebar.html.erb +35 -0
  115. data/app/views/binda/structures/edit.html.erb +2 -2
  116. data/app/views/binda/structures/index.html.erb +21 -16
  117. data/app/views/binda/structures/sort_index.html.erb +36 -0
  118. data/app/views/{users → binda/users}/confirmations/new.html.erb +1 -1
  119. data/app/views/{users → binda/users}/mailer/confirmation_instructions.html.erb +0 -0
  120. data/app/views/{users → binda/users}/mailer/password_change.html.erb +0 -0
  121. data/app/views/{users → binda/users}/mailer/reset_password_instructions.html.erb +0 -0
  122. data/app/views/{users → binda/users}/mailer/unlock_instructions.html.erb +0 -0
  123. data/app/views/{users → binda/users}/passwords/edit.html.erb +1 -1
  124. data/app/views/{users → binda/users}/passwords/new.html.erb +1 -1
  125. data/app/views/{users → binda/users}/registrations/edit.html.erb +0 -0
  126. data/app/views/{users → binda/users}/registrations/new.html.erb +1 -1
  127. data/app/views/binda/users/sessions/_background.html.erb +139 -0
  128. data/app/views/binda/users/sessions/new.html.erb +62 -0
  129. data/app/views/{users → binda/users}/shared/_links.html.erb +3 -3
  130. data/app/views/{users → binda/users}/unlocks/new.html.erb +1 -1
  131. data/app/views/kaminari/_first_page.html.erb +11 -0
  132. data/app/views/kaminari/_gap.html.erb +8 -0
  133. data/app/views/kaminari/_last_page.html.erb +11 -0
  134. data/app/views/kaminari/_next_page.html.erb +11 -0
  135. data/app/views/kaminari/_page.html.erb +12 -0
  136. data/app/views/kaminari/_paginator.html.erb +19 -0
  137. data/app/views/kaminari/_prev_page.html.erb +11 -0
  138. data/app/views/layouts/binda/_flash.html.erb +1 -1
  139. data/app/views/layouts/binda/_header.html.erb +2 -6
  140. data/app/views/layouts/binda/_sidebar.html.erb +11 -4
  141. data/app/views/layouts/binda/application.html.erb +15 -7
  142. data/config/autoprefixer.yml +5 -0
  143. data/config/database.yml.travis +3 -0
  144. data/config/initializers/assets.rb +1 -0
  145. data/config/initializers/autoprefixer.yml +5 -0
  146. data/config/initializers/carrierwave.rb +32 -0
  147. data/config/initializers/devise.rb +14 -10
  148. data/config/initializers/devise_patch.rb +8 -8
  149. data/config/initializers/simple_form.rb +4 -0
  150. data/config/initializers/simple_form__fileupload.rb +121 -0
  151. data/config/initializers/{simple_form_bootstrap.rb → simple_form_custom.rb} +79 -50
  152. data/config/locales/en.yml +61 -3
  153. data/config/locales/it.yml +51 -0
  154. data/config/locales/simple_form.en.yml +3 -3
  155. data/config/routes.rb +41 -24
  156. data/db/migrate/1_create_binda_tables.rb +18 -7
  157. data/db/migrate/20171214140451_add_preview_mode.rb +5 -0
  158. data/lib/binda.rb +1 -1
  159. data/lib/binda/engine.rb +19 -23
  160. data/lib/binda/version.rb +2 -2
  161. data/lib/generators/binda/install/install_generator.rb +59 -54
  162. data/lib/generators/binda/install/templates/config/initializers/carrierwave.rb +11 -2
  163. data/lib/generators/binda/maintenance/USAGE +8 -0
  164. data/lib/generators/binda/maintenance/maintenance_generator.rb +50 -0
  165. data/lib/generators/binda/maintenance/templates/app/assets/javascripts/maintenance.js +0 -0
  166. data/lib/generators/binda/maintenance/templates/app/assets/stylesheets/maintenance.scss +0 -0
  167. data/lib/generators/binda/maintenance/templates/app/views/layouts/maintenance.html.erb +16 -0
  168. data/lib/generators/binda/maintenance/templates/config/initializers/maintenance.rb +1 -0
  169. data/lib/generators/binda/setup/setup_generator.rb +41 -30
  170. data/lib/tasks/add_default_helpers_class_task.rake +11 -0
  171. data/lib/tasks/add_video_feature_task.rake +15 -0
  172. data/lib/tasks/remove_orphan_fields_task.rake +16 -0
  173. data/lib/tasks/set_repeater_position_task.rake +13 -0
  174. data/lib/tasks/upgrade_to_v007_task.rake +72 -0
  175. data/lib/tasks/user_tasks.rake +14 -0
  176. data/vendor/assets/fonts/font-awesome/fa-brands-400.eot +0 -0
  177. data/vendor/assets/fonts/font-awesome/fa-brands-400.svg +978 -0
  178. data/vendor/assets/fonts/font-awesome/fa-brands-400.ttf +0 -0
  179. data/vendor/assets/fonts/font-awesome/fa-brands-400.woff +0 -0
  180. data/vendor/assets/fonts/font-awesome/fa-brands-400.woff2 +0 -0
  181. data/vendor/assets/fonts/font-awesome/fa-regular-400.eot +0 -0
  182. data/vendor/assets/fonts/font-awesome/fa-regular-400.svg +363 -0
  183. data/vendor/assets/fonts/font-awesome/fa-regular-400.ttf +0 -0
  184. data/vendor/assets/fonts/font-awesome/fa-regular-400.woff +0 -0
  185. data/vendor/assets/fonts/font-awesome/fa-regular-400.woff2 +0 -0
  186. data/vendor/assets/fonts/font-awesome/fa-solid-900.eot +0 -0
  187. data/vendor/assets/fonts/font-awesome/fa-solid-900.svg +1410 -0
  188. data/vendor/assets/fonts/font-awesome/fa-solid-900.ttf +0 -0
  189. data/vendor/assets/fonts/font-awesome/fa-solid-900.woff +0 -0
  190. data/vendor/assets/fonts/font-awesome/fa-solid-900.woff2 +0 -0
  191. data/vendor/assets/javascripts/GSAP/CSSPlugin.min.js +13 -0
  192. data/vendor/assets/javascripts/GSAP/EasePack.min.js +12 -0
  193. data/vendor/assets/javascripts/GSAP/ScrollToPlugin.min.js +12 -0
  194. data/vendor/assets/javascripts/GSAP/TweenLite.min.js +12 -0
  195. data/vendor/assets/javascripts/select2/i18n/af.js +3 -0
  196. data/vendor/assets/javascripts/select2/i18n/ar.js +3 -0
  197. data/vendor/assets/javascripts/select2/i18n/az.js +3 -0
  198. data/vendor/assets/javascripts/select2/i18n/bg.js +3 -0
  199. data/vendor/assets/javascripts/select2/i18n/bs.js +3 -0
  200. data/vendor/assets/javascripts/select2/i18n/ca.js +3 -0
  201. data/vendor/assets/javascripts/select2/i18n/cs.js +3 -0
  202. data/vendor/assets/javascripts/select2/i18n/da.js +3 -0
  203. data/vendor/assets/javascripts/select2/i18n/de.js +3 -0
  204. data/vendor/assets/javascripts/select2/i18n/dsb.js +3 -0
  205. data/vendor/assets/javascripts/select2/i18n/el.js +3 -0
  206. data/vendor/assets/javascripts/select2/i18n/en.js +3 -0
  207. data/vendor/assets/javascripts/select2/i18n/es.js +3 -0
  208. data/vendor/assets/javascripts/select2/i18n/et.js +3 -0
  209. data/vendor/assets/javascripts/select2/i18n/eu.js +3 -0
  210. data/vendor/assets/javascripts/select2/i18n/fa.js +3 -0
  211. data/vendor/assets/javascripts/select2/i18n/fi.js +3 -0
  212. data/vendor/assets/javascripts/select2/i18n/fr.js +3 -0
  213. data/vendor/assets/javascripts/select2/i18n/gl.js +3 -0
  214. data/vendor/assets/javascripts/select2/i18n/he.js +3 -0
  215. data/vendor/assets/javascripts/select2/i18n/hi.js +3 -0
  216. data/vendor/assets/javascripts/select2/i18n/hr.js +3 -0
  217. data/vendor/assets/javascripts/select2/i18n/hsb.js +3 -0
  218. data/vendor/assets/javascripts/select2/i18n/hu.js +3 -0
  219. data/vendor/assets/javascripts/select2/i18n/hy.js +3 -0
  220. data/vendor/assets/javascripts/select2/i18n/id.js +3 -0
  221. data/vendor/assets/javascripts/select2/i18n/is.js +3 -0
  222. data/vendor/assets/javascripts/select2/i18n/it.js +3 -0
  223. data/vendor/assets/javascripts/select2/i18n/ja.js +3 -0
  224. data/vendor/assets/javascripts/select2/i18n/km.js +3 -0
  225. data/vendor/assets/javascripts/select2/i18n/ko.js +3 -0
  226. data/vendor/assets/javascripts/select2/i18n/lt.js +3 -0
  227. data/vendor/assets/javascripts/select2/i18n/lv.js +3 -0
  228. data/vendor/assets/javascripts/select2/i18n/mk.js +3 -0
  229. data/vendor/assets/javascripts/select2/i18n/ms.js +3 -0
  230. data/vendor/assets/javascripts/select2/i18n/nb.js +3 -0
  231. data/vendor/assets/javascripts/select2/i18n/nl.js +3 -0
  232. data/vendor/assets/javascripts/select2/i18n/pl.js +3 -0
  233. data/vendor/assets/javascripts/select2/i18n/ps.js +3 -0
  234. data/vendor/assets/javascripts/select2/i18n/pt-BR.js +3 -0
  235. data/vendor/assets/javascripts/select2/i18n/pt.js +3 -0
  236. data/vendor/assets/javascripts/select2/i18n/ro.js +3 -0
  237. data/vendor/assets/javascripts/select2/i18n/ru.js +3 -0
  238. data/vendor/assets/javascripts/select2/i18n/sk.js +3 -0
  239. data/vendor/assets/javascripts/select2/i18n/sl.js +3 -0
  240. data/vendor/assets/javascripts/select2/i18n/sr-Cyrl.js +3 -0
  241. data/vendor/assets/javascripts/select2/i18n/sr.js +3 -0
  242. data/vendor/assets/javascripts/select2/i18n/sv.js +3 -0
  243. data/vendor/assets/javascripts/select2/i18n/th.js +3 -0
  244. data/vendor/assets/javascripts/select2/i18n/tr.js +3 -0
  245. data/vendor/assets/javascripts/select2/i18n/uk.js +3 -0
  246. data/vendor/assets/javascripts/select2/i18n/vi.js +3 -0
  247. data/vendor/assets/javascripts/select2/i18n/zh-CN.js +3 -0
  248. data/vendor/assets/javascripts/select2/i18n/zh-TW.js +3 -0
  249. data/vendor/assets/javascripts/select2/select2.full.min.js +1 -0
  250. data/vendor/assets/javascripts/select2/select2.min.js +1 -0
  251. data/vendor/assets/javascripts/tether.min.js +1 -0
  252. data/vendor/assets/stylesheets/{bootstrap-select.css → bootstrap/bootstrap-select.css} +0 -0
  253. data/vendor/assets/stylesheets/font-awesome/_animated.scss +6 -20
  254. data/vendor/assets/stylesheets/font-awesome/_bordered-pulled.scss +6 -11
  255. data/vendor/assets/stylesheets/font-awesome/_core.scss +11 -7
  256. data/vendor/assets/stylesheets/font-awesome/_fixed-width.scss +1 -1
  257. data/vendor/assets/stylesheets/font-awesome/_icons.scss +785 -787
  258. data/vendor/assets/stylesheets/font-awesome/_larger.scss +16 -6
  259. data/vendor/assets/stylesheets/font-awesome/_list.scss +7 -8
  260. data/vendor/assets/stylesheets/font-awesome/_mixins.scss +17 -20
  261. data/vendor/assets/stylesheets/font-awesome/_rotated-flipped.scss +9 -6
  262. data/vendor/assets/stylesheets/font-awesome/_screen-reader.scss +2 -2
  263. data/vendor/assets/stylesheets/font-awesome/_stacked.scss +19 -8
  264. data/vendor/assets/stylesheets/font-awesome/_variables.scss +795 -795
  265. data/vendor/assets/stylesheets/font-awesome/fa-brands.scss +21 -0
  266. data/vendor/assets/stylesheets/font-awesome/fa-regular.scss +22 -0
  267. data/vendor/assets/stylesheets/font-awesome/fa-solid.scss +23 -0
  268. data/vendor/assets/stylesheets/font-awesome/fontawesome.scss +20 -0
  269. data/vendor/assets/stylesheets/select2/select2.min.css +1 -0
  270. metadata +278 -125
  271. data/app/assets/javascripts/binda/components/form_item_asset.js +0 -25
  272. data/app/assets/stylesheets/binda/application.css +0 -6
  273. data/app/assets/stylesheets/binda/components/form_body.scss +0 -2
  274. data/app/assets/stylesheets/binda/components/form_item_asset.scss +0 -20
  275. data/app/assets/stylesheets/binda/components/form_section.scss +0 -40
  276. data/app/assets/stylesheets/binda/components/sidebar.scss +0 -131
  277. data/app/assets/stylesheets/binda/layout/components_index.scss +0 -9
  278. data/app/assets/stylesheets/binda/layout/dashboard.scss +0 -7
  279. data/app/assets/stylesheets/binda/layout/users_sign_in.scss +0 -29
  280. data/app/controllers/binda/bindings_controller.rb +0 -62
  281. data/app/controllers/concerns/binda/default_helpers.rb +0 -226
  282. data/app/helpers/binda/bindings_helper.rb +0 -4
  283. data/app/models/binda/binda.rb +0 -7
  284. data/app/models/binda/binding.rb +0 -24
  285. data/app/views/binda/bindings/_form.html.erb +0 -32
  286. data/app/views/binda/bindings/edit.html.erb +0 -6
  287. data/app/views/binda/bindings/index.html.erb +0 -31
  288. data/app/views/binda/bindings/new.html.erb +0 -5
  289. data/app/views/binda/bindings/show.html.erb +0 -19
  290. data/app/views/binda/field_groups/index.html.erb +0 -34
  291. data/app/views/binda/fieldable/_form_item_asset.html.erb +0 -20
  292. data/app/views/users/sessions/new.html.erb +0 -27
  293. data/lib/tasks/binda.rake +0 -79
  294. data/vendor/assets/fonts/font-awesome/FontAwesome.otf +0 -0
  295. data/vendor/assets/fonts/font-awesome/fontawesome-webfont.eot +0 -0
  296. data/vendor/assets/fonts/font-awesome/fontawesome-webfont.svg +0 -2671
  297. data/vendor/assets/fonts/font-awesome/fontawesome-webfont.ttf +0 -0
  298. data/vendor/assets/fonts/font-awesome/fontawesome-webfont.woff +0 -0
  299. data/vendor/assets/fonts/font-awesome/fontawesome-webfont.woff2 +0 -0
  300. data/vendor/assets/stylesheets/font-awesome/_path.scss +0 -15
  301. data/vendor/assets/stylesheets/font-awesome/font-awesome.scss +0 -18
@@ -4,17 +4,40 @@
4
4
 
5
5
  import { _FormItem } from './components/form_item'
6
6
  import { _FormItemRepeater } from './components/form_item_repeater'
7
- import { _FormItemAsset } from './components/form_item_asset'
7
+ import { _FormItemImage } from './components/form_item_image'
8
8
  import { _FormItemChoice } from './components/form_item_choice'
9
9
  import { _FormItemEditor } from './components/form_item_editor'
10
+ import { _FileUpload } from './components/fileupload'
11
+ import { _Shader } from './components/login-shader'
12
+ import { _LoginForm } from './components/login_form'
10
13
  import setupSortable from './components/sortable'
14
+ import setupFieldGroupEditor from './components/field_group_editor'
15
+ import setupBootstrap from './components/bootstrap'
16
+ import setupSelect2 from './components/select2'
17
+ import setupRadioToggle from './components/radio-toggle'
11
18
 
12
19
  $(document).ready( function()
13
20
  {
14
21
  if ( _FormItem.isSet() ) { _FormItem.setEvents() }
15
22
  if ( _FormItemRepeater.isSet() ) { _FormItemRepeater.setEvents() }
16
- if ( _FormItemAsset.isSet() ) { _FormItemAsset.setEvents() }
23
+ if ( _FormItemImage.isSet() ) { _FormItemImage.setEvents() }
17
24
  if ( _FormItemChoice.isSet() ) { _FormItemChoice.setEvents() }
18
25
  if ( _FormItemEditor.isSet() ) { _FormItemEditor.setEvents() }
26
+ if ( _FileUpload.isSet() ) { _FileUpload.setEvents() }
27
+ if ( _LoginForm.isSet() ) { _LoginForm.setEvents() }
28
+ if ( _Shader.isSet() )
29
+ {
30
+ _Shader.setup()
31
+ _Shader.start()
32
+ }
33
+ setupRadioToggle()
19
34
  setupSortable()
20
- })
35
+ setupFieldGroupEditor()
36
+ setupBootstrap()
37
+ setupSelect2()
38
+ })
39
+
40
+ // handle event
41
+ window.addEventListener("optimizedResize", function() {
42
+ if ( _Shader.isSet() ) { _Shader.resize() }
43
+ });
@@ -0,0 +1,6 @@
1
+ @import "bourbon";
2
+ @import "bootstrap/bootstrap";
3
+ @import "bootstrap/bootstrap-select";
4
+ @import "font-awesome/fontawesome";
5
+ @import "select2/select2.min";
6
+ @import "index";
@@ -1,46 +1,56 @@
1
- #assets-manager-index {
2
- display: none;
1
+ #assets-manager-index
2
+ {
3
+ display: none;
3
4
  }
4
5
 
5
- .assets-manager--list {
6
- list-style: none;
7
- width: 100%;
6
+ .assets-manager--list
7
+ {
8
+ width: 100%;
9
+ list-style: none;
8
10
  }
9
11
 
10
- .assets-manager--item {
11
- position: relative;
12
- display: inline-block;
13
- padding: $font-size-base / 2;
14
- margin-bottom: $font-size-base * 2;
15
- @extend .box-shadowed;
16
- transition: all 0.3s ease-in-out;
12
+ .assets-manager--item
13
+ {
14
+ position: relative;
15
+ display: inline-block;
16
+ margin-bottom: $font-size-base * 2;
17
+ padding: $font-size-base / 2;
18
+ transition: all .3s ease-in-out;
17
19
 
18
- &:hover {
19
- @extend .box-shadowed-up;
20
- }
20
+ @extend .box-shadowed;
21
+
22
+ &:hover
23
+ {
24
+ @extend .box-shadowed-up;
25
+ }
21
26
  }
22
27
 
23
- .assets-manager--image-buttons {
24
- position: absolute;
25
- top: 8px;
26
- right: 8px;
28
+ .assets-manager--image-buttons
29
+ {
30
+ position: absolute;
31
+ top: 8px;
32
+ right: 8px;
27
33
 
28
- a {
29
- display: block;
30
- padding: 3px;
31
- margin: 3px;
32
- background-color: #FFF;
33
- opacity: 0.7;
34
- transition: opacity 0.3s ease-in;
35
- }
36
- a:hover {
37
- opacity: 1;
38
- }
34
+ a
35
+ {
36
+ display: block;
37
+ margin: 3px;
38
+ padding: 3px;
39
+ transition: opacity .3s ease-in;
40
+ opacity: .7;
41
+ background-color: #fff;
42
+ }
43
+ a:hover
44
+ {
45
+ opacity: 1;
46
+ }
39
47
  }
40
48
 
41
- .assets-manager--selected {
42
- background-color: #AAA;
43
- img {
44
- opacity: 0.7;
45
- }
46
- }
49
+ .assets-manager--selected
50
+ {
51
+ background-color: #aaa;
52
+ img
53
+ {
54
+ opacity: .7;
55
+ }
56
+ }
@@ -0,0 +1,114 @@
1
+ .b-btn-primary
2
+ {
3
+ transition: background-color .3s ease-out;
4
+ color: $color-white;
5
+ border: 1px solid $color-gray-darker;
6
+ background-color: #333;
7
+ }
8
+
9
+ .b-btn-primary
10
+ {
11
+ &:hover
12
+ {
13
+ color: $color-white;
14
+ border: 1px solid $color-gray;
15
+ background-color: $color-gray;
16
+ }
17
+
18
+ &:focus
19
+ {
20
+ color: $color-white;
21
+ }
22
+ }
23
+
24
+ .b-btn-danger
25
+ {
26
+ transition: background-color .3s ease-out;
27
+ color: $color-white;
28
+ background-color: $color-danger;
29
+ }
30
+
31
+ .b-btn-danger
32
+ {
33
+ &:hover
34
+ {
35
+ color: $color-white;
36
+ background-color: darken($color-danger, 15%);
37
+ }
38
+
39
+ &:focus
40
+ {
41
+ color: $color-white;
42
+ }
43
+ }
44
+
45
+ .b-btn-outline-danger
46
+ {
47
+ transition: color .3s ease, background-color .3s ease;
48
+ color: $color-danger;
49
+ border: 1px solid $color-danger;
50
+ background-color: transparent;
51
+ }
52
+
53
+ .b-btn-outline-danger
54
+ {
55
+ &:hover
56
+ {
57
+ color: $color-white;
58
+ background-color: $color-danger;
59
+ }
60
+
61
+ &:focus
62
+ {
63
+ color: $color-white;
64
+ background-color: $color-danger;
65
+ }
66
+ }
67
+
68
+ .b-btn-alternative
69
+ {
70
+ transition: background-color .3s ease-out;
71
+ color: $text-color;
72
+ background-color: $color-white;
73
+ }
74
+
75
+ .b-btn-alternative
76
+ {
77
+ &:hover
78
+ {
79
+ color: $text-color;
80
+ background-color: $color-gray-light;
81
+ }
82
+ }
83
+
84
+ .b-btn
85
+ {
86
+ display: inline-block;
87
+ padding: 6px 12px;
88
+ cursor: pointer;
89
+ border-radius: 0;
90
+
91
+ i
92
+ {
93
+ padding-right: 6px;
94
+ }
95
+ }
96
+
97
+ .b-btn-settings
98
+ {
99
+ margin-bottom: 12px;
100
+ }
101
+
102
+ .b-btn-block
103
+ {
104
+ display: block;
105
+ float: left;
106
+ clear: left;
107
+
108
+ margin-left: 0px !important;
109
+ }
110
+
111
+ .b-btn--container {
112
+ margin-top: 32px;
113
+ margin-bottom: 40px;
114
+ }
@@ -1,7 +1,10 @@
1
+ // what is this?!
2
+
1
3
  .update-form--button {
2
4
  margin-bottom: 20px;
3
5
  }
4
6
 
5
7
  .custom-button--button {
6
8
  color: #337ab7;
7
- }
9
+ }
10
+
@@ -0,0 +1,134 @@
1
+ // see https://tympanus.net/codrops/2015/09/15/styling-customizing-file-inputs-smart-way/
2
+ .fileupload--preview
3
+ {
4
+ position: relative;
5
+ float: left;
6
+ width: 120px;
7
+ height: 120px;
8
+ margin-right: 16px;
9
+ transition: all .5s ease;
10
+ border: 1px solid $color-gray-lighter;
11
+ background-repeat: no-repeat;
12
+ background-position: left top;
13
+ background-size: contain;
14
+
15
+ p
16
+ {
17
+ position: absolute;
18
+ top: 50%;
19
+ left: 50%;
20
+ padding: 8px;
21
+ transform: translate(-50%, -50%);
22
+ text-align: center;
23
+ }
24
+
25
+ video {
26
+ display: none;
27
+ }
28
+ }
29
+
30
+ .fileupload--preview--uploaded
31
+ {
32
+ animation: fadePreview .6s ease-out;
33
+ border: 0;
34
+
35
+ p
36
+ {
37
+ display: none;
38
+ }
39
+
40
+ video {
41
+ display: block
42
+ }
43
+ }
44
+
45
+ @keyframes fadePreview
46
+ {
47
+ from
48
+ {
49
+ opacity: .01;
50
+ }
51
+ to
52
+ {
53
+ opacity: 1;
54
+ }
55
+ }
56
+
57
+ .fileupload--dashboard
58
+ {
59
+ float: left;
60
+
61
+ .control-label-wrap
62
+ {
63
+ float: left;
64
+ }
65
+ }
66
+
67
+ .fileupload input
68
+ {
69
+ position: absolute;
70
+ z-index: -1;
71
+ overflow: hidden;
72
+ width: 1px; // .1px didn't work so set minimum to 1px
73
+ height: 1px; // .1px didn't work so set minimum to 1px
74
+ opacity: 0;
75
+ }
76
+
77
+ .fileupload label.control-label
78
+ {
79
+ @extend .b-btn;
80
+ @extend .p;
81
+ font-weight: 300;
82
+ margin-right: 20px;
83
+ margin-bottom: 20px;
84
+ cursor: pointer; /* "hand" cursor */
85
+
86
+ *
87
+ {
88
+ pointer-events: none;
89
+ }
90
+
91
+ // &.control-label--focus {
92
+ // outline: 1px dotted #000;
93
+ // outline: -webkit-focus-ring-color auto 5px;
94
+ // }
95
+ }
96
+
97
+ // Override the real .from-group containing the input
98
+ .fileupload .form-group
99
+ {
100
+ padding: 0;
101
+ border: 0;
102
+ }
103
+
104
+ .fileupload--remove-image-btn
105
+ {
106
+ float: left;
107
+ transition: all .3s ease;
108
+ opacity: 1;
109
+ }
110
+
111
+ .fileupload--remove-image-btn--hidden
112
+ {
113
+ pointer-events: none;
114
+ opacity: 0;
115
+ }
116
+
117
+ .fileupload--details
118
+ {
119
+ float: left;
120
+ transition: opacity .3s ease-out;
121
+ opacity: 1;
122
+ }
123
+
124
+ .fileupload--details--hidden
125
+ {
126
+ pointer-events: none;
127
+ opacity: 0;
128
+ width: 0; // Odd but needed, otherwise it occupies few transparent pixels...
129
+ display: none;
130
+ }
131
+
132
+ .standard-form--video .fileupload--dimension {
133
+ display: none;
134
+ }
@@ -1,231 +1,296 @@
1
- .form-item {
2
- @extend .clearfix;
3
- display: block;
4
- margin-bottom: $font-size-base*1.5;
5
- border-bottom: 1px solid $gray-lighter;
6
- transition: all 0.3s linear;
7
- transform: scaleY(1);
8
-
9
- .form-group {
10
- margin-bottom: $font-size-base;
11
- }
1
+ .form-item
2
+ {
3
+ display: block;
4
+ transition: all .3s linear;
5
+ transform: scaleY(1);
6
+
7
+ @extend .clearfix;
8
+ // .form-group
9
+ // {
10
+ // margin-bottom: 20px;
11
+ // }
12
12
  }
13
13
 
14
+ .form-item
15
+ {
16
+ overflow-y: hidden;
17
+ transition: max-height .6s ease-out;
18
+ }
14
19
 
15
- .form-section--wide-container {
16
-
17
- .form-item {
18
- max-height: 2000px;
19
- overflow-y: hidden;
20
- transition: max-height 1s ease-out;
21
-
22
- h5 {
23
- width: 15%;
24
- float: left;
25
- }
26
-
27
- a {
28
- float: right;
29
- margin-top: $font-size-base/2;
30
- margin-left: $font-size-base/2;
31
- }
32
- }
33
-
34
- .form-item--half-size {
35
- position: relative;
36
- width: 46%;
37
- margin-right: 4%;
38
- float: left;
20
+ .form-item--half-size
21
+ {
22
+ position: relative;
23
+ float: left;
24
+ width: 50%;
39
25
 
40
- h5 {
41
- width: 100%;
42
- }
26
+ .form-group
27
+ {
28
+ border-top: none !important;
29
+ }
43
30
 
44
- .form-item--select-input {
45
- margin-left: 0;
46
- }
47
- }
31
+ }
48
32
 
49
- .form-item--full-size {
50
- position: relative;
51
- width: 96%;
52
- clear: both;
53
- }
33
+ .form-item--full-size
34
+ {
35
+ position: relative;
36
+ clear: both;
37
+ width: 100%;
38
+ }
54
39
 
55
- .form-item--new {
56
- position: absolute;
57
- top: 101%;
58
- max-height: 0;
59
- }
40
+ .form-item--main-actions
41
+ {
42
+ a
43
+ {
44
+ float: right;
45
+ margin-left: 8px;
46
+ }
47
+ }
60
48
 
61
- .form-group {
62
- margin-bottom: $font-size-base;
63
- }
49
+ .form-item--new
50
+ {
51
+ position: absolute;
52
+ top: 101%;
53
+ max-height: 0;
64
54
  }
65
55
 
66
- .form-item--select-input {
67
- display: inline-block;
68
- width: 240px;
69
- margin-left: 5%;
56
+ .form-item--select-input
57
+ {
58
+ display: inline-block;
59
+ width: 240px;
60
+ margin-left: 5%;
70
61
  }
71
62
 
72
- .form-item--textarea {
73
- display: inline-block;
74
- width: 70%;
75
- margin-left: 5%;
63
+ .form-item--textarea
64
+ {
65
+ display: inline-block;
66
+ width: 70%;
67
+ margin-left: 5%;
76
68
  }
77
69
 
78
- .form-item--category {
79
- padding-bottom: $font-size-base*1.5;
80
- margin-bottom: $font-size-base*1.5;
70
+ .form-item--category
71
+ {
72
+ margin-bottom: 20px;
73
+ padding-bottom: 20px;
81
74
 
82
- input[type=submit] {
83
- width: 20%;
84
- float: left;
85
- }
75
+ input[type=submit]
76
+ {
77
+ float: left;
78
+ width: 20%;
79
+ }
86
80
 
87
- .form-group {
88
- width: 70%;
89
- margin: 0;
90
- margin-right: 10%;
91
- float: left;
92
- }
81
+ .form-group
82
+ {
83
+ float: left;
84
+ width: 70%;
85
+ margin: 0;
86
+ margin-right: 10%;
87
+ }
93
88
  }
94
89
 
95
- .form-item--open-button,
96
- .form-item--close-button {
97
- cursor: pointer;
90
+ .form-item--toggle-button
91
+ {
92
+ cursor: pointer;
93
+ transition: transform .3s ease;
94
+ transform: rotate(0deg);
98
95
  }
99
96
 
100
- .form-item--open-button {
101
- display: none;
97
+ .form-item--toggle-button-closed
98
+ {
99
+ transform: rotate(180deg);
102
100
  }
103
101
 
104
- .form-item--editor {
105
- // max-height: is set via javascript in app/assets/javscripts/components/form_item_editor.js;
106
- overflow-y: hidden;
107
- transition: max-height 0.6s ease-out;
102
+ .form-item--editor
103
+ {
104
+ overflow-y: hidden;
105
+ // max-height: is set via javascript in app/assets/javscripts/components/form_item_editor.js;
106
+ // default is 0
107
+ max-height: 0;
108
+ transition: max-height .6s ease-out;
108
109
  }
109
110
 
110
- .form-item--editor-close {
111
- max-height: 0 !important;
111
+ .form-item--repeater
112
+ {
113
+ overflow-y: hidden;
114
+ // inherit transitions from sortable and add max-height
115
+ transition: box-shadow .3s ease, transform .3s ease, max-height .6s ease-out !important;
112
116
  }
113
117
 
114
- .form-item--label-on-top .form-group {
118
+ .standard-form--container .form-item--repeater .control-label
119
+ {
120
+ @extend .p;
115
121
  }
116
122
 
117
- .form-item--label-on-left .form-group {
118
- display: inline-block;
119
- width: 70%;
120
- margin-left: 5%;
123
+ .form-item--repeater-fields
124
+ {
125
+ overflow-y: hidden;
126
+ transition: all .6s ease;
121
127
  }
122
128
 
123
- .form-item--repeater-fields {
124
- padding-left: $font-size-base/2;
125
- margin-bottom: $font-size-base;
126
- border-bottom: 1px solid $gray-lighter;
127
- border-left: 2px solid $gray-lighter;
129
+ .font-item--collapsed .form-item--repeater-fields
130
+ {
131
+ margin-bottom: 8px;
128
132
  }
129
133
 
130
- .form-item--repeater-section {
131
- border: none;
132
- margin-bottom: 0;
134
+ .form-item--repeater-section
135
+ {
136
+ overflow-x: hidden; // This ensure that the div doesn't become wider when draggin sortable items to the right
137
+ margin-bottom: 0;
133
138
 
134
- > *,
135
- ul.sortable li > * {
136
- display: block;
137
- background-color: $body-bg;
138
- }
139
+ ul.sortable > li
140
+ {
141
+ margin-top: -1px; // this solve the issue of a 2px border between 2 repeaters
142
+ border: 1px solid $color-gray-darker;
143
+ }
139
144
 
140
- ul.sortable--disabled li {
141
- cursor: default;
145
+ ul.sortable > li > *
146
+ {
147
+ display: block;
142
148
  }
143
149
 
144
- ul.sortable {
145
- margin-bottom: $font-size-base/2;
150
+ ul.sortable
151
+ {
152
+ margin-bottom: 0px;
153
+ }
154
+
155
+ .sortable--toggle-text:first-child
156
+ {
157
+ display: none;
158
+ }
146
159
 
147
- li {
148
- border-bottom: none;
149
- padding-bottom: 0;
150
- }
160
+ .sortable--toggle
161
+ {
162
+ float: right;
163
+ margin: 0;
151
164
  }
152
-
153
- .sortable--toggle {
154
- margin-top: 0;
165
+
166
+ .sortable--enabled
167
+ {
168
+ .form-item--repeater-fields
169
+ {
170
+ margin: 0;
171
+ padding: 0;
172
+ }
155
173
  }
156
174
 
157
- .sortable--toggle-text:first-child {
158
- display: none;
175
+ .form-item--new
176
+ {
177
+ position: absolute;
178
+ top: 101%;
179
+ max-height: 0;
159
180
  }
181
+ }
160
182
 
161
- h5 {
162
- width: 15%;
163
- float: left;
164
- }
183
+ .form-item--repeater-section--add-new
184
+ {
185
+ float: right;
186
+ margin-right: 8px;
187
+ }
165
188
 
166
- h5.form-item--repeater-title {
167
- width: 100%;
168
- padding: $font-size-base / 2;
169
- margin-bottom: $font-size-base / 2;
170
- background-color: $gray-lighter;
171
- font-weight: normal;
172
- float: none;
173
- }
189
+ .form-item--repeater-title
190
+ {
191
+ display: block;
192
+ margin-bottom: 20px;
193
+ }
174
194
 
175
- a {
176
- float: right;
177
- margin-top: $font-size-base/2;
178
- margin-left: $font-size-base/2;
179
- }
195
+ .form-item--repeater-header
196
+ {
197
+ padding: 4px 0;
198
+ background-color: $color-white !important;
199
+
200
+ p
201
+ {
202
+ margin-top: 8px;
203
+ margin-left: 8px;
204
+ }
205
+ }
206
+ .form-item--collapse-btn,
207
+ .form-item--delete-repeater-item
208
+ {
209
+ float: right;
210
+ margin-top: 8px;
211
+ margin-right: 8px;
212
+ }
213
+
214
+ a.form-item--delete-repeater-item
215
+ {
216
+ transition: color .2s ease;
217
+ color: $color-danger;
218
+ &:hover
219
+ {
220
+ color: $color-danger-hover;
221
+ }
222
+ }
180
223
 
181
- .form-item--new {
182
- position: absolute;
183
- top: 101%;
184
- max-height: 0;
185
- }
224
+ .form-item--collapse-btn
225
+ {
226
+ span:first-child
227
+ {
228
+ display: block;
229
+ }
230
+ span:last-child
231
+ {
232
+ display: none;
233
+ }
234
+ }
186
235
 
187
- .form-group {
188
- margin-bottom: $font-size-base;
189
- }
236
+ .form-item--collapsed .form-item--collapse-btn
237
+ {
238
+ span:first-child
239
+ {
240
+ display: none;
241
+ }
242
+ span:last-child
243
+ {
244
+ display: block;
245
+ }
190
246
  }
191
247
 
192
- .form-item--choices {
193
- position: relative;
248
+ .form-item--choices
249
+ {
250
+ position: relative;
194
251
  }
195
252
 
196
- .form-item--editor .form-item--choice {
197
- position: relative;
198
- clear: left;
253
+ .form-item--editor .form-item--choice
254
+ {
255
+ position: relative;
256
+ clear: left;
257
+
199
258
 
200
- &:last-child {
201
- padding-bottom: $font-size-base/2;
202
- border-bottom: 1px solid $gray-lighter;
203
- margin-bottom: $font-size-base;
204
- }
259
+ &:last-child
260
+ {
261
+ margin-bottom: $font-size-base;
262
+ padding-bottom: $font-size-base/2;
263
+ border-bottom: 1px solid $color-gray-lightest;
264
+ }
205
265
  }
206
266
 
207
- .form-item--new-choice {
208
- display: none;
267
+ .form-item--new-choice
268
+ {
269
+ display: none;
209
270
  }
210
271
 
211
272
  .form-item--choice-label,
212
- .form-item--choice-content {
213
- @extend .form-item--half-size;
273
+ .form-item--choice-value
274
+ {
275
+ @extend .form-item--half-size;
214
276
  }
215
277
 
216
278
  .form-item--delete-choice,
217
- .form-item--js-delete-choice {
218
- position: absolute;
219
- top: 32px;
220
- right: 0;
279
+ .form-item--js-delete-choice
280
+ {
281
+ position: absolute;
282
+ top: 32px;
283
+ right: 0;
221
284
  }
222
285
 
223
- .form-item--add-choice {
224
- position: absolute;
225
- top: 0;
226
- right: 0;
286
+ .form-item--add-choice
287
+ {
288
+ position: absolute;
289
+ top: 0;
290
+ right: 0;
227
291
  }
228
292
 
229
- .form-item--new-choice .form-item--delete-choice {
230
- display: none;
231
- }
293
+ .form-item--new-choice .form-item--delete-choice
294
+ {
295
+ display: none;
296
+ }