cm-admin 0.2.0 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (117) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +12 -0
  3. data/.rspec +3 -0
  4. data/.travis.yml +6 -0
  5. data/Gemfile +6 -1
  6. data/Gemfile.lock +118 -0
  7. data/LICENSE.txt +21 -0
  8. data/README.md +6 -40
  9. data/app/assets/images/logo.png +0 -0
  10. data/{lib/generators/cm_admin/templates/assets/stylesheets → app/assets/stylesheets/cm_admin}/base/auth.scss +16 -6
  11. data/app/assets/stylesheets/cm_admin/base/common.scss +237 -0
  12. data/app/assets/stylesheets/cm_admin/base/filters.scss +199 -0
  13. data/app/assets/stylesheets/cm_admin/base/form.scss +262 -0
  14. data/app/assets/stylesheets/cm_admin/base/main-nav.scss +47 -0
  15. data/app/assets/stylesheets/cm_admin/base/navbar.scss +67 -0
  16. data/app/assets/stylesheets/cm_admin/base/quicksearch.scss +69 -0
  17. data/app/assets/stylesheets/cm_admin/base/scaffold.scss +61 -0
  18. data/app/assets/stylesheets/cm_admin/base/show.scss +54 -0
  19. data/app/assets/stylesheets/cm_admin/base/sidebar.scss +225 -0
  20. data/app/assets/stylesheets/cm_admin/base/table.scss +303 -0
  21. data/app/assets/stylesheets/cm_admin/base/tabs.scss +26 -0
  22. data/app/assets/stylesheets/cm_admin/cm_admin.css.scss +26 -0
  23. data/app/assets/stylesheets/cm_admin/components/_alerts.scss +101 -0
  24. data/app/assets/stylesheets/cm_admin/components/_buttons.scss +135 -0
  25. data/app/assets/stylesheets/cm_admin/components/_dropdown-popup.scss +141 -0
  26. data/app/assets/stylesheets/cm_admin/components/_input.scss +274 -0
  27. data/app/assets/stylesheets/cm_admin/components/_modal.scss +34 -0
  28. data/app/assets/stylesheets/cm_admin/components/_range.scss +20 -0
  29. data/app/assets/stylesheets/cm_admin/components/_status-tag.scss +67 -0
  30. data/app/assets/stylesheets/cm_admin/components/index.scss +7 -0
  31. data/app/assets/stylesheets/cm_admin/dependency/bootstrap.min.css +7 -0
  32. data/app/assets/stylesheets/cm_admin/helpers/_mixins.scss +20 -0
  33. data/app/assets/stylesheets/cm_admin/helpers/_variable.scss +86 -0
  34. data/app/assets/stylesheets/cm_admin/helpers/index.scss +2 -0
  35. data/app/controllers/cm_admin/application_controller.rb +6 -0
  36. data/app/controllers/cm_admin/exports_controller.rb +16 -0
  37. data/app/controllers/cm_admin/main_controller.rb +8 -0
  38. data/app/helpers/cm_admin/application_helper.rb +11 -0
  39. data/app/javascript/packs/cm_admin/application.js +9 -0
  40. data/app/javascript/packs/cm_admin/filters.js +32 -0
  41. data/app/javascript/packs/cm_admin/scaffolds.js +14 -0
  42. data/app/views/cm_admin/main/_cm_pagy_nav.html.slim +23 -0
  43. data/app/views/cm_admin/main/_filters.html.slim +10 -0
  44. data/app/views/cm_admin/main/_table.html.slim +59 -0
  45. data/app/views/cm_admin/main/_top_navbar.html.slim +25 -0
  46. data/app/views/cm_admin/main/dashboard.html.slim +1 -0
  47. data/app/views/cm_admin/main/edit.html.slim +19 -0
  48. data/app/views/cm_admin/main/index.html.slim +9 -0
  49. data/app/views/cm_admin/main/new.html.slim +22 -0
  50. data/app/views/cm_admin/main/show.html.slim +13 -0
  51. data/app/views/layouts/_left_sidebar_nav.html.slim +30 -0
  52. data/app/views/layouts/cm_admin.html.slim +18 -0
  53. data/bin/console +1 -0
  54. data/bin/webpack +18 -0
  55. data/bin/webpack-dev-server +18 -0
  56. data/cm_admin.gemspec +20 -31
  57. data/{lib → config}/.DS_Store +0 -0
  58. data/config/initializers/active_record_extension.rb +9 -0
  59. data/config/routes.rb +18 -0
  60. data/config/webpack/development.js +5 -0
  61. data/config/webpack/environment.js +12 -0
  62. data/config/webpack/production.js +5 -0
  63. data/config/webpack/test.js +5 -0
  64. data/config/webpacker.yml +92 -0
  65. data/lib/c.png +0 -0
  66. data/lib/cm_admin.rb +31 -2
  67. data/lib/cm_admin/constants.rb +33 -0
  68. data/lib/cm_admin/engine.rb +38 -0
  69. data/lib/cm_admin/model.rb +262 -0
  70. data/lib/cm_admin/models/action.rb +22 -0
  71. data/lib/cm_admin/models/actions/blocks.rb +25 -0
  72. data/lib/cm_admin/models/blocks.rb +19 -0
  73. data/lib/cm_admin/models/column.rb +16 -0
  74. data/lib/cm_admin/models/export.rb +43 -0
  75. data/lib/cm_admin/models/field.rb +14 -0
  76. data/lib/cm_admin/models/filter.rb +30 -0
  77. data/lib/cm_admin/utils.rb +67 -0
  78. data/lib/cm_admin/version.rb +1 -1
  79. data/lib/cm_admin/view_helpers.rb +72 -0
  80. data/lib/cm_admin/view_helpers/field_column_helper.rb +23 -0
  81. data/lib/cm_admin/view_helpers/form_field_helper.rb +16 -0
  82. data/lib/cm_admin/view_helpers/form_helper.rb +55 -0
  83. data/lib/cm_admin/view_helpers/navigation_helper.rb +18 -0
  84. data/lib/cm_admin/view_helpers/page_info_helper.rb +21 -0
  85. data/lib/generators/cm_admin/install_generator.rb +10 -32
  86. data/lib/generators/cm_admin/templates/cm_admin_initializer.rb +4 -0
  87. data/lib/tasks/webpack_install.rake +63 -0
  88. data/package.json +18 -0
  89. data/postcss.config.js +12 -0
  90. data/yarn-error.log +44 -0
  91. data/yarn.lock +6903 -0
  92. metadata +123 -48
  93. data/CODE_OF_CONDUCT.md +0 -74
  94. data/lib/generators/cm_admin/USAGE +0 -8
  95. data/lib/generators/cm_admin/templates/assets/images/cm.png +0 -0
  96. data/lib/generators/cm_admin/templates/assets/stylesheets/application.css.scss +0 -33
  97. data/lib/generators/cm_admin/templates/assets/stylesheets/base/_variable.scss +0 -14
  98. data/lib/generators/cm_admin/templates/assets/stylesheets/base/form.scss +0 -125
  99. data/lib/generators/cm_admin/templates/assets/stylesheets/base/input-styles.scss +0 -72
  100. data/lib/generators/cm_admin/templates/assets/stylesheets/base/main-nav.scss +0 -79
  101. data/lib/generators/cm_admin/templates/assets/stylesheets/base/scaffold.scss +0 -95
  102. data/lib/generators/cm_admin/templates/assets/stylesheets/base/show.scss +0 -88
  103. data/lib/generators/cm_admin/templates/assets/stylesheets/base/sidebar.scss +0 -69
  104. data/lib/generators/cm_admin/templates/assets/stylesheets/base/table.scss +0 -246
  105. data/lib/generators/cm_admin/templates/layouts/_navbar.html.slim +0 -8
  106. data/lib/generators/cm_admin/templates/layouts/_side_navbar.html.slim +0 -12
  107. data/lib/generators/cm_admin/templates/layouts/application.html.slim +0 -20
  108. data/lib/generators/cm_admin/templates/layouts/initializer.rb +0 -2
  109. data/lib/generators/cm_admin/templates/views/_form.erb +0 -67
  110. data/lib/generators/cm_admin/templates/views/_table.erb +0 -22
  111. data/lib/generators/cm_admin/templates/views/edit.erb +0 -10
  112. data/lib/generators/cm_admin/templates/views/index.erb +0 -11
  113. data/lib/generators/cm_admin/templates/views/new.erb +0 -10
  114. data/lib/generators/cm_admin/templates/views/reset_password.erb +0 -12
  115. data/lib/generators/cm_admin/templates/views/show.erb +0 -18
  116. data/lib/generators/cm_admin/templates/views/sign_in.erb +0 -18
  117. data/lib/generators/cm_admin/view_generator.rb +0 -78
