adminterface 0.0.0 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (267) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.md +1 -1
  3. data/README.md +61 -0
  4. data/Rakefile +43 -0
  5. data/app/assets/config/adminterface_manifest.js +1 -0
  6. data/app/assets/stylesheets/adminterface/_base.scss +20 -0
  7. data/app/assets/stylesheets/adminterface/_print.scss +56 -0
  8. data/app/assets/stylesheets/adminterface/components/_active_admin_comment.scss +19 -0
  9. data/app/assets/stylesheets/adminterface/components/_all.scss +24 -0
  10. data/app/assets/stylesheets/adminterface/components/_aside.scss +28 -0
  11. data/app/assets/stylesheets/adminterface/components/_attributes_table.scss +19 -0
  12. data/app/assets/stylesheets/adminterface/components/_comments.scss +7 -0
  13. data/app/assets/stylesheets/adminterface/components/_divider.scss +28 -0
  14. data/app/assets/stylesheets/adminterface/components/_filters.scss +27 -0
  15. data/app/assets/stylesheets/adminterface/components/_flash.scss +4 -0
  16. data/app/assets/stylesheets/adminterface/components/_footer.scss +4 -0
  17. data/app/assets/stylesheets/adminterface/components/_form.scss +219 -0
  18. data/app/assets/stylesheets/adminterface/components/_header.scss +30 -0
  19. data/app/assets/stylesheets/adminterface/components/_index.scss +1 -0
  20. data/app/assets/stylesheets/adminterface/components/_index_as_grid.scss +5 -0
  21. data/app/assets/stylesheets/adminterface/components/_index_as_table.scss +1 -0
  22. data/app/assets/stylesheets/adminterface/components/_index_footer.scss +19 -0
  23. data/app/assets/stylesheets/adminterface/components/_modal_dialog.scss +4 -0
  24. data/app/assets/stylesheets/adminterface/components/_pagination.scss +3 -0
  25. data/app/assets/stylesheets/adminterface/components/_panel.scss +21 -0
  26. data/app/assets/stylesheets/adminterface/components/_sidebar.scss +13 -0
  27. data/app/assets/stylesheets/adminterface/components/_site_title.scss +17 -0
  28. data/app/assets/stylesheets/adminterface/components/_table_for.scss +37 -0
  29. data/app/assets/stylesheets/adminterface/components/_table_tools.scss +19 -0
  30. data/app/assets/stylesheets/adminterface/components/_thumbnail.scss +29 -0
  31. data/app/assets/stylesheets/adminterface/components/_title_bar.scss +36 -0
  32. data/app/assets/stylesheets/adminterface/components/inputs/_all.scss +2 -0
  33. data/app/assets/stylesheets/adminterface/components/inputs/_password.scss +28 -0
  34. data/app/assets/stylesheets/adminterface/components/inputs/_text.scss +30 -0
  35. data/app/assets/stylesheets/adminterface/helpers/_aa_icon.scss +1 -0
  36. data/app/assets/stylesheets/adminterface/helpers/_all.scss +2 -0
  37. data/app/assets/stylesheets/adminterface/helpers/_pointer.scss +1 -0
  38. data/app/assets/stylesheets/adminterface/layouts/_all.scss +4 -0
  39. data/app/assets/stylesheets/adminterface/layouts/_base.scss +5 -0
  40. data/app/assets/stylesheets/adminterface/layouts/_logged_in.scss +30 -0
  41. data/app/assets/stylesheets/adminterface/layouts/_logged_out.scss +14 -0
  42. data/app/assets/stylesheets/adminterface/layouts/types/_all.scss +4 -0
  43. data/app/assets/stylesheets/adminterface/layouts/types/_mixins.scss +195 -0
  44. data/app/assets/stylesheets/adminterface/layouts/types/_navigation_aside.scss +33 -0
  45. data/app/assets/stylesheets/adminterface/layouts/types/_navigation_sidebar.scss +15 -0
  46. data/app/assets/stylesheets/adminterface/layouts/types/_navigation_top.scss +33 -0
  47. data/app/assets/stylesheets/adminterface/mixins/_all.scss +3 -0
  48. data/app/assets/stylesheets/adminterface/mixins/_layouts.scss +38 -0
  49. data/app/assets/stylesheets/adminterface/mixins/_utilities.scss +39 -0
  50. data/app/assets/stylesheets/adminterface/mixins/_variables.scss +100 -0
  51. data/app/assets/stylesheets/adminterface/placeholders/_aa_icon.scss +10 -0
  52. data/app/assets/stylesheets/adminterface/placeholders/_all.scss +3 -0
  53. data/app/assets/stylesheets/adminterface/placeholders/_background.scss +5 -0
  54. data/app/assets/stylesheets/adminterface/placeholders/_typography.scss +11 -0
  55. data/app/assets/stylesheets/adminterface/vendors/_all.scss +4 -0
  56. data/app/assets/stylesheets/adminterface/vendors/bootstrap/_all.scss +6 -0
  57. data/app/assets/stylesheets/adminterface/vendors/bootstrap/_variables.scss +51 -0
  58. data/app/assets/stylesheets/adminterface/vendors/bootstrap/components/_buttons.scss +5 -0
  59. data/app/assets/stylesheets/adminterface/vendors/bootstrap/components/_dropdowns.scss +28 -0
  60. data/app/assets/stylesheets/adminterface/vendors/bootstrap/components/_navs.scss +25 -0
  61. data/app/assets/stylesheets/adminterface/vendors/bootstrap/components/form/_labels.scss +5 -0
  62. data/app/assets/stylesheets/adminterface/vendors/bootstrap/content/_tables.scss +2 -0
  63. data/app/assets/stylesheets/adminterface/vendors/bootstrap/content/_typography.scss +2 -0
  64. data/app/assets/stylesheets/adminterface/vendors/flatpickr/_all.scss +2 -0
  65. data/app/assets/stylesheets/adminterface/vendors/flatpickr/_variables.scss +7 -0
  66. data/app/assets/stylesheets/adminterface/vendors/flatpickr/main.scss +50 -0
  67. data/app/assets/stylesheets/adminterface/vendors/tom_select/_all.scss +1 -0
  68. data/app/assets/stylesheets/adminterface/vendors/tom_select/_main.scss +6 -0
  69. data/app/assets/stylesheets/adminterface/vendors/trix/_actiontext.scss +36 -0
  70. data/app/assets/stylesheets/adminterface/vendors/trix/_all.scss +3 -0
  71. data/app/assets/stylesheets/adminterface/vendors/trix/_trix_editor.scss +86 -0
  72. data/app/assets/stylesheets/adminterface/vendors/trix/_variables.scss +31 -0
  73. data/app/javascript/adminterface/base.js +14 -0
  74. data/app/javascript/adminterface/config.js +129 -0
  75. data/app/javascript/adminterface/initializers/batch_actions.js +9 -0
  76. data/app/javascript/adminterface/initializers/bootstrap.js +29 -0
  77. data/app/javascript/adminterface/initializers/confirm_dialog.js +23 -0
  78. data/app/javascript/adminterface/initializers/detached_dropdown.js +16 -0
  79. data/app/javascript/adminterface/initializers/drawer_menu_item_toggler.js +15 -0
  80. data/app/javascript/adminterface/initializers/filters.js +23 -0
  81. data/app/javascript/adminterface/initializers/has_many.js +7 -0
  82. data/app/javascript/adminterface/initializers/header_toggler.js +10 -0
  83. data/app/javascript/adminterface/initializers/index.js +2 -0
  84. data/app/javascript/adminterface/initializers/per_page.js +12 -0
  85. data/app/javascript/adminterface/initializers/plugins/flatpickr.js +24 -0
  86. data/app/javascript/adminterface/initializers/plugins/input_counter.js +21 -0
  87. data/app/javascript/adminterface/initializers/plugins/password_visibility.js +23 -0
  88. data/app/javascript/adminterface/initializers/plugins/tom_select.js +24 -0
  89. data/app/javascript/adminterface/lib/__tests__/detached_dropdown.spec.js +70 -0
  90. data/app/javascript/adminterface/lib/__tests__/filters.spec.js +151 -0
  91. data/app/javascript/adminterface/lib/__tests__/utils.spec.js +281 -0
  92. data/app/javascript/adminterface/lib/batch_actions.js +106 -0
  93. data/app/javascript/adminterface/lib/checkbox_toggler.js +55 -0
  94. data/app/javascript/adminterface/lib/confirm_dialog.js +113 -0
  95. data/app/javascript/adminterface/lib/detached_dropdown.js +34 -0
  96. data/app/javascript/adminterface/lib/filters.js +34 -0
  97. data/app/javascript/adminterface/lib/has_many.js +122 -0
  98. data/app/javascript/adminterface/lib/header_toggler.js +54 -0
  99. data/app/javascript/adminterface/lib/input.js +108 -0
  100. data/app/javascript/adminterface/lib/inputs/base/groupish.js +55 -0
  101. data/app/javascript/adminterface/lib/inputs/base/pluginish.js +63 -0
  102. data/app/javascript/adminterface/lib/inputs/base_input.js +87 -0
  103. data/app/javascript/adminterface/lib/inputs/boolean_input.js +30 -0
  104. data/app/javascript/adminterface/lib/inputs/check_boxes_input.js +14 -0
  105. data/app/javascript/adminterface/lib/inputs/choices_input.js +96 -0
  106. data/app/javascript/adminterface/lib/inputs/color_input.js +14 -0
  107. data/app/javascript/adminterface/lib/inputs/country_input.js +90 -0
  108. data/app/javascript/adminterface/lib/inputs/datalist_input.js +41 -0
  109. data/app/javascript/adminterface/lib/inputs/date_picker_input.js +11 -0
  110. data/app/javascript/adminterface/lib/inputs/datetime_picker_input.js +11 -0
  111. data/app/javascript/adminterface/lib/inputs/hidden_input.js +21 -0
  112. data/app/javascript/adminterface/lib/inputs/password_input.js +13 -0
  113. data/app/javascript/adminterface/lib/inputs/radio_input.js +13 -0
  114. data/app/javascript/adminterface/lib/inputs/select_input.js +68 -0
  115. data/app/javascript/adminterface/lib/inputs/string_input.js +13 -0
  116. data/app/javascript/adminterface/lib/inputs/switch_input.js +9 -0
  117. data/app/javascript/adminterface/lib/inputs/text_input.js +12 -0
  118. data/app/javascript/adminterface/lib/inputs/time_picker_input.js +13 -0
  119. data/app/javascript/adminterface/lib/inputs/time_zone_input.js +66 -0
  120. data/app/javascript/adminterface/lib/per_page.js +18 -0
  121. data/app/javascript/adminterface/lib/plugins/input_counter.js +94 -0
  122. data/app/javascript/adminterface/lib/plugins/password_visibility.js +70 -0
  123. data/app/javascript/adminterface/lib/table_checkbox_toggler.js +47 -0
  124. data/app/javascript/adminterface/lib/utils.js +148 -0
  125. data/app/views/active_admin/devise/confirmations/new.html.erb +19 -0
  126. data/app/views/active_admin/devise/passwords/edit.html.erb +21 -0
  127. data/app/views/active_admin/devise/passwords/new.html.erb +19 -0
  128. data/app/views/active_admin/devise/registrations/new.html.erb +24 -0
  129. data/app/views/active_admin/devise/sessions/new.html.erb +23 -0
  130. data/app/views/active_admin/devise/shared/_links.html.erb +25 -0
  131. data/app/views/active_admin/devise/shared/_omniauth.html.erb +10 -0
  132. data/app/views/active_admin/devise/unlocks/new.html.erb +19 -0
  133. data/app/views/kaminari/active_admin/_first_page.html.erb +11 -0
  134. data/app/views/kaminari/active_admin/_gap.html.erb +12 -0
  135. data/app/views/kaminari/active_admin/_last_page.html.erb +11 -0
  136. data/app/views/kaminari/active_admin/_next_page.html.erb +11 -0
  137. data/app/views/kaminari/active_admin/_page.html.erb +12 -0
  138. data/app/views/kaminari/active_admin/_paginator.html.erb +27 -0
  139. data/app/views/kaminari/active_admin/_prev_page.html.erb +11 -0
  140. data/app/views/layouts/active_admin_logged_out.html.erb +56 -0
  141. data/config/locales/active_admin.en.yml +25 -0
  142. data/lib/adminterface/callable.rb +7 -0
  143. data/lib/adminterface/configs.rb +76 -0
  144. data/lib/adminterface/data/base.rb +11 -0
  145. data/lib/adminterface/data/countries.rb +44 -0
  146. data/lib/adminterface/data/time_zones.rb +31 -0
  147. data/lib/adminterface/data.rb +6 -0
  148. data/lib/adminterface/encryption/encryptor.rb +26 -0
  149. data/lib/adminterface/engine.rb +22 -0
  150. data/lib/adminterface/extensions/base_controller.rb +55 -0
  151. data/lib/adminterface/extensions/batch_actions/resource_extension.rb +64 -0
  152. data/lib/adminterface/extensions/batch_actions/views/batch_action_selector.rb +48 -0
  153. data/lib/adminterface/extensions/batch_actions/views/selection_cells.rb +39 -0
  154. data/lib/adminterface/extensions/dsl.rb +13 -0
  155. data/lib/adminterface/extensions/dynamic_settings_node.rb +26 -0
  156. data/lib/adminterface/extensions/filters/forms.rb +76 -0
  157. data/lib/adminterface/extensions/form_builder.rb +165 -0
  158. data/lib/adminterface/extensions/inputs/base/active_admin_config.rb +21 -0
  159. data/lib/adminterface/extensions/inputs/base/choices.rb +33 -0
  160. data/lib/adminterface/extensions/inputs/base/groupish.rb +50 -0
  161. data/lib/adminterface/extensions/inputs/base/html.rb +15 -0
  162. data/lib/adminterface/extensions/inputs/base/labelling.rb +15 -0
  163. data/lib/adminterface/extensions/inputs/base/pluginish.rb +56 -0
  164. data/lib/adminterface/extensions/inputs/base/stringish.rb +19 -0
  165. data/lib/adminterface/extensions/inputs/base/wrapping.rb +25 -0
  166. data/lib/adminterface/extensions/inputs/base.rb +19 -0
  167. data/lib/adminterface/extensions/inputs/boolean_input.rb +42 -0
  168. data/lib/adminterface/extensions/inputs/check_boxes_input.rb +34 -0
  169. data/lib/adminterface/extensions/inputs/color_input.rb +29 -0
  170. data/lib/adminterface/extensions/inputs/country_input.rb +33 -0
  171. data/lib/adminterface/extensions/inputs/datalist_input.rb +26 -0
  172. data/lib/adminterface/extensions/inputs/date_picker_input.rb +30 -0
  173. data/lib/adminterface/extensions/inputs/date_select_input.rb +7 -0
  174. data/lib/adminterface/extensions/inputs/datetime_picker_input.rb +19 -0
  175. data/lib/adminterface/extensions/inputs/datetime_select_input.rb +7 -0
  176. data/lib/adminterface/extensions/inputs/email_input.rb +23 -0
  177. data/lib/adminterface/extensions/inputs/file_input.rb +19 -0
  178. data/lib/adminterface/extensions/inputs/filters/base/search_method_select.rb +37 -0
  179. data/lib/adminterface/extensions/inputs/filters/base.rb +3 -0
  180. data/lib/adminterface/extensions/inputs/filters/boolean_input.rb +4 -0
  181. data/lib/adminterface/extensions/inputs/filters/check_boxes_input.rb +12 -0
  182. data/lib/adminterface/extensions/inputs/filters/date_picker_input.rb +4 -0
  183. data/lib/adminterface/extensions/inputs/filters/date_range_input.rb +50 -0
  184. data/lib/adminterface/extensions/inputs/filters/select_input.rb +4 -0
  185. data/lib/adminterface/extensions/inputs/number_input.rb +23 -0
  186. data/lib/adminterface/extensions/inputs/password_input.rb +23 -0
  187. data/lib/adminterface/extensions/inputs/phone_input.rb +23 -0
  188. data/lib/adminterface/extensions/inputs/radio_input.rb +41 -0
  189. data/lib/adminterface/extensions/inputs/range_input.rb +22 -0
  190. data/lib/adminterface/extensions/inputs/rich_text_area_input.rb +21 -0
  191. data/lib/adminterface/extensions/inputs/search_input.rb +23 -0
  192. data/lib/adminterface/extensions/inputs/select_input.rb +33 -0
  193. data/lib/adminterface/extensions/inputs/string_input.rb +19 -0
  194. data/lib/adminterface/extensions/inputs/switch_input.rb +11 -0
  195. data/lib/adminterface/extensions/inputs/text_input.rb +27 -0
  196. data/lib/adminterface/extensions/inputs/time_picker_input.rb +19 -0
  197. data/lib/adminterface/extensions/inputs/time_select_input.rb +7 -0
  198. data/lib/adminterface/extensions/inputs/time_zone_input.rb +33 -0
  199. data/lib/adminterface/extensions/inputs/url_input.rb +23 -0
  200. data/lib/adminterface/extensions/menu_item.rb +16 -0
  201. data/lib/adminterface/extensions/namespace_settings.rb +30 -0
  202. data/lib/adminterface/extensions/orm/active_record/comments/views/active_admin_comments.rb +122 -0
  203. data/lib/adminterface/extensions/resource/action_items.rb +117 -0
  204. data/lib/adminterface/extensions/sidebar_section.rb +35 -0
  205. data/lib/adminterface/extensions/view_helpers/alert_helper.rb +36 -0
  206. data/lib/adminterface/extensions/view_helpers/component_helper.rb +23 -0
  207. data/lib/adminterface/extensions/views/action_items.rb +39 -0
  208. data/lib/adminterface/extensions/views/columns.rb +59 -0
  209. data/lib/adminterface/extensions/views/components/active_admin_form.rb +47 -0
  210. data/lib/adminterface/extensions/views/components/attributes_table.rb +28 -0
  211. data/lib/adminterface/extensions/views/components/blank_slate.rb +19 -0
  212. data/lib/adminterface/extensions/views/components/dropdown_menu.rb +55 -0
  213. data/lib/adminterface/extensions/views/components/icon.rb +26 -0
  214. data/lib/adminterface/extensions/views/components/index_list.rb +43 -0
  215. data/lib/adminterface/extensions/views/components/menu.rb +18 -0
  216. data/lib/adminterface/extensions/views/components/menu_item.rb +64 -0
  217. data/lib/adminterface/extensions/views/components/paginated_collection.rb +52 -0
  218. data/lib/adminterface/extensions/views/components/panel.rb +71 -0
  219. data/lib/adminterface/extensions/views/components/scopes.rb +53 -0
  220. data/lib/adminterface/extensions/views/components/sidebar_section.rb +39 -0
  221. data/lib/adminterface/extensions/views/components/site_title.rb +36 -0
  222. data/lib/adminterface/extensions/views/components/status_tag.rb +26 -0
  223. data/lib/adminterface/extensions/views/components/table_for.rb +23 -0
  224. data/lib/adminterface/extensions/views/components/tabs.rb +76 -0
  225. data/lib/adminterface/extensions/views/footer.rb +27 -0
  226. data/lib/adminterface/extensions/views/header.rb +59 -0
  227. data/lib/adminterface/extensions/views/index_as_grid.rb +53 -0
  228. data/lib/adminterface/extensions/views/index_as_table.rb +77 -0
  229. data/lib/adminterface/extensions/views/pages/base.rb +164 -0
  230. data/lib/adminterface/extensions/views/pages/form.rb +27 -0
  231. data/lib/adminterface/extensions/views/pages/index.rb +136 -0
  232. data/lib/adminterface/extensions/views/pages/page.rb +18 -0
  233. data/lib/adminterface/extensions/views/title_bar.rb +74 -0
  234. data/lib/adminterface/fixtures/components.yml +73 -0
  235. data/lib/adminterface/fixtures/css_classes.yml +107 -0
  236. data/lib/adminterface/initializers/batch_actions.rb +15 -0
  237. data/lib/adminterface/initializers/comments.rb +13 -0
  238. data/lib/adminterface/initializers/configurations.rb +38 -0
  239. data/lib/adminterface/initializers/formtastic.rb +58 -0
  240. data/lib/adminterface/initializers/resource.rb +20 -0
  241. data/lib/adminterface/initializers/view_helpers.rb +14 -0
  242. data/lib/adminterface/initializers/views.rb +39 -0
  243. data/lib/adminterface/license.rb +18 -0
  244. data/lib/adminterface/licensing/base.rb +99 -0
  245. data/lib/adminterface/licensing/commercial.rb +7 -0
  246. data/lib/adminterface/licensing/notice.rb +54 -0
  247. data/lib/adminterface/licensing/personal.rb +13 -0
  248. data/lib/adminterface/public.pem +9 -0
  249. data/lib/adminterface/version.rb +3 -0
  250. data/lib/adminterface.rb +55 -0
  251. data/lib/generators/adminterface/comments/comments_generator.rb +29 -0
  252. data/lib/generators/adminterface/comments/templates/README +13 -0
  253. data/lib/generators/adminterface/comments/templates/active_admin_comment_action_text.rb +18 -0
  254. data/lib/generators/adminterface/comments/templates/migrations/drop_body_for_active_admin_comments.rb.erb +28 -0
  255. data/lib/generators/adminterface/configs/configs_generator.rb +19 -0
  256. data/lib/generators/adminterface/configs/templates/README +33 -0
  257. data/lib/generators/adminterface/install/install_generator.rb +41 -0
  258. data/lib/generators/adminterface/install/templates/dashboard.rb +32 -0
  259. data/lib/generators/adminterface/views/views_generator.rb +15 -0
  260. data/lib/generators/adminterface/webpacker/templates/README +27 -0
  261. data/lib/generators/adminterface/webpacker/templates/active_admin.js +12 -0
  262. data/lib/generators/adminterface/webpacker/templates/active_admin.scss +8 -0
  263. data/lib/generators/adminterface/webpacker/templates/print.scss +3 -0
  264. data/lib/generators/adminterface/webpacker/webpacker_generator.rb +55 -0
  265. data/lib/tasks/adminterface_tasks.rake +4 -0
  266. metadata +285 -9
  267. data/lib/name.rb +0 -1
