@nanoporetech-digital/components 2.5.0 → 2.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/dist/cjs/{form-control-3bc82e3e.js → form-control-8f530f7d.js} +18 -20
  3. package/dist/cjs/form-control-8f530f7d.js.map +1 -0
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/nano-checkbox-group.cjs.entry.js +1 -1
  6. package/dist/cjs/nano-checkbox-group.cjs.entry.js.map +1 -1
  7. package/dist/cjs/nano-checkbox.cjs.entry.js +1 -1
  8. package/dist/cjs/nano-components.cjs.js +1 -1
  9. package/dist/cjs/nano-date-input.cjs.entry.js +1 -1
  10. package/dist/cjs/nano-date-input.cjs.entry.js.map +1 -1
  11. package/dist/cjs/nano-dropdown.cjs.entry.js +1 -1
  12. package/dist/cjs/nano-file-upload.cjs.entry.js +1 -1
  13. package/dist/cjs/nano-file-upload.cjs.entry.js.map +1 -1
  14. package/dist/cjs/nano-global-nav.cjs.entry.js +50 -47
  15. package/dist/cjs/nano-global-nav.cjs.entry.js.map +1 -1
  16. package/dist/cjs/nano-input.cjs.entry.js +6 -6
  17. package/dist/cjs/nano-input.cjs.entry.js.map +1 -1
  18. package/dist/cjs/nano-nav-item_2.cjs.entry.js +18 -13
  19. package/dist/cjs/nano-nav-item_2.cjs.entry.js.map +1 -1
  20. package/dist/cjs/nano-tooltip.cjs.entry.js +1 -1
  21. package/dist/cjs/{popover-8c86d338.js → popover-5f152a19.js} +3 -8
  22. package/dist/cjs/{popover-8c86d338.js.map → popover-5f152a19.js.map} +1 -1
  23. package/dist/collection/components/accordion/accordion.js +1 -1
  24. package/dist/collection/components/alert/alert.js +1 -1
  25. package/dist/collection/components/algolia/algolia-filter.js +2 -2
  26. package/dist/collection/components/algolia/algolia-input.js +5 -5
  27. package/dist/collection/components/algolia/algolia-results.js +1 -1
  28. package/dist/collection/components/algolia/algolia.js +6 -6
  29. package/dist/collection/components/checkbox/checkbox-group.css +4 -1
  30. package/dist/collection/components/checkbox/checkbox-group.js +2 -2
  31. package/dist/collection/components/checkbox/checkbox.css +2 -2
  32. package/dist/collection/components/checkbox/checkbox.js +3 -3
  33. package/dist/collection/components/datalist/datalist.js +1 -1
  34. package/dist/collection/components/date-input/date-input.css +1 -0
  35. package/dist/collection/components/date-input/date-input.js +7 -7
  36. package/dist/collection/components/date-picker/date-picker.js +5 -5
  37. package/dist/collection/components/details/details.js +1 -1
  38. package/dist/collection/components/dialog/dialog.js +1 -1
  39. package/dist/collection/components/dropdown/dropdown.js +1 -1
  40. package/dist/collection/components/file-upload/file-upload.css +2 -2
  41. package/dist/collection/components/file-upload/file-upload.js +4 -4
  42. package/dist/collection/components/form-control/form-control.js +17 -19
  43. package/dist/collection/components/form-control/form-control.js.map +1 -1
  44. package/dist/collection/components/global-nav/global-nav.js +78 -50
  45. package/dist/collection/components/global-nav/global-nav.js.map +1 -1
  46. package/dist/collection/components/grid/grid-item.js +1 -1
  47. package/dist/collection/components/icon/icon.js +1 -1
  48. package/dist/collection/components/input/input.css +200 -258
  49. package/dist/collection/components/input/input.js +9 -9
  50. package/dist/collection/components/input/input.js.map +1 -1
  51. package/dist/collection/components/nav-item/nav-item.css +22 -0
  52. package/dist/collection/components/nav-item/nav-item.js +34 -6
  53. package/dist/collection/components/nav-item/nav-item.js.map +1 -1
  54. package/dist/collection/components/range/range.js +4 -4
  55. package/dist/collection/components/resize-observe/resize-observe.js +1 -1
  56. package/dist/collection/components/select/select.css +223 -274
  57. package/dist/collection/components/select/select.js +15 -18
  58. package/dist/collection/components/select/select.js.map +1 -1
  59. package/dist/collection/components/slides/slides.js +7 -7
  60. package/dist/collection/components/tabs/tab-group.js +2 -2
  61. package/dist/collection/utils/popover.js +2 -7
  62. package/dist/collection/utils/popover.js.map +1 -1
  63. package/dist/components/form-control.js +17 -19
  64. package/dist/components/form-control.js.map +1 -1
  65. package/dist/components/input.js +5 -5
  66. package/dist/components/input.js.map +1 -1
  67. package/dist/components/nano-checkbox-group.js +1 -1
  68. package/dist/components/nano-checkbox-group.js.map +1 -1
  69. package/dist/components/nano-checkbox.js +1 -1
  70. package/dist/components/nano-date-input.js +1 -1
  71. package/dist/components/nano-date-input.js.map +1 -1
  72. package/dist/components/nano-file-upload.js +1 -1
  73. package/dist/components/nano-file-upload.js.map +1 -1
  74. package/dist/components/nano-global-nav.js +51 -47
  75. package/dist/components/nano-global-nav.js.map +1 -1
  76. package/dist/components/nav-item.js +11 -2
  77. package/dist/components/nav-item.js.map +1 -1
  78. package/dist/components/popover.js +2 -7
  79. package/dist/components/popover.js.map +1 -1
  80. package/dist/components/select.js +7 -10
  81. package/dist/components/select.js.map +1 -1
  82. package/dist/custom-elements/index.js +97 -96
  83. package/dist/custom-elements/index.js.map +1 -1
  84. package/dist/esm/{form-control-67eeb108.js → form-control-c52b6256.js} +18 -20
  85. package/dist/esm/form-control-c52b6256.js.map +1 -0
  86. package/dist/esm/loader.js +1 -1
  87. package/dist/esm/nano-checkbox-group.entry.js +1 -1
  88. package/dist/esm/nano-checkbox-group.entry.js.map +1 -1
  89. package/dist/esm/nano-checkbox.entry.js +1 -1
  90. package/dist/esm/nano-components.js +1 -1
  91. package/dist/esm/nano-date-input.entry.js +1 -1
  92. package/dist/esm/nano-date-input.entry.js.map +1 -1
  93. package/dist/esm/nano-dropdown.entry.js +1 -1
  94. package/dist/esm/nano-file-upload.entry.js +1 -1
  95. package/dist/esm/nano-file-upload.entry.js.map +1 -1
  96. package/dist/esm/nano-global-nav.entry.js +50 -47
  97. package/dist/esm/nano-global-nav.entry.js.map +1 -1
  98. package/dist/esm/nano-input.entry.js +6 -6
  99. package/dist/esm/nano-input.entry.js.map +1 -1
  100. package/dist/esm/nano-nav-item_2.entry.js +18 -13
  101. package/dist/esm/nano-nav-item_2.entry.js.map +1 -1
  102. package/dist/esm/nano-tooltip.entry.js +1 -1
  103. package/dist/esm/{popover-7639005b.js → popover-a03563f3.js} +3 -8
  104. package/dist/esm/{popover-7639005b.js.map → popover-a03563f3.js.map} +1 -1
  105. package/dist/esm-es5/form-control-c52b6256.js +5 -0
  106. package/dist/esm-es5/form-control-c52b6256.js.map +1 -0
  107. package/dist/esm-es5/loader.js +1 -1
  108. package/dist/esm-es5/loader.js.map +1 -1
  109. package/dist/esm-es5/nano-checkbox-group.entry.js +1 -1
  110. package/dist/esm-es5/nano-checkbox-group.entry.js.map +1 -1
  111. package/dist/esm-es5/nano-checkbox.entry.js +1 -1
  112. package/dist/esm-es5/nano-components.js +1 -1
  113. package/dist/esm-es5/nano-components.js.map +1 -1
  114. package/dist/esm-es5/nano-date-input.entry.js +1 -1
  115. package/dist/esm-es5/nano-date-input.entry.js.map +1 -1
  116. package/dist/esm-es5/nano-dropdown.entry.js +1 -1
  117. package/dist/esm-es5/nano-file-upload.entry.js +1 -1
  118. package/dist/esm-es5/nano-file-upload.entry.js.map +1 -1
  119. package/dist/esm-es5/nano-global-nav.entry.js +1 -1
  120. package/dist/esm-es5/nano-global-nav.entry.js.map +1 -1
  121. package/dist/esm-es5/nano-input.entry.js +2 -2
  122. package/dist/esm-es5/nano-input.entry.js.map +1 -1
  123. package/dist/esm-es5/nano-nav-item_2.entry.js +1 -1
  124. package/dist/esm-es5/nano-nav-item_2.entry.js.map +1 -1
  125. package/dist/esm-es5/nano-tooltip.entry.js +1 -1
  126. package/dist/esm-es5/{popover-7639005b.js → popover-a03563f3.js} +2 -2
  127. package/dist/esm-es5/popover-a03563f3.js.map +1 -0
  128. package/dist/nano-components/nano-components.esm.js +1 -1
  129. package/dist/nano-components/nano-components.esm.js.map +1 -1
  130. package/dist/nano-components/p-096682d9.system.js +1 -1
  131. package/dist/nano-components/p-096682d9.system.js.map +1 -1
  132. package/dist/nano-components/{p-820d9e23.system.entry.js → p-09e38c5f.system.entry.js} +2 -2
  133. package/dist/nano-components/p-09e38c5f.system.entry.js.map +1 -0
  134. package/dist/nano-components/p-10a6216d.system.entry.js +5 -0
  135. package/dist/nano-components/p-10a6216d.system.entry.js.map +1 -0
  136. package/dist/nano-components/p-18176c26.system.entry.js +5 -0
  137. package/dist/nano-components/p-18176c26.system.entry.js.map +1 -0
  138. package/dist/nano-components/{p-e7fdc62d.entry.js → p-1e8321ea.entry.js} +2 -2
  139. package/dist/nano-components/{p-e7fdc62d.entry.js.map → p-1e8321ea.entry.js.map} +0 -0
  140. package/dist/nano-components/{p-f9e30f31.system.entry.js → p-2057d480.system.entry.js} +2 -2
  141. package/dist/nano-components/p-2057d480.system.entry.js.map +1 -0
  142. package/dist/nano-components/{p-9acc4596.system.entry.js → p-2ae4918d.system.entry.js} +3 -3
  143. package/dist/nano-components/{p-9acc4596.system.entry.js.map → p-2ae4918d.system.entry.js.map} +0 -0
  144. package/dist/nano-components/{p-c9d09839.entry.js → p-313970ff.entry.js} +2 -2
  145. package/dist/nano-components/{p-c9d09839.entry.js.map → p-313970ff.entry.js.map} +0 -0
  146. package/dist/nano-components/{p-178c34e3.js → p-3de7735c.js} +2 -2
  147. package/dist/nano-components/p-3de7735c.js.map +1 -0
  148. package/dist/nano-components/{p-93448bcd.system.entry.js → p-4265cf95.system.entry.js} +2 -2
  149. package/dist/nano-components/{p-93448bcd.system.entry.js.map → p-4265cf95.system.entry.js.map} +0 -0
  150. package/dist/nano-components/{p-f3bf942d.entry.js → p-457d4893.entry.js} +2 -2
  151. package/dist/nano-components/p-457d4893.entry.js.map +1 -0
  152. package/dist/nano-components/{p-383fda90.system.entry.js → p-4870e76d.system.entry.js} +2 -2
  153. package/dist/nano-components/{p-383fda90.system.entry.js.map → p-4870e76d.system.entry.js.map} +0 -0
  154. package/dist/nano-components/{p-20db18f3.entry.js → p-5a315696.entry.js} +2 -2
  155. package/dist/nano-components/{p-20db18f3.entry.js.map → p-5a315696.entry.js.map} +0 -0
  156. package/dist/nano-components/p-802e1416.system.entry.js +5 -0
  157. package/dist/nano-components/{p-ef4e0912.system.entry.js.map → p-802e1416.system.entry.js.map} +1 -1
  158. package/dist/nano-components/p-829d7f05.system.entry.js +5 -0
  159. package/dist/nano-components/p-829d7f05.system.entry.js.map +1 -0
  160. package/dist/nano-components/p-9d35768b.entry.js +5 -0
  161. package/dist/nano-components/p-9d35768b.entry.js.map +1 -0
  162. package/dist/nano-components/p-aaef7cc7.js +5 -0
  163. package/dist/nano-components/p-aaef7cc7.js.map +1 -0
  164. package/dist/nano-components/p-af7abf5e.entry.js +5 -0
  165. package/dist/nano-components/p-af7abf5e.entry.js.map +1 -0
  166. package/dist/nano-components/{p-8de6e276.entry.js → p-b4f8e541.entry.js} +2 -2
  167. package/dist/nano-components/p-b4f8e541.entry.js.map +1 -0
  168. package/dist/nano-components/p-df0897ec.system.js +5 -0
  169. package/dist/nano-components/p-df0897ec.system.js.map +1 -0
  170. package/dist/nano-components/{p-9745d44e.system.js → p-e43ec257.system.js} +2 -2
  171. package/dist/nano-components/p-e43ec257.system.js.map +1 -0
  172. package/dist/nano-components/p-e7c69d4f.entry.js +5 -0
  173. package/dist/nano-components/{p-d6569144.entry.js.map → p-e7c69d4f.entry.js.map} +1 -1
  174. package/dist/nano-components/p-f79c3ea0.entry.js +5 -0
  175. package/dist/nano-components/p-f79c3ea0.entry.js.map +1 -0
  176. package/dist/types/components/global-nav/global-nav.d.ts +10 -3
  177. package/dist/types/components/nav-item/nav-item.d.ts +4 -0
  178. package/dist/types/components/select/select.d.ts +0 -1
  179. package/dist/types/components.d.ts +19 -3
  180. package/docs-json.json +52 -15
  181. package/docs-vscode.json +9 -1
  182. package/package.json +4 -3
  183. package/dist/cjs/form-control-3bc82e3e.js.map +0 -1
  184. package/dist/esm/form-control-67eeb108.js.map +0 -1
  185. package/dist/esm-es5/form-control-67eeb108.js +0 -5
  186. package/dist/esm-es5/form-control-67eeb108.js.map +0 -1
  187. package/dist/esm-es5/popover-7639005b.js.map +0 -1
  188. package/dist/nano-components/p-12f70017.system.entry.js +0 -5
  189. package/dist/nano-components/p-12f70017.system.entry.js.map +0 -1
  190. package/dist/nano-components/p-178c34e3.js.map +0 -1
  191. package/dist/nano-components/p-2559e9c1.entry.js +0 -5
  192. package/dist/nano-components/p-2559e9c1.entry.js.map +0 -1
  193. package/dist/nano-components/p-2be7aab0.system.entry.js +0 -5
  194. package/dist/nano-components/p-2be7aab0.system.entry.js.map +0 -1
  195. package/dist/nano-components/p-2e38a927.entry.js +0 -5
  196. package/dist/nano-components/p-2e38a927.entry.js.map +0 -1
  197. package/dist/nano-components/p-3a13948a.system.entry.js +0 -5
  198. package/dist/nano-components/p-3a13948a.system.entry.js.map +0 -1
  199. package/dist/nano-components/p-672e5547.js +0 -5
  200. package/dist/nano-components/p-672e5547.js.map +0 -1
  201. package/dist/nano-components/p-6dd58c39.entry.js +0 -5
  202. package/dist/nano-components/p-6dd58c39.entry.js.map +0 -1
  203. package/dist/nano-components/p-820d9e23.system.entry.js.map +0 -1
  204. package/dist/nano-components/p-8de6e276.entry.js.map +0 -1
  205. package/dist/nano-components/p-9745d44e.system.js.map +0 -1
  206. package/dist/nano-components/p-d6569144.entry.js +0 -5
  207. package/dist/nano-components/p-ea5eb591.system.js +0 -5
  208. package/dist/nano-components/p-ea5eb591.system.js.map +0 -1
  209. package/dist/nano-components/p-ef4e0912.system.entry.js +0 -5
  210. package/dist/nano-components/p-f3bf942d.entry.js.map +0 -1
  211. package/dist/nano-components/p-f9e30f31.system.entry.js.map +0 -1
