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,12 @@
1
+ $form-label-font-size: 0.875rem !default;
2
+
3
+ $form-field-height: 3rem !default;
4
+ $form-field-line-height: 1.5rem !default;
5
+ $form-field-font-size: 1rem !default;
6
+ $form-field-padding-v: 0.75rem !default;
7
+ $form-field-padding-h: 1rem !default;
8
+ $form-field-text-color: $text-color !default;
9
+ $form-field-active-border-color: $link-color !default;
10
+
11
+ $form-hint-font-size: 0.75rem !default;
12
+ $form-hint-padding: 0.375rem 1rem !default;
@@ -0,0 +1,9 @@
1
+ $moment-picker-segment-labels-padding: 0.75rem 2.5rem !default;
2
+ $moment-picker-segment-label-padding: 0.25rem 0.75rem !default;
3
+ $moment-picker-segment-label-margin: 0.25rem !default;
4
+ $moment-picker-segment-label-font-size: 0.875rem !default;
5
+
6
+ $moment-picker-segment-arrow-position-v: -3rem !default;
7
+ $moment-picker-segment-arrow-position-h: 0 !default;
8
+
9
+ $moment-picker-segment-item-height: 3rem !default;
@@ -0,0 +1,9 @@
1
+ $select-option-height: $form-field-height - 0.125rem !default;
2
+ $select-option-padding: $form-field-padding-v $form-field-padding-h !default;
3
+ $select-option-line-height: $form-field-line-height !default;
4
+ $select-option-font-size: 0.875rem !default;
5
+
6
+ $select-item-padding: 0 0.5rem !default;
7
+ $select-item-margin: 0 0.25rem 0.25rem 0 !default;
8
+ $select-item-height: 2rem !default;
9
+ $select-item-font-size: 0.875rem !default;
@@ -0,0 +1,30 @@
1
+ @import './globals';
2
+
3
+ ::placeholder {
4
+ color: $lightest-grey-color;
5
+ }
6
+
7
+ textarea,
8
+ input[type=text],
9
+ input[type=tel],
10
+ input[type=email],
11
+ input[type=number],
12
+ input[type=password],
13
+ input[type=date],
14
+ input[type=time],
15
+ input[type=month],
16
+ input[type=datetime-local] {
17
+ @include text-field-style;
18
+ }
19
+
20
+ textarea {
21
+ display: block;
22
+ height: auto;
23
+ line-height: 1.6;
24
+ resize: none;
25
+ }
26
+
27
+ select {
28
+ @include text-field-style;
29
+ appearance: none;
30
+ }
@@ -0,0 +1,61 @@
1
+ tao-check-box {
2
+ display: inline-block;
3
+ vertical-align: middle;
4
+ user-select: none;
5
+ outline: none;
6
+
7
+ .checkbox-wrapper {
8
+ display: block;
9
+ background-color: #fff;
10
+ border: 1px #9B9B9B solid;
11
+ border-radius: 2px;
12
+ height: 1.125rem;
13
+ width: 1.125rem;
14
+ transition: border-color 200ms, background 200ms;
15
+ outline: none;
16
+
17
+ .icon {
18
+ display: none;
19
+ margin: 1px;
20
+ height: 0.875rem;
21
+ width: 0.875rem;
22
+ fill: #ffffff;
23
+
24
+ &.icon-indeterminate {
25
+ width: 10px;
26
+ height: 2px;
27
+ margin: 7px 3px;
28
+ border-radius: 2px;
29
+ background: #ffffff;
30
+ }
31
+ }
32
+ }
33
+
34
+ input[type=checkbox] {
35
+ display: none;
36
+
37
+ &:indeterminate + .checkbox-wrapper,
38
+ &:checked + .checkbox-wrapper {
39
+ background-color: #55BB33;
40
+ border-color: #55BB33;
41
+ }
42
+
43
+ &:indeterminate + .checkbox-wrapper .icon-indeterminate,
44
+ &:checked + .checkbox-wrapper .icon-checkbox {
45
+ display: block;
46
+ }
47
+
48
+ &:disabled + .checkbox-wrapper {
49
+ border: 1px #DDDDDD solid;
50
+ background-color: #F6F6F6;
51
+
52
+ .icon {
53
+ fill: #dddddd;
54
+ }
55
+
56
+ .icon-indeterminate {
57
+ background: #dddddd;
58
+ }
59
+ }
60
+ }
61
+ }
@@ -0,0 +1,53 @@
1
+ tao-radio-button {
2
+ display: inline-block;
3
+ vertical-align: middle;
4
+ user-select: none;
5
+
6
+ .radio-wrapper {
7
+ display: block;
8
+ height: 1rem;
9
+ width: 1rem;
10
+ padding: 2px;
11
+ border: 1px #9B9B9B solid;
12
+ border-radius: 50%;
13
+ background-color: #ffffff;
14
+ transition: 200ms border-color, 200ms background-color;
15
+
16
+ .icon-radio {
17
+ height: 100%;
18
+ width: 100%;
19
+ border-radius: 50%;
20
+ background-color: #55BB33;
21
+ display: none;
22
+ transition: 200ms border-color, 200ms background-color;
23
+ }
24
+ }
25
+
26
+ input[type=radio] {
27
+ display: none;
28
+
29
+ &:disabled + .radio-wrapper {
30
+ cursor: not-allowed;
31
+ border-color: #DDDDDD;
32
+ background-color: #F6F6F6;
33
+ }
34
+
35
+ &:checked + .radio-wrapper {
36
+ border-color: #55BB33;
37
+
38
+ .icon-radio {
39
+ display: block;
40
+ }
41
+ }
42
+
43
+ &:checked:disabled + .radio-wrapper {
44
+ border-color: #DDDDDD;
45
+ background-color: #F6F6F6;
46
+
47
+ .icon-radio {
48
+ background-color: #DDDDDD;
49
+ }
50
+ }
51
+ }
52
+
53
+ }
@@ -0,0 +1,56 @@
1
+ $switch-width: 3.75rem;
2
+ $switch-height: 1.75rem;
3
+ $switch-slot-height: 1.375rem;
4
+
5
+ tao-switch {
6
+ display: inline-block;
7
+
8
+ .switch-wrapper {
9
+ width: $switch-width;
10
+ height: $switch-height;
11
+ position: relative;
12
+
13
+ .switch-toggle {
14
+ width: 1.75rem;
15
+ height: 1.75rem;
16
+ background-color: $white-color;
17
+ margin-left: 0;
18
+ border: 1px solid $border-color;
19
+ border-radius: 50%;
20
+ box-shadow: 0 0 5px rgba(0,0,0,0.1);
21
+ transition: margin-left 0.2s;
22
+ position: relative;
23
+ z-index: 1;
24
+ }
25
+
26
+ .switch-slot {
27
+ width: $switch-width;
28
+ height: $switch-slot-height;
29
+ background-color: $light-line-color;
30
+ border-radius: 2.25rem;
31
+ position: absolute;
32
+ top: 50%;
33
+ left: 0;
34
+ transform: translateY(-$switch-slot-height / 2);
35
+ transition: background-color 0.2s;
36
+ }
37
+ }
38
+
39
+ input[type=checkbox] {
40
+ display: none;
41
+
42
+ &:checked + .switch-wrapper {
43
+ .switch-toggle {
44
+ margin-left: 2rem;
45
+ }
46
+
47
+ .switch-slot {
48
+ background-color: $ui-color;
49
+ }
50
+ }
51
+
52
+ &:disabled + .switch-wrapper {
53
+ opacity: 0.5;
54
+ }
55
+ }
56
+ }
@@ -0,0 +1,46 @@
1
+ tao-moment-picker-result {
2
+ display: flex;
3
+ align-items: center;
4
+
5
+ &[disabled] {
6
+ .result-text {
7
+ color: $lightest-grey-color;
8
+ }
9
+ }
10
+
11
+ input[type=text],
12
+ input[type=date],
13
+ input[type=time],
14
+ input[type=datetime-local],
15
+ input[type=month] {
16
+ display: none;
17
+ }
18
+
19
+ .placeholder,
20
+ .result-text {
21
+ flex: 1 1 auto;
22
+ padding: $form-field-padding-v 0;
23
+ font-size: $form-field-font-size;
24
+ line-height: $form-field-line-height;
25
+ min-height: $form-field-height - 0.125rem;
26
+ }
27
+
28
+ .placeholder {
29
+ color: $lightest-grey-color;
30
+ }
31
+
32
+ .result-text {
33
+ color: $form-field-text-color;
34
+ display: none;
35
+ }
36
+
37
+ &[selected] {
38
+ .placeholder {
39
+ display: none;
40
+ }
41
+
42
+ .result-text {
43
+ display: block;
44
+ }
45
+ }
46
+ }
@@ -0,0 +1,93 @@
1
+ tao-moment-picker-segment-list {
2
+
3
+ .segment-labels {
4
+ padding: $moment-picker-segment-labels-padding;
5
+ display: flex;
6
+ justify-content: center;
7
+ align-items: center;
8
+
9
+ .segment-label {
10
+ display: inline-block;
11
+ border: 1px solid $grey-bg-color;
12
+ background: $grey-bg-color;
13
+ color: $grey-color;
14
+ font-size: $moment-picker-segment-label-font-size;
15
+ padding: $moment-picker-segment-label-padding;
16
+ margin: 0 $moment-picker-segment-label-margin;
17
+ border-radius: $border-radius-s;
18
+ white-space: nowrap;
19
+ outline: none;
20
+
21
+ .placeholder {
22
+ }
23
+
24
+ .value {
25
+ display: none;
26
+ }
27
+
28
+ &.active {
29
+ border-color: $ui-color;
30
+ background: $white-color;
31
+ color: $ui-color;
32
+ cursor: default;
33
+ }
34
+
35
+ &.selected {
36
+ .placeholder {
37
+ display: none;
38
+ }
39
+
40
+ .value {
41
+ display: inline;
42
+ }
43
+ }
44
+ }
45
+
46
+ .separator {
47
+ font-size: $moment-picker-segment-label-font-size;
48
+ color: $lighter-grey-color;
49
+ margin: 0 $moment-picker-segment-label-margin / 2;
50
+ }
51
+ }
52
+
53
+ .segments {
54
+ .segment {
55
+ display: none;
56
+ justify-content: center;
57
+ align-items: center;
58
+ position: relative;
59
+ border-top: 1px solid $border-color;
60
+
61
+ &[active] {
62
+ display: block;
63
+ }
64
+
65
+ .link-prev,
66
+ .link-next {
67
+ display: block;
68
+ width: 2.5rem;
69
+ height: 2.5rem;
70
+ display: flex;
71
+ justify-content: center;
72
+ align-items: center;
73
+ fill: $light-grey-color;
74
+ position: absolute;
75
+ top: $moment-picker-segment-arrow-position-v;
76
+ outline: none;
77
+
78
+ .icon {
79
+ width: 0.875rem;
80
+ height: 0.875rem;
81
+ }
82
+ }
83
+
84
+ .link-next {
85
+ right: $moment-picker-segment-arrow-position-h;
86
+ }
87
+
88
+ .link-prev {
89
+ left: $moment-picker-segment-arrow-position-h;
90
+ }
91
+ }
92
+ }
93
+ }
@@ -0,0 +1,50 @@
1
+ tao-moment-picker-date-segment {
2
+ .calendar {
3
+ .weekdays {
4
+ display: flex;
5
+ justify-content: center;
6
+ align-content: center;
7
+ flex-wrap: wrap;
8
+ border-bottom: 1px dotted $border-color;
9
+
10
+ .weekday {
11
+ display: block;
12
+ width: percentage(1/7);
13
+ line-height: $moment-picker-segment-item-height;
14
+ text-align: center;
15
+ font-size: 0.875rem;
16
+ }
17
+ }
18
+
19
+ .days {
20
+ display: flex;
21
+ justify-content: center;
22
+ align-content: center;
23
+ flex-wrap: wrap;
24
+
25
+ .day {
26
+ display: block;
27
+ width: percentage(1/7);
28
+ line-height: $moment-picker-segment-item-height;
29
+ text-align: center;
30
+ font-size: 0.875rem;
31
+ border-radius: $border-radius-s;
32
+ color: $text-color;
33
+ outline: none;
34
+
35
+ &.outside {
36
+ color: $lightest-grey-color;
37
+ }
38
+
39
+ &.today {
40
+ color: $orange-color;
41
+ }
42
+
43
+ &.selected {
44
+ background: $green-bg-color !important;
45
+ color: $green-color !important;
46
+ }
47
+ }
48
+ }
49
+ }
50
+ }
@@ -0,0 +1,35 @@
1
+ tao-moment-picker-hour-segment {
2
+ .hours {
3
+ .morning-hours,
4
+ .afternoon-hours {
5
+ display: flex;
6
+ justify-content: center;
7
+ align-items: center;
8
+ flex-wrap: wrap;
9
+ }
10
+
11
+ .morning-hours {
12
+ padding-bottom: $moment-picker-segment-item-height / 3;
13
+ border-bottom: 1px dotted $border-color;
14
+ }
15
+
16
+ .afternoon-hours {
17
+ padding-top: $moment-picker-segment-item-height / 3;
18
+ }
19
+
20
+ .hour {
21
+ display: block;
22
+ width: percentage(1/6);
23
+ line-height: $moment-picker-segment-item-height;
24
+ text-align: center;
25
+ font-size: 0.875rem;
26
+ color: $text-color;
27
+ outline: none;
28
+
29
+ &.selected {
30
+ background: $green-bg-color;
31
+ color: $green-color;
32
+ }
33
+ }
34
+ }
35
+ }