docks_theme_api 1.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (237) hide show
  1. checksums.yaml +15 -0
  2. data/.babelrc +4 -0
  3. data/.editorconfig +8 -0
  4. data/.eslintrc +115 -0
  5. data/.gitignore +24 -0
  6. data/.rubocop.yml +20 -0
  7. data/.travis.yml +16 -0
  8. data/Gemfile +4 -0
  9. data/README.md +5 -0
  10. data/Rakefile +3 -0
  11. data/assets/images/icons.svg +63 -0
  12. data/assets/scripts/coffeescript/pattern_library_helpers.coffee +8 -0
  13. data/assets/scripts/javascript/pattern_library_helpers.js +11 -0
  14. data/assets/scripts/pattern_library.js +10380 -0
  15. data/assets/scripts/pattern_library_demo.js +0 -0
  16. data/assets/styles/less/pattern-library-helpers.less +103 -0
  17. data/assets/styles/pattern-library-demo.css +1882 -0
  18. data/assets/styles/pattern-library.css +1882 -0
  19. data/assets/styles/sass/pattern-library-helpers.sass +90 -0
  20. data/assets/styles/scss/pattern-library-helpers.scss +99 -0
  21. data/assets/styles/stylus/pattern-library-helpers.styl +90 -0
  22. data/assets/templates/erb/demo.erb +26 -0
  23. data/assets/templates/erb/layouts/demo.erb +17 -0
  24. data/assets/templates/erb/layouts/pattern.erb +76 -0
  25. data/assets/templates/erb/partials/sidebar.erb +124 -0
  26. data/assets/templates/erb/partials/symbols/class.erb +1 -0
  27. data/assets/templates/erb/partials/symbols/demo.erb +40 -0
  28. data/assets/templates/erb/partials/symbols/factory.erb +70 -0
  29. data/assets/templates/erb/partials/symbols/function.erb +103 -0
  30. data/assets/templates/erb/partials/symbols/mixin.erb +62 -0
  31. data/assets/templates/erb/partials/symbols/variable.erb +59 -0
  32. data/assets/templates/erb/pattern.erb +102 -0
  33. data/assets/templates/haml/demo.haml +14 -0
  34. data/assets/templates/haml/layouts/demo.haml +6 -0
  35. data/assets/templates/haml/layouts/pattern.haml +38 -0
  36. data/assets/templates/haml/partials/sidebar.haml +68 -0
  37. data/assets/templates/haml/partials/symbols/class.haml +1 -0
  38. data/assets/templates/haml/partials/symbols/demo.haml +23 -0
  39. data/assets/templates/haml/partials/symbols/factory.haml +38 -0
  40. data/assets/templates/haml/partials/symbols/function.haml +54 -0
  41. data/assets/templates/haml/partials/symbols/mixin.haml +31 -0
  42. data/assets/templates/haml/partials/symbols/variable.haml +22 -0
  43. data/assets/templates/haml/pattern.haml +54 -0
  44. data/assets/templates/slim/demo.slim +24 -0
  45. data/assets/templates/slim/layouts/demo.slim +5 -0
  46. data/assets/templates/slim/layouts/pattern.slim +48 -0
  47. data/assets/templates/slim/partials/sidebar.slim +112 -0
  48. data/assets/templates/slim/partials/symbols/class.slim +1 -0
  49. data/assets/templates/slim/partials/symbols/demo.slim +30 -0
  50. data/assets/templates/slim/partials/symbols/factory.slim +57 -0
  51. data/assets/templates/slim/partials/symbols/function.slim +81 -0
  52. data/assets/templates/slim/partials/symbols/mixin.slim +45 -0
  53. data/assets/templates/slim/partials/symbols/variable.slim +35 -0
  54. data/assets/templates/slim/pattern.slim +63 -0
  55. data/docks_config.rb +32 -0
  56. data/docks_theme_api.gemspec +37 -0
  57. data/gulpfile.js +88 -0
  58. data/karma.conf.js +6 -0
  59. data/lib/docks_theme_api/components/base_component.rb +99 -0
  60. data/lib/docks_theme_api/components/code_block_component.rb +10 -0
  61. data/lib/docks_theme_api/components/popover_component.rb +15 -0
  62. data/lib/docks_theme_api/components/table_component.rb +34 -0
  63. data/lib/docks_theme_api/components/tablist_component.rb +11 -0
  64. data/lib/docks_theme_api/components.rb +21 -0
  65. data/lib/docks_theme_api/helpers/ui_helper.rb +69 -0
  66. data/lib/docks_theme_api/theme.rb +21 -0
  67. data/lib/docks_theme_api.rb +1 -0
  68. data/package.json +60 -0
  69. data/source/behaviors/filterable/filterable.coffee +353 -0
  70. data/source/behaviors/filterable/filterable.js +0 -0
  71. data/source/behaviors/filterable/filterable.scss +34 -0
  72. data/source/behaviors/filterable/package.json +3 -0
  73. data/source/behaviors/index.js +0 -0
  74. data/source/components/avatar/avatar.erb +20 -0
  75. data/source/components/avatar/avatar.js +142 -0
  76. data/source/components/avatar/avatar.scss +200 -0
  77. data/source/components/avatar/avatar_container.erb +13 -0
  78. data/source/components/avatar/package.json +3 -0
  79. data/source/components/avatar/spec/avatar_spec.js +81 -0
  80. data/source/components/badge/badge.scss +158 -0
  81. data/source/components/button/button.scss +213 -0
  82. data/source/components/card/card.scss +32 -0
  83. data/source/components/code_block/code-block.scss +353 -0
  84. data/source/components/code_block/code_block.erb +95 -0
  85. data/source/components/code_block/code_block.js +444 -0
  86. data/source/components/code_block/package.json +3 -0
  87. data/source/components/code_block/spec/code_block_spec.js +10 -0
  88. data/source/components/demo/demo.js +244 -0
  89. data/source/components/demo/demo.scss +90 -0
  90. data/source/components/demo/package.json +3 -0
  91. data/source/components/exploded/exploded.erb +25 -0
  92. data/source/components/exploded/exploded.js +694 -0
  93. data/source/components/exploded/exploded.scss +166 -0
  94. data/source/components/exploded/package.json +3 -0
  95. data/source/components/field/field.js +24 -0
  96. data/source/components/field/field.scss +101 -0
  97. data/source/components/field/package.json +3 -0
  98. data/source/components/header/header.scss +33 -0
  99. data/source/components/iframe/iframe.erb +12 -0
  100. data/source/components/iframe/iframe.js +381 -0
  101. data/source/components/iframe/package.json +3 -0
  102. data/source/components/index.js +37 -0
  103. data/source/components/inline_group/inline-group.scss +14 -0
  104. data/source/components/internal_link/internal_link.js +49 -0
  105. data/source/components/internal_link/package.json +3 -0
  106. data/source/components/list/list.scss +230 -0
  107. data/source/components/modal/modal.coffee +84 -0
  108. data/source/components/modal/modal.erb +19 -0
  109. data/source/components/modal/modal.js +0 -0
  110. data/source/components/modal/modal.scss +57 -0
  111. data/source/components/modal/package.json +3 -0
  112. data/source/components/notice/notice.scss +48 -0
  113. data/source/components/popover/package.json +3 -0
  114. data/source/components/popover/popover.coffee +562 -0
  115. data/source/components/popover/popover.erb +21 -0
  116. data/source/components/popover/popover.js +0 -0
  117. data/source/components/popover/popover.scss +139 -0
  118. data/source/components/range/range.scss +78 -0
  119. data/source/components/resizable/package.json +3 -0
  120. data/source/components/resizable/resizable.erb +30 -0
  121. data/source/components/resizable/resizable.js +250 -0
  122. data/source/components/resizable/resizable.scss +245 -0
  123. data/source/components/resizable/size_buttons.js +249 -0
  124. data/source/components/scroll_container/package.json +3 -0
  125. data/source/components/scroll_container/scroll-container.scss +4 -0
  126. data/source/components/scroll_container/scroll_container.js +24 -0
  127. data/source/components/section/section.scss +99 -0
  128. data/source/components/select/package.json +3 -0
  129. data/source/components/select/select.erb +21 -0
  130. data/source/components/select/select.js +35 -0
  131. data/source/components/select/select.scss +163 -0
  132. data/source/components/table/package.json +3 -0
  133. data/source/components/table/table.erb +16 -0
  134. data/source/components/table/table.js +351 -0
  135. data/source/components/table/table.scss +236 -0
  136. data/source/components/tablist/package.json +3 -0
  137. data/source/components/tablist/tablist.erb +13 -0
  138. data/source/components/tablist/tablist.js +246 -0
  139. data/source/components/tablist/tablist.scss +191 -0
  140. data/source/components/tablist/tablist_panel.erb +14 -0
  141. data/source/components/tablist/tablist_tab.erb +20 -0
  142. data/source/components/toggle/package.json +3 -0
  143. data/source/components/toggle/toggle.erb +11 -0
  144. data/source/components/toggle/toggle.js +211 -0
  145. data/source/components/toggle/toggle_container.erb +30 -0
  146. data/source/components/vertical_spacer/vertical-spacer.scss +3 -0
  147. data/source/components/vertical_stack/vertical-stack.scss +19 -0
  148. data/source/components/xray/package.json +3 -0
  149. data/source/components/xray/xray.erb +50 -0
  150. data/source/components/xray/xray.js +123 -0
  151. data/source/components/xray/xray.scss +79 -0
  152. data/source/foundation/app/app.js +15 -0
  153. data/source/foundation/app/package.json +3 -0
  154. data/source/pattern-library-demo.scss +13 -0
  155. data/source/pattern-library.scss +13 -0
  156. data/source/pattern_library.js +8 -0
  157. data/source/pattern_library_demo.js +8 -0
  158. data/source/structures/index.js +11 -0
  159. data/source/structures/sidebar/package.json +3 -0
  160. data/source/structures/sidebar/sidebar.js +69 -0
  161. data/source/structures/sidebar/sidebar.scss +79 -0
  162. data/source/utilities/builder/builder.js +138 -0
  163. data/source/utilities/builder/package.json +3 -0
  164. data/source/utilities/client/client.js +7 -0
  165. data/source/utilities/client/package.json +3 -0
  166. data/source/utilities/colors/colors.scss +112 -0
  167. data/source/utilities/defaults/defaults.scss +38 -0
  168. data/source/utilities/dom_cache/dom_cache.js +24 -0
  169. data/source/utilities/dom_cache/package.json +3 -0
  170. data/source/utilities/events/events.js +25 -0
  171. data/source/utilities/events/package.json +3 -0
  172. data/source/utilities/font_sizes/font-sizes.scss +85 -0
  173. data/source/utilities/foundation/a11y.scss +10 -0
  174. data/source/utilities/foundation/base.scss +29 -0
  175. data/source/utilities/foundation/icon.scss +114 -0
  176. data/source/utilities/foundation/layout.scss +67 -0
  177. data/source/utilities/foundation/page.scss +39 -0
  178. data/source/utilities/foundation/type.scss +208 -0
  179. data/source/utilities/functions/functions.scss +127 -0
  180. data/source/utilities/keycodes/keycodes.js +23 -0
  181. data/source/utilities/keycodes/package.json +3 -0
  182. data/source/utilities/markup/markup.js +90 -0
  183. data/source/utilities/markup/package.json +3 -0
  184. data/source/utilities/media/media.scss +172 -0
  185. data/source/utilities/mixins/mixins.scss +89 -0
  186. data/source/utilities/naming_convention/naming_convention.js +3 -0
  187. data/source/utilities/naming_convention/package.json +3 -0
  188. data/source/utilities/numbers/numbers.js +14 -0
  189. data/source/utilities/numbers/package.json +3 -0
  190. data/source/utilities/painting/package.json +3 -0
  191. data/source/utilities/painting/painting.js +7 -0
  192. data/source/utilities/pattern/package.json +3 -0
  193. data/source/utilities/pattern/pattern.js +50 -0
  194. data/source/utilities/query_string/package.json +3 -0
  195. data/source/utilities/query_string/query_string.js +24 -0
  196. data/source/utilities/template/package.json +3 -0
  197. data/source/utilities/template/template.js +10 -0
  198. data/source/utilities/text_range/package.json +3 -0
  199. data/source/utilities/text_range/text_range.js +30 -0
  200. data/source/utilities/ui_events/package.json +3 -0
  201. data/source/utilities/ui_events/ui_events.js +85 -0
  202. data/source/utilities/variables/variables.scss +18 -0
  203. data/source/utilities/z_indexes/z-indexes.scss +88 -0
  204. data/source/vendor/array_includes.js +28 -0
  205. data/source/vendor/highlight.js +1142 -0
  206. data/source/vendor/index.js +1 -0
  207. data/source/vendor/matrix.js +399 -0
  208. data/source/vendor/query_string.js +66 -0
  209. data/spec/assets/.eslintrc +9 -0
  210. data/spec/assets/spec_fixture.js +33 -0
  211. data/spec/assets/spec_helper.js +19 -0
  212. data/spec/lib/components/base_component_spec.rb +156 -0
  213. data/spec/lib/components_spec.rb +30 -0
  214. data/spec/lib/helpers/ui_helper_spec.rb +62 -0
  215. data/spec/lib/theme_spec.rb +25 -0
  216. data/spec/spec_helper.rb +15 -0
  217. data/tasks/gulp/.eslintrc +6 -0
  218. data/tasks/gulp/browser_sync.js +8 -0
  219. data/tasks/gulp/code_quality/scripts.js +10 -0
  220. data/tasks/gulp/config/index.js +116 -0
  221. data/tasks/gulp/minify/scripts.js +13 -0
  222. data/tasks/gulp/minify/styles.js +13 -0
  223. data/tasks/gulp/pattern_library/index.js +5 -0
  224. data/tasks/gulp/pattern_library/scripts.js +10 -0
  225. data/tasks/gulp/pattern_library/styles.js +10 -0
  226. data/tasks/gulp/scripts.js +8 -0
  227. data/tasks/gulp/spec/scripts.js +11 -0
  228. data/tasks/gulp/styles.js +17 -0
  229. data/tasks/gulp/utilities/babel/relative_require.js +22 -0
  230. data/tasks/gulp/utilities/babel/spec_helper.js +20 -0
  231. data/tasks/gulp/utilities/browserify_bundler.js +22 -0
  232. data/tasks/gulp/utilities/handle_errors.js +13 -0
  233. data/tasks/gulp/watch.js +9 -0
  234. data/tasks/rake/rspec.rake +7 -0
  235. data/tasks/rake/rubocop.rake +8 -0
  236. data/tasks/rake/templates.rake +50 -0
  237. metadata +470 -0