@@ -0,0 +1,135 @@
1
+ @import '../helpers/index.scss';
2
+
3
+ .cta-btn {
4
+ padding: 8px 16px;
5
+ @include font($size: $t4-text, $color: $white, $weight: bold);
6
+ background-color: $brand-color;
7
+ border: none;
8
+ border-radius: $radius-4;
9
+ transition: all .2s linear;
10
+ &:hover {
11
+ background-color: #4D40AA;
12
+ }
13
+ &:focus {
14
+ outline: 3px auto rgba(47, 128, 237, 0.3);
15
+ outline-offset: 1px;
16
+ }
17
+ &.disabled {
18
+ color: $disabled-clr;
19
+ background: $grey-lighter-clr;
20
+ cursor: not-allowed !important;
21
+ &:hover {
22
+ background-color: $grey-lighter-clr;
23
+ }
24
+ }
25
+ }
26
+
27
+ .primary-btn {
28
+ padding: 8px 16px;
29
+ @include font($size: $t4-text, $color: $brand-color, $weight: bold);
30
+ background-color: $white;
31
+ border: 1px solid $brand-color;
32
+ border-radius: $radius-4;
33
+ transition: all .2s linear;
34
+ &:hover {
35
+ background-color: #E6E4FA;
36
+ }
37
+ &:focus {
38
+ outline: 3px auto rgba(47, 128, 237, 0.3);
39
+ outline-offset: 2px;
40
+ }
41
+ &.disabled {
42
+ color: $disabled-clr;
43
+ background: $white;
44
+ border: 1px solid $grey-regular-clr;
45
+ cursor: not-allowed !important;
46
+ &:hover {
47
+ background-color: $white;
48
+ }
49
+ }
50
+ }
51
+
52
+ .secondary-btn {
53
+ padding: 8px 16px;
54
+ @include font($size: $t4-text, $color: $primary-text-clr, $weight: bold);
55
+ background-color: $white;
56
+ border: 1px solid $ink-regular-clr;
57
+ border-radius: $radius-4;
58
+ transition: all .2s linear;
59
+ &:hover {
60
+ background-color: $grey-light-clr;
61
+ }
62
+ &:focus {
63
+ outline: 3px auto rgba(47, 128, 237, 0.3);
64
+ outline-offset: 2px;
65
+ }
66
+ &.disabled {
67
+ color: $disabled-clr;
68
+ background: $white;
69
+ border: 1px solid $grey-regular-clr;
70
+ cursor: not-allowed !important;
71
+ &:hover {
72
+ background-color: $white;
73
+ }
74
+ }
75
+ span:nth-child(2) {
76
+ margin: 0 4px 0 8px;
77
+ }
78
+ }
79
+
80
+ .gray-border-btn {
81
+ padding: 7px 16px;
82
+ @include font($size: $t4-text, $color: $primary-text-clr, $weight: bold);
83
+ background-color: $white;
84
+ border: 1px solid $ink-regular-clr;
85
+ border-radius: $radius-4;
86
+ transition: all .2s linear;
87
+ &:hover {
88
+ background-color: $grey-light-clr;
89
+ }
90
+ &:focus {
91
+ outline: 3px auto rgba(47, 128, 237, 0.3);
92
+ outline-offset: 2px;
93
+ }
94
+ &.disabled {
95
+ color: $disabled-clr;
96
+ background: $white;
97
+ border: 1px solid $grey-regular-clr;
98
+ cursor: not-allowed !important;
99
+ &:hover {
100
+ background-color: $white;
101
+ }
102
+ }
103
+ }
104
+
105
+ .ghost-btn {
106
+ padding: 8px 16px;
107
+ @include font($size: $t4-text, $color: $primary-text-clr, $weight: bold);
108
+ background-color: transparent;
109
+ border: none;
110
+ border-radius: $radius-4;
111
+ transition: all .2s linear;
112
+ &:hover {
113
+ background: $grey-light-clr;
114
+ }
115
+ &:focus {
116
+ outline: 3px auto rgba(47, 128, 237, 0.3);
117
+ }
118
+ &.disabled {
119
+ color: $disabled-clr;
120
+ background: $grey-light-clr;
121
+ border: none;
122
+ cursor: not-allowed !important;
123
+ &:hover {
124
+ background-color: $grey-light-clr;
125
+ }
126
+ }
127
+ }
128
+
129
+ .text-btn {
130
+ border: none;
131
+ background-color: transparent;
132
+ &:focus {
133
+ outline: none;
134
+ }
135
+ }
@@ -0,0 +1,141 @@
1
+ @import "../helpers/index.scss";
2
+
3
+ .dropdown-popup {
4
+ width: 256px;
5
+ .popup-base {
6
+ position: absolute;
7
+ width: 256px;
8
+ height: 56px;
9
+ padding: 8px;
10
+ background: $white;
11
+ border: 1px solid $grey-lighter-clr;
12
+ box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.16);
13
+ border-radius: $radius-4;
14
+ }
15
+ .popup-inner {
16
+ position: relative;
17
+ width: 240px;
18
+ margin: 0 auto;
19
+ background-color: $white;
20
+ border: 1px solid #e0e0e0;
21
+ box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.16);
22
+ border-radius: $radius-4;
23
+ .search-area {
24
+ input {
25
+ width: 100%;
26
+ min-height: 40px;
27
+ padding: 9px 16px 9px 16px;
28
+ font-size: $t4-text;
29
+ border: none;
30
+ &::placeholder {
31
+ color: $ink-lightest-clr;
32
+ }
33
+ &:focus {
34
+ outline: 3px auto rgba(47, 128, 237, 0.3);
35
+ }
36
+ }
37
+ }
38
+ .search-with-chips {
39
+ display: flex;
40
+ flex-wrap: wrap;
41
+ padding: 8px 16px;
42
+ .chip {
43
+ display: inline-flex;
44
+ align-items: center;
45
+ margin: 2px;
46
+ padding: 0 4px;
47
+ background: $grey-lighter-clr;
48
+ border-radius: $radius-4;
49
+ span:nth-child(1) {
50
+ @include font($size: $t4-text, $color: $primary-text-clr);
51
+ line-height: 22px;
52
+ }
53
+ span:nth-child(2) {
54
+ @include font($size: 10px, $color: $ink-lightest-clr);
55
+ margin-left: 4px;
56
+ cursor: pointer;
57
+ }
58
+ }
59
+ input {
60
+ border: none;
61
+ font-size: $t4-text;
62
+ margin: 2px;
63
+ &:focus {
64
+ outline: 3px auto rgba(47, 128, 237, 0.3);
65
+ }
66
+ }
67
+ }
68
+ .list-area {
69
+ max-height: 240px;
70
+ overflow-y: auto;
71
+ border-top: 1px solid #e0e0e0;
72
+ .list-item {
73
+ display: flex;
74
+ align-items: center;
75
+ padding: 9px 16px;
76
+ label {
77
+ @include font($size: $t4-text, $color: $primary-text-clr);
78
+ line-height: 22px;
79
+ margin: 0 0 0 8px;
80
+ }
81
+ }
82
+ }
83
+ .apply-area {
84
+ @include font($size: $t4-text, $color: $ink-lightest-clr, $weight: 600);
85
+ line-height: 22px;
86
+ text-align: center;
87
+ padding: 9px 16px;
88
+ box-shadow: inset 0px 1px 0px rgba(148, 151, 155, 0.15);
89
+ cursor: pointer;
90
+ &.active {
91
+ color: $blue-regular-clr;
92
+ }
93
+ }
94
+ }
95
+ }
96
+
97
+ .applied-select {
98
+ margin-left: 20rem;
99
+ }
100
+
101
+ .column-popup {
102
+ display: inline-block;
103
+ min-width: 156px;
104
+ max-height: 295px;
105
+ background-color: $white;
106
+ filter: drop-shadow(0px 4px 16px rgba(0, 0, 0, 0.16));
107
+ border-radius: $radius-4;
108
+ z-index: 1;
109
+ .column-option {
110
+ .option-title {
111
+ @include font($size: $t6-text, $color: $ink-lightest-clr, $weight: 600);
112
+ line-height: 16px;
113
+ text-transform: uppercase;
114
+ margin: 0;
115
+ padding: 18px 16px 9px;
116
+ }
117
+ .option-action {
118
+ padding: 9px 16px;
119
+ cursor: pointer;
120
+ @include transition-linear;
121
+ &:hover {
122
+ background-color: $grey-lighter-clr;
123
+ }
124
+ .action-icon {
125
+ font-size: $t4-text;
126
+ }
127
+ .action-name {
128
+ @include font($size: $t4-text, $color: $primary-text-clr);
129
+ line-height: 22px;
130
+ margin-left: 8px;
131
+ }
132
+ }
133
+ .cannot-sort {
134
+ font-size: $t6-text;
135
+ line-height: 16px;
136
+ color: $ink-lightest-clr;
137
+ margin-bottom: 9px;
138
+ padding: 0 16px;
139
+ }
140
+ }
141
+ }
@@ -0,0 +1,274 @@
1
+ @import "../helpers/index.scss";
2
+
3
+ .form-field {
4
+ .field-label-wrapper {
5
+ .field-label {
6
+ @include font($size: $t4-text, $color: $primary-text-clr);
7
+ line-height: 22px;
8
+ margin: 0 0 4px;
9
+ span {
10
+ color: $ink-lightest-clr;
11
+ margin-left: 4px;
12
+ }
13
+ }
14
+ .field-helper-text {
15
+ @include font($size: $t4-text, $color: $ink-lighter-clr);
16
+ line-height: 22px;
17
+ margin: 0 0 4px;
18
+ }
19
+ }
20
+ .field-input-wrapper {
21
+ position: relative;
22
+ .error-msg {
23
+ @include font($size: $t4-text, $color: $error-clr);
24
+ line-height: 22px;
25
+ margin: 4px 0 0;
26
+ animation: shakeError 0.5s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
27
+ transform: translate3d(0, 0, 0);
28
+ backface-visibility: hidden;
29
+ perspective: 1000px;
30
+ span {
31
+ margin-right: 4px;
32
+ }
33
+ }
34
+ }
35
+ }
36
+
37
+ //Search input styles
38
+ .search-input {
39
+ position: relative;
40
+ width: 100%;
41
+ padding: 8px 0 8px 40px;
42
+ @include font($size: $t4-text, $color: $primary-text-clr);
43
+ line-height: 22px;
44
+ background-color: $white;
45
+ border: 1px solid $grey-light-clr;
46
+ border-radius: $radius-4;
47
+ &::placeholder {
48
+ color: $ink-lightest-clr;
49
+ }
50
+ &:focus {
51
+ outline: 3px auto rgba(47, 128, 237, 0.3);
52
+ }
53
+ }
54
+ .search-input-icon {
55
+ position: absolute;
56
+ top: 8px;
57
+ left: 16px;
58
+ @include font($size: $t4-text, $color: $ink-lightest-clr);
59
+ }
60
+
61
+ //Normal input styles
62
+ .normal-input {
63
+ width: 100%;
64
+ padding: 8px 16px;
65
+ @include font($size: $t4-text, $color: $primary-text-clr);
66
+ line-height: 22px;
67
+ background-color: $white;
68
+ border: 1px solid $grey-light-clr;
69
+ border-radius: $radius-4;
70
+ &::placeholder {
71
+ color: $ink-lightest-clr;
72
+ }
73
+ &:focus {
74
+ outline: 3px auto rgba(47, 128, 237, 0.3);
75
+ }
76
+ &.error {
77
+ border: 1px solid $error-clr;
78
+ &:focus {
79
+ outline: 3px auto rgba(248, 54, 54, 0.3);
80
+ }
81
+ }
82
+ }
83
+
84
+ .file-upload-wrapper {
85
+ display: inline-flex;
86
+ align-items: center;
87
+ .file-upload-input {
88
+ position: relative;
89
+ display: flex;
90
+ justify-content: center;
91
+ align-items: center;
92
+ padding: 5px 16px;
93
+ border: 1px solid $primary-text-clr;
94
+ border-radius: $radius-4;
95
+ cursor: pointer;
96
+ input[type="file"] {
97
+ position: absolute;
98
+ top: 0;
99
+ right: 0;
100
+ bottom: 0;
101
+ left: 0;
102
+ width: 100%;
103
+ height: 100%;
104
+ opacity: 0;
105
+ cursor: pointer;
106
+ &::-webkit-file-upload-button {
107
+ cursor: pointer;
108
+ }
109
+ }
110
+
111
+ .upload-placeholder-1 {
112
+ @include font($size: $t4-text, $color: $ink-lighter-clr, $weight: 600);
113
+ }
114
+ .upload-placeholder-2 {
115
+ @include font($size: $t4-text, $color: $primary-text-clr, $weight: 600);
116
+ margin-left: 4px;
117
+ }
118
+ }
119
+ .file-name {
120
+ @include font($size: $t4-text, $color: $primary-text-clr);
121
+ margin: 0 0 0 8px;
122
+ }
123
+ }
124
+
125
+ //checkbox-style
126
+ input.cm-checkbox[type="checkbox"] {
127
+ position: relative;
128
+ // display: block;
129
+ display: inline-block;
130
+ width: 16px;
131
+ height: 16px;
132
+ // float: left;
133
+ -webkit-font-smoothing: antialiased;
134
+ text-rendering: optimizeSpeed;
135
+ &:hover::after {
136
+ background: $grey-lighter-clr;
137
+ }
138
+ &:after {
139
+ content: "";
140
+ vertical-align: middle;
141
+ text-align: center;
142
+ position: absolute;
143
+ height: 16px;
144
+ width: 16px;
145
+ font-size: 11px;
146
+ line-height: 17px;
147
+ background: $white;
148
+ border: 1.5px solid $grey-regular-clr;
149
+ border-radius: $radius-2;
150
+ cursor: pointer;
151
+ }
152
+ &:checked:after {
153
+ background: $brand-color;
154
+ content: "\f00c";
155
+ font-family: FontAwesome !important;
156
+ color: $white;
157
+ border: none;
158
+ }
159
+ &.disabled {
160
+ &:hover::after {
161
+ background: transparent;
162
+ cursor: not-allowed;
163
+ }
164
+ &:checked:after {
165
+ background: $grey-light-clr;
166
+ content: "\f00c";
167
+ font-family: FontAwesome !important;
168
+ color: $white;
169
+ border: none;
170
+ }
171
+ }
172
+ }
173
+
174
+ //Radio button styles
175
+ input.cm-radio[type="radio"] {
176
+ position: relative;
177
+ display: inline-block;
178
+ width: 16px;
179
+ height: 14px;
180
+ -webkit-font-smoothing: antialiased;
181
+ text-rendering: optimizeSpeed;
182
+ &:focus {
183
+ outline: none;
184
+ }
185
+ &:hover::after {
186
+ background: $grey-lighter-clr;
187
+ }
188
+ &:after {
189
+ content: "";
190
+ vertical-align: middle;
191
+ text-align: center;
192
+ position: absolute;
193
+ height: 16px;
194
+ width: 16px;
195
+ background-color: $white;
196
+ border: 1.5px solid $grey-regular-clr;
197
+ border-radius: $circle;
198
+ cursor: pointer;
199
+ }
200
+ &:checked:after {
201
+ background: $brand-color;
202
+ content: "\25CF";
203
+ color: $white;
204
+ font-size: 9px;
205
+ line-height: 16px;
206
+ border: none;
207
+ }
208
+ &.disabled {
209
+ &:hover::after {
210
+ background: transparent;
211
+ cursor: not-allowed;
212
+ }
213
+ &:checked:after {
214
+ background: $grey-light-clr;
215
+ content: "\25CF";
216
+ color: $white;
217
+ font-size: 9px;
218
+ line-height: 16px;
219
+ border: none;
220
+ }
221
+ }
222
+ }
223
+
224
+ //Switch styles
225
+ .cm-switch {
226
+ position: relative;
227
+ display: inline-block;
228
+ width: 36px;
229
+ height: 22px;
230
+
231
+ input {
232
+ display: none;
233
+ }
234
+
235
+ .slider {
236
+ position: absolute;
237
+ cursor: pointer;
238
+ top: 0;
239
+ left: 0;
240
+ right: 0;
241
+ bottom: 0;
242
+ background: $grey-light-clr;
243
+ transition: all .2s linear;
244
+ }
245
+
246
+ .slider:before {
247
+ position: absolute;
248
+ content: "";
249
+ width: 18px;
250
+ height: 18px;
251
+ left: 2px;
252
+ bottom: 2px;
253
+ background-color: $white;
254
+ transition: all .2s linear;
255
+ }
256
+
257
+ input:checked + .slider {
258
+ background: $brand-color;
259
+ }
260
+
261
+ input:checked + .slider:before {
262
+ -webkit-transform: translateX(14px);
263
+ -ms-transform: translateX(14px);
264
+ transform: translateX(14px);
265
+ }
266
+
267
+ .slider.round {
268
+ border-radius: 12px;
269
+ }
270
+
271
+ .slider.round:before {
272
+ border-radius: $circle;
273
+ }
274
+ }