@dropi/ui-components 1.0.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 (393) hide show
  1. package/.gitignore +13 -0
  2. package/CONTRIBUTING.md +188 -0
  3. package/MIGRATION_STEPS.md +39 -0
  4. package/PUBLISH_CHECKLIST.md +97 -0
  5. package/QUICK_START.md +108 -0
  6. package/README.md +146 -0
  7. package/jest.config.ts +21 -0
  8. package/ng-package.json +8 -0
  9. package/package.json +66 -0
  10. package/project.json +48 -0
  11. package/publish.sh +113 -0
  12. package/src/components-source/accordion/accordion-item/accordion-item.component.html +12 -0
  13. package/src/components-source/accordion/accordion-item/accordion-item.component.scss +47 -0
  14. package/src/components-source/accordion/accordion-item/accordion-item.component.spec.ts +122 -0
  15. package/src/components-source/accordion/accordion-item/accordion-item.component.ts +42 -0
  16. package/src/components-source/accordion/accordion.component.html +3 -0
  17. package/src/components-source/accordion/accordion.component.scss +5 -0
  18. package/src/components-source/accordion/accordion.component.spec.ts +243 -0
  19. package/src/components-source/accordion/accordion.component.stories.ts +111 -0
  20. package/src/components-source/accordion/accordion.component.ts +43 -0
  21. package/src/components-source/alert/alert.component.html +28 -0
  22. package/src/components-source/alert/alert.component.scss +154 -0
  23. package/src/components-source/alert/alert.component.spec.ts +185 -0
  24. package/src/components-source/alert/alert.component.stories.ts +310 -0
  25. package/src/components-source/alert/alert.component.ts +203 -0
  26. package/src/components-source/alert-legacy/alert.component.html +21 -0
  27. package/src/components-source/alert-legacy/alert.component.scss +42 -0
  28. package/src/components-source/alert-legacy/alert.component.spec.ts +159 -0
  29. package/src/components-source/alert-legacy/alert.component.ts +33 -0
  30. package/src/components-source/alert-modal/alert-modal.component.html +124 -0
  31. package/src/components-source/alert-modal/alert-modal.component.scss +203 -0
  32. package/src/components-source/alert-modal/alert-modal.component.spec.ts +557 -0
  33. package/src/components-source/alert-modal/alert-modal.component.stories.ts +295 -0
  34. package/src/components-source/alert-modal/alert-modal.component.ts +294 -0
  35. package/src/components-source/alert-modal/services/template-alert-modal.service.ts +75 -0
  36. package/src/components-source/badge/badge.component.html +49 -0
  37. package/src/components-source/badge/badge.component.scss +57 -0
  38. package/src/components-source/badge/badge.component.spec.ts +181 -0
  39. package/src/components-source/badge/badge.component.ts +21 -0
  40. package/src/components-source/breadcrumb/breadcrumb.component.html +5 -0
  41. package/src/components-source/breadcrumb/breadcrumb.component.scss +46 -0
  42. package/src/components-source/breadcrumb/breadcrumb.component.spec.ts +279 -0
  43. package/src/components-source/breadcrumb/breadcrumb.component.ts +24 -0
  44. package/src/components-source/card-product/card-product.component.html +173 -0
  45. package/src/components-source/card-product/card-product.component.spec.ts +601 -0
  46. package/src/components-source/card-product/card-product.component.stories.ts +322 -0
  47. package/src/components-source/card-product/card-product.component.ts +1101 -0
  48. package/src/components-source/card-section/card-section.component.html +22 -0
  49. package/src/components-source/card-section/card-section.component.scss +14 -0
  50. package/src/components-source/card-section/card-section.component.spec.ts +333 -0
  51. package/src/components-source/card-section/card-section.component.stories.ts +141 -0
  52. package/src/components-source/card-section/card-section.component.ts +35 -0
  53. package/src/components-source/checkbox-selection-list/checkbox-selection-list.component.html +38 -0
  54. package/src/components-source/checkbox-selection-list/checkbox-selection-list.component.scss +147 -0
  55. package/src/components-source/checkbox-selection-list/checkbox-selection-list.component.spec.ts +555 -0
  56. package/src/components-source/checkbox-selection-list/checkbox-selection-list.component.stories.ts +157 -0
  57. package/src/components-source/checkbox-selection-list/checkbox-selection-list.component.ts +219 -0
  58. package/src/components-source/city-selector/city-selector.component.html +22 -0
  59. package/src/components-source/city-selector/city-selector.component.scss +1 -0
  60. package/src/components-source/city-selector/city-selector.component.spec.ts +278 -0
  61. package/src/components-source/city-selector/city-selector.component.stories.ts +200 -0
  62. package/src/components-source/city-selector/city-selector.component.ts +151 -0
  63. package/src/components-source/color-picker/color-picker.component.html +54 -0
  64. package/src/components-source/color-picker/color-picker.component.scss +203 -0
  65. package/src/components-source/color-picker/color-picker.component.spec.ts +148 -0
  66. package/src/components-source/color-picker/color-picker.component.stories.ts +70 -0
  67. package/src/components-source/color-picker/color-picker.component.ts +353 -0
  68. package/src/components-source/country-flags/country-flags.component.html +10 -0
  69. package/src/components-source/country-flags/country-flags.component.scss +34 -0
  70. package/src/components-source/country-flags/country-flags.component.spec.ts +78 -0
  71. package/src/components-source/country-flags/country-flags.component.ts +18 -0
  72. package/src/components-source/date-picker/date-picker.component.html +35 -0
  73. package/src/components-source/date-picker/date-picker.component.scss +388 -0
  74. package/src/components-source/date-picker/date-picker.component.spec.ts +510 -0
  75. package/src/components-source/date-picker/date-picker.component.stories.ts +444 -0
  76. package/src/components-source/date-picker/date-picker.component.ts +313 -0
  77. package/src/components-source/date-picker/date-picker.stories.spec.ts +150 -0
  78. package/src/components-source/date-picker-range/date-picker-range.component.html +45 -0
  79. package/src/components-source/date-picker-range/date-picker-range.component.scss +229 -0
  80. package/src/components-source/date-picker-range/date-picker-range.component.spec.ts +555 -0
  81. package/src/components-source/date-picker-range/date-picker-range.component.ts +254 -0
  82. package/src/components-source/dropi-avatars/dropi-avatars.component.html +17 -0
  83. package/src/components-source/dropi-avatars/dropi-avatars.component.scss +58 -0
  84. package/src/components-source/dropi-avatars/dropi-avatars.component.spec.ts +403 -0
  85. package/src/components-source/dropi-avatars/dropi-avatars.component.ts +24 -0
  86. package/src/components-source/dropi-badge/dropi-badge.component.html +12 -0
  87. package/src/components-source/dropi-badge/dropi-badge.component.scss +50 -0
  88. package/src/components-source/dropi-badge/dropi-badge.component.spec.ts +108 -0
  89. package/src/components-source/dropi-badge/dropi-badge.component.stories.ts +140 -0
  90. package/src/components-source/dropi-badge/dropi-badge.component.ts +39 -0
  91. package/src/components-source/dropi-banner-external/dropi-banner-external.component.html +67 -0
  92. package/src/components-source/dropi-banner-external/dropi-banner-external.component.scss +46 -0
  93. package/src/components-source/dropi-banner-external/dropi-banner-external.component.spec.ts +170 -0
  94. package/src/components-source/dropi-banner-external/dropi-banner-external.component.stories.ts +203 -0
  95. package/src/components-source/dropi-banner-external/dropi-banner-external.component.ts +204 -0
  96. package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.html +65 -0
  97. package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.scss +65 -0
  98. package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.spec.ts +125 -0
  99. package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.ts +38 -0
  100. package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.stories.ts +133 -0
  101. package/src/components-source/dropi-button/dropi-button.component.html +37 -0
  102. package/src/components-source/dropi-button/dropi-button.component.scss +266 -0
  103. package/src/components-source/dropi-button/dropi-button.component.spec.ts +264 -0
  104. package/src/components-source/dropi-button/dropi-button.component.stories.ts +221 -0
  105. package/src/components-source/dropi-button/dropi-button.component.ts +82 -0
  106. package/src/components-source/dropi-card-checkbox/dropi-card-checkbox.component.html +24 -0
  107. package/src/components-source/dropi-card-checkbox/dropi-card-checkbox.component.scss +85 -0
  108. package/src/components-source/dropi-card-checkbox/dropi-card-checkbox.component.spec.ts +157 -0
  109. package/src/components-source/dropi-card-checkbox/dropi-card-checkbox.component.stories.ts +209 -0
  110. package/src/components-source/dropi-card-checkbox/dropi-card-checkbox.component.ts +41 -0
  111. package/src/components-source/dropi-carousel/dropi-carousel.component.html +57 -0
  112. package/src/components-source/dropi-carousel/dropi-carousel.component.scss +156 -0
  113. package/src/components-source/dropi-carousel/dropi-carousel.component.spec.ts +224 -0
  114. package/src/components-source/dropi-carousel/dropi-carousel.component.ts +266 -0
  115. package/src/components-source/dropi-carousel/dropi-carousel.stories.ts +365 -0
  116. package/src/components-source/dropi-checkbox/dropi-checkbox.component.css +39 -0
  117. package/src/components-source/dropi-checkbox/dropi-checkbox.component.html +18 -0
  118. package/src/components-source/dropi-checkbox/dropi-checkbox.component.spec.ts +155 -0
  119. package/src/components-source/dropi-checkbox/dropi-checkbox.component.stories.ts +101 -0
  120. package/src/components-source/dropi-checkbox/dropi-checkbox.component.ts +25 -0
  121. package/src/components-source/dropi-chips/dropi-chips.component.html +10 -0
  122. package/src/components-source/dropi-chips/dropi-chips.component.scss +54 -0
  123. package/src/components-source/dropi-chips/dropi-chips.component.spec.ts +356 -0
  124. package/src/components-source/dropi-chips/dropi-chips.component.stories.ts +275 -0
  125. package/src/components-source/dropi-chips/dropi-chips.component.ts +100 -0
  126. package/src/components-source/dropi-country-selector/countries.data.ts +239 -0
  127. package/src/components-source/dropi-country-selector/dropi-country-selector.component.html +59 -0
  128. package/src/components-source/dropi-country-selector/dropi-country-selector.component.scss +126 -0
  129. package/src/components-source/dropi-country-selector/dropi-country-selector.component.spec.ts +244 -0
  130. package/src/components-source/dropi-country-selector/dropi-country-selector.component.stories.ts +117 -0
  131. package/src/components-source/dropi-country-selector/dropi-country-selector.component.ts +179 -0
  132. package/src/components-source/dropi-drawer/dropi-drawer.component.html +23 -0
  133. package/src/components-source/dropi-drawer/dropi-drawer.component.scss +88 -0
  134. package/src/components-source/dropi-drawer/dropi-drawer.component.spec.ts +84 -0
  135. package/src/components-source/dropi-drawer/dropi-drawer.component.ts +90 -0
  136. package/src/components-source/dropi-dropdown/dropi-dropdown.component.html +30 -0
  137. package/src/components-source/dropi-dropdown/dropi-dropdown.component.scss +58 -0
  138. package/src/components-source/dropi-dropdown/dropi-dropdown.component.spec.ts +213 -0
  139. package/src/components-source/dropi-dropdown/dropi-dropdown.component.stories.ts +143 -0
  140. package/src/components-source/dropi-dropdown/dropi-dropdown.component.ts +53 -0
  141. package/src/components-source/dropi-favorite-button/dropi-favorite-button.component.html +23 -0
  142. package/src/components-source/dropi-favorite-button/dropi-favorite-button.component.scss +21 -0
  143. package/src/components-source/dropi-favorite-button/dropi-favorite-button.component.spec.ts +240 -0
  144. package/src/components-source/dropi-favorite-button/dropi-favorite-button.component.ts +31 -0
  145. package/src/components-source/dropi-file-upload/card-view/card-view.component.html +154 -0
  146. package/src/components-source/dropi-file-upload/card-view/card-view.component.scss +118 -0
  147. package/src/components-source/dropi-file-upload/card-view/card-view.component.ts +72 -0
  148. package/src/components-source/dropi-file-upload/drop-zone/drop-zone.coment.stories.ts +179 -0
  149. package/src/components-source/dropi-file-upload/drop-zone/drop-zone.component.html +111 -0
  150. package/src/components-source/dropi-file-upload/drop-zone/drop-zone.component.scss +90 -0
  151. package/src/components-source/dropi-file-upload/drop-zone/drop-zone.component.ts +172 -0
  152. package/src/components-source/dropi-file-upload/dropi-file-upload.component.html +42 -0
  153. package/src/components-source/dropi-file-upload/dropi-file-upload.component.scss +31 -0
  154. package/src/components-source/dropi-file-upload/dropi-file-upload.component.spec.ts +398 -0
  155. package/src/components-source/dropi-file-upload/dropi-file-upload.component.stories.ts +139 -0
  156. package/src/components-source/dropi-file-upload/dropi-file-upload.component.ts +329 -0
  157. package/src/components-source/dropi-file-upload/file-list/file-list.component.html +51 -0
  158. package/src/components-source/dropi-file-upload/file-list/file-list.component.scss +60 -0
  159. package/src/components-source/dropi-file-upload/file-list/file-list.component.ts +84 -0
  160. package/src/components-source/dropi-file-upload/grid-view/grid-view.component.html +77 -0
  161. package/src/components-source/dropi-file-upload/grid-view/grid-view.component.scss +85 -0
  162. package/src/components-source/dropi-file-upload/grid-view/grid-view.component.ts +35 -0
  163. package/src/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.html +38 -0
  164. package/src/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.scss +59 -0
  165. package/src/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.spec.ts +214 -0
  166. package/src/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.ts +65 -0
  167. package/src/components-source/dropi-image-overlay/dropi-image-overlay.component.html +54 -0
  168. package/src/components-source/dropi-image-overlay/dropi-image-overlay.component.scss +210 -0
  169. package/src/components-source/dropi-image-overlay/dropi-image-overlay.component.spec.ts +145 -0
  170. package/src/components-source/dropi-image-overlay/dropi-image-overlay.component.ts +76 -0
  171. package/src/components-source/dropi-image-overlay/dropi-image-overlay.stories.ts +267 -0
  172. package/src/components-source/dropi-languages-selector/dropi-languages-selector.component.html +17 -0
  173. package/src/components-source/dropi-languages-selector/dropi-languages-selector.component.scss +82 -0
  174. package/src/components-source/dropi-languages-selector/dropi-languages-selector.component.spec.ts +152 -0
  175. package/src/components-source/dropi-languages-selector/dropi-languages-selector.component.ts +41 -0
  176. package/src/components-source/dropi-logo/dropi-logo.component.html +3 -0
  177. package/src/components-source/dropi-logo/dropi-logo.component.scss +20 -0
  178. package/src/components-source/dropi-logo/dropi-logo.component.spec.ts +274 -0
  179. package/src/components-source/dropi-logo/dropi-logo.component.ts +24 -0
  180. package/src/components-source/dropi-modal/dropi-modal-stack.service.ts +75 -0
  181. package/src/components-source/dropi-modal/dropi-modal.component.html +55 -0
  182. package/src/components-source/dropi-modal/dropi-modal.component.scss +274 -0
  183. package/src/components-source/dropi-modal/dropi-modal.component.spec.ts +46 -0
  184. package/src/components-source/dropi-modal/dropi-modal.component.stories.ts +392 -0
  185. package/src/components-source/dropi-modal/dropi-modal.component.ts +392 -0
  186. package/src/components-source/dropi-modal/p-template.directive.ts +11 -0
  187. package/src/components-source/dropi-navbar/dropi-navbar.component.html +41 -0
  188. package/src/components-source/dropi-navbar/dropi-navbar.component.scss +227 -0
  189. package/src/components-source/dropi-navbar/dropi-navbar.component.spec.ts +110 -0
  190. package/src/components-source/dropi-navbar/dropi-navbar.component.ts +52 -0
  191. package/src/components-source/dropi-paginator/dropi-paginator.component.html +64 -0
  192. package/src/components-source/dropi-paginator/dropi-paginator.component.scss +43 -0
  193. package/src/components-source/dropi-paginator/dropi-paginator.component.spec.ts +285 -0
  194. package/src/components-source/dropi-paginator/dropi-paginator.component.stories.ts +345 -0
  195. package/src/components-source/dropi-paginator/dropi-paginator.component.ts +85 -0
  196. package/src/components-source/dropi-phone-input/dropi-phone-input.component.html +93 -0
  197. package/src/components-source/dropi-phone-input/dropi-phone-input.component.scss +224 -0
  198. package/src/components-source/dropi-phone-input/dropi-phone-input.component.spec.ts +376 -0
  199. package/src/components-source/dropi-phone-input/dropi-phone-input.component.ts +203 -0
  200. package/src/components-source/dropi-phone-input/numeric-input.directive.ts +17 -0
  201. package/src/components-source/dropi-radio-button/dropi-radio-button.component.html +8 -0
  202. package/src/components-source/dropi-radio-button/dropi-radio-button.component.scss +33 -0
  203. package/src/components-source/dropi-radio-button/dropi-radio-button.component.spec.ts +225 -0
  204. package/src/components-source/dropi-radio-button/dropi-radio-button.component.ts +48 -0
  205. package/src/components-source/dropi-search/dropi-search.component.html +124 -0
  206. package/src/components-source/dropi-search/dropi-search.component.scss +116 -0
  207. package/src/components-source/dropi-search/dropi-search.component.spec.ts +483 -0
  208. package/src/components-source/dropi-search/dropi-search.component.stories.ts +267 -0
  209. package/src/components-source/dropi-search/dropi-search.component.ts +230 -0
  210. package/src/components-source/dropi-select/dropi-select.component.html +158 -0
  211. package/src/components-source/dropi-select/dropi-select.component.scss +275 -0
  212. package/src/components-source/dropi-select/dropi-select.component.spec.ts +386 -0
  213. package/src/components-source/dropi-select/dropi-select.component.stories.ts +686 -0
  214. package/src/components-source/dropi-select/dropi-select.component.ts +465 -0
  215. package/src/components-source/dropi-skeleton/dropi-skeleton.component.html +10 -0
  216. package/src/components-source/dropi-skeleton/dropi-skeleton.component.scss +28 -0
  217. package/src/components-source/dropi-skeleton/dropi-skeleton.component.spec.ts +273 -0
  218. package/src/components-source/dropi-skeleton/dropi-skeleton.component.stories.ts +145 -0
  219. package/src/components-source/dropi-skeleton/dropi-skeleton.component.ts +30 -0
  220. package/src/components-source/dropi-steps/dropi-steps.component.html +29 -0
  221. package/src/components-source/dropi-steps/dropi-steps.component.scss +110 -0
  222. package/src/components-source/dropi-steps/dropi-steps.component.spec.ts +228 -0
  223. package/src/components-source/dropi-steps/dropi-steps.component.stories.ts +231 -0
  224. package/src/components-source/dropi-steps/dropi-steps.component.ts +98 -0
  225. package/src/components-source/dropi-switch/dropi-switch.component.html +4 -0
  226. package/src/components-source/dropi-switch/dropi-switch.component.scss +50 -0
  227. package/src/components-source/dropi-switch/dropi-switch.component.spec.ts +105 -0
  228. package/src/components-source/dropi-switch/dropi-switch.component.stories.ts +106 -0
  229. package/src/components-source/dropi-switch/dropi-switch.component.ts +22 -0
  230. package/src/components-source/dropi-table/dropi-table.component.html +395 -0
  231. package/src/components-source/dropi-table/dropi-table.component.scss +506 -0
  232. package/src/components-source/dropi-table/dropi-table.component.spec.ts +578 -0
  233. package/src/components-source/dropi-table/dropi-table.component.stories.ts +313 -0
  234. package/src/components-source/dropi-table/dropi-table.component.ts +580 -0
  235. package/src/components-source/dropi-tag/dropi-tag.component.html +17 -0
  236. package/src/components-source/dropi-tag/dropi-tag.component.scss +50 -0
  237. package/src/components-source/dropi-tag/dropi-tag.component.spec.ts +267 -0
  238. package/src/components-source/dropi-tag/dropi-tag.component.stories.ts +290 -0
  239. package/src/components-source/dropi-tag/dropi-tag.component.ts +92 -0
  240. package/src/components-source/dropi-text-area/droip-text-area.component.stories.ts +138 -0
  241. package/src/components-source/dropi-text-area/dropi-text-area.component.html +63 -0
  242. package/src/components-source/dropi-text-area/dropi-text-area.component.scss +106 -0
  243. package/src/components-source/dropi-text-area/dropi-text-area.component.spec.ts +507 -0
  244. package/src/components-source/dropi-text-area/dropi-text-area.component.ts +80 -0
  245. package/src/components-source/dropi-tooltip/dropi-tooltip.component.html +70 -0
  246. package/src/components-source/dropi-tooltip/dropi-tooltip.component.scss +250 -0
  247. package/src/components-source/dropi-tooltip/dropi-tooltip.component.spec.ts +423 -0
  248. package/src/components-source/dropi-tooltip/dropi-tooltip.component.ts +153 -0
  249. package/src/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.component.html +20 -0
  250. package/src/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.component.scss +63 -0
  251. package/src/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.component.spec.ts +121 -0
  252. package/src/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.component.ts +43 -0
  253. package/src/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.stories.ts +125 -0
  254. package/src/components-source/empty-state/empty-state.component.html +30 -0
  255. package/src/components-source/empty-state/empty-state.component.scss +76 -0
  256. package/src/components-source/empty-state/empty-state.component.spec.ts +244 -0
  257. package/src/components-source/empty-state/empty-state.component.stories.ts +198 -0
  258. package/src/components-source/empty-state/empty-state.component.ts +34 -0
  259. package/src/components-source/file-upload-progress-bar/file-upload-progress-bar.component.html +81 -0
  260. package/src/components-source/file-upload-progress-bar/file-upload-progress-bar.component.scss +86 -0
  261. package/src/components-source/file-upload-progress-bar/file-upload-progress-bar.component.spec.ts +27 -0
  262. package/src/components-source/file-upload-progress-bar/file-upload-progress-bar.component.stories.ts +149 -0
  263. package/src/components-source/file-upload-progress-bar/file-upload-progress-bar.component.ts +89 -0
  264. package/src/components-source/foundations/dropi-border-radius-demo/dropi-border-radius-demo.component.scss +32 -0
  265. package/src/components-source/foundations/dropi-border-radius-demo/dropi-border-radius-demo.component.ts +17 -0
  266. package/src/components-source/foundations/foundations.component.html +183 -0
  267. package/src/components-source/foundations/foundations.component.scss +31 -0
  268. package/src/components-source/foundations/foundations.component.ts +26 -0
  269. package/src/components-source/icon/icon-names.const.ts +270 -0
  270. package/src/components-source/icon/icon.component.html +3 -0
  271. package/src/components-source/icon/icon.component.scss +4 -0
  272. package/src/components-source/icon/icon.component.spec.ts +304 -0
  273. package/src/components-source/icon/icon.component.ts +53 -0
  274. package/src/components-source/index.ts +89 -0
  275. package/src/components-source/input/input.component.html +97 -0
  276. package/src/components-source/input/input.component.scss +149 -0
  277. package/src/components-source/input/input.component.spec.ts +243 -0
  278. package/src/components-source/input/input.component.stories.ts +269 -0
  279. package/src/components-source/input/input.component.ts +119 -0
  280. package/src/components-source/lottie-loader/lottie-loader.component.html +16 -0
  281. package/src/components-source/lottie-loader/lottie-loader.component.scss +32 -0
  282. package/src/components-source/lottie-loader/lottie-loader.component.spec.ts +103 -0
  283. package/src/components-source/lottie-loader/lottie-loader.component.ts +20 -0
  284. package/src/components-source/otp-send-code/mock-otp-services.ts +214 -0
  285. package/src/components-source/otp-send-code/otp-send-code.component.html +151 -0
  286. package/src/components-source/otp-send-code/otp-send-code.component.scss +156 -0
  287. package/src/components-source/otp-send-code/otp-send-code.component.spec.ts +419 -0
  288. package/src/components-source/otp-send-code/otp-send-code.component.stories.ts +190 -0
  289. package/src/components-source/otp-send-code/otp-send-code.component.ts +659 -0
  290. package/src/components-source/radio-selection-list/radio-selection-list.component.html +107 -0
  291. package/src/components-source/radio-selection-list/radio-selection-list.component.scss +280 -0
  292. package/src/components-source/radio-selection-list/radio-selection-list.component.spec.ts +243 -0
  293. package/src/components-source/radio-selection-list/radio-selection-list.component.stories.ts +313 -0
  294. package/src/components-source/radio-selection-list/radio-selection-list.component.ts +143 -0
  295. package/src/components-source/read-more/read-more.component.html +14 -0
  296. package/src/components-source/read-more/read-more.component.scss +16 -0
  297. package/src/components-source/read-more/read-more.component.spec.ts +272 -0
  298. package/src/components-source/read-more/read-more.component.stories.ts +131 -0
  299. package/src/components-source/read-more/read-more.component.ts +88 -0
  300. package/src/components-source/sidebar/sidebar.component.html +42 -0
  301. package/src/components-source/sidebar/sidebar.component.scss +70 -0
  302. package/src/components-source/sidebar/sidebar.component.spec.ts +354 -0
  303. package/src/components-source/sidebar/sidebar.component.stories.ts +145 -0
  304. package/src/components-source/sidebar/sidebar.component.ts +105 -0
  305. package/src/components-source/simple-stepper/simple-stepper.component.html +17 -0
  306. package/src/components-source/simple-stepper/simple-stepper.component.scss +117 -0
  307. package/src/components-source/simple-stepper/simple-stepper.component.spec.ts +348 -0
  308. package/src/components-source/simple-stepper/simple-stepper.component.stories.ts +104 -0
  309. package/src/components-source/simple-stepper/simple-stepper.component.ts +69 -0
  310. package/src/components-source/storybook-doc-components/avatars-storybook/avatars-storybook.component.html +192 -0
  311. package/src/components-source/storybook-doc-components/avatars-storybook/avatars-storybook.component.scss +15 -0
  312. package/src/components-source/storybook-doc-components/avatars-storybook/avatars-storybook.component.ts +17 -0
  313. package/src/components-source/storybook-doc-components/border-radius-storybook/border-radius-storybook.component.html +22 -0
  314. package/src/components-source/storybook-doc-components/border-radius-storybook/border-radius-storybook.component.scss +0 -0
  315. package/src/components-source/storybook-doc-components/border-radius-storybook/border-radius-storybook.component.ts +54 -0
  316. package/src/components-source/storybook-doc-components/breakpoints-and-grids-storybook/breakpoints-and-grids-storybook.component.css +81 -0
  317. package/src/components-source/storybook-doc-components/breakpoints-and-grids-storybook/breakpoints-and-grids-storybook.component.html +143 -0
  318. package/src/components-source/storybook-doc-components/breakpoints-and-grids-storybook/breakpoints-and-grids-storybook.component.ts +97 -0
  319. package/src/components-source/storybook-doc-components/colors-storybook/colors-storybook.component.css +10 -0
  320. package/src/components-source/storybook-doc-components/colors-storybook/colors-storybook.component.html +63 -0
  321. package/src/components-source/storybook-doc-components/colors-storybook/colors-storybook.component.ts +542 -0
  322. package/src/components-source/storybook-doc-components/dropi-modal/dropi-modal.component.html +132 -0
  323. package/src/components-source/storybook-doc-components/dropi-modal/dropi-modal.component.scss +15 -0
  324. package/src/components-source/storybook-doc-components/dropi-modal/dropi-modal.component.ts +67 -0
  325. package/src/components-source/storybook-doc-components/dropi-toast/dropi-toast.component.html +156 -0
  326. package/src/components-source/storybook-doc-components/dropi-toast/dropi-toast.component.scss +13 -0
  327. package/src/components-source/storybook-doc-components/dropi-toast/dropi-toast.component.ts +55 -0
  328. package/src/components-source/storybook-doc-components/flags-storybook/flags-storybook.component.css +0 -0
  329. package/src/components-source/storybook-doc-components/flags-storybook/flags-storybook.component.html +99 -0
  330. package/src/components-source/storybook-doc-components/flags-storybook/flags-storybook.component.ts +19 -0
  331. package/src/components-source/storybook-doc-components/icons-storybook/icons-storybook.component.css +82 -0
  332. package/src/components-source/storybook-doc-components/icons-storybook/icons-storybook.component.html +111 -0
  333. package/src/components-source/storybook-doc-components/icons-storybook/icons-storybook.component.ts +196 -0
  334. package/src/components-source/storybook-doc-components/logo-storybook/logo-foundations.component.ts +19 -0
  335. package/src/components-source/storybook-doc-components/logo-storybook/logo-storybook.component.css +0 -0
  336. package/src/components-source/storybook-doc-components/logo-storybook/logo-storybook.component.html +104 -0
  337. package/src/components-source/storybook-doc-components/lustration-storybook/lustration-storybook.component.css +0 -0
  338. package/src/components-source/storybook-doc-components/lustration-storybook/lustration-storybook.component.html +218 -0
  339. package/src/components-source/storybook-doc-components/lustration-storybook/lustration-storybook.component.ts +20 -0
  340. package/src/components-source/storybook-doc-components/shadow-storybook/shadow-storybook.component.html +21 -0
  341. package/src/components-source/storybook-doc-components/shadow-storybook/shadow-storybook.component.scss +0 -0
  342. package/src/components-source/storybook-doc-components/shadow-storybook/shadow-storybook.component.ts +66 -0
  343. package/src/components-source/storybook-doc-components/spacing-storybook/spacing-storybook.component.html +33 -0
  344. package/src/components-source/storybook-doc-components/spacing-storybook/spacing-storybook.component.scss +0 -0
  345. package/src/components-source/storybook-doc-components/spacing-storybook/spacing-storybook.component.ts +37 -0
  346. package/src/components-source/storybook-doc-components/story-page/story-page.component.html +74 -0
  347. package/src/components-source/storybook-doc-components/story-page/story-page.component.scss +103 -0
  348. package/src/components-source/storybook-doc-components/story-page/story-page.component.ts +424 -0
  349. package/src/components-source/storybook-doc-components/template-breakpoint-storybook/template-breakpoint-storybook.component.html +35 -0
  350. package/src/components-source/storybook-doc-components/template-breakpoint-storybook/template-breakpoint-storybook.component.scss +64 -0
  351. package/src/components-source/storybook-doc-components/template-breakpoint-storybook/template-breakpoint-storybook.component.ts +71 -0
  352. package/src/components-source/storybook-doc-components/tillte-table-documentation/tillte-table-documentation.component.html +44 -0
  353. package/src/components-source/storybook-doc-components/tillte-table-documentation/tillte-table-documentation.component.scss +270 -0
  354. package/src/components-source/storybook-doc-components/tillte-table-documentation/tillte-table-documentation.component.ts +153 -0
  355. package/src/components-source/tabs/tabs.component.html +26 -0
  356. package/src/components-source/tabs/tabs.component.scss +62 -0
  357. package/src/components-source/tabs/tabs.component.spec.ts +212 -0
  358. package/src/components-source/tabs/tabs.component.stories.ts +203 -0
  359. package/src/components-source/tabs/tabs.component.ts +138 -0
  360. package/src/components-source/tag-type-product/tag-type-product.component.html +1 -0
  361. package/src/components-source/tag-type-product/tag-type-product.component.scss +10 -0
  362. package/src/components-source/tag-type-product/tag-type-product.component.spec.ts +38 -0
  363. package/src/components-source/tag-type-product/tag-type-product.component.ts +9 -0
  364. package/src/components-source/toast/toast.component.html +37 -0
  365. package/src/components-source/toast/toast.component.scss +142 -0
  366. package/src/components-source/toast/toast.component.spec.ts +368 -0
  367. package/src/components-source/toast/toast.component.ts +59 -0
  368. package/src/components-source/toast/toast.stories.ts +69 -0
  369. package/src/components-source/tooltip/tooltip.component.html +46 -0
  370. package/src/components-source/tooltip/tooltip.component.scss +44 -0
  371. package/src/components-source/tooltip/tooltip.component.spec.ts +327 -0
  372. package/src/components-source/tooltip/tooltip.component.ts +24 -0
  373. package/src/components-source/ui-dropi.module.ts +125 -0
  374. package/src/components-source/ui-inventory.json +1138 -0
  375. package/src/components-source/vertical-steps/vertical-steps.component.html +35 -0
  376. package/src/components-source/vertical-steps/vertical-steps.component.scss +143 -0
  377. package/src/components-source/vertical-steps/vertical-steps.component.spec.ts +121 -0
  378. package/src/components-source/vertical-steps/vertical-steps.component.stories.ts +216 -0
  379. package/src/components-source/vertical-steps/vertical-steps.component.ts +151 -0
  380. package/src/index.ts +31 -0
  381. package/src/lib/bootstrap.ts +28 -0
  382. package/src/lib/dropi-ui-elements/dropi-ui-elements.component.html +1 -0
  383. package/src/lib/dropi-ui-elements/dropi-ui-elements.component.scss +0 -0
  384. package/src/lib/dropi-ui-elements/dropi-ui-elements.component.spec.ts +21 -0
  385. package/src/lib/dropi-ui-elements/dropi-ui-elements.component.ts +9 -0
  386. package/src/lib/elements-registry.ts +66 -0
  387. package/src/lib/elements.module.ts +22 -0
  388. package/src/styles.scss +152 -0
  389. package/src/test-setup.ts +6 -0
  390. package/tsconfig.json +28 -0
  391. package/tsconfig.lib.json +18 -0
  392. package/tsconfig.lib.prod.json +9 -0
  393. package/tsconfig.spec.json +12 -0
