@aquera/nile-elements 0.1.24 → 0.1.26

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 (220) hide show
  1. package/README.md +13 -0
  2. package/demo/filenames.txt +1 -1
  3. package/demo/index.html +0 -2
  4. package/demo/variables.css +1 -0
  5. package/demo/variables_v2.css +1 -0
  6. package/dist/{angular-ts-a62c12b7.cjs.js → angular-ts-5f927069.cjs.js} +2 -2
  7. package/dist/{angular-ts-a62c12b7.cjs.js.map → angular-ts-5f927069.cjs.js.map} +1 -1
  8. package/dist/index.cjs.js +1 -1
  9. package/dist/index.esm.js +1 -1
  10. package/dist/lit-element-9e4e16c6.cjs.js +18 -0
  11. package/dist/lit-element-9e4e16c6.cjs.js.map +1 -0
  12. package/dist/lit-element-a5a64515.esm.js +23 -0
  13. package/dist/nile-auto-complete/index.cjs.js +1 -1
  14. package/dist/nile-auto-complete/index.esm.js +1 -1
  15. package/dist/nile-auto-complete/nile-auto-complete.cjs.js +5 -13
  16. package/dist/nile-auto-complete/nile-auto-complete.cjs.js.map +1 -1
  17. package/dist/nile-auto-complete/nile-auto-complete.css.cjs.js +1 -1
  18. package/dist/nile-auto-complete/nile-auto-complete.css.cjs.js.map +1 -1
  19. package/dist/nile-auto-complete/nile-auto-complete.css.esm.js +6 -4
  20. package/dist/nile-auto-complete/nile-auto-complete.esm.js +9 -22
  21. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  22. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js.map +1 -1
  23. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  24. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  25. package/dist/nile-avatar/nile-avatar.test.cjs.js.map +1 -1
  26. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  27. package/dist/nile-badge/index.cjs.js +1 -1
  28. package/dist/nile-badge/index.esm.js +1 -1
  29. package/dist/nile-badge/nile-badge.cjs.js +1 -1
  30. package/dist/nile-badge/nile-badge.cjs.js.map +1 -1
  31. package/dist/nile-badge/nile-badge.esm.js +1 -1
  32. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  33. package/dist/nile-badge/nile-badge.test.cjs.js.map +1 -1
  34. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  35. package/dist/nile-button/index.cjs.js +1 -1
  36. package/dist/nile-button/index.esm.js +1 -1
  37. package/dist/nile-button/nile-button.cjs.js +1 -1
  38. package/dist/nile-button/nile-button.cjs.js.map +1 -1
  39. package/dist/nile-button/nile-button.esm.js +1 -1
  40. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  41. package/dist/nile-button/nile-button.test.cjs.js.map +1 -1
  42. package/dist/nile-button/nile-button.test.esm.js +1 -1
  43. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  44. package/dist/nile-calendar/nile-calendar.test.cjs.js.map +1 -1
  45. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  46. package/dist/nile-chip/nile-chip.cjs.js.map +1 -1
  47. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  48. package/dist/nile-chip/nile-chip.test.cjs.js.map +1 -1
  49. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  50. package/dist/nile-dialog/index.cjs.js +1 -1
  51. package/dist/nile-dialog/index.esm.js +1 -1
  52. package/dist/nile-dialog/nile-dialog.cjs.js +1 -1
  53. package/dist/nile-dialog/nile-dialog.cjs.js.map +1 -1
  54. package/dist/nile-dialog/nile-dialog.esm.js +1 -1
  55. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  56. package/dist/nile-dialog/nile-dialog.test.cjs.js.map +1 -1
  57. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  58. package/dist/nile-drawer/index.cjs.js +1 -1
  59. package/dist/nile-drawer/index.esm.js +1 -1
  60. package/dist/nile-drawer/nile-drawer.cjs.js +1 -1
  61. package/dist/nile-drawer/nile-drawer.cjs.js.map +1 -1
  62. package/dist/nile-drawer/nile-drawer.esm.js +1 -1
  63. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  64. package/dist/nile-drawer/nile-drawer.test.cjs.js.map +1 -1
  65. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  66. package/dist/nile-highlighter/index.cjs.js +1 -1
  67. package/dist/nile-highlighter/index.esm.js +1 -1
  68. package/dist/nile-highlighter/nile-highlighter.cjs.js +1 -1
  69. package/dist/nile-highlighter/nile-highlighter.esm.js +1 -1
  70. package/dist/nile-icon/icons/svg/comment.cjs.js +2 -0
  71. package/dist/nile-icon/icons/svg/comment.cjs.js.map +1 -0
  72. package/dist/nile-icon/icons/svg/comment.esm.js +1 -0
  73. package/dist/nile-icon/icons/svg/index.cjs.js +1 -1
  74. package/dist/nile-icon/icons/svg/index.esm.js +1 -1
  75. package/dist/nile-icon/icons/svg/returnvalue.cjs.js +1 -1
  76. package/dist/nile-icon/icons/svg/returnvalue.cjs.js.map +1 -1
  77. package/dist/nile-icon/icons/svg/returnvalue.esm.js +1 -1
  78. package/dist/nile-icon/index.cjs.js +1 -1
  79. package/dist/nile-icon/index.cjs.js.map +1 -1
  80. package/dist/nile-icon/index.esm.js +1 -1
  81. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  82. package/dist/nile-icon/nile-icon.test.cjs.js.map +1 -1
  83. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  84. package/dist/nile-icon-button/index.cjs.js +1 -1
  85. package/dist/nile-icon-button/index.esm.js +1 -1
  86. package/dist/nile-icon-button/nile-icon-button.cjs.js +1 -1
  87. package/dist/nile-icon-button/nile-icon-button.cjs.js.map +1 -1
  88. package/dist/nile-icon-button/nile-icon-button.esm.js +1 -1
  89. package/dist/nile-input/index.cjs.js +1 -1
  90. package/dist/nile-input/index.esm.js +1 -1
  91. package/dist/nile-input/nile-input.cjs.js +1 -1
  92. package/dist/nile-input/nile-input.cjs.js.map +1 -1
  93. package/dist/nile-input/nile-input.esm.js +1 -1
  94. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  95. package/dist/nile-input/nile-input.test.cjs.js.map +1 -1
  96. package/dist/nile-input/nile-input.test.esm.js +1 -1
  97. package/dist/nile-menu-item/index.cjs.js +1 -1
  98. package/dist/nile-menu-item/index.esm.js +1 -1
  99. package/dist/nile-menu-item/nile-menu-item.cjs.js +1 -1
  100. package/dist/nile-menu-item/nile-menu-item.cjs.js.map +1 -1
  101. package/dist/nile-menu-item/nile-menu-item.esm.js +1 -1
  102. package/dist/nile-option/index.cjs.js +1 -1
  103. package/dist/nile-option/index.esm.js +1 -1
  104. package/dist/nile-option/nile-option.cjs.js +1 -1
  105. package/dist/nile-option/nile-option.cjs.js.map +1 -1
  106. package/dist/nile-option/nile-option.esm.js +1 -1
  107. package/dist/nile-popover/index.cjs.js +1 -1
  108. package/dist/nile-popover/index.esm.js +1 -1
  109. package/dist/nile-popover/nile-popover.cjs.js +1 -1
  110. package/dist/nile-popover/nile-popover.esm.js +1 -1
  111. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  112. package/dist/nile-popover/nile-popover.test.esm.js +1 -1
  113. package/dist/nile-select/index.cjs.js +1 -1
  114. package/dist/nile-select/index.esm.js +1 -1
  115. package/dist/nile-select/nile-select.cjs.js +1 -1
  116. package/dist/nile-select/nile-select.cjs.js.map +1 -1
  117. package/dist/nile-select/nile-select.esm.js +1 -1
  118. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  119. package/dist/nile-select/nile-select.test.cjs.js.map +1 -1
  120. package/dist/nile-select/nile-select.test.esm.js +1 -1
  121. package/dist/nile-slide-toggle/nile-slide-toggle.cjs.js +1 -1
  122. package/dist/nile-slide-toggle/nile-slide-toggle.cjs.js.map +1 -1
  123. package/dist/nile-slide-toggle/nile-slide-toggle.esm.js +2 -2
  124. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  125. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js.map +1 -1
  126. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  127. package/dist/nile-tab/index.cjs.js +1 -1
  128. package/dist/nile-tab/index.esm.js +1 -1
  129. package/dist/nile-tab/nile-tab.cjs.js +1 -1
  130. package/dist/nile-tab/nile-tab.cjs.js.map +1 -1
  131. package/dist/nile-tab/nile-tab.esm.js +1 -1
  132. package/dist/nile-tab-group/index.cjs.js +1 -1
  133. package/dist/nile-tab-group/index.esm.js +1 -1
  134. package/dist/nile-tab-group/nile-tab-group.cjs.js +1 -1
  135. package/dist/nile-tab-group/nile-tab-group.cjs.js.map +1 -1
  136. package/dist/nile-tab-group/nile-tab-group.css.cjs.js +1 -1
  137. package/dist/nile-tab-group/nile-tab-group.css.cjs.js.map +1 -1
  138. package/dist/nile-tab-group/nile-tab-group.css.esm.js +1 -1
  139. package/dist/nile-tab-group/nile-tab-group.esm.js +1 -1
  140. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  141. package/dist/nile-tab-group/nile-tab-group.test.cjs.js.map +1 -1
  142. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  143. package/dist/nile-tag/index.cjs.js +1 -1
  144. package/dist/nile-tag/index.esm.js +1 -1
  145. package/dist/nile-tag/nile-tag.cjs.js +1 -1
  146. package/dist/nile-tag/nile-tag.cjs.js.map +1 -1
  147. package/dist/nile-tag/nile-tag.esm.js +1 -1
  148. package/dist/nile-toast/index.cjs.js +1 -1
  149. package/dist/nile-toast/index.esm.js +1 -1
  150. package/dist/nile-toast/nile-toast.cjs.js +1 -1
  151. package/dist/nile-toast/nile-toast.cjs.js.map +1 -1
  152. package/dist/nile-toast/nile-toast.esm.js +2 -2
  153. package/dist/nile-tree/index.cjs.js +1 -1
  154. package/dist/nile-tree/index.esm.js +1 -1
  155. package/dist/nile-tree/nile-tree.cjs.js +1 -1
  156. package/dist/nile-tree/nile-tree.cjs.js.map +1 -1
  157. package/dist/nile-tree/nile-tree.esm.js +1 -1
  158. package/dist/nile-tree-item/index.cjs.js +1 -1
  159. package/dist/nile-tree-item/index.esm.js +1 -1
  160. package/dist/nile-tree-item/nile-tree-item.cjs.js +1 -1
  161. package/dist/nile-tree-item/nile-tree-item.cjs.js.map +1 -1
  162. package/dist/nile-tree-item/nile-tree-item.esm.js +1 -1
  163. package/dist/src/index.d.ts +0 -1
  164. package/dist/src/index.js +0 -1
  165. package/dist/src/index.js.map +1 -1
  166. package/dist/src/nile-auto-complete/nile-auto-complete.css.js +6 -4
  167. package/dist/src/nile-auto-complete/nile-auto-complete.css.js.map +1 -1
  168. package/dist/src/nile-auto-complete/nile-auto-complete.d.ts +4 -3
  169. package/dist/src/nile-auto-complete/nile-auto-complete.js +35 -11
  170. package/dist/src/nile-auto-complete/nile-auto-complete.js.map +1 -1
  171. package/dist/src/nile-chip/nile-chip.d.ts +2 -2
  172. package/dist/src/nile-chip/nile-chip.js.map +1 -1
  173. package/dist/src/nile-icon/icons/svg/comment.d.ts +5 -0
  174. package/dist/src/nile-icon/icons/svg/comment.js +5 -0
  175. package/dist/src/nile-icon/icons/svg/comment.js.map +1 -0
  176. package/dist/src/nile-icon/icons/svg/index.d.ts +1 -1
  177. package/dist/src/nile-icon/icons/svg/index.js +1 -1
  178. package/dist/src/nile-icon/icons/svg/index.js.map +1 -1
  179. package/dist/src/nile-slide-toggle/nile-slide-toggle.js +2 -2
  180. package/dist/src/nile-slide-toggle/nile-slide-toggle.js.map +1 -1
  181. package/dist/src/nile-slide-toggle/nile-slide-toggle.test.js +2 -2
  182. package/dist/src/nile-slide-toggle/nile-slide-toggle.test.js.map +1 -1
  183. package/dist/src/nile-tab-group/nile-tab-group.css.js +1 -1
  184. package/dist/src/nile-tab-group/nile-tab-group.css.js.map +1 -1
  185. package/dist/tsconfig.tsbuildinfo +1 -1
  186. package/package.json +3 -4
  187. package/src/index.ts +1 -2
  188. package/src/nile-auto-complete/nile-auto-complete.css.ts +6 -4
  189. package/src/nile-auto-complete/nile-auto-complete.ts +37 -13
  190. package/src/nile-chip/nile-chip.ts +2 -2
  191. package/src/nile-icon/icons/svg/comment.ts +5 -0
  192. package/src/nile-icon/icons/svg/index.ts +1 -1
  193. package/src/nile-slide-toggle/nile-slide-toggle.test.ts +2 -2
  194. package/src/nile-slide-toggle/nile-slide-toggle.ts +2 -2
  195. package/src/nile-tab-group/nile-tab-group.css.ts +1 -1
  196. package/vscode-html-custom-data.json +6 -21
  197. package/dist/lit-element-3b4aa6c6.esm.js +0 -23
  198. package/dist/lit-element-b510b02d.cjs.js +0 -14
  199. package/dist/lit-element-b510b02d.cjs.js.map +0 -1
  200. package/dist/nile-tour/index.cjs.js +0 -2
  201. package/dist/nile-tour/index.cjs.js.map +0 -1
  202. package/dist/nile-tour/index.esm.js +0 -1
  203. package/dist/nile-tour/nile-tour.cjs.js +0 -10
  204. package/dist/nile-tour/nile-tour.cjs.js.map +0 -1
  205. package/dist/nile-tour/nile-tour.css.cjs.js +0 -2
  206. package/dist/nile-tour/nile-tour.css.cjs.js.map +0 -1
  207. package/dist/nile-tour/nile-tour.css.esm.js +0 -233
  208. package/dist/nile-tour/nile-tour.esm.js +0 -24
  209. package/dist/src/nile-tour/index.d.ts +0 -1
  210. package/dist/src/nile-tour/index.js +0 -2
  211. package/dist/src/nile-tour/index.js.map +0 -1
  212. package/dist/src/nile-tour/nile-tour.css.d.ts +0 -12
  213. package/dist/src/nile-tour/nile-tour.css.js +0 -245
  214. package/dist/src/nile-tour/nile-tour.css.js.map +0 -1
  215. package/dist/src/nile-tour/nile-tour.d.ts +0 -36
  216. package/dist/src/nile-tour/nile-tour.js +0 -180
  217. package/dist/src/nile-tour/nile-tour.js.map +0 -1
  218. package/src/nile-tour/index.ts +0 -1
  219. package/src/nile-tour/nile-tour.css.ts +0 -247
  220. package/src/nile-tour/nile-tour.ts +0 -199