@@ -0,0 +1,230 @@
1
+ // ___
2
+ // ___ / /\ ___
3
+ // / /\ / /:/_ / /\
4
+ // ___ ___ / /:/ / /:/ /\ / /:/
5
+ // /__/\ / /\/__/::\ / /:/ /::\ / /:/
6
+ // \ \:\ / /:/\__\/\:\__/__/:/ /:/\:\/ /::\
7
+ // \ \:\ /:/ \ \:\/\ \:\/:/~/:/__/:/\:\
8
+ // \ \:\/:/ \__\::/\ \::/ /:/\__\/ \:\
9
+ // \ \::/ /__/:/ \__\/ /:/ \ \:\
10
+ // \__\/ \__\/ /__/:/ \__\/
11
+ // \__\/
12
+
13
+ //*
14
+ // @pattern List
15
+ //
16
+ // A list allows you to present a set of selectable items vertically. These
17
+ // lists can be be separated into any number of sublists, and two levels of
18
+ // subheadings are available (so, you can have a sublist within a sublist).
19
+ //
20
+ // The sublists can optionally allow a subheading to toggle the visibility of
21
+ // the associated sublist. It also supports the ability to filter the contents
22
+ // of a list to only items matching a given string, hiding subheadings as
23
+ // necessary.
24
+ //
25
+ // @since 1.0.0
26
+
27
+
28
+
29
+ //*
30
+ // The core container for a list. List items can go directly in this container
31
+ // or, if you want to provide toggle-able or filter-able sublists, within a
32
+ // sublist.
33
+
34
+ .list {
35
+ padding: 0;
36
+ margin: default(spacing) 0 double(default(spacing));
37
+ list-style: none;
38
+
39
+ .type--heading {
40
+ padding-left: default(spacing);
41
+ padding-right: default(spacing);
42
+ }
43
+
44
+ .popover & {
45
+ margin-bottom: default(spacing);
46
+ }
47
+ }
48
+
49
+ //*
50
+ // An individual item within a list. These items have hover, focus, and active
51
+ // states so that it is clear what item is actionable/ being actioned.
52
+
53
+ .list__item {
54
+ // box model
55
+ display: block;
56
+ padding: quarter(default(spacing)) default(spacing);
57
+
58
+ // backdrop
59
+ cursor: pointer;
60
+
61
+ // type
62
+ text-decoration: none;
63
+ color: ui-color(gray, darkest);
64
+ white-space: nowrap;
65
+ text-overflow: ellipsis;
66
+ overflow: hidden;
67
+
68
+ &:hover,
69
+ &:focus {
70
+ outline: none;
71
+ background: ui-color(gray, light);
72
+ }
73
+
74
+ &:active {
75
+ background-color: ui-color(blue);
76
+ color: ui-color(blue, darker);
77
+ }
78
+ }
79
+
80
+ //*
81
+ // An item that is currently active For example, in the sidebar, this class is
82
+ // used for the item representing the currently-active pattern.
83
+
84
+ .list__item--is-active {
85
+ &,
86
+ &:hover,
87
+ &:focus {
88
+ background-color: ui-color(blue);
89
+ color: ui-color(blue, darker);
90
+ }
91
+ }
92
+
93
+ //*
94
+ // A list item that is indented on the left to indicate that it is related to
95
+ // the closest, non-indented item above it.
96
+
97
+ .list__item--indented {
98
+ padding-left: calc(#{default(spacing)} + 2ch);
99
+ position: relative;
100
+
101
+ &:before {
102
+ content: "";
103
+ display: block;
104
+ position: absolute;
105
+ left: calc(#{default(spacing)} + 1ch);
106
+ top: 0;
107
+ height: 100%;
108
+ width: 2px;
109
+ background: rgba(ui-color(black), 0.07);
110
+ }
111
+
112
+ &:last-child:before {
113
+ height: 85%;
114
+ }
115
+
116
+ .list__item:not(.list__item--indented) + &:before {
117
+ top: 15%;
118
+ height: 85%;
119
+ }
120
+ }
121
+
122
+ //*
123
+ // A subset of items that have their own hading to distinguish them. This
124
+ // subcomponent can contain any number of items and/ or other sublists. This
125
+ // grouping also allows the [`Filterable`](@link filterable) component to
126
+ // accurately hide subsets of the list, including headings within a group
127
+ // where all items are hidden.
128
+
129
+ .list__group {}
130
+
131
+
132
+
133
+ //*
134
+ // A horizontal list of links separated by slashes.
135
+
136
+ .link-list {
137
+ padding: 0;
138
+ margin: 0;
139
+ list-style: none;
140
+ display: flex;
141
+ flex-wrap: wrap;
142
+
143
+ > li {
144
+ position: relative;
145
+ flex: 0 0 auto;
146
+
147
+ &:after {
148
+ $link-list__item--separator-height: 80%;
149
+
150
+ content: "";
151
+
152
+ // position
153
+ position: absolute;
154
+ top: half(100% - $link-list__item--separator-height);
155
+ right: -1px;
156
+ transform: rotate(15deg);
157
+
158
+ // box model
159
+ display: block;
160
+ height: $link-list__item--separator-height;
161
+
162
+ // backdrop
163
+ border-right: 2px solid rgba(ui-color(gray, darkest), 0.1);
164
+ }
165
+
166
+ &:last-child:after {
167
+ display: none;
168
+ margin-right: 0;
169
+ }
170
+ }
171
+ }
172
+
173
+ //*
174
+ // An individual list within a link list. This class should go on the actual
175
+ // anchor (or `button`, if there is no reasonable `href`) element so that
176
+ // there is as large a hit target as possible.
177
+ //
178
+ // Each item (except for the last one) is given a small separator so that it is
179
+ // clear where the hit areas end. This is placed on the containing `li` since
180
+ // the `link-list__item` can be a `button`.
181
+ //
182
+ // In the dark theme, the colors for each list item invert.
183
+
184
+ .link-list__item {
185
+ // position
186
+ position: relative;
187
+
188
+ // box model
189
+ display: block;
190
+ cursor: pointer;
191
+ padding: quarter(default(spacing)) half(default(spacing));
192
+
193
+ // backdrop
194
+ @include remove-browser-styling;
195
+ background: none;
196
+ border: none;
197
+ opacity: 0.6;
198
+
199
+ // type
200
+ font-size: 1em;
201
+ line-height: 1;
202
+ color: ui-color(gray, darker);
203
+ transition: opacity 0.25s ease;
204
+
205
+ &:hover,
206
+ &:focus {
207
+ opacity: 1;
208
+ outline: none;
209
+ }
210
+ }
211
+
212
+
213
+
214
+ //*
215
+ // A list that simply arranges the contained `li`s with some spacing between
216
+ // them.
217
+
218
+ .unstyled-list {
219
+ margin: 0;
220
+ padding: 0;
221
+ list-style: none;
222
+
223
+ > li {
224
+ margin: double(default(spacing)) 0;
225
+
226
+ &:first-child {
227
+ margin-top: 0;
228
+ }
229
+ }
230
+ }
@@ -0,0 +1,84 @@
1
+ BASE_CLASS = "details-sheet"
2
+
3
+ CLASSES =
4
+ BASE: BASE_CLASS
5
+ OVERLAY: "#{BASE_CLASS}__overlay"
6
+ CLOSER: "#{BASE_CLASS}__close"
7
+ NAME: "#{BASE_CLASS}__name"
8
+ TYPE: "#{BASE_CLASS}__type"
9
+ DESCRIPTION: "#{BASE_CLASS}__description"
10
+ PRECLUDES: "#{BASE_CLASS}__precludes"
11
+ ACTIVATE_WITH: "#{BASE_CLASS}__activate-with"
12
+ SET_BY: "#{BASE_CLASS}__set-by"
13
+
14
+ STATES =
15
+ BASE: ACTIVE: "#{CLASSES.BASE}--is-active"
16
+ OVERLAY: ACTIVE: "#{CLASSES.OVERLAY}--is-active"
17
+
18
+
19
+ create_comma_string = (items, options = {}) ->
20
+ connector = options.connector || "and"
21
+ string = ""
22
+
23
+ for item, index in items
24
+ new_string = "<code>#{item}</code>"
25
+ new_string = ", #{new_string}" if index > 0 && index < items.length - 1
26
+ new_string = ", #{connector} #{new_string}" if index > 0 && index == items.length - 1 && items.length > 2
27
+ new_string = " #{connector} #{new_string}" if index > 0 && index == items.length - 1 && items.length == 2
28
+ string += new_string
29
+
30
+ string
31
+
32
+ sheet = undefined
33
+
34
+ fill_in_details = (details) ->
35
+ sheet.name.innerHTML = details.name
36
+ node.innerHTML = details.type for node in sheet.type
37
+
38
+ sheet.description.innerHTML = details.description
39
+ sheet.description.parentNode.style.display = if details.description.length then "" else "none"
40
+
41
+ for complex_attr in ["precludes", "activate_with", "set_by"]
42
+ sheet[complex_attr].innerHTML = create_comma_string(details[complex_attr])
43
+ sheet[complex_attr].parentNode.style.display = if details[complex_attr].length then "" else "none"
44
+
45
+ show_sheet = ->
46
+ sheet.base.classList.add(STATES.BASE.ACTIVE)
47
+ sheet.overlay.classList.add(STATES.OVERLAY.ACTIVE)
48
+
49
+ hide_sheet = ->
50
+ sheet.base.classList.remove(STATES.BASE.ACTIVE)
51
+ sheet.overlay.classList.remove(STATES.OVERLAY.ACTIVE)
52
+
53
+
54
+ $ ->
55
+ node = document.querySelector(".#{CLASSES.BASE}")
56
+ return unless node
57
+
58
+ sheet =
59
+ base: node
60
+ overlay: node.nextElementSibling
61
+ name: node.querySelector(".#{CLASSES.NAME}")
62
+ type: node.querySelectorAll(".#{CLASSES.TYPE}")
63
+ description: node.querySelector(".#{CLASSES.DESCRIPTION}")
64
+ precludes: node.querySelector(".#{CLASSES.PRECLUDES}")
65
+ activate_with: node.querySelector(".#{CLASSES.ACTIVATE_WITH}")
66
+ set_by: node.querySelector(".#{CLASSES.SET_BY}")
67
+
68
+ $(document).on("click touchend", ".#{CLASSES.OVERLAY}", hide_sheet)
69
+
70
+ DetailsSheet =
71
+ present: (details) ->
72
+ return unless sheet
73
+ fill_in_details(details)
74
+ show_sheet()
75
+
76
+ receive: (event) ->
77
+ return unless event.type == Docks.EVENTS.INFO_REQUEST
78
+
79
+ @present(event.details)
80
+
81
+ Lemon.mix(Docks.Iframe.Mixins.Registerable, into: DetailsSheet)
82
+ $ -> Docks.Iframe.register_with_all_iframes(DetailsSheet)
83
+
84
+ window.Docks.DetailsSheet = DetailsSheet
@@ -0,0 +1,19 @@
1
+ <div class="details-sheet">
2
+ <div class="details-sheet__section">
3
+ <h6 class="details-sheet__subtitle">Details for</h6>
4
+ <h5 class="details-sheet__name"></h5>
5
+ </div>
6
+
7
+ <div class="details-sheet__section">
8
+ <div class="details-sheet__description"></div>
9
+ </div>
10
+
11
+ <div class="details-sheet__section">
12
+ <p>When using this <span class="details-sheet__type"></span>, always also use <span class="details-sheet__activate-with"></span>.</p>
13
+ <p>Don't use this <span class="details-sheet__type"></span> with <span class="details-sheet__precludes"></span>.</p>
14
+ <p>This <span class="details-sheet__type"></span> is set by <span class="details-sheet__set-by"></span>.</p>
15
+ </div>
16
+ </div>
17
+
18
+
19
+ <div class="details-sheet__overlay"></div>
File without changes
@@ -0,0 +1,57 @@
1
+ .details-sheet {
2
+ max-width: 90%;
3
+ position: fixed;
4
+ top: 50%; left: 50%;
5
+ transform: translate(-50%, -50%);
6
+ background-color: white;
7
+ border-radius: 0.4rem;
8
+ box-shadow: 0 0 10px rgba(color(black), 0.3);
9
+ z-index: 20;
10
+ display: none;
11
+ }
12
+
13
+ .details-sheet--is-active {
14
+ display: block;
15
+ }
16
+
17
+ .details-sheet__overlay {
18
+ background: rgba(color(black), 0.9);
19
+ position: absolute;
20
+ top: 0; bottom: 0;
21
+ right: 0; left: 0;
22
+ z-index: 19;
23
+ display: none;
24
+ }
25
+
26
+ .details-sheet__overlay--is-active {
27
+ display: block;
28
+ }
29
+
30
+
31
+ .details-sheet__section {
32
+ padding: 1rem;
33
+
34
+ + .details-sheet__section {
35
+ border-top: 1px solid color(sky-dark);
36
+ }
37
+ }
38
+
39
+ .details-sheet__name {
40
+ display: inline-block;
41
+ background-color: color(sky-light);
42
+ padding: 0.1rem 0.25em;
43
+ border-radius: 0.25em;
44
+ color: color(slate-light);
45
+ font-size: 1.2em;
46
+ font-family: Consolas, monospace;
47
+ margin: 0;
48
+ }
49
+
50
+ .details-sheet__subtitle {
51
+ margin: 0 0 0.5rem;
52
+ font-size: 0.6rem;
53
+ text-transform: uppercase;
54
+ color: color(slate-light);
55
+ opacity: 0.3;
56
+ font-weight: 600;
57
+ }
@@ -0,0 +1,3 @@
1
+ {
2
+ "main": "modal.js"
3
+ }
@@ -0,0 +1,48 @@
1
+ //*
2
+ // @pattern Notice
3
+ //
4
+ // A simple, colored container around that emphasizes the contained text. This
5
+ // should be used for important details about a symbol; for example, to
6
+ // indicate that a component is deprecated or experimental.
7
+ //
8
+ // @since 1.0.0
9
+
10
+
11
+ //*
12
+ // A regular notice.
13
+ //
14
+ // @markup
15
+ // <div class="notice">
16
+ // <div class="type-container">
17
+ // <p>Please don't use this component anymore! It's no good.</p>
18
+ // </div>
19
+ // </div>
20
+
21
+ .notice {
22
+ background-color: ui-color(yellow);
23
+ width: fit-content;
24
+ color: ui-color(yellow, dark);
25
+ padding: 1rem;
26
+ border-radius: default(border-radius);
27
+ @include font-size(paragraph-small);
28
+ position: relative;
29
+
30
+ .type, p, code {
31
+ color: inherit;
32
+ font-size: inherit;
33
+ }
34
+
35
+ .type--heading {
36
+ font-weight: 400;
37
+ }
38
+ }
39
+
40
+ //*
41
+ // A notice that indicates something is new about the attached symbol.
42
+ //
43
+ // @demo_type joint
44
+
45
+ .notice--new {
46
+ background-color: ui-color(blue);
47
+ color: ui-color(blue, darker);
48
+ }
@@ -0,0 +1,3 @@
1
+ {
2
+ "main": "popover.js"
3
+ }