package/.gitignore ADDED
@@ -0,0 +1,13 @@
1
+ # Dropi UI Components
2
+
3
+ node_modules/
4
+ dist/
5
+ *.log
6
+ .DS_Store
7
+ *.tgz
8
+ coverage/
9
+ .nyc_output/
10
+ .angular/
11
+ .nx/
12
+ tmp/
13
+ temp/
@@ -0,0 +1,188 @@
1
+ # Contributing to @dropi/ui-components
2
+
3
+ ## Estructura del Proyecto
4
+
5
+ ```
6
+ dropi-ui-components/
7
+ ├── src/
8
+ │ ├── lib/
9
+ │ │ ├── elements-registry.ts # Registro de Web Components
10
+ │ │ ├── elements.module.ts # Módulo Angular
11
+ │ │ └── bootstrap.ts # Inicialización
12
+ │ ├── components-source/ # Componentes Angular originales
13
+ │ │ ├── alert/
14
+ │ │ ├── button/
15
+ │ │ └── ... (33 componentes)
16
+ │ ├── styles.scss # CSS tokens/variables
17
+ │ └── index.ts # Entry point público
18
+ ├── dist/ # Build output (git ignored)
19
+ └── package.json
20
+ ```
21
+
22
+ ## Desarrollo
23
+
24
+ ### Setup Inicial
25
+
26
+ ```bash
27
+ npm install
28
+ npm run build:complete
29
+ ```
30
+
31
+ ### Agregar Nuevo Componente
32
+
33
+ 1. **Crear componente en `src/components-source/`**
34
+
35
+ ```bash
36
+ mkdir src/components-source/new-component
37
+ ```
38
+
39
+ 2. **Registrar en `src/lib/elements-registry.ts`**
40
+
41
+ ```typescript
42
+ import { NewComponent } from "../components-source/new-component/new-component.component";
43
+
44
+ // Agregar a la lista
45
+ const components = [
46
+ // ...
47
+ {
48
+ component: NewComponent,
49
+ selector: "dropi-new-component",
50
+ description: "Descripción del componente",
51
+ },
52
+ ];
53
+ ```
54
+
55
+ 3. **Build y probar**
56
+
57
+ ```bash
58
+ npm run build:complete
59
+ cd ../dist
60
+ npm link
61
+
62
+ # En proyecto de prueba
63
+ npm link @dropi/ui-components
64
+ ```
65
+
66
+ ### Modificar Estilos Globales
67
+
68
+ Editar `src/styles.scss`:
69
+
70
+ ```scss
71
+ :root {
72
+ /* Agregar nuevas variables */
73
+ --New-Variable: #value;
74
+ }
75
+ ```
76
+
77
+ Luego rebuild:
78
+
79
+ ```bash
80
+ npm run build:complete
81
+ ```
82
+
83
+ ## Testing
84
+
85
+ ### Manual Testing
86
+
87
+ ```bash
88
+ # Crear página de prueba
89
+ cat > test.html << 'EOF'
90
+ <!DOCTYPE html>
91
+ <html>
92
+ <head>
93
+ <link rel="stylesheet" href="dist/dropi-tokens.css">
94
+ <script src="dist/fesm2022/dropi-ui-elements.mjs" type="module"></script>
95
+ </head>
96
+ <body>
97
+ <dropi-button type="primary" text="Test"></dropi-button>
98
+ </body>
99
+ </html>
100
+ EOF
101
+
102
+ # Abrir en navegador
103
+ open test.html
104
+ ```
105
+
106
+ ## Publicación
107
+
108
+ ### Versioning
109
+
110
+ Seguir [Semantic Versioning](https://semver.org/):
111
+
112
+ - **MAJOR** (1.0.0 → 2.0.0): Cambios breaking
113
+ - **MINOR** (1.0.0 → 1.1.0): Nuevas features (backwards compatible)
114
+ - **PATCH** (1.0.0 → 1.0.1): Bug fixes
115
+
116
+ ```bash
117
+ npm version patch -m "Fix: descripción del fix"
118
+ npm version minor -m "Feat: nueva feature"
119
+ npm version major -m "BREAKING: descripción del cambio"
120
+ ```
121
+
122
+ ### Proceso de Release
123
+
124
+ ```bash
125
+ # 1. Asegurar que todo está commiteado
126
+ git status
127
+
128
+ # 2. Actualizar versión
129
+ npm version patch
130
+
131
+ # 3. Build
132
+ npm run build:complete
133
+
134
+ # 4. Publicar
135
+ cd dist
136
+ npm publish
137
+
138
+ # 5. Push con tags
139
+ cd ..
140
+ git push --tags
141
+ ```
142
+
143
+ ## Guidelines
144
+
145
+ ### CSS Variables
146
+
147
+ - Siempre usar nomenclatura `--Category-Subcategory-Value`
148
+ - Ejemplo: `--Success-Success-500`, `--Primary-Primary-100`
149
+ - Incluir fallbacks: `var(--Success-Success-500, #0abb87)`
150
+
151
+ ### Componentes
152
+
153
+ - Todos los componentes deben ser standalone (sin dependencias de negocio)
154
+ - Usar `@Input()` para todas las props
155
+ - Usar `@Output()` para eventos
156
+ - Documentar en Storybook
157
+
158
+ ### Commits
159
+
160
+ Formato: `type(scope): description`
161
+
162
+ Tipos:
163
+
164
+ - `feat`: Nueva feature
165
+ - `fix`: Bug fix
166
+ - `docs`: Documentación
167
+ - `style`: Formato/estilo
168
+ - `refactor`: Refactoring
169
+ - `test`: Tests
170
+ - `chore`: Mantenimiento
171
+
172
+ Ejemplo:
173
+
174
+ ```bash
175
+ git commit -m "feat(button): add loading state"
176
+ git commit -m "fix(alert): icon alignment issue"
177
+ ```
178
+
179
+ ## FAQ
180
+
181
+ **P: ¿Cómo agrego una nueva variable CSS?**
182
+ R: Edita `src/styles.scss`, agrega la variable en `:root`, y rebuild.
183
+
184
+ **P: ¿Puedo usar servicios de Angular?**
185
+ R: Sí, pero solo servicios sin estado (ej: TranslateService está OK, pero evita servicios de HTTP/negocio).
186
+
187
+ **P: ¿Cómo actualizo un componente existente?**
188
+ R: Edita en `src/components-source/`, rebuild, bump version, y publica.
@@ -0,0 +1,39 @@
1
+ # Migración de UI Components a Repositorio Separado
2
+
3
+ ## Paso 1: Instalación de Dependencias ✅
4
+
5
+ ```bash
6
+ cd ~/Desktop/dropi-ui-components
7
+ npm install
8
+ ```
9
+
10
+ ## Paso 2: Build de la Librería
11
+
12
+ ```bash
13
+ npm run build:complete
14
+ ```
15
+
16
+ ## Paso 3: Publicar a GitHub
17
+
18
+ ```bash
19
+ # En GitHub.com, crear repo: dropi/ui-components
20
+ git remote add origin https://github.com/dropi/ui-components.git
21
+ git branch -M main
22
+ git push -u origin main
23
+ ```
24
+
25
+ ## Paso 4: Publicar a NPM (Opcional)
26
+
27
+ ```bash
28
+ cd dist
29
+ npm publish --access public
30
+ ```
31
+
32
+ ## Paso 5: Consumir en dropi-core_front
33
+
34
+ ```bash
35
+ cd ~/Documents/dropi-core_front
36
+ npm install @dropi/ui-components
37
+ # o desde GitHub antes de publicar a NPM:
38
+ npm install git+https://github.com/dropi/ui-components.git
39
+ ```
@@ -0,0 +1,97 @@
1
+ # ✅ Checklist de Publicación
2
+
3
+ ## Antes de Publicar
4
+
5
+ - [x] Build exitoso (674ms)
6
+ - [x] npm link funcionando
7
+ - [x] dropi-core_front integrado
8
+ - [x] angular.json actualizado
9
+ - [x] Documentación completa
10
+
11
+ ## Publicar a GitHub (5 minutos)
12
+
13
+ ### Paso 1: Crear Repositorio en GitHub
14
+
15
+ 1. Ir a https://github.com/new
16
+ 2. **Repository name**: `ui-components`
17
+ 3. **Owner**: Selecciona tu organización `dropi` (o personal)
18
+ 4. **Description**: `Dropi UI Components - Framework-agnostic Web Components library`
19
+ 5. **Visibility**: Privado (recommended) o Público
20
+ 6. ✅ **NO** marcar "Add a README file"
21
+ 7. ✅ **NO** marcar "Add .gitignore"
22
+ 8. ✅ **NO** marcar "Choose a license"
23
+ 9. Click "Create repository"
24
+
25
+ ### Paso 2: Ejecutar Script de Publicación
26
+
27
+ ```bash
28
+ cd ~/Desktop/dropi-ui-components
29
+ bash publish.sh
30
+ ```
31
+
32
+ El script te pedirá:
33
+ 1. **URL del repositorio**: Copia la URL HTTPS que GitHub te muestra
34
+ - Ejemplo: `https://github.com/dropi/ui-components.git`
35
+ 2. **Publicar a NPM**: Responde `n` por ahora (lo haremos después)
36
+
37
+ ### Paso 3: Verificar Publicación
38
+
39
+ ```bash
40
+ # Ver repo en GitHub
41
+ git remote get-url origin
42
+
43
+ # Verificar commits en GitHub
44
+ # Abre la URL en el navegador
45
+ ```
46
+
47
+ ## Publicar a NPM (Opcional - Después)
48
+
49
+ ```bash
50
+ # 1. Login a NPM
51
+ npm login
52
+
53
+ # 2. Build
54
+ cd ~/Desktop/dropi-ui-components
55
+ npm run build:complete
56
+
57
+ # 3. Publicar
58
+ cd ../dist
59
+ npm publish --access public
60
+
61
+ # 4. Verificar
62
+ npm info @dropi/ui-components
63
+ ```
64
+
65
+ ## Verificar Integración en dropi-core_front
66
+
67
+ El dev server ya debería estar funcionando con los nuevos tokens CSS.
68
+
69
+ ### Opción A: Verificar sin reiniciar
70
+
71
+ Abre http://localhost:4500 y verifica que los componentes se ven bien.
72
+
73
+ ### Opción B: Reiniciar dev server
74
+
75
+ ```bash
76
+ # Detener el servidor actual (Ctrl+C)
77
+ # Luego:
78
+ cd ~/Documents/dropi-core_front
79
+ npm start
80
+ ```
81
+
82
+ ## ¿Qué Sigue?
83
+
84
+ ### Corto Plazo
85
+ - [ ] Publicar a GitHub ✅ (hoy)
86
+ - [ ] Verificar en localhost:4500 funciona
87
+ - [ ] (Opcional) Publicar a NPM
88
+
89
+ ### Mediano Plazo
90
+ - [ ] CI/CD para auto-publicar en cada release
91
+ - [ ] Primer micro frontend consumiendo la librería
92
+ - [ ] Storybook público en ui.dropi.co
93
+
94
+ ### Largo Plazo
95
+ - [ ] 3+ micro frontends usando @dropi/ui-components
96
+ - [ ] Equipo UI independiente
97
+ - [ ] Versión 2.0 con nuevos componentes
package/QUICK_START.md ADDED
@@ -0,0 +1,108 @@
1
+ # Guía Rápida: Publicación y Uso
2
+
3
+ ## 🚀 Para Publicar (Ejecuta UNA VEZ)
4
+
5
+ ```bash
6
+ cd ~/Desktop/dropi-ui-components
7
+ bash publish.sh
8
+ ```
9
+
10
+ El script te pedirá:
11
+
12
+ 1. URL del repo GitHub (créalo primero en github.com)
13
+ 2. Si quieres publicar a NPM
14
+
15
+ ## 📖 Para Usar en dropi-core_front
16
+
17
+ ### Opción A: Desde NPM (después de publicar)
18
+
19
+ ```bash
20
+ cd ~/Documents/dropi-core_front
21
+ npm install @dropi/ui-components
22
+ ```
23
+
24
+ ### Opción B: Desde GitHub (antes de NPM)
25
+
26
+ ```bash
27
+ cd ~/Documents/dropi-core_front
28
+ npm install git+https://github.com/dropi/ui-components.git
29
+ ```
30
+
31
+ ### Opción C: npm link (desarrollo local)
32
+
33
+ ```bash
34
+ # En ui-components
35
+ cd ~/Desktop/dist
36
+ npm link
37
+
38
+ # En dropi-core_front
39
+ cd ~/Documents/dropi-core_front
40
+ npm link @dropi/ui-components
41
+ ```
42
+
43
+ ## 📝 Usar en el Código
44
+
45
+ ```typescript
46
+ // src/main.ts o app.module.ts
47
+ import "@dropi/ui-components/dropi-tokens.css"; // CSS primero
48
+ import "@dropi/ui-components"; // Web Components
49
+
50
+ // Ya puedes usar en HTML:
51
+ // <dropi-button type="primary" text="Click"></dropi-button>
52
+ ```
53
+
54
+ ## 🔄 Para Nueva Versión
55
+
56
+ ```bash
57
+ cd ~/Desktop/dropi-ui-components
58
+
59
+ # Hacer cambios en src/...
60
+
61
+ # Actualizar versión
62
+ npm version patch # 1.0.0 → 1.0.1
63
+ npm version minor # 1.0.1 → 1.1.0
64
+ npm version major # 1.1.0 → 2.0.0
65
+
66
+ # Build y publicar
67
+ npm run build:complete
68
+ cd ../dist
69
+ npm publish
70
+
71
+ # Push git tags
72
+ git push --tags
73
+ ```
74
+
75
+ ## 📦 Archivos Importantes
76
+
77
+ | Archivo | Descripción |
78
+ | ---------------- | ---------------------------------- |
79
+ | `publish.sh` | Script automatizado de publicación |
80
+ | `QUICK_START.md` | Esta guía |
81
+ | `README.md` | Documentación completa |
82
+ | `src/` | Código fuente |
83
+ | `dist/` | Build output (no commiteado) |
84
+
85
+ ## 🆘 Troubleshooting
86
+
87
+ ### "remote origin already exists"
88
+
89
+ ```bash
90
+ git remote remove origin
91
+ git remote add origin <nueva-url>
92
+ ```
93
+
94
+ ### "npm ERR! need auth"
95
+
96
+ ```bash
97
+ npm login
98
+ ```
99
+
100
+ ### "Module not found" en dropi-core_front
101
+
102
+ ```bash
103
+ # Verificar que instalaste el paquete
104
+ npm list @dropi/ui-components
105
+
106
+ # Re-instalar
107
+ npm install @dropi/ui-components --force
108
+ ```
package/README.md ADDED
@@ -0,0 +1,146 @@
1
+ # @dropi/ui-components
2
+
3
+ > Framework-agnostic Web Components library built with Angular Elements
4
+
5
+ [![npm version](https://img.shields.io/npm/v/@dropi/ui-components.svg)](https://www.npmjs.com/package/@dropi/ui-components)
6
+ [![License](https://img.shields.io/npm/l/@dropi/ui-components.svg)](./LICENSE)
7
+
8
+ ## 📦 Installation
9
+
10
+ ```bash
11
+ npm install @dropi/ui-components
12
+ # or
13
+ yarn add @dropi/ui-components
14
+ ```
15
+
16
+ ## 🚀 Quick Start
17
+
18
+ ### HTML / Vanilla JS
19
+
20
+ ```html
21
+ <!DOCTYPE html>
22
+ <html>
23
+ <head>
24
+ <link
25
+ rel="stylesheet"
26
+ href="node_modules/@dropi/ui-components/dropi-tokens.css"
27
+ />
28
+ <script
29
+ src="node_modules/@dropi/ui-components/index.js"
30
+ type="module"
31
+ ></script>
32
+ </head>
33
+ <body>
34
+ <dropi-button type="primary" text="Click Me"></dropi-button>
35
+ <dropi-alert state="success" message="Success!"></dropi-alert>
36
+ </body>
37
+ </html>
38
+ ```
39
+
40
+ ### React
41
+
42
+ ```jsx
43
+ import "@dropi/ui-components/dropi-tokens.css";
44
+ import "@dropi/ui-components";
45
+
46
+ function App() {
47
+ return (
48
+ <>
49
+ <dropi-button type="primary" text="React Button" />
50
+ <dropi-alert state="info" message="Works in React!" />
51
+ </>
52
+ );
53
+ }
54
+ ```
55
+
56
+ ### Vue 3
57
+
58
+ ```vue
59
+ <template>
60
+ <dropi-button type="primary" text="Vue Button" />
61
+ <dropi-alert state="success" message="Works in Vue!" />
62
+ </template>
63
+
64
+ <script setup>
65
+ import "@dropi/ui-components/dropi-tokens.css";
66
+ import "@dropi/ui-components";
67
+ </script>
68
+ ```
69
+
70
+ **vite.config.js:**
71
+
72
+ ```javascript
73
+ export default {
74
+ plugins: [
75
+ vue({
76
+ template: {
77
+ compilerOptions: {
78
+ isCustomElement: (tag) => tag.startsWith("dropi-"),
79
+ },
80
+ },
81
+ }),
82
+ ],
83
+ };
84
+ ```
85
+
86
+ ### Angular
87
+
88
+ ```typescript
89
+ // main.ts or app.module.ts
90
+ import '@dropi/ui-components/dropi-tokens.css';
91
+ import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
92
+
93
+ @NgModule({
94
+ schemas: [CUSTOM_ELEMENTS_SCHEMA]
95
+ })
96
+ ```
97
+
98
+ ## 📚 Components
99
+
100
+ - `<dropi-button>` - Button with variants
101
+ - `<dropi-alert>` - Alerts (success/info/warning/error)
102
+ - `<dropi-tag>` - Tags with colors
103
+ - `<dropi-input>` - Text input with validation
104
+ - `<dropi-search>` - Search input
105
+ - `<dropi-switch>` - Toggle switch
106
+ - [See all 33 components →](https://ui.dropi.co)
107
+
108
+ ## ⚠️ Important
109
+
110
+ Always import `dropi-tokens.css` **before** the JavaScript:
111
+
112
+ ```javascript
113
+ // ✅ CORRECT
114
+ import "@dropi/ui-components/dropi-tokens.css"; // First
115
+ import "@dropi/ui-components"; // Second
116
+ ```
117
+
118
+ ## 📖 Documentation
119
+
120
+ - [Full Documentation](https://ui.dropi.co)
121
+ - [Storybook](https://ui.dropi.co)
122
+ - [Migration Guide](./MIGRATION.md)
123
+
124
+ ## 🛠️ Development
125
+
126
+ ```bash
127
+ # Install dependencies
128
+ npm install
129
+
130
+ # Build library
131
+ npm run build:complete
132
+
133
+ # Watch mode
134
+ npm run watch
135
+ ```
136
+
137
+ ## 📄 License
138
+
139
+ Proprietary - Dropi
140
+
141
+ ## 🤝 Contributing
142
+
143
+ This is a private package for Dropi projects. For issues or questions, contact the UI team.
144
+ # ui-components
145
+ # ui-components
146
+ # ui-components
package/jest.config.ts ADDED
@@ -0,0 +1,21 @@
1
+ export default {
2
+ displayName: 'dropi-ui-elements',
3
+ preset: '../../jest.preset.js',
4
+ setupFilesAfterEnv: ['<rootDir>/src/test-setup.ts'],
5
+ coverageDirectory: '../../coverage/libs/dropi-ui-elements',
6
+ transform: {
7
+ '^.+\\.(ts|mjs|js|html)$': [
8
+ 'jest-preset-angular',
9
+ {
10
+ tsconfig: '<rootDir>/tsconfig.spec.json',
11
+ stringifyContentPathRegex: '\\.(html|svg)$',
12
+ },
13
+ ],
14
+ },
15
+ transformIgnorePatterns: ['node_modules/(?!.*\\.mjs$)'],
16
+ snapshotSerializers: [
17
+ 'jest-preset-angular/build/serializers/no-ng-attributes',
18
+ 'jest-preset-angular/build/serializers/ng-snapshot',
19
+ 'jest-preset-angular/build/serializers/html-comment',
20
+ ],
21
+ };
@@ -0,0 +1,8 @@
1
+ {
2
+ "$schema": "../../node_modules/ng-packagr/ng-package.schema.json",
3
+ "dest": "../dist",
4
+ "lib": {
5
+ "entryFile": "src/index.ts"
6
+ },
7
+ "allowedNonPeerDependencies": ["@ngx-translate/core"]
8
+ }
package/package.json ADDED
@@ -0,0 +1,66 @@
1
+ {
2
+ "name": "@dropi/ui-components",
3
+ "version": "1.0.0",
4
+ "description": "Dropi UI Components - Framework-agnostic Web Components library built with Angular Elements",
5
+ "keywords": [
6
+ "web-components",
7
+ "angular-elements",
8
+ "ui-library",
9
+ "dropi",
10
+ "framework-agnostic"
11
+ ],
12
+ "author": "Dropi Team",
13
+ "license": "UNLICENSED",
14
+ "private": false,
15
+ "main": "index.js",
16
+ "module": "fesm2022/dropi-ui-elements.mjs",
17
+ "types": "index.d.ts",
18
+ "exports": {
19
+ ".": {
20
+ "types": "./index.d.ts",
21
+ "esm2022": "./esm2022/dropi-ui-elements.mjs",
22
+ "esm": "./esm2022/dropi-ui-elements.mjs",
23
+ "default": "./fesm2022/dropi-ui-elements.mjs"
24
+ },
25
+ "./dropi-tokens.css": "./dropi-tokens.css"
26
+ },
27
+ "files": [
28
+ "**/*",
29
+ "dropi-tokens.css",
30
+ "README.md"
31
+ ],
32
+ "scripts": {
33
+ "build": "ng-packagr -p ng-package.json",
34
+ "copy:tokens": "cp src/styles.scss ../dist/dropi-tokens.css",
35
+ "build:complete": "npm run build && npm run copy:tokens",
36
+ "watch": "ng-packagr -p ng-package.json -w",
37
+ "test": "echo \"Tests coming soon\"",
38
+ "prepublishOnly": "npm run build:complete"
39
+ },
40
+ "peerDependencies": {
41
+ "@angular/common": "^19.0.0",
42
+ "@angular/core": "^19.0.0",
43
+ "@angular/elements": "^19.0.0"
44
+ },
45
+ "devDependencies": {
46
+ "@angular-devkit/build-angular": "^19.0.0",
47
+ "@angular/cli": "^19.0.0",
48
+ "@angular/compiler": "^19.2.18",
49
+ "@angular/compiler-cli": "^19.0.0",
50
+ "ng-packagr": "^19.0.0",
51
+ "tslib": "^2.3.0",
52
+ "typescript": "~5.6.2",
53
+ "zone.js": "~0.15.0"
54
+ },
55
+ "dependencies": {
56
+ "@ngx-translate/core": "^15.0.0"
57
+ },
58
+ "repository": {
59
+ "type": "git",
60
+ "url": "https://github.com/dropi/ui-components.git"
61
+ },
62
+ "bugs": {
63
+ "url": "https://github.com/dropi/ui-components/issues"
64
+ },
65
+ "homepage": "https://ui.dropi.co"
66
+ }