tao_form 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (208) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +20 -0
  3. data/README.md +28 -0
  4. data/Rakefile +10 -0
  5. data/lib/assets/icons/arrow-down.svg +12 -0
  6. data/lib/assets/icons/arrow-left.svg +12 -0
  7. data/lib/assets/icons/arrow-right.svg +12 -0
  8. data/lib/assets/icons/calendar.svg +12 -0
  9. data/lib/assets/icons/checkbox.svg +12 -0
  10. data/lib/assets/icons/clock.svg +12 -0
  11. data/lib/assets/icons/search.svg +12 -0
  12. data/lib/assets/icons/success.svg +12 -0
  13. data/lib/assets/javascripts/tao/form/element.coffee +16 -0
  14. data/lib/assets/javascripts/tao/form/fields/checkbox.coffee +14 -0
  15. data/lib/assets/javascripts/tao/form/fields/index.coffee +9 -0
  16. data/lib/assets/javascripts/tao/form/fields/moment_picker/element.coffee +38 -0
  17. data/lib/assets/javascripts/tao/form/fields/moment_picker/index.coffee +7 -0
  18. data/lib/assets/javascripts/tao/form/fields/moment_picker/result.coffee +25 -0
  19. data/lib/assets/javascripts/tao/form/fields/moment_picker/segment_list.coffee +14 -0
  20. data/lib/assets/javascripts/tao/form/fields/radio.coffee +14 -0
  21. data/lib/assets/javascripts/tao/form/fields/select/element.coffee +79 -0
  22. data/lib/assets/javascripts/tao/form/fields/select/index.coffee +8 -0
  23. data/lib/assets/javascripts/tao/form/fields/select/list.coffee +98 -0
  24. data/lib/assets/javascripts/tao/form/fields/select/multiple_result.coffee +41 -0
  25. data/lib/assets/javascripts/tao/form/fields/select/result.coffee +39 -0
  26. data/lib/assets/javascripts/tao/form/fields/switch.coffee +14 -0
  27. data/lib/assets/javascripts/tao/form/index.coffee +17 -0
  28. data/lib/assets/javascripts/tao/form/mobile/element.coffee +5 -0
  29. data/lib/assets/javascripts/tao/form/mobile/fields/checkbox.coffee +5 -0
  30. data/lib/assets/javascripts/tao/form/mobile/fields/index.coffee +9 -0
  31. data/lib/assets/javascripts/tao/form/mobile/fields/moment_picker/element.coffee +36 -0
  32. data/lib/assets/javascripts/tao/form/mobile/fields/moment_picker/index.coffee +7 -0
  33. data/lib/assets/javascripts/tao/form/mobile/fields/moment_picker/result.coffee +5 -0
  34. data/lib/assets/javascripts/tao/form/mobile/fields/moment_picker/segment_list.coffee +24 -0
  35. data/lib/assets/javascripts/tao/form/mobile/fields/radio.coffee +5 -0
  36. data/lib/assets/javascripts/tao/form/mobile/fields/select/element.coffee +61 -0
  37. data/lib/assets/javascripts/tao/form/mobile/fields/select/index.coffee +8 -0
  38. data/lib/assets/javascripts/tao/form/mobile/fields/select/list.coffee +13 -0
  39. data/lib/assets/javascripts/tao/form/mobile/fields/select/multiple_result.coffee +5 -0
  40. data/lib/assets/javascripts/tao/form/mobile/fields/select/result.coffee +5 -0
  41. data/lib/assets/javascripts/tao/form/mobile/fields/switch.coffee +5 -0
  42. data/lib/assets/javascripts/tao/form/mobile/index.coffee +10 -0
  43. data/lib/assets/javascripts/tao/form/shared/element/base.coffee +48 -0
  44. data/lib/assets/javascripts/tao/form/shared/fields/checkbox.coffee +21 -0
  45. data/lib/assets/javascripts/tao/form/shared/fields/date_picker.coffee +10 -0
  46. data/lib/assets/javascripts/tao/form/shared/fields/datetime_picker.coffee +62 -0
  47. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/element/base.coffee +52 -0
  48. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/result/base.coffee +39 -0
  49. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segment_list/base.coffee +85 -0
  50. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/base.coffee +25 -0
  51. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/date_segment.coffee +95 -0
  52. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/hour_segment.coffee +28 -0
  53. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/index.coffee +1 -0
  54. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/minute_segment.coffee +28 -0
  55. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/month_segment.coffee +46 -0
  56. data/lib/assets/javascripts/tao/form/shared/fields/moment_picker/segments/year_segment.coffee +57 -0
  57. data/lib/assets/javascripts/tao/form/shared/fields/month_picker.coffee +10 -0
  58. data/lib/assets/javascripts/tao/form/shared/fields/radio.coffee +19 -0
  59. data/lib/assets/javascripts/tao/form/shared/fields/select/element/base.coffee +122 -0
  60. data/lib/assets/javascripts/tao/form/shared/fields/select/list/base.coffee +79 -0
  61. data/lib/assets/javascripts/tao/form/shared/fields/select/models/data_provider.coffee +75 -0
  62. data/lib/assets/javascripts/tao/form/shared/fields/select/models/index.coffee +2 -0
  63. data/lib/assets/javascripts/tao/form/shared/fields/select/models/option.coffee +37 -0
  64. data/lib/assets/javascripts/tao/form/shared/fields/select/multiple_result/base.coffee +81 -0
  65. data/lib/assets/javascripts/tao/form/shared/fields/select/result/base.coffee +57 -0
  66. data/lib/assets/javascripts/tao/form/shared/fields/switch.coffee +19 -0
  67. data/lib/assets/javascripts/tao/form/shared/fields/time_picker.coffee +10 -0
  68. data/lib/assets/javascripts/tao/form/shared/mixins/checkable.coffee +11 -0
  69. data/lib/assets/javascripts/tao/ui/icons/form.coffee +11 -0
  70. data/lib/assets/stylesheets/tao/form/_globals.scss +3 -0
  71. data/lib/assets/stylesheets/tao/form/_mixins.scss +28 -0
  72. data/lib/assets/stylesheets/tao/form/_variables.scss +3 -0
  73. data/lib/assets/stylesheets/tao/form/fields/checkbox.scss +36 -0
  74. data/lib/assets/stylesheets/tao/form/fields/datetime_picker.scss +22 -0
  75. data/lib/assets/stylesheets/tao/form/fields/index.scss +6 -0
  76. data/lib/assets/stylesheets/tao/form/fields/moment_picker/index.scss +10 -0
  77. data/lib/assets/stylesheets/tao/form/fields/moment_picker/result.scss +61 -0
  78. data/lib/assets/stylesheets/tao/form/fields/moment_picker/segment_list.scss +53 -0
  79. data/lib/assets/stylesheets/tao/form/fields/moment_picker/segments/date_segment.scss +17 -0
  80. data/lib/assets/stylesheets/tao/form/fields/moment_picker/segments/hour_segment.scss +15 -0
  81. data/lib/assets/stylesheets/tao/form/fields/moment_picker/segments/minute_segment.scss +17 -0
  82. data/lib/assets/stylesheets/tao/form/fields/moment_picker/segments/month_segment.scss +15 -0
  83. data/lib/assets/stylesheets/tao/form/fields/moment_picker/segments/year_segment.scss +15 -0
  84. data/lib/assets/stylesheets/tao/form/fields/radio.scss +33 -0
  85. data/lib/assets/stylesheets/tao/form/fields/select/index.scss +10 -0
  86. data/lib/assets/stylesheets/tao/form/fields/select/list.scss +61 -0
  87. data/lib/assets/stylesheets/tao/form/fields/select/multiple_result.scss +72 -0
  88. data/lib/assets/stylesheets/tao/form/fields/select/result.scss +101 -0
  89. data/lib/assets/stylesheets/tao/form/fields/switch.scss +12 -0
  90. data/lib/assets/stylesheets/tao/form/index.scss +5 -0
  91. data/lib/assets/stylesheets/tao/form/inputs/boolean.scss +8 -0
  92. data/lib/assets/stylesheets/tao/form/inputs/group.scss +2 -0
  93. data/lib/assets/stylesheets/tao/form/inputs/index.scss +1 -0
  94. data/lib/assets/stylesheets/tao/form/inputs/text.scss +2 -0
  95. data/lib/assets/stylesheets/tao/form/layout.scss +148 -0
  96. data/lib/assets/stylesheets/tao/form/mobile/_globals.scss +3 -0
  97. data/lib/assets/stylesheets/tao/form/mobile/_mixins.scss +22 -0
  98. data/lib/assets/stylesheets/tao/form/mobile/_variables.scss +3 -0
  99. data/lib/assets/stylesheets/tao/form/mobile/fields/checkbox.scss +2 -0
  100. data/lib/assets/stylesheets/tao/form/mobile/fields/datetime_picker.scss +18 -0
  101. data/lib/assets/stylesheets/tao/form/mobile/fields/index.scss +1 -0
  102. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/index.scss +9 -0
  103. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/result.scss +19 -0
  104. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/segment_list.scss +52 -0
  105. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/segments/date_segment.scss +14 -0
  106. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/segments/hour_segment.scss +14 -0
  107. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/segments/minute_segment.scss +14 -0
  108. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/segments/month_segment.scss +14 -0
  109. data/lib/assets/stylesheets/tao/form/mobile/fields/moment_picker/segments/year_segment.scss +14 -0
  110. data/lib/assets/stylesheets/tao/form/mobile/fields/radio.scss +2 -0
  111. data/lib/assets/stylesheets/tao/form/mobile/fields/select/index.scss +66 -0
  112. data/lib/assets/stylesheets/tao/form/mobile/fields/select/list.scss +10 -0
  113. data/lib/assets/stylesheets/tao/form/mobile/fields/select/multiple_result.scss +12 -0
  114. data/lib/assets/stylesheets/tao/form/mobile/fields/select/result.scss +28 -0
  115. data/lib/assets/stylesheets/tao/form/mobile/fields/switch.scss +2 -0
  116. data/lib/assets/stylesheets/tao/form/mobile/index.scss +5 -0
  117. data/lib/assets/stylesheets/tao/form/mobile/inputs/boolean.scss +7 -0
  118. data/lib/assets/stylesheets/tao/form/mobile/inputs/group.scss +6 -0
  119. data/lib/assets/stylesheets/tao/form/mobile/inputs/index.scss +1 -0
  120. data/lib/assets/stylesheets/tao/form/mobile/inputs/text.scss +2 -0
  121. data/lib/assets/stylesheets/tao/form/mobile/layout.scss +137 -0
  122. data/lib/assets/stylesheets/tao/form/mobile/reset.scss +30 -0
  123. data/lib/assets/stylesheets/tao/form/mobile/variables/_base.scss +12 -0
  124. data/lib/assets/stylesheets/tao/form/mobile/variables/_moment_picker.scss +9 -0
  125. data/lib/assets/stylesheets/tao/form/mobile/variables/_select.scss +9 -0
  126. data/lib/assets/stylesheets/tao/form/reset.scss +30 -0
  127. data/lib/assets/stylesheets/tao/form/shared/fields/_checkbox.scss +61 -0
  128. data/lib/assets/stylesheets/tao/form/shared/fields/_radio.scss +53 -0
  129. data/lib/assets/stylesheets/tao/form/shared/fields/_switch.scss +56 -0
  130. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/_result.scss +46 -0
  131. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/_segment_list.scss +93 -0
  132. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/segments/_date_segment.scss +50 -0
  133. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/segments/_hour_segment.scss +35 -0
  134. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/segments/_minute_segment.scss +23 -0
  135. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/segments/_month_segment.scss +27 -0
  136. data/lib/assets/stylesheets/tao/form/shared/fields/moment_picker/segments/_year_segment.scss +27 -0
  137. data/lib/assets/stylesheets/tao/form/shared/fields/select/_list.scss +136 -0
  138. data/lib/assets/stylesheets/tao/form/shared/fields/select/_multiple_result.scss +46 -0
  139. data/lib/assets/stylesheets/tao/form/shared/inputs/_boolean.scss +5 -0
  140. data/lib/assets/stylesheets/tao/form/shared/inputs/_group.scss +25 -0
  141. data/lib/assets/stylesheets/tao/form/shared/inputs/_text.scss +33 -0
  142. data/lib/assets/stylesheets/tao/form/variables/_base.scss +15 -0
  143. data/lib/assets/stylesheets/tao/form/variables/_moment_picker.scss +9 -0
  144. data/lib/assets/stylesheets/tao/form/variables/_select.scss +10 -0
  145. data/lib/tao_form.rb +5 -0
  146. data/lib/tao_form/components.rb +10 -0
  147. data/lib/tao_form/components/check_box_component.rb +29 -0
  148. data/lib/tao_form/components/date_picker_component.rb +25 -0
  149. data/lib/tao_form/components/datetime_picker_component.rb +50 -0
  150. data/lib/tao_form/components/field_component.rb +15 -0
  151. data/lib/tao_form/components/form_component.rb +24 -0
  152. data/lib/tao_form/components/moment_picker/base.rb +68 -0
  153. data/lib/tao_form/components/moment_picker/result_component.rb +31 -0
  154. data/lib/tao_form/components/moment_picker/segment_list_component.rb +36 -0
  155. data/lib/tao_form/components/moment_picker/segments.rb +6 -0
  156. data/lib/tao_form/components/moment_picker/segments/base.rb +17 -0
  157. data/lib/tao_form/components/moment_picker/segments/date_segment_component.rb +21 -0
  158. data/lib/tao_form/components/moment_picker/segments/hour_segment_component.rb +21 -0
  159. data/lib/tao_form/components/moment_picker/segments/minute_segment_component.rb +28 -0
  160. data/lib/tao_form/components/moment_picker/segments/month_segment_component.rb +15 -0
  161. data/lib/tao_form/components/moment_picker/segments/year_segment_component.rb +21 -0
  162. data/lib/tao_form/components/month_picker_component.rb +23 -0
  163. data/lib/tao_form/components/radio_button_component.rb +29 -0
  164. data/lib/tao_form/components/select/list_component.rb +23 -0
  165. data/lib/tao_form/components/select/multiple_result_component.rb +23 -0
  166. data/lib/tao_form/components/select/result_component.rb +35 -0
  167. data/lib/tao_form/components/select_component.rb +78 -0
  168. data/lib/tao_form/components/switch_component.rb +11 -0
  169. data/lib/tao_form/components/time_picker_component.rb +29 -0
  170. data/lib/tao_form/engine.rb +15 -0
  171. data/lib/tao_form/inputs.rb +9 -0
  172. data/lib/tao_form/inputs/boolean_input.rb +30 -0
  173. data/lib/tao_form/inputs/collection_check_boxes_input.rb +19 -0
  174. data/lib/tao_form/inputs/collection_radio_buttons_input.rb +19 -0
  175. data/lib/tao_form/inputs/collection_select_input.rb +21 -0
  176. data/lib/tao_form/inputs/date_time_input.rb +22 -0
  177. data/lib/tao_form/inputs/grouped_collection_select_input.rb +22 -0
  178. data/lib/tao_form/inputs/month_input.rb +7 -0
  179. data/lib/tao_form/inputs/numeric_input.rb +19 -0
  180. data/lib/tao_form/inputs/string_input.rb +19 -0
  181. data/lib/tao_form/version.rb +3 -0
  182. data/lib/views/components/tao_form/components/_check_box.html.erb +10 -0
  183. data/lib/views/components/tao_form/components/_datetime_picker.html.erb +7 -0
  184. data/lib/views/components/tao_form/components/_moment_picker.html+mobile.erb +17 -0
  185. data/lib/views/components/tao_form/components/_moment_picker.html.erb +4 -0
  186. data/lib/views/components/tao_form/components/_radio_button.html.erb +9 -0
  187. data/lib/views/components/tao_form/components/_select.html+mobile.erb +27 -0
  188. data/lib/views/components/tao_form/components/_select.html.erb +4 -0
  189. data/lib/views/components/tao_form/components/_switch.html.erb +10 -0
  190. data/lib/views/components/tao_form/components/moment_picker/_result.html+mobile.erb +11 -0
  191. data/lib/views/components/tao_form/components/moment_picker/_result.html.erb +14 -0
  192. data/lib/views/components/tao_form/components/moment_picker/_segment_list.html+mobile.erb +8 -0
  193. data/lib/views/components/tao_form/components/moment_picker/_segment_list.html.erb +4 -0
  194. data/lib/views/components/tao_form/components/moment_picker/segment_list/_labels.html.erb +13 -0
  195. data/lib/views/components/tao_form/components/moment_picker/segment_list/_segments.html.erb +7 -0
  196. data/lib/views/components/tao_form/components/moment_picker/segments/_date_segment.html.erb +14 -0
  197. data/lib/views/components/tao_form/components/moment_picker/segments/_hour_segment.html.erb +14 -0
  198. data/lib/views/components/tao_form/components/moment_picker/segments/_minute_segment.html.erb +9 -0
  199. data/lib/views/components/tao_form/components/moment_picker/segments/_month_segment.html.erb +16 -0
  200. data/lib/views/components/tao_form/components/moment_picker/segments/_year_segment.html.erb +10 -0
  201. data/lib/views/components/tao_form/components/select/_list.html.erb +18 -0
  202. data/lib/views/components/tao_form/components/select/_multiple_result.html+mobile.erb +3 -0
  203. data/lib/views/components/tao_form/components/select/_multiple_result.html.erb +7 -0
  204. data/lib/views/components/tao_form/components/select/_result.html+mobile.erb +10 -0
  205. data/lib/views/components/tao_form/components/select/_result.html.erb +14 -0
  206. data/vendor/assets/javascripts/moment.js +4463 -0
  207. data/vendor/assets/javascripts/moment/zh-cn.js +112 -0
  208. metadata +334 -0