package/docs-json.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
- "timestamp": "2022-05-26T00:24:07",
2
+ "timestamp": "2022-06-07T11:55:03",
3
3
  "compiler": {
4
4
  "name": "@stencil/core",
5
5
  "version": "2.12.2",
@@ -2024,7 +2024,7 @@
2024
2024
  {
2025
2025
  "name": "--control-invalid-style",
2026
2026
  "annotation": "prop",
2027
- "docs": "Control box-shadow when invalid. Defaults to to var(--nano-control-focus-shadow, 0 0 0 0.1875rem #fac6c3);"
2027
+ "docs": "Control box-shadow when invalid. Defaults to to var(--nano-control-focus-shadow, 0 0 0 0.1875rem #e4e6e8);"
2028
2028
  },
2029
2029
  {
2030
2030
  "name": "--control-padding",
@@ -5692,7 +5692,7 @@
5692
5692
  {
5693
5693
  "name": "--drop-bg--invalid",
5694
5694
  "annotation": "prop",
5695
- "docs": "Default value var(--nano-input-background-color, #fee8de);"
5695
+ "docs": "Default value var(--nano-input-background-color, white);"
5696
5696
  },
5697
5697
  {
5698
5698
  "name": "--drop-border--invalid",
@@ -5898,7 +5898,7 @@
5898
5898
  "mutable": false,
5899
5899
  "attr": "env",
5900
5900
  "reflectToAttr": false,
5901
- "docs": "Connect to local, dev, test or prod MyAccount\nenvironments to retrieve global nav / sso data",
5901
+ "docs": "Connect to local, dev, test or prod MyAccount\nenvironments to retrieve global nav / sso data.\nAlternatively, you can use the `ssoDataUrl` prop.",
5902
5902
  "docsTags": [],
5903
5903
  "default": "'prod'",
5904
5904
  "values": [
@@ -5919,7 +5919,7 @@
5919
5919
  "type": "string"
5920
5920
  }
5921
5921
  ],
5922
- "optional": false,
5922
+ "optional": true,
5923
5923
  "required": false,
5924
5924
  "getter": false,
5925
5925
  "setter": false
@@ -6148,6 +6148,24 @@
6148
6148
  "getter": false,
6149
6149
  "setter": false
6150
6150
  },
6151
+ {
6152
+ "name": "ssoDataUrl",
6153
+ "type": "string",
6154
+ "mutable": false,
6155
+ "attr": "sso-data-url",
6156
+ "reflectToAttr": false,
6157
+ "docs": "A base url to retrieve global nav / sso data.\n`nav_bar_data.json` will be appended to this url.\nAn alternative to the pre-defined `env` urls",
6158
+ "docsTags": [],
6159
+ "values": [
6160
+ {
6161
+ "type": "string"
6162
+ }
6163
+ ],
6164
+ "optional": true,
6165
+ "required": false,
6166
+ "getter": false,
6167
+ "setter": false
6168
+ },
6151
6169
  {
6152
6170
  "name": "ssoRedirect",
6153
6171
  "type": "string",
@@ -8751,7 +8769,7 @@
8751
8769
  {
8752
8770
  "name": "--input-bg-color--invalid",
8753
8771
  "annotation": "prop",
8754
- "docs": "defaults to var(--nano-input-background-color, #fee8de);"
8772
+ "docs": "defaults to var(--nano-input-background-color, white);"
8755
8773
  },
8756
8774
  {
8757
8775
  "name": "--input-border-radius",
@@ -8771,17 +8789,17 @@
8771
8789
  {
8772
8790
  "name": "--input-border-style--invalid",
8773
8791
  "annotation": "prop",
8774
- "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #fac6c3);"
8792
+ "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #e4e6e8);"
8775
8793
  },
8776
8794
  {
8777
8795
  "name": "--input-border-style--invalid-focus",
8778
8796
  "annotation": "prop",
8779
- "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #f36d64);"
8797
+ "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #ef4135);"
8780
8798
  },
8781
8799
  {
8782
8800
  "name": "--input-border-width",
8783
8801
  "annotation": "prop",
8784
- "docs": "defaults to var(--input-border-width-sh, var(--nano-input-border-width, 2px));"
8802
+ "docs": "defaults to var(--input-border-width-sh, var(--nano-input-border-width, 1px));"
8785
8803
  },
8786
8804
  {
8787
8805
  "name": "--input-font-size",
@@ -8831,7 +8849,7 @@
8831
8849
  {
8832
8850
  "name": "--multi-input-value-border",
8833
8851
  "annotation": "prop",
8834
- "docs": "Tag / multivalue border. defaults to var(--nano-input-tag-color, #90c6e7);"
8852
+ "docs": "Tag / multivalue border. defaults to var(--nano-input-tag-color, #badcf0);"
8835
8853
  },
8836
8854
  {
8837
8855
  "name": "--multi-input-value-text-color",
@@ -9390,6 +9408,25 @@
9390
9408
  "getter": false,
9391
9409
  "setter": false
9392
9410
  },
9411
+ {
9412
+ "name": "notification",
9413
+ "type": "boolean",
9414
+ "mutable": false,
9415
+ "attr": "notification",
9416
+ "reflectToAttr": false,
9417
+ "docs": "Will show an indicator badge - only when placed in a nano-menu-draw",
9418
+ "docsTags": [],
9419
+ "default": "false",
9420
+ "values": [
9421
+ {
9422
+ "type": "boolean"
9423
+ }
9424
+ ],
9425
+ "optional": false,
9426
+ "required": false,
9427
+ "getter": false,
9428
+ "setter": false
9429
+ },
9393
9430
  {
9394
9431
  "name": "open",
9395
9432
  "type": "boolean",
@@ -11289,7 +11326,7 @@
11289
11326
  {
11290
11327
  "name": "--input-bg-color--invalid",
11291
11328
  "annotation": "prop",
11292
- "docs": "defaults to var(--nano-input-background-color, #fee8de);"
11329
+ "docs": "defaults to var(--nano-input-background-color, white);"
11293
11330
  },
11294
11331
  {
11295
11332
  "name": "--input-border-radius",
@@ -11309,17 +11346,17 @@
11309
11346
  {
11310
11347
  "name": "--input-border-style--invalid",
11311
11348
  "annotation": "prop",
11312
- "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #fac6c3);"
11349
+ "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #e4e6e8);"
11313
11350
  },
11314
11351
  {
11315
11352
  "name": "--input-border-style--invalid-focus",
11316
11353
  "annotation": "prop",
11317
- "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #f36d64);"
11354
+ "docs": "defaults to var(--nano-input-border-style, solid) var(--nano-input-border-color--invalid, #ef4135);"
11318
11355
  },
11319
11356
  {
11320
11357
  "name": "--input-border-width",
11321
11358
  "annotation": "prop",
11322
- "docs": "defaults to var(--input-border-width-sh, var(--nano-input-border-width, 2px));"
11359
+ "docs": "defaults to var(--input-border-width-sh, var(--nano-input-border-width, 1px));"
11323
11360
  },
11324
11361
  {
11325
11362
  "name": "--input-font-size",
@@ -11369,7 +11406,7 @@
11369
11406
  {
11370
11407
  "name": "--multi-input-value-border",
11371
11408
  "annotation": "prop",
11372
- "docs": "Tag / multivalue border. defaults to var(--nano-input-tag-color, #90c6e7);"
11409
+ "docs": "Tag / multivalue border. defaults to var(--nano-input-tag-color, #badcf0);"
11373
11410
  },
11374
11411
  {
11375
11412
  "name": "--multi-input-value-text-color",
package/docs-vscode.json CHANGED
@@ -1148,7 +1148,7 @@
1148
1148
  },
1149
1149
  {
1150
1150
  "name": "env",
1151
- "description": "Connect to local, dev, test or prod MyAccount\nenvironments to retrieve global nav / sso data",
1151
+ "description": "Connect to local, dev, test or prod MyAccount\nenvironments to retrieve global nav / sso data.\nAlternatively, you can use the `ssoDataUrl` prop.",
1152
1152
  "values": [
1153
1153
  {
1154
1154
  "name": "dev"
@@ -1204,6 +1204,10 @@
1204
1204
  "name": "show-search",
1205
1205
  "description": "Whether to show search functionality"
1206
1206
  },
1207
+ {
1208
+ "name": "sso-data-url",
1209
+ "description": "A base url to retrieve global nav / sso data.\n`nav_bar_data.json` will be appended to this url.\nAn alternative to the pre-defined `env` urls"
1210
+ },
1207
1211
  {
1208
1212
  "name": "sso-redirect",
1209
1213
  "description": "Where to take user after SSO login"
@@ -1873,6 +1877,10 @@
1873
1877
  "name": "href",
1874
1878
  "description": "Href to link to"
1875
1879
  },
1880
+ {
1881
+ "name": "notification",
1882
+ "description": "Will show an indicator badge - only when placed in a nano-menu-draw"
1883
+ },
1876
1884
  {
1877
1885
  "name": "open",
1878
1886
  "description": "Whether a secondary menu should be or is currently open"
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nanoporetech-digital/components",
3
- "version": "2.5.0",
3
+ "version": "2.8.0",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "https://git.oxfordnanolabs.local/Digital/nano-components"
@@ -43,7 +43,8 @@
43
43
  "prettier.base": "prettier \"./{src,jest}/**/*.{ts,tsx,js,jsx}\"",
44
44
  "test": "run-p themes.prod test.all.base",
45
45
  "test.ci": "run-p themes.prod test.all.base",
46
- "test.spec": "stencil test --spec --max-workers=2 --watch --config='./stencil.config.test.ts'",
46
+ "test.spec": "stencil test --spec --watch --config='./stencil.config.test.ts'",
47
+ "test.e2e": "stencil test --e2e --max-workers=1 --watch --config='./stencil.config.test.ts'",
47
48
  "test.spec.debug": "npx --node-arg=\"--inspect-brk\" stencil test --spec --config='./stencil.config.test.ts'",
48
49
  "test.watch": "run-s themes.prod test.all.watch",
49
50
  "test.all.watch": "stencil test --spec --e2e --watch --bail --config='./stencil.config.test.ts'",
@@ -126,5 +127,5 @@
126
127
  "peerDependencies": {
127
128
  "@stencil/core": "^2.5.0"
128
129
  },
129
- "gitHead": "3bc259ad0d07a38138061b0268ec10baf39d5b1e"
130
+ "gitHead": "988c32f7f274729b1fde3b5f0530b72396ca2436"
130
131
  }
@@ -1 +0,0 @@
1
- {"file":"form-control-3bc82e3e.js","mappings":"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","names":["h"],"sources":["./src/components/form-control/form-control.tsx"],"sourcesContent":["import { FunctionalComponent, h, VNode } from '@stencil/core';\nimport { TextFieldTypes } from '../../interface';\n\ninterface FormControlWrapProps {\n rtl: boolean;\n floatLabel: boolean;\n labelId: string;\n label: string;\n moreId: string;\n type?: TextFieldTypes;\n showInlineError: boolean;\n hasHelperSlot: boolean;\n errorMessage: string;\n controlId: string;\n hasLabelSlot: boolean;\n hideLabel: boolean;\n placeholder: string;\n hasValue: boolean;\n showCharCount?: boolean;\n maxlength?: number;\n charCount?: number;\n}\n\ninterface FormControlProps {\n clearControl: boolean;\n onClearText?: () => void;\n readonly: boolean;\n disabled: boolean;\n control: HTMLNanoInputElement | HTMLNanoSelectElement;\n ref?: (elm?: HTMLElement) => void;\n endSlot?: VNode;\n endValueSlot?: VNode;\n startSlot?: VNode;\n}\n\ninterface LabelProps extends FormControlWrapProps {\n rtl: boolean;\n}\n\nconst renderLabel = ({\n label,\n hasLabelSlot,\n controlId,\n labelId,\n floatLabel,\n placeholder,\n hideLabel,\n hasValue,\n rtl,\n showCharCount,\n maxlength,\n charCount,\n}: LabelProps) => {\n if (!label && !hasLabelSlot) return;\n if (floatLabel) {\n return (\n <label class=\"placeholder-as-label\" htmlFor={controlId} id={labelId}>\n {label && label}\n {!label && hasLabelSlot && <slot name=\"label\" />}\n </label>\n );\n } else {\n return (\n <label\n class={{ label: true, 'visually-hide': hideLabel }}\n htmlFor={controlId}\n id={labelId}\n >\n <div class=\"label-placeholder\">\n {placeholder && hasValue && rtl && (\n <span class=\"placeholder\">{placeholder} / </span>\n )}\n <span class=\"labeltext\">\n {label && label}\n {!label && hasLabelSlot && <slot name=\"label\" />}\n </span>\n {placeholder && hasValue && !rtl && (\n <span class=\"placeholder\"> / {placeholder}</span>\n )}\n </div>\n {showCharCount && (\n <span class=\"charcount\">\n {maxlength\n ? maxlength - charCount + ' left'\n : charCount + ' characters'}\n </span>\n )}\n </label>\n );\n }\n};\n\nexport const FormControlWrap: FunctionalComponent<FormControlWrapProps> = (\n props: FormControlWrapProps,\n children\n) => {\n const {\n rtl,\n floatLabel,\n label,\n moreId,\n type,\n hasHelperSlot,\n showInlineError,\n errorMessage,\n } = props;\n const isLegacy = !document.head.attachShadow;\n\n return [\n !floatLabel ? renderLabel({ ...props }) : '',\n <div\n class={{\n 'has-label': label !== null && !floatLabel,\n 'has-float-label': label !== null && floatLabel,\n rtl,\n legacy: isLegacy,\n input: true,\n textarea: type === 'textarea',\n }}\n >\n {floatLabel && renderLabel({ ...props, rtl })}\n {children}\n </div>,\n showInlineError || hasHelperSlot ? (\n <div class=\"more\" id={moreId}>\n {!!showInlineError ? <div class=\"error\">{errorMessage}</div> : ''}\n <div class=\"helper\">\n <slot name=\"helper\" />\n </div>\n </div>\n ) : (\n ''\n ),\n ];\n};\n\nexport const FormControl: FunctionalComponent<FormControlProps> = (\n props: FormControlProps,\n children\n) => {\n const {\n clearControl,\n onClearText,\n readonly,\n disabled,\n control,\n ref,\n endSlot,\n endValueSlot,\n startSlot,\n } = props;\n const clickThrough = () => {\n control.setFocus();\n };\n\n return (\n <div\n class=\"native-input-wrap\"\n ref={(el) => {\n if (ref) ref(el);\n }}\n >\n <span class=\"start\">\n <slot name=\"start\" />\n {startSlot}\n </span>\n {children}\n {clearControl && !readonly && !disabled && (\n <button\n type=\"button\"\n class=\"icon input-clear-icon\"\n tabindex=\"-1\"\n onTouchStart={onClearText}\n onMouseDown={onClearText}\n >\n <nano-icon name=\"light/times\"></nano-icon>\n </button>\n )}\n <span class=\"value-end\" onClick={clickThrough}>\n <slot name=\"value-end\" />\n {endValueSlot}\n </span>\n <span class=\"end\">\n <slot name=\"end\" />\n {endSlot}\n </span>\n </div>\n );\n};\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"form-control-67eeb108.js","mappings":"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","names":[],"sources":["./src/components/form-control/form-control.tsx"],"sourcesContent":["import { FunctionalComponent, h, VNode } from '@stencil/core';\nimport { TextFieldTypes } from '../../interface';\n\ninterface FormControlWrapProps {\n rtl: boolean;\n floatLabel: boolean;\n labelId: string;\n label: string;\n moreId: string;\n type?: TextFieldTypes;\n showInlineError: boolean;\n hasHelperSlot: boolean;\n errorMessage: string;\n controlId: string;\n hasLabelSlot: boolean;\n hideLabel: boolean;\n placeholder: string;\n hasValue: boolean;\n showCharCount?: boolean;\n maxlength?: number;\n charCount?: number;\n}\n\ninterface FormControlProps {\n clearControl: boolean;\n onClearText?: () => void;\n readonly: boolean;\n disabled: boolean;\n control: HTMLNanoInputElement | HTMLNanoSelectElement;\n ref?: (elm?: HTMLElement) => void;\n endSlot?: VNode;\n endValueSlot?: VNode;\n startSlot?: VNode;\n}\n\ninterface LabelProps extends FormControlWrapProps {\n rtl: boolean;\n}\n\nconst renderLabel = ({\n label,\n hasLabelSlot,\n controlId,\n labelId,\n floatLabel,\n placeholder,\n hideLabel,\n hasValue,\n rtl,\n showCharCount,\n maxlength,\n charCount,\n}: LabelProps) => {\n if (!label && !hasLabelSlot) return;\n if (floatLabel) {\n return (\n <label class=\"placeholder-as-label\" htmlFor={controlId} id={labelId}>\n {label && label}\n {!label && hasLabelSlot && <slot name=\"label\" />}\n </label>\n );\n } else {\n return (\n <label\n class={{ label: true, 'visually-hide': hideLabel }}\n htmlFor={controlId}\n id={labelId}\n >\n <div class=\"label-placeholder\">\n {placeholder && hasValue && rtl && (\n <span class=\"placeholder\">{placeholder} / </span>\n )}\n <span class=\"labeltext\">\n {label && label}\n {!label && hasLabelSlot && <slot name=\"label\" />}\n </span>\n {placeholder && hasValue && !rtl && (\n <span class=\"placeholder\"> / {placeholder}</span>\n )}\n </div>\n {showCharCount && (\n <span class=\"charcount\">\n {maxlength\n ? maxlength - charCount + ' left'\n : charCount + ' characters'}\n </span>\n )}\n </label>\n );\n }\n};\n\nexport const FormControlWrap: FunctionalComponent<FormControlWrapProps> = (\n props: FormControlWrapProps,\n children\n) => {\n const {\n rtl,\n floatLabel,\n label,\n moreId,\n type,\n hasHelperSlot,\n showInlineError,\n errorMessage,\n } = props;\n const isLegacy = !document.head.attachShadow;\n\n return [\n !floatLabel ? renderLabel({ ...props }) : '',\n <div\n class={{\n 'has-label': label !== null && !floatLabel,\n 'has-float-label': label !== null && floatLabel,\n rtl,\n legacy: isLegacy,\n input: true,\n textarea: type === 'textarea',\n }}\n >\n {floatLabel && renderLabel({ ...props, rtl })}\n {children}\n </div>,\n showInlineError || hasHelperSlot ? (\n <div class=\"more\" id={moreId}>\n {!!showInlineError ? <div class=\"error\">{errorMessage}</div> : ''}\n <div class=\"helper\">\n <slot name=\"helper\" />\n </div>\n </div>\n ) : (\n ''\n ),\n ];\n};\n\nexport const FormControl: FunctionalComponent<FormControlProps> = (\n props: FormControlProps,\n children\n) => {\n const {\n clearControl,\n onClearText,\n readonly,\n disabled,\n control,\n ref,\n endSlot,\n endValueSlot,\n startSlot,\n } = props;\n const clickThrough = () => {\n control.setFocus();\n };\n\n return (\n <div\n class=\"native-input-wrap\"\n ref={(el) => {\n if (ref) ref(el);\n }}\n >\n <span class=\"start\">\n <slot name=\"start\" />\n {startSlot}\n </span>\n {children}\n {clearControl && !readonly && !disabled && (\n <button\n type=\"button\"\n class=\"icon input-clear-icon\"\n tabindex=\"-1\"\n onTouchStart={onClearText}\n onMouseDown={onClearText}\n >\n <nano-icon name=\"light/times\"></nano-icon>\n </button>\n )}\n <span class=\"value-end\" onClick={clickThrough}>\n <slot name=\"value-end\" />\n {endValueSlot}\n </span>\n <span class=\"end\">\n <slot name=\"end\" />\n {endSlot}\n </span>\n </div>\n );\n};\n"],"version":3}
@@ -1,5 +0,0 @@
1
- /*!
2
- * Web Components for Nanopore digital Web Apps
3
- */
4
- import{h}from"./index-5f8d16e7.js";var renderLabel=function(a){var l=a.label,e=a.hasLabelSlot,r=a.controlId,t=a.labelId,n=a.floatLabel,s=a.placeholder,o=a.hideLabel,c=a.hasValue,i=a.rtl,d=a.showCharCount,u=a.maxlength,b=a.charCount;if(!l&&!e)return;if(n){return h("label",{class:"placeholder-as-label",htmlFor:r,id:t},l&&l,!l&&e&&h("slot",{name:"label"}))}else{return h("label",{class:{label:true,"visually-hide":o},htmlFor:r,id:t},h("div",{class:"label-placeholder"},s&&c&&i&&h("span",{class:"placeholder"},s," / "),h("span",{class:"labeltext"},l&&l,!l&&e&&h("slot",{name:"label"})),s&&c&&!i&&h("span",{class:"placeholder"}," / ",s)),d&&h("span",{class:"charcount"},u?u-b+" left":b+" characters"))}};var FormControlWrap=function(a,l){var e=a.rtl,r=a.floatLabel,t=a.label,n=a.moreId,s=a.type,o=a.hasHelperSlot,c=a.showInlineError,i=a.errorMessage;var d=!document.head.attachShadow;return[!r?renderLabel(Object.assign({},a)):"",h("div",{class:{"has-label":t!==null&&!r,"has-float-label":t!==null&&r,rtl:e,legacy:d,input:true,textarea:s==="textarea"}},r&&renderLabel(Object.assign(Object.assign({},a),{rtl:e})),l),c||o?h("div",{class:"more",id:n},!!c?h("div",{class:"error"},i):"",h("div",{class:"helper"},h("slot",{name:"helper"}))):""]};var FormControl=function(a,l){var e=a.clearControl,r=a.onClearText,t=a.readonly,n=a.disabled,s=a.control,o=a.ref,c=a.endSlot,i=a.endValueSlot,d=a.startSlot;var u=function(){s.setFocus()};return h("div",{class:"native-input-wrap",ref:function(a){if(o)o(a)}},h("span",{class:"start"},h("slot",{name:"start"}),d),l,e&&!t&&!n&&h("button",{type:"button",class:"icon input-clear-icon",tabindex:"-1",onTouchStart:r,onMouseDown:r},h("nano-icon",{name:"light/times"})),h("span",{class:"value-end",onClick:u},h("slot",{name:"value-end"}),i),h("span",{class:"end"},h("slot",{name:"end"}),c))};export{FormControlWrap as F,FormControl as a};
5
- //# sourceMappingURL=form-control-67eeb108.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["src/components/form-control/form-control.tsx"],"names":["renderLabel","_a","label","hasLabelSlot","controlId","labelId","floatLabel","placeholder","hideLabel","hasValue","rtl","showCharCount","maxlength","charCount","h","class","htmlFor","id","name","visually-hide","FormControlWrap","props","children","moreId","type","hasHelperSlot","showInlineError","errorMessage","isLegacy","document","head","attachShadow","Object","assign","has-label","has-float-label","legacy","input","textarea","FormControl","clearControl","onClearText","readonly","disabled","control","ref","endSlot","endValueSlot","startSlot","clickThrough","setFocus","el","tabindex","onTouchStart","onMouseDown","onClick"],"mappings":";;;mCAuCA,IAAMA,YAAc,SAACC,OACnBC,EAAKD,EAAAC,MACLC,EAAYF,EAAAE,aACZC,EAASH,EAAAG,UACTC,EAAOJ,EAAAI,QACPC,EAAUL,EAAAK,WACVC,EAAWN,EAAAM,YACXC,EAASP,EAAAO,UACTC,EAAQR,EAAAQ,SACRC,EAAGT,EAAAS,IACHC,EAAaV,EAAAU,cACbC,EAASX,EAAAW,UACTC,EAASZ,EAAAY,UAET,IAAKX,IAAUC,EAAc,OAC7B,GAAIG,EAAY,CACd,OACEQ,EAAA,QAAA,CAAOC,MAAM,uBAAuBC,QAASZ,EAAWa,GAAIZ,GACzDH,GAASA,GACRA,GAASC,GAAgBW,EAAA,OAAA,CAAMI,KAAK,eAGrC,CACL,OACEJ,EAAA,QAAA,CACEC,MAAO,CAAEb,MAAO,KAAMiB,gBAAiBX,GACvCQ,QAASZ,EACTa,GAAIZ,GAEJS,EAAA,MAAA,CAAKC,MAAM,qBACRR,GAAeE,GAAYC,GAC1BI,EAAA,OAAA,CAAMC,MAAM,eAAeR,EAAW,OAExCO,EAAA,OAAA,CAAMC,MAAM,aACTb,GAASA,GACRA,GAASC,GAAgBW,EAAA,OAAA,CAAMI,KAAK,WAEvCX,GAAeE,IAAaC,GAC3BI,EAAA,OAAA,CAAMC,MAAM,eAAa,MAAKR,IAGjCI,GACCG,EAAA,OAAA,CAAMC,MAAM,aACTH,EACGA,EAAYC,EAAY,QACxBA,EAAY,sBAQfO,gBAA6D,SACxEC,EACAC,GAGE,IAAAZ,EAQEW,EAAKX,IAPPJ,EAOEe,EAAKf,WANPJ,EAMEmB,EAAKnB,MALPqB,EAKEF,EAAKE,OAJPC,EAIEH,EAAKG,KAHPC,EAGEJ,EAAKI,cAFPC,EAEEL,EAAKK,gBADPC,EACEN,EAAKM,aACT,IAAMC,GAAYC,SAASC,KAAKC,aAEhC,MAAO,EACJzB,EAAaN,YAAWgC,OAAAC,OAAA,GAAMZ,IAAW,GAC1CP,EAAA,MAAA,CACEC,MAAO,CACLmB,YAAahC,IAAU,OAASI,EAChC6B,kBAAmBjC,IAAU,MAAQI,EACrCI,IAAGA,EACH0B,OAAQR,EACRS,MAAO,KACPC,SAAUd,IAAS,aAGpBlB,GAAcN,YAAWgC,OAAAC,OAAAD,OAAAC,OAAA,GAAMZ,GAAK,CAAEX,IAAGA,KACzCY,GAEHI,GAAmBD,EACjBX,EAAA,MAAA,CAAKC,MAAM,OAAOE,GAAIM,KACjBG,EAAkBZ,EAAA,MAAA,CAAKC,MAAM,SAASY,GAAsB,GAC/Db,EAAA,MAAA,CAAKC,MAAM,UACTD,EAAA,OAAA,CAAMI,KAAK,aAET,SAOCqB,YAAqD,SAChElB,EACAC,GAGE,IAAAkB,EASEnB,EAAKmB,aARPC,EAQEpB,EAAKoB,YAPPC,EAOErB,EAAKqB,SANPC,EAMEtB,EAAKsB,SALPC,EAKEvB,EAAKuB,QAJPC,EAIExB,EAAKwB,IAHPC,EAGEzB,EAAKyB,QAFPC,EAEE1B,EAAK0B,aADPC,EACE3B,EAAK2B,UACT,IAAMC,EAAe,WACnBL,EAAQM,YAGV,OACEpC,EAAA,MAAA,CACEC,MAAM,oBACN8B,IAAK,SAACM,GACJ,GAAIN,EAAKA,EAAIM,KAGfrC,EAAA,OAAA,CAAMC,MAAM,SACVD,EAAA,OAAA,CAAMI,KAAK,UACV8B,GAEF1B,EACAkB,IAAiBE,IAAaC,GAC7B7B,EAAA,SAAA,CACEU,KAAK,SACLT,MAAM,wBACNqC,SAAS,KACTC,aAAcZ,EACda,YAAab,GAEb3B,EAAA,YAAA,CAAWI,KAAK,iBAGpBJ,EAAA,OAAA,CAAMC,MAAM,YAAYwC,QAASN,GAC/BnC,EAAA,OAAA,CAAMI,KAAK,cACV6B,GAEHjC,EAAA,OAAA,CAAMC,MAAM,OACVD,EAAA,OAAA,CAAMI,KAAK,QACV4B","sourcesContent":["import { FunctionalComponent, h, VNode } from '@stencil/core';\nimport { TextFieldTypes } from '../../interface';\n\ninterface FormControlWrapProps {\n rtl: boolean;\n floatLabel: boolean;\n labelId: string;\n label: string;\n moreId: string;\n type?: TextFieldTypes;\n showInlineError: boolean;\n hasHelperSlot: boolean;\n errorMessage: string;\n controlId: string;\n hasLabelSlot: boolean;\n hideLabel: boolean;\n placeholder: string;\n hasValue: boolean;\n showCharCount?: boolean;\n maxlength?: number;\n charCount?: number;\n}\n\ninterface FormControlProps {\n clearControl: boolean;\n onClearText?: () => void;\n readonly: boolean;\n disabled: boolean;\n control: HTMLNanoInputElement | HTMLNanoSelectElement;\n ref?: (elm?: HTMLElement) => void;\n endSlot?: VNode;\n endValueSlot?: VNode;\n startSlot?: VNode;\n}\n\ninterface LabelProps extends FormControlWrapProps {\n rtl: boolean;\n}\n\nconst renderLabel = ({\n label,\n hasLabelSlot,\n controlId,\n labelId,\n floatLabel,\n placeholder,\n hideLabel,\n hasValue,\n rtl,\n showCharCount,\n maxlength,\n charCount,\n}: LabelProps) => {\n if (!label && !hasLabelSlot) return;\n if (floatLabel) {\n return (\n <label class=\"placeholder-as-label\" htmlFor={controlId} id={labelId}>\n {label && label}\n {!label && hasLabelSlot && <slot name=\"label\" />}\n </label>\n );\n } else {\n return (\n <label\n class={{ label: true, 'visually-hide': hideLabel }}\n htmlFor={controlId}\n id={labelId}\n >\n <div class=\"label-placeholder\">\n {placeholder && hasValue && rtl && (\n <span class=\"placeholder\">{placeholder} / </span>\n )}\n <span class=\"labeltext\">\n {label && label}\n {!label && hasLabelSlot && <slot name=\"label\" />}\n </span>\n {placeholder && hasValue && !rtl && (\n <span class=\"placeholder\"> / {placeholder}</span>\n )}\n </div>\n {showCharCount && (\n <span class=\"charcount\">\n {maxlength\n ? maxlength - charCount + ' left'\n : charCount + ' characters'}\n </span>\n )}\n </label>\n );\n }\n};\n\nexport const FormControlWrap: FunctionalComponent<FormControlWrapProps> = (\n props: FormControlWrapProps,\n children\n) => {\n const {\n rtl,\n floatLabel,\n label,\n moreId,\n type,\n hasHelperSlot,\n showInlineError,\n errorMessage,\n } = props;\n const isLegacy = !document.head.attachShadow;\n\n return [\n !floatLabel ? renderLabel({ ...props }) : '',\n <div\n class={{\n 'has-label': label !== null && !floatLabel,\n 'has-float-label': label !== null && floatLabel,\n rtl,\n legacy: isLegacy,\n input: true,\n textarea: type === 'textarea',\n }}\n >\n {floatLabel && renderLabel({ ...props, rtl })}\n {children}\n </div>,\n showInlineError || hasHelperSlot ? (\n <div class=\"more\" id={moreId}>\n {!!showInlineError ? <div class=\"error\">{errorMessage}</div> : ''}\n <div class=\"helper\">\n <slot name=\"helper\" />\n </div>\n </div>\n ) : (\n ''\n ),\n ];\n};\n\nexport const FormControl: FunctionalComponent<FormControlProps> = (\n props: FormControlProps,\n children\n) => {\n const {\n clearControl,\n onClearText,\n readonly,\n disabled,\n control,\n ref,\n endSlot,\n endValueSlot,\n startSlot,\n } = props;\n const clickThrough = () => {\n control.setFocus();\n };\n\n return (\n <div\n class=\"native-input-wrap\"\n ref={(el) => {\n if (ref) ref(el);\n }}\n >\n <span class=\"start\">\n <slot name=\"start\" />\n {startSlot}\n </span>\n {children}\n {clearControl && !readonly && !disabled && (\n <button\n type=\"button\"\n class=\"icon input-clear-icon\"\n tabindex=\"-1\"\n onTouchStart={onClearText}\n onMouseDown={onClearText}\n >\n <nano-icon name=\"light/times\"></nano-icon>\n </button>\n )}\n <span class=\"value-end\" onClick={clickThrough}>\n <slot name=\"value-end\" />\n {endValueSlot}\n </span>\n <span class=\"end\">\n <slot name=\"end\" />\n {endSlot}\n </span>\n </div>\n );\n};\n"]}