@@ -1,247 +0,0 @@
1
- /**
2
- * Copyright Aquera Inc 2023
3
- *
4
- * This source code is licensed under the BSD-3-Clause license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- */
7
-
8
- import { css } from 'lit-element';
9
-
10
- /**
11
- * Tour CSS
12
- */
13
- export const styles = css`
14
- :host {
15
- }
16
-
17
- .introjs-tooltip {
18
- background-color: var(--nile-tour-background-color, #1978b8);
19
- color: var(--nile-tour-text-color, #fff);
20
- width: 300px;
21
- max-width: 300px;
22
- border-radius: 12px;
23
- border: 1px solid var(--Neutral-30, #1978b8);
24
- background: var(--White-Normal, #1978b8);
25
- /* border: 1px solid var(--Neutral-30, #C7CED4); */
26
-
27
- /* Elevation/Lifted */
28
- box-shadow: 0px 4px 8px 0px rgba(119, 125, 130, 0.15);
29
- }
30
-
31
- .introjs-tooltip-title {
32
- color: var(--nile-colors-white-base);
33
- font-size: 16px;
34
- font-style: normal;
35
- font-weight: 500;
36
- line-height: 16px;
37
- letter-spacing: 0.2px;
38
- }
39
-
40
- .introjs-tooltip-header {
41
- padding-left: 18px;
42
- padding-right: 18px;
43
- padding-top: 18px;
44
- }
45
-
46
- .introjs-progress {
47
- display: none;
48
- }
49
-
50
- .introjs-tooltiptext {
51
- color: #c7ced4;
52
- font-size: 14px;
53
- font-style: normal;
54
- font-weight: 400;
55
- line-height: 20px;
56
- letter-spacing: 0.2px;
57
- padding: 15px 18px;
58
- }
59
-
60
- .introjs-arrow {
61
- width: 15px;
62
- height: 20px;
63
- background-image: url('data:image/svg+xml,%3Csvg width="15" height="20" viewBox="0 0 15 20" fill="none" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M1.13333 11.6C0.0666661 10.8 0.0666662 9.2 1.13333 8.4L11.8 0.400001C13.1185 -0.588854 15 0.351909 15 2L15 18C15 19.6481 13.1185 20.5889 11.8 19.6L1.13333 11.6Z" fill="%231978B8"/%3E%3C/svg%3E');
64
- background-repeat: no-repeat;
65
- background-size: contain;
66
- background-position: center;
67
- position: absolute;
68
- border: none;
69
- content: none;
70
- }
71
-
72
- .introjs-arrow.top {
73
- top: -14.5px;
74
- transform: rotate(90deg);
75
- clip-path: inset(0px 3px 0px 0px);
76
- }
77
-
78
- .introjs-arrow.bottom {
79
- bottom: -14.5px;
80
- transform: rotate(270deg);
81
- clip-path: inset(0px 3px 0px 0px);
82
- }
83
-
84
- .introjs-arrow.left {
85
- left: -11.5px;
86
- transform: rotate(0);
87
- clip-path: inset(0px 3px 0px 0px);
88
- }
89
-
90
- .introjs-arrow.right {
91
- right: -12px;
92
- transform: rotate(180deg);
93
- clip-path: inset(0px 3px 0px 0px);
94
- }
95
-
96
- .introjs-arrow.left-bottom {
97
- transform: rotate(0);
98
- clip-path: inset(0px 1px 0px 0px);
99
- left: -13.5px;
100
- border-right-color: var(--nile-tour-background-color, var(--nile-colors-white-base)) !important;
101
- }
102
-
103
- .introjs-arrow.right-bottom {
104
- right: -12px;
105
- transform: rotate(180deg);
106
- clip-path: inset(0px 3px 0px 0px);
107
- border-left-color: var(--nile-tour-background-color, var(--nile-colors-white-base)) !important;
108
- }
109
-
110
- .introjs-arrow.top-middle {
111
- top: -14px;
112
- left: 50%;
113
- margin-left: -5px;
114
- transform: rotate(90deg);
115
- clip-path: inset(0px 3px 0px 0px);
116
- }
117
-
118
- .introjs-button {
119
- background: none;
120
- border: none;
121
- color: var(--nile-tour-text-color, var(--nile-colors-white-base));
122
- font-size: 14px;
123
- padding: 0;
124
- cursor: pointer;
125
- text-shadow: none;
126
- background: var(--Primary-Normal, #1978b8);
127
- border-color: transparent;
128
- display: flex;
129
- padding: 12px;
130
- align-items: center;
131
- gap: 12px;
132
- border-radius: 4px;
133
- font-weight: 500;
134
- }
135
-
136
- .introjs-button:hover {
137
- background: none;
138
- border: none;
139
- color: var(--nile-tour-text-color, var(--nile-colors-white-base));
140
- font-size: 14px;
141
- padding: 0;
142
- cursor: pointer;
143
- text-shadow: none;
144
- background: var(--Primary-Normal, #1978b8);
145
- border-color: transparent;
146
- display: flex;
147
- padding: 12px;
148
- align-items: center;
149
- gap: 12px;
150
- }
151
-
152
- .introjs-button:focus {
153
- background: none;
154
- border: none;
155
- color: var(--nile-tour-text-color, var(--nile-colors-white-base));
156
- font-size: 14px;
157
- padding: 0;
158
- cursor: pointer;
159
- text-shadow: none;
160
- box-shadow: none;
161
- background: var(--Primary-Normal, #1978b8);
162
- border-color: transparent;
163
- display: flex;
164
- padding: 12px;
165
- align-items: center;
166
- gap: 12px;
167
- }
168
-
169
- .introjs-tooltipbuttons {
170
- border-top: none;
171
- display: flex;
172
- justify-content: flex-end;
173
- gap: 10px;
174
- }
175
-
176
- .introjs-helperNumberLayer {
177
- display: none;
178
- }
179
-
180
- .introjs-bullets {
181
- display: none;
182
- }
183
-
184
- .introjs-skipbutton {
185
- display: none;
186
- }
187
-
188
- .introjs-prev-button {
189
- color: #c7ced4;
190
- }
191
-
192
- .introjs-helperLayer {
193
- box-shadow: rgb(33 33 33 / 0%) 0px 0px 1px 2px,
194
- rgba(33, 33, 33, 0.5) 0px 0px 0px 5000px !important;
195
- }
196
-
197
- .introjs-step-counter {
198
- margin-right: auto;
199
- font-size: 14px;
200
- padding: 0 10px;
201
- display: flex;
202
- align-items: center;
203
- color: var(--Color-Text-Inverted-Secondary, rgba(255, 255, 255, 0.5));
204
- font-style: normal;
205
- font-weight: 500;
206
- line-height: 14px;
207
- letter-spacing: 0.2px;
208
- }
209
-
210
- @keyframes shake {
211
- 0% {
212
- transform: translateX(0);
213
- }
214
- 25% {
215
- transform: translateX(-5px);
216
- }
217
- 50% {
218
- transform: translateX(5px);
219
- }
220
- 75% {
221
- transform: translateX(-5px);
222
- }
223
- 100% {
224
- transform: translateX(0);
225
- }
226
- }
227
-
228
- .introjs-shake {
229
- animation: shake 0.5s ease infinite;
230
- }
231
-
232
- .introjs-close-btn {
233
- position: absolute;
234
- top: 15px;
235
- right: 10px;
236
- background: none;
237
- border: none;
238
- font-size: 16px;
239
- cursor: pointer;
240
- }
241
-
242
- a[disabled='true'] {
243
- display: none;
244
- }
245
- `;
246
-
247
- export default [styles];
@@ -1,199 +0,0 @@
1
- /**
2
- * Copyright Aquera Inc 2023
3
- *
4
- * This source code is licensed under the BSD-3-Clause license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- */
7
-
8
- import { LitElement, html, css, CSSResultArray, TemplateResult } from 'lit';
9
- import { customElement, property } from 'lit/decorators.js';
10
- import introJs from 'intro.js';
11
- import { styles } from './nile-tour.css';
12
-
13
- @customElement('nile-tour')
14
- export class NileTour extends LitElement {
15
- tourInstance: ReturnType<typeof introJs> | null = null;
16
-
17
- /**
18
- * JSON string for steps.
19
- */
20
- @property({ type: String })
21
- stepsJson: string = '';
22
-
23
- /**
24
- * Whether to show the backdrop overlay.
25
- */
26
- @property({ type: Boolean })
27
- showBackdrop: boolean = false;
28
-
29
- /**
30
- * Whether to disable interaction during the tour.
31
- */
32
- @property({ type: Boolean })
33
- disableInteraction: boolean = false;
34
-
35
- public static get styles(): CSSResultArray {
36
- return [styles];
37
- }
38
-
39
- createRenderRoot() {
40
- return this;
41
- }
42
-
43
- constructor() {
44
- super();
45
- }
46
-
47
- private parseSteps(): any[] {
48
- if (Array.isArray(this.stepsJson)) {
49
- return this.stepsJson;
50
- }
51
-
52
- console.error('Invalid stepsJson format');
53
- return [];
54
- }
55
-
56
- private async getElementWhenNeeded(step: any): Promise<any> {
57
- return {
58
- element: () => document.querySelector(`[data-tour="${step.element}"]`) as HTMLElement | null,
59
- intro: step.content,
60
- title: step.title,
61
- position: step.position,
62
- beforeChange: step.beforeChange,
63
- afterChange: step.afterChange,
64
- disableNext: step.disableNext || false,
65
- disablePrev: step.disablePrev || false
66
- };
67
- }
68
-
69
- public nextStep() {
70
- this.tourInstance?.nextStep();
71
- }
72
-
73
- public async startTour(): Promise<void> {
74
- const steps = await Promise.all(this.parseSteps().map(step => this.getElementWhenNeeded(step)));
75
-
76
- if (steps.length === 0) {
77
- console.error('No valid steps found for the tour.');
78
- return;
79
- }
80
-
81
- this.tourInstance = introJs().setOptions({
82
- steps: steps as any,
83
- disableInteraction: this.disableInteraction,
84
- nextLabel: 'Next',
85
- prevLabel: 'Prev',
86
- overlayOpacity: this.showBackdrop ? 0.5 : 0,
87
- exitOnOverlayClick: false,
88
- showProgress: false,
89
- showButtons: true
90
- });
91
-
92
- this.tourInstance.onbeforechange(async (targetElement) => {
93
- const currentStepIndex = this.tourInstance?._currentStep ?? 0;
94
- const step = steps[currentStepIndex];
95
- if (step && typeof step.element === 'function') {
96
- const el = step.element();
97
- if (el) {
98
- if (this.tourInstance && this.tourInstance._introItems) {
99
- this.tourInstance._introItems[currentStepIndex].element = el;
100
- }
101
- }
102
- }
103
- if (step.beforeChange) {
104
- return await step.beforeChange();
105
- }
106
- return true;
107
- });
108
-
109
- this.tourInstance.onafterchange((targetElement) => {
110
- const currentStepIndex = this.tourInstance?._currentStep ?? 0;
111
- const step = steps[currentStepIndex];
112
- if (step?.afterChange) {
113
- step.afterChange();
114
- }
115
-
116
-
117
- const nextBtn = document.querySelector('.introjs-nextbutton');
118
- const prevBtn = document.querySelector('.introjs-prevbutton');
119
-
120
- if (nextBtn) {
121
- nextBtn.setAttribute('disabled', step.disableNext ? 'true' : 'false');
122
- }
123
- if (prevBtn) {
124
- prevBtn.setAttribute('disabled', step.disablePrev ? 'true' : 'false');
125
- }
126
- });
127
-
128
- this.tourInstance.onchange(() => {
129
- const currentStep = this.tourInstance?._currentStep ?? 0;
130
- const totalSteps = steps.length;
131
- const tooltip = document.querySelector('.introjs-tooltip');
132
- if (tooltip) {
133
- const navBar = tooltip.querySelector('.introjs-tooltipbuttons');
134
- if (navBar) {
135
- let stepCounter = navBar.querySelector('.introjs-step-counter') as HTMLElement;
136
- if (!stepCounter) {
137
- stepCounter = document.createElement('div');
138
- stepCounter.className = 'introjs-step-counter';
139
- navBar.insertBefore(stepCounter, navBar.firstChild);
140
- }
141
- stepCounter.textContent = `${currentStep + 1} of ${totalSteps}`;
142
- }
143
- }
144
- });
145
-
146
- this.tourInstance.start().then(() => {
147
- const currentStep = this.tourInstance?._currentStep ?? 0;
148
- const totalSteps = steps.length;
149
- const tooltip = document.querySelector('.introjs-tooltip');
150
- if (tooltip) {
151
- const navBar = tooltip.querySelector('.introjs-tooltipbuttons');
152
- if (navBar) {
153
- let stepCounter = navBar.querySelector('.introjs-step-counter') as HTMLElement;
154
- if (!stepCounter) {
155
- stepCounter = document.createElement('div');
156
- stepCounter.className = 'introjs-step-counter';
157
- navBar.insertBefore(stepCounter, navBar.firstChild);
158
- }
159
- stepCounter.textContent = `${currentStep + 1} of ${totalSteps}`;
160
- }
161
-
162
- const closeButton = document.createElement('button');
163
- closeButton.className = 'introjs-close-btn';
164
- closeButton.innerHTML = `
165
- <svg width="12" height="12" viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg">
166
- <path d="M5.33228 5.99996L0 11.3322L0.667759 12L6.00004 6.66772L11.3323 12L12.0001 11.3322L6.66779 5.99996L12 0.667759L11.3322 0L6.00004 5.3322L0.667842 5.96046e-08L8.40425e-05 0.667759L5.33228 5.99996Z" fill="white" fill-opacity="0.5"/>
167
- </svg>`;
168
- closeButton.onclick = () => this.tourInstance?.exit(true);
169
- tooltip.appendChild(closeButton);
170
- }
171
- }).catch(err => {
172
- console.error('Error starting the tour:', err);
173
- });
174
- }
175
-
176
- public render(): TemplateResult {
177
- return html`
178
- <style>
179
- ${styles.cssText}
180
- .introjs-close-btn {
181
- position: absolute;
182
- top: 5px;
183
- right: 10px;
184
- background: none;
185
- border: none;
186
- cursor: pointer;
187
- padding: 0;
188
- }
189
- </style>
190
- <slot></slot>
191
- `;
192
- }
193
- }
194
-
195
- declare global {
196
- interface HTMLElementTagNameMap {
197
- 'nile-tour': NileTour;
198
- }
199
- }