@@ -0,0 +1,23 @@
1
+ tao-moment-picker-minute-segment {
2
+ .minutes {
3
+ display: flex;
4
+ justify-content: center;
5
+ align-items: center;
6
+ flex-wrap: wrap;
7
+
8
+ .minute {
9
+ display: block;
10
+ width: percentage(1/6);
11
+ line-height: $moment-picker-segment-item-height;
12
+ text-align: center;
13
+ font-size: 0.875rem;
14
+ color: $text-color;
15
+ outline: none;
16
+
17
+ &.selected {
18
+ background: $green-bg-color;
19
+ color: $green-color;
20
+ }
21
+ }
22
+ }
23
+ }
@@ -0,0 +1,27 @@
1
+ tao-moment-picker-month-segment {
2
+ .month-list {
3
+ display: flex;
4
+ justify-content: center;
5
+ align-items: center;
6
+ flex-wrap: wrap;
7
+
8
+ .month {
9
+ display: block;
10
+ width: percentage(1/4);
11
+ line-height: $moment-picker-segment-item-height;
12
+ text-align: center;
13
+ font-size: 0.875rem;
14
+ color: $text-color;
15
+ outline: none;
16
+
17
+ &.current {
18
+ color: $orange-color;
19
+ }
20
+
21
+ &.selected {
22
+ background: $green-bg-color !important;
23
+ color: $green-color !important;
24
+ }
25
+ }
26
+ }
27
+ }
@@ -0,0 +1,27 @@
1
+ tao-moment-picker-year-segment {
2
+ .year-list {
3
+ display: flex;
4
+ justify-content: center;
5
+ align-items: center;
6
+ flex-wrap: wrap;
7
+
8
+ .year {
9
+ display: block;
10
+ width: percentage(1/3);
11
+ line-height: $moment-picker-segment-item-height;
12
+ text-align: center;
13
+ font-size: 0.875rem;
14
+ color: $text-color;
15
+ outline: none;
16
+
17
+ &.current {
18
+ color: $orange-color;
19
+ }
20
+
21
+ &.selected {
22
+ background: $green-bg-color !important;
23
+ color: $green-color !important;
24
+ }
25
+ }
26
+ }
27
+ }
@@ -0,0 +1,136 @@
1
+ tao-select-list {
2
+ background: $white-color;
3
+
4
+ .search-input {
5
+ display: none;
6
+ flex: 0 0 auto;
7
+ border-bottom: 1px solid $border-color;
8
+ align-items: center;
9
+ justify-content: space-between;
10
+
11
+ .icon-wrapper {
12
+ display: flex;
13
+ align-items: center;
14
+ justify-content: center;
15
+ flex: 0 0 auto;
16
+ width: $select-option-height;
17
+ height: $select-option-height;
18
+ fill: $lightest-grey-color;
19
+ }
20
+
21
+ .search-field {
22
+ display: block;
23
+ flex: 1 1 auto;
24
+ width: auto;
25
+ padding: $select-option-padding;
26
+ padding-left: 0;
27
+ font-size: $select-option-font-size;
28
+ line-height: $select-option-line-height;
29
+ border: none;
30
+ outline: none;
31
+ }
32
+ }
33
+
34
+ &[searchable] {
35
+ .search-input {
36
+ display: flex;
37
+ }
38
+ }
39
+
40
+ .list-wrapper {
41
+ overflow-y: auto;
42
+ }
43
+
44
+ .options-list {
45
+ .option {
46
+ display: flex;
47
+ flex: 0 0 auto;
48
+ padding: $select-option-padding;
49
+ font-size: $select-option-font-size;
50
+ line-height: $select-option-line-height;
51
+ border-bottom: 1px solid $border-color;
52
+ justify-content: space-between;
53
+ align-items: center;
54
+ cursor: pointer;
55
+
56
+ &.highlighted {
57
+ background: $grey-bg-color;
58
+ }
59
+
60
+ &:last-child {
61
+ border-bottom: none;
62
+ }
63
+
64
+ .hint {
65
+ font-size: $font-size-xs;
66
+ color: $lightest-grey-color;
67
+ }
68
+ }
69
+
70
+ .optgroup {
71
+ background: #efefef;
72
+ padding: 0 1rem;
73
+ line-height: 1.875rem;
74
+ color: $lighter-grey-color;
75
+ font-size: $font-size-xs;
76
+ font-weight: bold;
77
+ }
78
+ }
79
+
80
+ .tips,
81
+ .search-not-found,
82
+ .remote-no-option,
83
+ .no-option,
84
+ .loading-message {
85
+ display: none;
86
+ flex: 0 0 auto;
87
+ height: $select-option-height;
88
+ padding: $select-option-padding;
89
+ font-size: $select-option-font-size;
90
+ line-height: $select-option-line-height;
91
+ color: $lightest-grey-color;
92
+ text-align: center;
93
+ }
94
+
95
+ .tips {
96
+ border-top: 1px solid $border-color;
97
+ }
98
+
99
+ &[empty] {
100
+ &:not([hidden-size='0']) .remote-no-option {
101
+ display: block;
102
+ }
103
+
104
+ &[hidden-size='0'] .no-option {
105
+ display: block;
106
+ }
107
+
108
+ &[searching] {
109
+ .remote-no-option,
110
+ .no-option {
111
+ display: none;
112
+ }
113
+
114
+ .search-not-found{
115
+ display: block;
116
+ }
117
+ }
118
+ }
119
+
120
+ &:not([empty]):not([hidden-size='0']) .tips {
121
+ display: block;
122
+ }
123
+
124
+ &[loading] {
125
+ .loading-message {
126
+ display: block;
127
+ }
128
+
129
+ .tips,
130
+ .search-not-found,
131
+ .remote-no-option,
132
+ .no-option {
133
+ display: none !important;
134
+ }
135
+ }
136
+ }
@@ -0,0 +1,46 @@
1
+ tao-multiple-select-result {
2
+ display: flex;
3
+ align-items: flex-start;
4
+ align-content: flex-start;
5
+ flex-wrap: wrap;
6
+
7
+ select {
8
+ display: none;
9
+ }
10
+
11
+ .selected-item {
12
+ display: flex;
13
+ align-items: center;
14
+ align-content: center;
15
+ flex: 0 0 auto;
16
+ padding: $select-item-padding;
17
+ margin: $select-item-margin;
18
+ height: $select-item-height;
19
+ border: 1px solid $grey-bg-color;
20
+ background: $grey-bg-color;
21
+ border-radius: $border-radius-s;
22
+ color: $text-color;
23
+ font-size: $select-item-font-size;
24
+ text-decoration: none;
25
+ outline: none;
26
+
27
+ .icon-close {
28
+ width: 1em;
29
+ height: 1em;
30
+ margin: 0 0 0 0.5rem;
31
+ fill: $lighter-grey-color;
32
+ }
33
+ }
34
+
35
+ &.disabled {
36
+ .selected-item {
37
+ cursor: not-allowed;
38
+ color: $lightest-grey-color;
39
+
40
+ .icon-close {
41
+ cursor: not-allowed;
42
+ fill: $lightest-grey-color;
43
+ }
44
+ }
45
+ }
46
+ }
@@ -0,0 +1,5 @@
1
+ tao-form .boolean-field {
2
+ height: $form-field-height;
3
+ display: flex;
4
+ align-items: center;
5
+ }
@@ -0,0 +1,25 @@
1
+ tao-form .group-field {
2
+ display: flex;
3
+ align-items: flex-start;
4
+ align-content: flex-start;
5
+ flex-wrap: wrap;
6
+ justify-content: flex-start;
7
+
8
+ .checkbox,
9
+ .radio {
10
+ display: inline-block;
11
+ margin: 0 1.5em 0 0;
12
+
13
+ label {
14
+ display: flex;
15
+ @include truncate-text;
16
+ height: $form-field-height;
17
+ align-items: center;
18
+
19
+ tao-check-box,
20
+ tao-radio-button {
21
+ margin: 0 0.5em 0 0;
22
+ }
23
+ }
24
+ }
25
+ }
@@ -0,0 +1,33 @@
1
+ tao-form .text-field {
2
+ position: relative;
3
+
4
+ .prefix, .suffix {
5
+ display: flex;
6
+ justify-content: center;
7
+ align-items: center;
8
+ position: absolute;
9
+ width: $form-field-height;
10
+ height: $form-field-height;
11
+ font-size: $form-field-font-size;
12
+ color: $lighter-grey-color;
13
+ fill: $lighter-grey-color;
14
+ }
15
+
16
+ .prefix {
17
+ top: 0;
18
+ left: 0;
19
+ }
20
+
21
+ .suffix {
22
+ top: 0;
23
+ right: 0;
24
+ }
25
+
26
+ &.text-field-with-prefix .input-field {
27
+ padding-left: $form-field-height;
28
+ }
29
+
30
+ &.text-field-with-suffix .input-field {
31
+ padding-right: $form-field-height;
32
+ }
33
+ }
@@ -0,0 +1,15 @@
1
+ $form-label-width: 10rem !default;
2
+ $form-label-font-size: 0.875rem !default;
3
+ $form-label-line-height: 1.5rem !default;
4
+
5
+ $form-field-width: 20rem !default;
6
+ $form-field-height: 2.5rem !default;
7
+ $form-field-line-height: 1.375rem !default;
8
+ $form-field-font-size: 1rem !default;
9
+ $form-field-padding-v: 0.5rem !default;
10
+ $form-field-padding-h: 0.625rem !default;
11
+ $form-field-margin-h: 1.875rem !default;
12
+ $form-field-text-color: $text-color !default;
13
+ $form-field-active-border-color: $link-color !default;
14
+
15
+ $form-hint-font-size: 0.75rem !default;
@@ -0,0 +1,9 @@
1
+ $moment-picker-segment-labels-padding: 0.5rem 2.5rem !default;
2
+ $moment-picker-segment-label-padding: 0.125rem 0.5rem !default;
3
+ $moment-picker-segment-label-margin: 0.25rem !default;
4
+ $moment-picker-segment-label-font-size: 0.75rem !default;
5
+
6
+ $moment-picker-segment-arrow-position-v: -2.5rem !default;
7
+ $moment-picker-segment-arrow-position-h: -0.5rem !default;
8
+
9
+ $moment-picker-segment-item-height: 2.125rem !default;
@@ -0,0 +1,10 @@
1
+ $select-list-offset: 0.375rem !default;
2
+ $select-option-height: $form-field-height - 0.125rem !default;
3
+ $select-option-padding: $form-field-padding-v $form-field-padding-h !default;
4
+ $select-option-line-height: $form-field-line-height !default;
5
+ $select-option-font-size: 0.875rem !default;
6
+
7
+ $select-item-padding: 0 0.75rem !default;
8
+ $select-item-margin: 0 0.5rem 0.5rem 0 !default;
9
+ $select-item-height: 2.25rem !default;
10
+ $select-item-font-size: 0.875rem !default;
data/lib/tao_form.rb ADDED
@@ -0,0 +1,5 @@
1
+ require 'tao_form/version'
2
+ require 'tao_form/engine'
3
+
4
+ module TaoForm
5
+ end
@@ -0,0 +1,10 @@
1
+ require 'tao_form/components/form_component'
2
+ require 'tao_form/components/field_component'
3
+ require 'tao_form/components/check_box_component'
4
+ require 'tao_form/components/switch_component'
5
+ require 'tao_form/components/radio_button_component'
6
+ require 'tao_form/components/select_component'
7
+ require 'tao_form/components/date_picker_component'
8
+ require 'tao_form/components/time_picker_component'
9
+ require 'tao_form/components/datetime_picker_component'
10
+ require 'tao_form/components/month_picker_component'
@@ -0,0 +1,29 @@
1
+ module TaoForm
2
+ module Components
3
+ class CheckBoxComponent < FieldComponent
4
+
5
+ attr_reader :checked_value, :unchecked_value
6
+
7
+ def initialize view, builder = nil, attribute_name = nil, options = {}, checked_value = '1', unchecked_value = '0'
8
+ super view, builder, attribute_name, options
9
+ @checked_value = checked_value
10
+ @unchecked_value = unchecked_value
11
+ end
12
+
13
+ def self.component_name
14
+ :check_box
15
+ end
16
+
17
+ def render &block
18
+ if block_given?
19
+ super
20
+ else
21
+ super {
22
+ builder.check_box attribute_name, {}, checked_value, unchecked_value
23
+ }
24
+ end
25
+ end
26
+
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,25 @@
1
+ require 'tao_form/components/moment_picker/base'
2
+
3
+ module TaoForm
4
+ module Components
5
+ class DatePickerComponent < MomentPicker::Base
6
+
7
+ def input_type
8
+ @input_type ||= :date
9
+ end
10
+
11
+ def segments
12
+ @segments ||= %w(year month date)
13
+ end
14
+
15
+ def default_segment
16
+ @default_segment ||= :date
17
+ end
18
+
19
+ def self.component_name
20
+ :date_picker
21
+ end
22
+
23
+ end
24
+ end
25
+ end