@@ -0,0 +1,100 @@
1
+ //***** Logged Out
2
+ $logged-out-bg: $light !default;
3
+ $logged-out-logo-height: 64px !default;
4
+
5
+ //***** Logged In
6
+ // Layout
7
+ $layout-navigation-top: () !default;
8
+ $layout-navigation-sidebar: () !default;
9
+ $layout-navigation-aside: () !default;
10
+
11
+ $layout-navigation-top: map-merge(
12
+ (
13
+ header: (
14
+ height: 64px,
15
+ z-index: $zindex-fixed
16
+ ),
17
+ title_bar: (
18
+ height: 54px,
19
+ z-index: $zindex-fixed - 1
20
+ )
21
+ ),
22
+ $layout-navigation-top
23
+ );
24
+
25
+ $layout-navigation-sidebar: map-merge(
26
+ (
27
+ "header": 280px,
28
+ "title_bar": 64px,
29
+ "breakpoint": lg,
30
+ "menu-item-active-bg": shade-color($primary, 20%)
31
+ ),
32
+ $layout-navigation-sidebar
33
+ );
34
+
35
+ $layout-navigation-aside: map-merge(
36
+ (
37
+ "header": 280px,
38
+ "title_bar": 64px,
39
+ "breakpoint": lg,
40
+ "menu-item-active-bg": shade-color($primary, 20%)
41
+ ),
42
+ $layout-navigation-aside
43
+ );
44
+
45
+ // Header
46
+ $header-icon-size: 18px !default;
47
+
48
+ // Site Title
49
+ $site-title-logo-height: 32px !default;
50
+
51
+ // Breadcrumb
52
+ $breadcrumb-item-max-width: 200px !default;
53
+
54
+ // Sidebar
55
+ $sidebar-breakpoint: lg !default;
56
+ $sidebar-left-width: 320px !default;
57
+ $sidebar-left-bg: $body-bg !default;
58
+ $sidebar-right-width: 320px !default;
59
+ $sidebar-right-bg: $body-bg !default;
60
+
61
+ // Aside
62
+ $aside-breakpoint: lg !default;
63
+ $aside-width: 320px !default;
64
+ $aside-box-shadow: 0 1px 1px $card-border-color, $box-shadow-sm !default;
65
+
66
+ // Attributes Table
67
+ $attribute-table-key-width: 30% !default;
68
+
69
+ // Form
70
+ $form-sortable-placeholder-bg: rgba($info, 0.12) !default;
71
+ $form-sortable-drag-bg: $white !default;
72
+ $form-sortable-placeholder-max-height: none !default;
73
+ $form-sortable-drag-max-height: 140px !default;
74
+
75
+ // Icon
76
+ $aa-icon-font-family: "bootstrap-icons" !default;
77
+ $aa-icon-size: 22px !default;
78
+ $aa-icons: (
79
+ "table-sorted-asc": "\f145",
80
+ "table-sorted-desc": "\f124",
81
+ "form-has-many-sortable-handle": "\f3fe",
82
+ "form-has-many-destroy": "\f62a",
83
+ "caret-dots": "\f5d4",
84
+ "visible": "\f33e",
85
+ "hidden": "\f33f",
86
+ ) !default;
87
+ $custom-icons: () !default;
88
+ $aa-icons: map-merge($aa-icons, $custom-icons);
89
+
90
+ // Thumbnails
91
+ $thumbnail-default-size: sm !default;
92
+ $thumbnail-sizes: (
93
+ "xs": 24px,
94
+ "sm": 32px,
95
+ "md": 64px,
96
+ "lg": 128px,
97
+ ) !default;
98
+
99
+ // Datepicker
100
+ $datepicker-option-today-bg: transparent !default;
@@ -0,0 +1,10 @@
1
+ %aa-icon {
2
+ font-family: $aa-icon-font-family;
3
+ font-size: $aa-icon-size;
4
+ font-style: normal;
5
+ font-weight: normal;
6
+ line-height: 1;
7
+ vertical-align: middle;
8
+
9
+ &::before { vertical-align: baseline; }
10
+ }
@@ -0,0 +1,3 @@
1
+ @import './aa_icon';
2
+ @import './background';
3
+ @import './typography';
@@ -0,0 +1,5 @@
1
+ %background-cover {
2
+ background-position: center;
3
+ background-repeat: no-repeat;
4
+ background-size: cover;
5
+ }
@@ -0,0 +1,11 @@
1
+ %text-truncate {
2
+ overflow: hidden;
3
+ text-overflow: ellipsis;
4
+ white-space: nowrap;
5
+ }
6
+
7
+ %list-unstyled {
8
+ padding: 0;
9
+ margin: 0;
10
+ list-style: none;
11
+ }
@@ -0,0 +1,4 @@
1
+ @import './bootstrap/all';
2
+ @import './flatpickr/all';
3
+ @import './tom_select/all';
4
+ @import './trix/all';
@@ -0,0 +1,6 @@
1
+ @import './components/buttons';
2
+ @import './components/dropdowns';
3
+ @import './components/form/labels';
4
+ @import './components/navs';
5
+ @import './content/tables';
6
+ @import './content/typography';
@@ -0,0 +1,51 @@
1
+ $white: #fff !default;
2
+ $gray-100: #f8f9fa !default;
3
+ $gray-200: #e9ecef !default;
4
+ $gray-300: #dee2e6 !default;
5
+ $gray-400: #ced4da !default;
6
+ $gray-500: #adb5bd !default;
7
+ $gray-600: #6c757d !default;
8
+ $gray-700: #495057 !default;
9
+ $gray-800: #343a40 !default;
10
+ $gray-900: #212529 !default;
11
+ $black: #000 !default;
12
+
13
+ $blue: #0d6efd !default;
14
+ $indigo: #6610f2 !default;
15
+ $purple: #6f42c1 !default;
16
+ $pink: #d63384 !default;
17
+ $red: #dc3545 !default;
18
+ $orange: #fd7e14 !default;
19
+ $yellow: #ffc107 !default;
20
+ $green: #198754 !default;
21
+ $teal: #20c997 !default;
22
+ $cyan: #0dcaf0 !default;
23
+
24
+ $primary: $blue !default;
25
+ $secondary: $gray-600 !default;
26
+ $success: $green !default;
27
+ $info: $blue !default;
28
+ $warning: $yellow !default;
29
+ $danger: $red !default;
30
+ $light: $gray-100 !default;
31
+ $dark: $gray-900 !default;
32
+
33
+ $link-color: $info !default;
34
+
35
+ $custom-colors: () !default;
36
+
37
+ $theme-colors: (
38
+ "primary": $primary,
39
+ "secondary": $secondary,
40
+ "success": $success,
41
+ "info": $info,
42
+ "warning": $warning,
43
+ "danger": $danger,
44
+ "light": $light,
45
+ "dark": $dark
46
+ ) !default;
47
+
48
+ $theme-colors: map-merge($theme-colors, $custom-colors);
49
+
50
+ $table-active-bg-factor: 0.1 !default;
51
+ $table-active-bg: rgba($primary, $table-active-bg-factor) !default;
@@ -0,0 +1,5 @@
1
+ // https://getbootstrap.com/docs/4.0/components/buttons/
2
+ .btn * {
3
+ display: inline-block;
4
+ vertical-align: middle;
5
+ }
@@ -0,0 +1,28 @@
1
+ .dropdown-toggle {
2
+ &::after { vertical-align: middle; }
3
+ &.no-caret::after { content: none; }
4
+
5
+ &.caret-dots::after {
6
+ @extend %aa-icon;
7
+
8
+ content: map-get($aa-icons, 'caret-dots');
9
+ border: 0;
10
+ }
11
+ }
12
+
13
+ .dropdown-item {
14
+ &:not(a) {
15
+ padding: 0;
16
+
17
+ & > a { padding: $dropdown-item-padding-y $dropdown-item-padding-x; }
18
+ }
19
+
20
+ a {
21
+ display: block;
22
+
23
+ &,
24
+ &:hover {
25
+ text-decoration: none;
26
+ }
27
+ }
28
+ }
@@ -0,0 +1,25 @@
1
+ .nav + .tab-content { margin-top: $spacer; }
2
+
3
+ .nav-tabs {
4
+ flex-wrap: nowrap;
5
+ white-space: nowrap;
6
+ overflow-x: auto;
7
+ overflow-y: hidden;
8
+ border-bottom: 0;
9
+ position: relative;
10
+
11
+ .nav-link {
12
+ position: relative;
13
+
14
+ & > * { vertical-align: middle; }
15
+ }
16
+
17
+ &::before {
18
+ content: "";
19
+ position: absolute;
20
+ left: 0;
21
+ right: 0;
22
+ bottom: 0;
23
+ border-bottom: $nav-tabs-border-width solid $nav-tabs-border-color;
24
+ }
25
+ }
@@ -0,0 +1,5 @@
1
+ .label-group {
2
+ display: flex;
3
+
4
+ label { flex: 1; }
5
+ }
@@ -0,0 +1,2 @@
1
+ // https://getbootstrap.com/docs/5.0/content/tables/
2
+ .table-responsive { overflow-y: hidden; }
@@ -0,0 +1,2 @@
1
+ // https://getbootstrap.com/docs/5.0/content/typography/
2
+ pre { white-space: normal !important; }
@@ -0,0 +1,2 @@
1
+ @import './variables';
2
+ @import './main';
@@ -0,0 +1,7 @@
1
+ $flatpickr-day-border-radius: $border-radius !default;
2
+ $flatpickr-day-bg: $gray-200 !default;
3
+ $flatpickr-day-hover-bg: $gray-200 !default;
4
+ $flatpickr-day-selected-bg: $component-active-bg !default;
5
+ $flatpickr-ctrl-bg: $gray-200 !default;
6
+ $flatpickr-ctrl-padding: 0.25rem !default;
7
+ $flatpickr-ctrl-hover-bg: $component-active-bg !default;
@@ -0,0 +1,50 @@
1
+ .flatpickr-calendar {
2
+ .flatpickr-day { border-radius: $flatpickr-day-border-radius; }
3
+
4
+ .flatpickr-months {
5
+ .flatpickr-prev-month,
6
+ .flatpickr-next-month {
7
+ padding: 5px 10px;
8
+
9
+ &:hover svg {
10
+ fill: $flatpickr-ctrl-hover-bg;
11
+ }
12
+ }
13
+ }
14
+
15
+ .flatpickr-current-month {
16
+ display: flex;
17
+ padding: $flatpickr-ctrl-padding;
18
+
19
+ .flatpickr-monthDropdown-months { margin-right: $flatpickr-ctrl-padding; }
20
+
21
+ .numInputWrapper {
22
+ display: flex;
23
+ align-items: center;
24
+ }
25
+
26
+ .numInputWrapper,
27
+ .flatpickr-monthDropdown-months {
28
+ flex: 1;
29
+ background: $flatpickr-ctrl-bg;
30
+ }
31
+ }
32
+
33
+ .flatpickr-day.selected {
34
+ background: $flatpickr-day-selected-bg;
35
+ border-color: $flatpickr-day-selected-bg;
36
+ color: color-contrast($flatpickr-day-selected-bg);
37
+ }
38
+
39
+ .flatpickr-day.today {
40
+ background: $flatpickr-day-bg;
41
+ border-color: $flatpickr-day-bg;
42
+ color: color-contrast($flatpickr-day-bg);
43
+ }
44
+
45
+ .flatpickr-day:hover {
46
+ background: $flatpickr-day-hover-bg;
47
+ border-color: $flatpickr-day-hover-bg;
48
+ color: color-contrast($flatpickr-day-hover-bg);
49
+ }
50
+ }
@@ -0,0 +1 @@
1
+ @import './main';
@@ -0,0 +1,6 @@
1
+ .input-group {
2
+ .ts-control:nth-child(2) {
3
+ border-top-left-radius: $input-border-radius !important;
4
+ border-bottom-left-radius: $input-border-radius !important;
5
+ }
6
+ }
@@ -0,0 +1,36 @@
1
+ //
2
+ // Provides a drop-in pointer for the default Trix stylesheet that will format the toolbar and
3
+ // the trix-editor content (whether displayed or under editing). Feel free to incorporate this
4
+ // inclusion directly in any other asset bundle and remove this file.
5
+ //
6
+ @import 'trix/dist/trix';
7
+
8
+ // We need to override trix.css’s image gallery styles to accommodate the
9
+ // <action-text-attachment> element we wrap around attachments. Otherwise,
10
+ // images in galleries will be squished by the max-width: 33%; rule.
11
+ .trix-content {
12
+ .attachment-gallery {
13
+ > action-text-attachment,
14
+ > .attachment {
15
+ flex: 1 0 33%;
16
+ padding: 0 0.5em;
17
+ max-width: 33%;
18
+ }
19
+
20
+ &.attachment-gallery--2,
21
+ &.attachment-gallery--4 {
22
+ > action-text-attachment,
23
+ > .attachment {
24
+ flex-basis: 50%;
25
+ max-width: 50%;
26
+ }
27
+ }
28
+ }
29
+
30
+ action-text-attachment {
31
+ .attachment {
32
+ padding: 0 !important;
33
+ max-width: 100% !important;
34
+ }
35
+ }
36
+ }
@@ -0,0 +1,3 @@
1
+ @import './variables';
2
+ @import './actiontext';
3
+ @import './trix_editor';
@@ -0,0 +1,86 @@
1
+ trix-editor {
2
+ background: $input-bg;
3
+ border: $input-border-width solid $input-border-color;
4
+ border-width: 0 0 $input-border-width;
5
+ &:empty:not(:focus)::before { color: $input-placeholder-color; }
6
+ }
7
+
8
+ trix-toolbar {
9
+ .trix-button-row {
10
+ flex-wrap: wrap !important;
11
+ justify-content: flex-start !important;
12
+ }
13
+
14
+ .trix-button-group {
15
+ margin-left: 0 !important;
16
+ background: $trix-toolbar-btn-group-bg;
17
+ border: 0;
18
+
19
+ &:not(:last-child) { margin-right: 1.5vw; }
20
+
21
+ .trix-button {
22
+ height: auto;
23
+ padding: $input-btn-padding-y-sm $input-btn-padding-x-sm;
24
+ color: color-contrast($trix-toolbar-btn-group-bg);
25
+ border-bottom: 0;
26
+ border: 0;
27
+
28
+ &:first-child { border-radius: $btn-border-radius 0 0 $btn-border-radius; }
29
+ &:last-child { border-radius: 0 $btn-border-radius $btn-border-radius 0; }
30
+
31
+ &.trix-active {
32
+ color: color-contrast($trix-toolbar-btn-active-bg);
33
+ background: $trix-toolbar-btn-active-bg;
34
+ }
35
+ }
36
+ }
37
+
38
+ .trix-button-group-spacer { display: none; }
39
+
40
+ .trix-input--dialog {
41
+ background-color: $trix-input-dialog-bg;
42
+ border: $trix-input-dialog-border;
43
+ border-radius: $trix-input-dialog-border-radius;
44
+
45
+ &.validate:invalid {
46
+ border-color: $trix-input-dialog-invalid-color;
47
+ box-shadow: none;
48
+ }
49
+ }
50
+
51
+ .trix-button--icon::before {
52
+ @extend %aa-icon;
53
+
54
+ top: 50%;
55
+ right: auto;
56
+ bottom: auto;
57
+ left: 50%;
58
+ font-size: $trix-icon-size;
59
+ text-indent: 0;
60
+ background-image: none;
61
+
62
+ @include transform(translate(-50%, -50%));
63
+ }
64
+
65
+ @each $_key, $_value in $trix-icons {
66
+ .trix-button--icon-#{$_key}::before { content: $_value; }
67
+ }
68
+ }
69
+
70
+ .trix-content {
71
+ img {
72
+ height: auto !important;
73
+ max-width: 100% !important;
74
+ }
75
+
76
+ blockquote { border-left-color: $trix-content-blockquote-bg; }
77
+
78
+ pre {
79
+ color: $trix-content-pre-color;
80
+ white-space: pre !important;
81
+ background: $trix-content-pre-bg;
82
+ }
83
+
84
+ .attachment__caption { color: $trix-content-attachment-caption-color; }
85
+ .attachment--file { border-color: $trix-content-attachment-border-color; }
86
+ }
@@ -0,0 +1,31 @@
1
+ $trix-toolbar-btn-group-bg: $gray-200 !default;
2
+ $trix-toolbar-btn-active-bg: $component-active-bg !default;
3
+
4
+ $trix-content-pre-bg: $gray-200 !default;
5
+ $trix-content-pre-color: inherit !default;
6
+ $trix-content-blockquote-bg: $gray-200 !default;
7
+ $trix-content-attachment-caption-color: $secondary !default;
8
+ $trix-content-attachment-border-color: $border-color !default;
9
+
10
+ $trix-input-dialog-bg: $modal-content-bg !default;
11
+ $trix-input-dialog-border: $modal-content-border-width solid $modal-content-border-color !default;
12
+ $trix-input-dialog-border-radius: $modal-content-border-radius !default;
13
+ $trix-input-dialog-invalid-color: $danger !default;
14
+
15
+ $trix-icon-size: 20px !default;
16
+ $trix-icons: (
17
+ 'attach': '\f4b3',
18
+ 'bold': '\f5f0',
19
+ 'bullet-list': '\f478',
20
+ 'code': '\f2c8',
21
+ 'decrease-nesting-level': '\f5c6',
22
+ 'heading-1': '\f3da',
23
+ 'increase-nesting-level': '\f5c5',
24
+ 'italic': '\f5f4',
25
+ 'link': '\f470',
26
+ 'number-list': '\f475',
27
+ 'quote': '\f190',
28
+ 'redo': '\f116',
29
+ 'strike': '\f5f5',
30
+ 'undo': '\f117',
31
+ ) !default;
@@ -0,0 +1,14 @@
1
+ import 'bootstrap'
2
+ import './config'
3
+ import './initializers'
4
+
5
+ export { default as InputCounter } from './lib/plugins/input_counter'
6
+ export { default as ConfirmDialog } from './lib/confirm_dialog'
7
+ export { default as DetachedDropdown } from './lib/detached_dropdown'
8
+ export { default as initBootstrap } from './initializers/bootstrap'
9
+ export { default as initDetachedDropdown } from './initializers/detached_dropdown'
10
+ export { default as initFlatpickr } from './initializers/plugins/flatpickr'
11
+ export { default as initInputCounter } from './initializers/plugins/input_counter'
12
+ export { default as initPasswordVisibility } from './initializers/plugins/password_visibility'
13
+ export { default as initTomSelect } from './initializers/plugins/tom_select'
14
+ export * from './lib/input'
@@ -0,0 +1,129 @@
1
+ /* global adminterface */
2
+ import { camalize, getObjectValue, setObjectValue } from './lib/utils'
3
+ import { inputMapping } from './lib/input'
4
+ import { v4 as uuidv4 } from 'uuid'
5
+
6
+ const info = {
7
+ title: 'ADMINTERFACE',
8
+ docURL: 'https://adminterface.io'
9
+ }
10
+
11
+ const admonitionStyles = {
12
+ heading: {
13
+ head: 'font-weight: bold; color: #3C324C; background: #9E82C8;',
14
+ body: 'color: white; background: #3C324C;'
15
+ },
16
+ success: {
17
+ head: 'font-weight: bold; color: #003100; background: #58B67E',
18
+ body: 'color: white; background: #003100'
19
+ },
20
+ danger: {
21
+ head: 'font-weight: bold; color: #4B1113; background: #E13238',
22
+ body: 'color: white; background: #4B1113'
23
+ }
24
+ }
25
+
26
+ const admonition = (text, type) => {
27
+ console.log(text, admonitionStyles[type].head, admonitionStyles[type].body, '')
28
+ }
29
+
30
+ const parseMeta = (name) => {
31
+ const meta = (document.querySelector(`#meta-tags-for-js meta[name="${name}"]`))
32
+
33
+ try {
34
+ return JSON.parse(meta.content)
35
+ } catch (_err) {
36
+ return {}
37
+ }
38
+ }
39
+
40
+ window.adminterface = {
41
+ _debug: false,
42
+ _observers: [],
43
+ _trackers: () => {
44
+ return [].slice.call(document.querySelectorAll('[data-observer-id]'))
45
+ },
46
+ meta: {
47
+ inputs: inputMapping
48
+ },
49
+ get observers () {
50
+ const results = {}
51
+
52
+ this._getPristineObservers().forEach(item => {
53
+ const currentData = getObjectValue(results, item.path) || []
54
+ const data = { observerId: item.observerId, data: item.data }
55
+ const newData = [...currentData, data]
56
+ setObjectValue(results, item.path, newData)
57
+ })
58
+
59
+ return results
60
+ },
61
+ get version () {
62
+ if (this._version) return this._version
63
+
64
+ const metaVersion = document.querySelector('meta[name="version"]')
65
+ this._version = (metaVersion || {}).content
66
+ return this._version
67
+ },
68
+ get debug () {
69
+ return this._debug
70
+ },
71
+ set debug (value) {
72
+ this._debug = !!value
73
+
74
+ if (this._debug) {
75
+ admonition(`%c ${info.title} %c DEBUGGER ON %c`, 'heading')
76
+ admonition("%c WARNING %c PLEASE ENSURE YOU DISABLE THE DEBUGGER IN PRODUCTION AS IT MIGHT IMPACT YOUR APP'S PERFORMANCE! %c", 'danger')
77
+ console.log('Adminterface will now track its JavaScript instances in the "adminterface.observers" object.')
78
+ } else {
79
+ admonition(`%c ${info.title} %c DEBUGGER OFF %c`, 'heading')
80
+ }
81
+
82
+ this.help()
83
+ },
84
+ help: function () {
85
+ console.log(`%cVERSION: %c${this.version}`, 'font-weight: bold;', '')
86
+ console.log(`%cDOCS: %c${info.docURL}`, 'font-weight: bold;', '')
87
+ console.log('%cCOMMANDS:', 'font-weight: bold;')
88
+ admonition('∟ %c %c adminterface.debug = true %c Turn on the debugger. ', 'success')
89
+ admonition('∟ %c %c adminterface.debug = false %c Turn off the debugger. ', 'success')
90
+ admonition('∟ %c %c adminterface.observers %c View Adminterface\'s JavaScript instances. ', 'success')
91
+ admonition('∟ %c %c adminterface.meta %c View configurations and data passed from the backend. ', 'success')
92
+ admonition('∟ %c %c adminterface.help() %c List available commands and properties. ', 'success')
93
+ admonition('∟ %c %c adminterface.clear() %c Clear the observer object. ', 'success')
94
+ },
95
+ clear: function () {
96
+ const trackers = this._trackers()
97
+ this._observers = []
98
+ trackers.forEach(item => item.removeAttribute('data-observer-id'))
99
+ console.log('observer cleared')
100
+ return true
101
+ },
102
+ addObserver: function (target, data, path) {
103
+ if (!this.debug) return
104
+
105
+ const id = uuidv4()
106
+ const observer = { id: id, path: path, data: data }
107
+ this._getPristineObservers()
108
+
109
+ if (target) target.setAttribute('data-observer-id', id)
110
+
111
+ this._observers = [...this._observers, observer]
112
+ return id
113
+ },
114
+ _getPristineObservers: function () {
115
+ const observers = this._observers || []
116
+ const ids = this._trackers().map(el => el.dataset.observerId)
117
+ this._observers = observers.filter(item => ids.includes(item.id))
118
+ return this._observers
119
+ },
120
+ _addMeta: function (name) {
121
+ const content = parseMeta(name)
122
+ this.meta = { ...this.meta, ...{ [camalize(name)]: content } }
123
+ }
124
+ }
125
+
126
+ document.addEventListener('DOMContentLoaded', () => {
127
+ const metaTags = ['components', 'translations', 'css_classes', 'countries', 'time_zones']
128
+ metaTags.forEach((name) => adminterface._addMeta(name))
129
+ })
@@ -0,0 +1,9 @@
1
+ import BatchActions from '../lib/batch_actions'
2
+
3
+ document.addEventListener('DOMContentLoaded', () => {
4
+ const el = document.getElementById('main')
5
+
6
+ /* eslint-disable no-new */
7
+ if (el) new BatchActions(el)
8
+ /* eslint-enable no-new */
9
+ })