@testgorilla/tgo-ui 2.10.0 → 2.10.1

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 (962) hide show
  1. package/.circleci/config.yml +112 -0
  2. package/.editorconfig +16 -0
  3. package/.eslintignore +5 -0
  4. package/.eslintrc.js +301 -0
  5. package/.github/README.md +81 -0
  6. package/.husky/pre-commit +4 -0
  7. package/.prettierignore +2 -0
  8. package/.prettierrc +13 -0
  9. package/.storybook/main.js +25 -0
  10. package/.storybook/preview-head.html +10 -0
  11. package/.storybook/preview.js +107 -0
  12. package/.storybook/tsconfig.json +24 -0
  13. package/.storybook/typings.d.ts +4 -0
  14. package/.stylelintrc.json +30 -0
  15. package/.vscode/extensions.json +4 -0
  16. package/.vscode/launch.json +20 -0
  17. package/.vscode/tasks.json +42 -0
  18. package/CHANGELOG.md +123 -0
  19. package/angular.json +164 -0
  20. package/e2e/bannerAction.spec.ts +46 -0
  21. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--default-chromium-darwin.png +0 -0
  22. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--default-chromium-linux.png +0 -0
  23. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--error-chromium-darwin.png +0 -0
  24. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--error-chromium-linux.png +0 -0
  25. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--info-chromium-darwin.png +0 -0
  26. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--info-chromium-linux.png +0 -0
  27. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--warning-chromium-darwin.png +0 -0
  28. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--warning-chromium-linux.png +0 -0
  29. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--with-relative-width-chromium-darwin.png +0 -0
  30. package/e2e/bannerAction.spec.ts-snapshots/id-alert-bars-banner-action--with-relative-width-chromium-linux.png +0 -0
  31. package/e2e/bannerAction.spec.ts-snapshots/id-bars-banner-action--default-chromium-linux.png +0 -0
  32. package/e2e/bannerAction.spec.ts-snapshots/id-bars-banner-action--error-chromium-linux.png +0 -0
  33. package/e2e/bannerAction.spec.ts-snapshots/id-bars-banner-action--info-chromium-linux.png +0 -0
  34. package/e2e/bannerAction.spec.ts-snapshots/id-bars-banner-action--warning-chromium-linux.png +0 -0
  35. package/e2e/bannerAction.spec.ts-snapshots/id-bars-banner-action--with-relative-width-chromium-linux.png +0 -0
  36. package/e2e/button.spec.ts +53 -0
  37. package/e2e/button.spec.ts-snapshots/id-button--basic-chromium-linux.png +0 -0
  38. package/e2e/button.spec.ts-snapshots/id-button--button-as-link-chromium-linux.png +0 -0
  39. package/e2e/button.spec.ts-snapshots/id-button--button-only-label-chromium-linux.png +0 -0
  40. package/e2e/button.spec.ts-snapshots/id-button--disabled-chromium-linux.png +0 -0
  41. package/e2e/button.spec.ts-snapshots/id-button--full-width-chromium-linux.png +0 -0
  42. package/e2e/button.spec.ts-snapshots/id-button--label-icon-left-chromium-linux.png +0 -0
  43. package/e2e/button.spec.ts-snapshots/id-button--label-icon-right-chromium-linux.png +0 -0
  44. package/e2e/button.spec.ts-snapshots/id-button--loading-chromium-linux.png +0 -0
  45. package/e2e/button.spec.ts-snapshots/id-button--menu-cell-chromium-linux.png +0 -0
  46. package/e2e/button.spec.ts-snapshots/id-button--menu-trigger-chromium-linux.png +0 -0
  47. package/e2e/button.spec.ts-snapshots/id-button--only-icon-chromium-linux.png +0 -0
  48. package/e2e/button.spec.ts-snapshots/id-button--small-chromium-linux.png +0 -0
  49. package/e2e/card.spec.ts +43 -0
  50. package/e2e/card.spec.ts-snapshots/id-card--default-chromium-linux.png +0 -0
  51. package/e2e/colors.spec.ts +47 -0
  52. package/e2e/colors.spec.ts-snapshots/id-foundations-colors--greysacale-chromium-linux.png +0 -0
  53. package/e2e/colors.spec.ts-snapshots/id-foundations-colors--primary-error-chromium-linux.png +0 -0
  54. package/e2e/colors.spec.ts-snapshots/id-foundations-colors--primary-petrol-chromium-linux.png +0 -0
  55. package/e2e/colors.spec.ts-snapshots/id-foundations-colors--primary-teal-chromium-linux.png +0 -0
  56. package/e2e/colors.spec.ts-snapshots/id-foundations-colors--primary-warning-chromium-linux.png +0 -0
  57. package/e2e/colors.spec.ts-snapshots/id-foundations-colors--secondary-colors-chromium-linux.png +0 -0
  58. package/e2e/createAccount.spec.ts +102 -0
  59. package/e2e/createAccount.spec.ts-snapshots/id-create-account--default-chromium-linux.png +0 -0
  60. package/e2e/createAccount.spec.ts-snapshots/id-deprecated-create-account--default-chromium-linux.png +0 -0
  61. package/e2e/createAccount.spec.ts-snapshots/register-with-errors-chromium-linux.png +0 -0
  62. package/e2e/createAccount.spec.ts-snapshots/register-with-texts-chromium-linux.png +0 -0
  63. package/e2e/createPassword.spec.ts +94 -0
  64. package/e2e/createPassword.spec.ts-snapshots/createPassword-with-errors-chromium-linux.png +0 -0
  65. package/e2e/createPassword.spec.ts-snapshots/createPassword-with-texts-chromium-linux.png +0 -0
  66. package/e2e/createPassword.spec.ts-snapshots/id-createpassword--default-args-viewMode-story-chromium-linux.png +0 -0
  67. package/e2e/createPassword.spec.ts-snapshots/id-createpassword--default-chromium-linux.png +0 -0
  68. package/e2e/createPassword.spec.ts-snapshots/id-deprecated-create-password--default-chromium-linux.png +0 -0
  69. package/e2e/dialog.spec.ts +43 -0
  70. package/e2e/dialog.spec.ts-snapshots/id-dialog-dialog--default-chromium-darwin.png +0 -0
  71. package/e2e/dialog.spec.ts-snapshots/id-dialog-dialog--default-chromium-linux.png +0 -0
  72. package/e2e/field.spec.ts +51 -0
  73. package/e2e/field.spec.ts-snapshots/id-forms-field--email-chromium-linux.png +0 -0
  74. package/e2e/field.spec.ts-snapshots/id-forms-field--number-type-chromium-linux.png +0 -0
  75. package/e2e/field.spec.ts-snapshots/id-forms-field--password-chromium-linux.png +0 -0
  76. package/e2e/field.spec.ts-snapshots/id-forms-field--search-chromium-linux.png +0 -0
  77. package/e2e/field.spec.ts-snapshots/id-forms-field--tel-chromium-linux.png +0 -0
  78. package/e2e/field.spec.ts-snapshots/id-forms-field--text-chromium-linux.png +0 -0
  79. package/e2e/field.spec.ts-snapshots/id-forms-field--with-disable-chromium-linux.png +0 -0
  80. package/e2e/field.spec.ts-snapshots/id-forms-field--with-errors-chromium-linux.png +0 -0
  81. package/e2e/field.spec.ts-snapshots/id-forms-field--with-require-chromium-linux.png +0 -0
  82. package/e2e/field.spec.ts-snapshots/id-forms-field--without-label-chromium-linux.png +0 -0
  83. package/e2e/forgotPassword.spec.ts +94 -0
  84. package/e2e/forgotPassword.spec.ts-snapshots/forgotPassword-with-errors-chromium-linux.png +0 -0
  85. package/e2e/forgotPassword.spec.ts-snapshots/forgotPassword-with-texts-chromium-linux.png +0 -0
  86. package/e2e/forgotPassword.spec.ts-snapshots/id-deprecated-forgot-password--default-chromium-linux.png +0 -0
  87. package/e2e/forgotPassword.spec.ts-snapshots/id-forgotpassword--default-args-viewMode-story-chromium-linux.png +0 -0
  88. package/e2e/forgotPassword.spec.ts-snapshots/id-forgotpassword--default-chromium-linux.png +0 -0
  89. package/e2e/label.spec.ts +47 -0
  90. package/e2e/label.spec.ts-snapshots/id-label--big-chromium-linux.png +0 -0
  91. package/e2e/label.spec.ts-snapshots/id-label--huge-chromium-linux.png +0 -0
  92. package/e2e/label.spec.ts-snapshots/id-label--large-chromium-linux.png +0 -0
  93. package/e2e/label.spec.ts-snapshots/id-label--medium-chromium-linux.png +0 -0
  94. package/e2e/label.spec.ts-snapshots/id-label--small-chromium-linux.png +0 -0
  95. package/e2e/label.spec.ts-snapshots/id-under-review-label--big-chromium-linux.png +0 -0
  96. package/e2e/label.spec.ts-snapshots/id-under-review-label--huge-chromium-linux.png +0 -0
  97. package/e2e/label.spec.ts-snapshots/id-under-review-label--large-chromium-linux.png +0 -0
  98. package/e2e/label.spec.ts-snapshots/id-under-review-label--medium-chromium-linux.png +0 -0
  99. package/e2e/label.spec.ts-snapshots/id-under-review-label--small-chromium-linux.png +0 -0
  100. package/e2e/login.spec.ts +102 -0
  101. package/e2e/login.spec.ts-snapshots/id-deprecated-login--default-chromium-linux.png +0 -0
  102. package/e2e/login.spec.ts-snapshots/id-login--default-chromium-linux.png +0 -0
  103. package/e2e/login.spec.ts-snapshots/login-with-errors-chromium-linux.png +0 -0
  104. package/e2e/login.spec.ts-snapshots/login-with-texts-chromium-linux.png +0 -0
  105. package/e2e/logo.spec.ts +45 -0
  106. package/e2e/logo.spec.ts-snapshots/id-logo--default-chromium-linux.png +0 -0
  107. package/e2e/logo.spec.ts-snapshots/id-logo--powered-by-chromium-linux.png +0 -0
  108. package/e2e/logo.spec.ts-snapshots/id-logo--reverse-chromium-linux.png +0 -0
  109. package/e2e/navbar.spec.ts +42 -0
  110. package/e2e/navbar.spec.ts-snapshots/id-navbar--default-chromium-linux.png +0 -0
  111. package/e2e/navigation.spec.ts +43 -0
  112. package/e2e/navigation.spec.ts-snapshots/id-navigation--default-chromium-linux.png +0 -0
  113. package/e2e/paginator.spec.ts +42 -0
  114. package/e2e/paginator.spec.ts-snapshots/id-paginator--default-chromium-linux.png +0 -0
  115. package/e2e/progressBar.spec.ts +42 -0
  116. package/e2e/progressBar.spec.ts-snapshots/id-progressbar--determinate-chromium-linux.png +0 -0
  117. package/e2e/table.spec.ts +47 -0
  118. package/e2e/table.spec.ts-snapshots/id-deprecated-table--default-chromium-linux.png +0 -0
  119. package/e2e/table.spec.ts-snapshots/id-table--default-chromium-darwin.png +0 -0
  120. package/e2e/table.spec.ts-snapshots/id-table--default-chromium-linux.png +0 -0
  121. package/e2e/table.spec.ts-snapshots/id-table--expandable-chromium-darwin.png +0 -0
  122. package/e2e/table.spec.ts-snapshots/id-table--expandable-chromium-linux.png +0 -0
  123. package/e2e/typography.spec.ts +42 -0
  124. package/e2e/typography.spec.ts-snapshots/id-foundations-typography--page-args-viewMode-story-chromium-linux.png +0 -0
  125. package/globalSetup.js +9 -0
  126. package/jest.config.js +69 -0
  127. package/ng-package.json +9 -0
  128. package/package.json +68 -17
  129. package/projects/client/src/app/app.component.html +1 -0
  130. package/projects/client/src/app/app.component.scss +8 -0
  131. package/projects/client/src/app/app.component.spec.ts +27 -0
  132. package/projects/client/src/app/app.component.ts +37 -0
  133. package/projects/client/src/app/app.routes.ts +8 -0
  134. package/projects/client/src/app/components/avatar/avatar.component.html +10 -0
  135. package/projects/client/src/app/components/avatar/avatar.component.scss +0 -0
  136. package/projects/client/src/app/components/avatar/avatar.component.ts +25 -0
  137. package/projects/client/src/assets/.gitkeep +0 -0
  138. package/projects/client/src/favicon.ico +0 -0
  139. package/projects/client/src/index.html +13 -0
  140. package/projects/client/src/main.ts +15 -0
  141. package/projects/client/src/styles.scss +10 -0
  142. package/projects/client/tsconfig.app.json +14 -0
  143. package/projects/client/tsconfig.spec.json +14 -0
  144. package/projects/tgo-canopy-ui/__mocks__/alert-bar.mock.ts +18 -0
  145. package/projects/tgo-canopy-ui/__mocks__/button.mock.ts +34 -0
  146. package/projects/tgo-canopy-ui/__mocks__/field.mock.ts +10 -0
  147. package/projects/tgo-canopy-ui/__mocks__/icon.mock.ts +14 -0
  148. package/projects/tgo-canopy-ui/__mocks__/tag.mock.ts +9 -0
  149. package/projects/tgo-canopy-ui/assets/.gitkeep +0 -0
  150. package/projects/tgo-canopy-ui/components/accordion/accordion.component.html +35 -0
  151. package/projects/tgo-canopy-ui/components/accordion/accordion.component.module.ts +26 -0
  152. package/projects/tgo-canopy-ui/components/accordion/accordion.component.scss +284 -0
  153. package/projects/tgo-canopy-ui/components/accordion/accordion.component.spec.ts +37 -0
  154. package/projects/tgo-canopy-ui/components/accordion/accordion.component.stories.ts +176 -0
  155. package/projects/tgo-canopy-ui/components/accordion/accordion.component.ts +97 -0
  156. package/projects/tgo-canopy-ui/components/alert-banner/__snapshots__/alert-banner.component.spec.ts.snap +42 -0
  157. package/projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.html +22 -0
  158. package/projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.module.ts +12 -0
  159. package/projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.scss +39 -0
  160. package/projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.spec.ts +177 -0
  161. package/projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.stories.ts +100 -0
  162. package/projects/tgo-canopy-ui/components/alert-banner/alert-banner.component.ts +130 -0
  163. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.html +198 -0
  164. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.module.ts +40 -0
  165. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.scss +283 -0
  166. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.spec.ts +238 -0
  167. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.stories.ts +135 -0
  168. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.ts +519 -0
  169. package/projects/tgo-canopy-ui/components/autocomplete/autocomplete.model.ts +22 -0
  170. package/projects/tgo-canopy-ui/components/autocomplete/includes.pipe.spec.ts +33 -0
  171. package/projects/tgo-canopy-ui/components/autocomplete/includes.pipe.ts +15 -0
  172. package/projects/tgo-canopy-ui/components/autocomplete/transform-Item.pipe.ts +21 -0
  173. package/projects/tgo-canopy-ui/components/autocomplete/transform-item.pipe.spec.ts +24 -0
  174. package/projects/tgo-canopy-ui/components/avatar/avatar.component.html +23 -0
  175. package/projects/tgo-canopy-ui/components/avatar/avatar.component.module.ts +14 -0
  176. package/projects/tgo-canopy-ui/components/avatar/avatar.component.scss +75 -0
  177. package/projects/tgo-canopy-ui/components/avatar/avatar.component.spec.ts +39 -0
  178. package/projects/tgo-canopy-ui/components/avatar/avatar.component.stories.ts +111 -0
  179. package/projects/tgo-canopy-ui/components/avatar/avatar.component.ts +76 -0
  180. package/projects/tgo-canopy-ui/components/avatar/avatar.model.ts +13 -0
  181. package/projects/tgo-canopy-ui/components/badge/badge.component.html +10 -0
  182. package/projects/tgo-canopy-ui/components/badge/badge.component.module.ts +11 -0
  183. package/projects/tgo-canopy-ui/components/badge/badge.component.scss +147 -0
  184. package/projects/tgo-canopy-ui/components/badge/badge.component.spec.ts +57 -0
  185. package/projects/tgo-canopy-ui/components/badge/badge.component.stories.ts +61 -0
  186. package/projects/tgo-canopy-ui/components/badge/badge.component.ts +99 -0
  187. package/projects/tgo-canopy-ui/components/badge/badge.model.ts +40 -0
  188. package/projects/tgo-canopy-ui/components/button/__snapshots__/button.component.spec.ts.snap +64 -0
  189. package/projects/tgo-canopy-ui/components/button/button.component.html +80 -0
  190. package/projects/tgo-canopy-ui/components/button/button.component.module.ts +23 -0
  191. package/projects/tgo-canopy-ui/components/button/button.component.scss +1012 -0
  192. package/projects/tgo-canopy-ui/components/button/button.component.spec.ts +274 -0
  193. package/projects/tgo-canopy-ui/components/button/button.component.stories.ts +455 -0
  194. package/projects/tgo-canopy-ui/components/button/button.component.ts +393 -0
  195. package/projects/tgo-canopy-ui/components/button/button.model.ts +28 -0
  196. package/projects/tgo-canopy-ui/components/card/card.component.html +9 -0
  197. package/projects/tgo-canopy-ui/components/card/card.component.module.ts +11 -0
  198. package/projects/tgo-canopy-ui/components/card/card.component.scss +91 -0
  199. package/projects/tgo-canopy-ui/components/card/card.component.spec.ts +76 -0
  200. package/projects/tgo-canopy-ui/components/card/card.component.stories.ts +88 -0
  201. package/projects/tgo-canopy-ui/components/card/card.component.ts +72 -0
  202. package/projects/tgo-canopy-ui/components/checkbox/checkbox.component.html +23 -0
  203. package/projects/tgo-canopy-ui/components/checkbox/checkbox.component.module.ts +17 -0
  204. package/projects/tgo-canopy-ui/components/checkbox/checkbox.component.scss +221 -0
  205. package/projects/tgo-canopy-ui/components/checkbox/checkbox.component.spec.ts +191 -0
  206. package/projects/tgo-canopy-ui/components/checkbox/checkbox.component.stories.ts +122 -0
  207. package/projects/tgo-canopy-ui/components/checkbox/checkbox.component.ts +233 -0
  208. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.component.html +16 -0
  209. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.component.module.ts +18 -0
  210. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.component.scss +3 -0
  211. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.component.spec.ts +42 -0
  212. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.component.ts +43 -0
  213. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.model.ts +10 -0
  214. package/projects/tgo-canopy-ui/components/confirm-dialog/confirm-dialog.stories.ts +37 -0
  215. package/projects/tgo-canopy-ui/components/datepicker/__snapshots__/datepicker.component.spec.ts.snap +56 -0
  216. package/projects/tgo-canopy-ui/components/datepicker/datepicker.component.html +98 -0
  217. package/projects/tgo-canopy-ui/components/datepicker/datepicker.component.module.ts +33 -0
  218. package/projects/tgo-canopy-ui/components/datepicker/datepicker.component.scss +195 -0
  219. package/projects/tgo-canopy-ui/components/datepicker/datepicker.component.spec.ts +249 -0
  220. package/projects/tgo-canopy-ui/components/datepicker/datepicker.component.stories.ts +138 -0
  221. package/projects/tgo-canopy-ui/components/datepicker/datepicker.component.ts +358 -0
  222. package/projects/tgo-canopy-ui/components/datepicker/no-date-format.directive.spec.ts +35 -0
  223. package/projects/tgo-canopy-ui/components/datepicker/no-date-format.directive.ts +43 -0
  224. package/projects/tgo-canopy-ui/components/deprecated-paginator/deprecated-paginator.component.html +5 -0
  225. package/projects/tgo-canopy-ui/components/deprecated-paginator/deprecated-paginator.component.module.ts +12 -0
  226. package/projects/tgo-canopy-ui/components/deprecated-paginator/deprecated-paginator.component.scss +32 -0
  227. package/projects/tgo-canopy-ui/components/deprecated-paginator/deprecated-paginator.component.stories.ts +31 -0
  228. package/projects/tgo-canopy-ui/components/deprecated-paginator/deprecated-paginator.component.ts +54 -0
  229. package/projects/tgo-canopy-ui/components/deprecated-table/deprecated-table.component.html +113 -0
  230. package/projects/tgo-canopy-ui/components/deprecated-table/deprecated-table.component.module.ts +25 -0
  231. package/projects/tgo-canopy-ui/components/deprecated-table/deprecated-table.component.scss +188 -0
  232. package/projects/tgo-canopy-ui/components/deprecated-table/deprecated-table.component.stories.ts +620 -0
  233. package/projects/tgo-canopy-ui/components/deprecated-table/deprecated-table.component.ts +160 -0
  234. package/projects/tgo-canopy-ui/components/deprecated-table/deprecated-table.model.ts +51 -0
  235. package/projects/tgo-canopy-ui/components/deprecated-table/directives/dynamic-component.directive.ts +41 -0
  236. package/projects/tgo-canopy-ui/components/dialog/__snapshots__/dialog.component.spec.ts.snap +51 -0
  237. package/projects/tgo-canopy-ui/components/dialog/dialog.component.html +41 -0
  238. package/projects/tgo-canopy-ui/components/dialog/dialog.component.module.ts +15 -0
  239. package/projects/tgo-canopy-ui/components/dialog/dialog.component.scss +133 -0
  240. package/projects/tgo-canopy-ui/components/dialog/dialog.component.spec.ts +230 -0
  241. package/projects/tgo-canopy-ui/components/dialog/dialog.component.stories.ts +60 -0
  242. package/projects/tgo-canopy-ui/components/dialog/dialog.component.ts +184 -0
  243. package/projects/tgo-canopy-ui/components/dialog/dialog.service.spec.ts +55 -0
  244. package/projects/tgo-canopy-ui/components/dialog/dialog.service.ts +33 -0
  245. package/projects/tgo-canopy-ui/components/dialog-custom/__snapshots__/dialog-custom.component.spec.ts.snap +28 -0
  246. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom +0 -0
  247. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.html +38 -0
  248. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.mdx +38 -0
  249. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.module.ts +11 -0
  250. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.scss +0 -0
  251. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.spec.ts +56 -0
  252. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.stories.ts +27 -0
  253. package/projects/tgo-canopy-ui/components/dialog-custom/dialog-custom.component.ts +45 -0
  254. package/projects/tgo-canopy-ui/components/dialog-demo/__snapshots__/dialog-demo.component.spec.ts.snap +21 -0
  255. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.html +4 -0
  256. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.mdx +28 -0
  257. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.module.ts +15 -0
  258. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.scss +12 -0
  259. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.spec.ts +58 -0
  260. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.stories.ts +30 -0
  261. package/projects/tgo-canopy-ui/components/dialog-demo/dialog-demo.component.ts +33 -0
  262. package/projects/tgo-canopy-ui/components/divider/divider.component.html +13 -0
  263. package/projects/tgo-canopy-ui/components/divider/divider.component.module.ts +11 -0
  264. package/projects/tgo-canopy-ui/components/divider/divider.component.scss +57 -0
  265. package/projects/tgo-canopy-ui/components/divider/divider.component.spec.ts +21 -0
  266. package/projects/tgo-canopy-ui/components/divider/divider.component.stories.ts +48 -0
  267. package/projects/tgo-canopy-ui/components/divider/divider.component.ts +54 -0
  268. package/projects/tgo-canopy-ui/components/dropdown/dropdown.component.html +43 -0
  269. package/projects/tgo-canopy-ui/components/dropdown/dropdown.component.module.ts +31 -0
  270. package/projects/tgo-canopy-ui/components/dropdown/dropdown.component.scss +237 -0
  271. package/projects/tgo-canopy-ui/components/dropdown/dropdown.component.spec.ts +104 -0
  272. package/projects/tgo-canopy-ui/components/dropdown/dropdown.component.stories.ts +213 -0
  273. package/projects/tgo-canopy-ui/components/dropdown/dropdown.component.ts +250 -0
  274. package/projects/tgo-canopy-ui/components/dropdown/dropdown.model.ts +5 -0
  275. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.component.html +3 -0
  276. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.component.module.ts +10 -0
  277. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.component.scss +41 -0
  278. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.component.spec.ts +39 -0
  279. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.component.stories.ts +59 -0
  280. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.component.ts +38 -0
  281. package/projects/tgo-canopy-ui/components/elevation-shadow/elevation-shadow.constant.ts +9 -0
  282. package/projects/tgo-canopy-ui/components/empty-state/empty-state.component.html +25 -0
  283. package/projects/tgo-canopy-ui/components/empty-state/empty-state.component.module.ts +13 -0
  284. package/projects/tgo-canopy-ui/components/empty-state/empty-state.component.scss +70 -0
  285. package/projects/tgo-canopy-ui/components/empty-state/empty-state.component.spec.ts +80 -0
  286. package/projects/tgo-canopy-ui/components/empty-state/empty-state.component.stories.ts +159 -0
  287. package/projects/tgo-canopy-ui/components/empty-state/empty-state.component.ts +174 -0
  288. package/projects/tgo-canopy-ui/components/field/__snapshots__/field.component.spec.ts.snap +55 -0
  289. package/projects/tgo-canopy-ui/components/field/field.component.html +105 -0
  290. package/projects/tgo-canopy-ui/components/field/field.component.module.ts +32 -0
  291. package/projects/tgo-canopy-ui/components/field/field.component.scss +492 -0
  292. package/projects/tgo-canopy-ui/components/field/field.component.spec.ts +268 -0
  293. package/projects/tgo-canopy-ui/components/field/field.component.stories.ts +212 -0
  294. package/projects/tgo-canopy-ui/components/field/field.component.ts +430 -0
  295. package/projects/tgo-canopy-ui/components/field/field.model.ts +11 -0
  296. package/projects/tgo-canopy-ui/components/file-upload/__snapshots__/file-upload.component.spec.ts.snap +59 -0
  297. package/projects/tgo-canopy-ui/components/file-upload/file-upload.component.html +94 -0
  298. package/projects/tgo-canopy-ui/components/file-upload/file-upload.component.module.ts +23 -0
  299. package/projects/tgo-canopy-ui/components/file-upload/file-upload.component.scss +182 -0
  300. package/projects/tgo-canopy-ui/components/file-upload/file-upload.component.spec.ts +142 -0
  301. package/projects/tgo-canopy-ui/components/file-upload/file-upload.component.stories.ts +96 -0
  302. package/projects/tgo-canopy-ui/components/file-upload/file-upload.component.ts +284 -0
  303. package/projects/tgo-canopy-ui/components/file-upload-demo/file-upload-demo.component.html +32 -0
  304. package/projects/tgo-canopy-ui/components/file-upload-demo/file-upload-demo.component.module.ts +14 -0
  305. package/projects/tgo-canopy-ui/components/file-upload-demo/file-upload-demo.component.scss +23 -0
  306. package/projects/tgo-canopy-ui/components/file-upload-demo/file-upload-demo.component.spec.ts +111 -0
  307. package/projects/tgo-canopy-ui/components/file-upload-demo/file-upload-demo.component.stories.ts +28 -0
  308. package/projects/tgo-canopy-ui/components/file-upload-demo/file-upload-demo.component.ts +74 -0
  309. package/projects/tgo-canopy-ui/components/form-demo/form-demo-component.stories.ts +41 -0
  310. package/projects/tgo-canopy-ui/components/form-demo/form-demo.component.html +210 -0
  311. package/projects/tgo-canopy-ui/components/form-demo/form-demo.component.module.ts +34 -0
  312. package/projects/tgo-canopy-ui/components/form-demo/form-demo.component.scss +59 -0
  313. package/projects/tgo-canopy-ui/components/form-demo/form-demo.component.spec.ts +127 -0
  314. package/projects/tgo-canopy-ui/components/form-demo/form-demo.component.ts +217 -0
  315. package/projects/tgo-canopy-ui/components/form-demo/form-demo.model.ts +6 -0
  316. package/projects/tgo-canopy-ui/components/icon/__snapshots__/icon.component.spec.ts.snap +20 -0
  317. package/projects/tgo-canopy-ui/components/icon/icon.component.html +1 -0
  318. package/projects/tgo-canopy-ui/components/icon/icon.component.module.ts +13 -0
  319. package/projects/tgo-canopy-ui/components/icon/icon.component.scss +66 -0
  320. package/projects/tgo-canopy-ui/components/icon/icon.component.spec.ts +150 -0
  321. package/projects/tgo-canopy-ui/components/icon/icon.component.stories.ts +68 -0
  322. package/projects/tgo-canopy-ui/components/icon/icon.component.ts +147 -0
  323. package/projects/tgo-canopy-ui/components/icon/icon.config.ts +658 -0
  324. package/projects/tgo-canopy-ui/components/icon/icon.model.ts +8 -0
  325. package/projects/tgo-canopy-ui/components/icon-label/__snapshots__/icon-label.component.spec.ts.snap +15 -0
  326. package/projects/tgo-canopy-ui/components/icon-label/icon-label.component.html +2 -0
  327. package/projects/tgo-canopy-ui/components/icon-label/icon-label.component.module.ts +12 -0
  328. package/projects/tgo-canopy-ui/components/icon-label/icon-label.component.scss +8 -0
  329. package/projects/tgo-canopy-ui/components/icon-label/icon-label.component.spec.ts +64 -0
  330. package/projects/tgo-canopy-ui/components/icon-label/icon-label.component.stories.ts +48 -0
  331. package/projects/tgo-canopy-ui/components/icon-label/icon-label.component.ts +53 -0
  332. package/projects/tgo-canopy-ui/components/icons-showcase/__snapshots__/icons-showcase.component.spec.ts.snap +3487 -0
  333. package/projects/tgo-canopy-ui/components/icons-showcase/icons-showcase.component.html +17 -0
  334. package/projects/tgo-canopy-ui/components/icons-showcase/icons-showcase.component.module.ts +12 -0
  335. package/projects/tgo-canopy-ui/components/icons-showcase/icons-showcase.component.scss +25 -0
  336. package/projects/tgo-canopy-ui/components/icons-showcase/icons-showcase.component.spec.ts +40 -0
  337. package/projects/tgo-canopy-ui/components/icons-showcase/icons-showcase.component.stories.ts +44 -0
  338. package/projects/tgo-canopy-ui/components/icons-showcase/icons-showcase.component.ts +43 -0
  339. package/projects/tgo-canopy-ui/components/login/login.component.scss +0 -0
  340. package/projects/tgo-canopy-ui/components/logo/logo.component.html +14 -0
  341. package/projects/tgo-canopy-ui/components/logo/logo.component.module.ts +10 -0
  342. package/projects/tgo-canopy-ui/components/logo/logo.component.scss +13 -0
  343. package/projects/tgo-canopy-ui/components/logo/logo.component.spec.ts +162 -0
  344. package/projects/tgo-canopy-ui/components/logo/logo.component.stories.ts +55 -0
  345. package/projects/tgo-canopy-ui/components/logo/logo.component.ts +148 -0
  346. package/projects/tgo-canopy-ui/components/logo/logo.model.ts +30 -0
  347. package/projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.html +36 -0
  348. package/projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.scss +70 -0
  349. package/projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.spec.ts +58 -0
  350. package/projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.ts +58 -0
  351. package/projects/tgo-canopy-ui/components/navbar/navbar.component.html +62 -0
  352. package/projects/tgo-canopy-ui/components/navbar/navbar.component.module.ts +36 -0
  353. package/projects/tgo-canopy-ui/components/navbar/navbar.component.scss +240 -0
  354. package/projects/tgo-canopy-ui/components/navbar/navbar.component.spec.ts +136 -0
  355. package/projects/tgo-canopy-ui/components/navbar/navbar.component.stories.ts +134 -0
  356. package/projects/tgo-canopy-ui/components/navbar/navbar.component.ts +206 -0
  357. package/projects/tgo-canopy-ui/components/navbar/navbar.model.ts +12 -0
  358. package/projects/tgo-canopy-ui/components/overflow-menu/__snapshots__/overflow-menu.component.spec.ts.snap +28 -0
  359. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.html +47 -0
  360. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.module.ts +13 -0
  361. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.scss +98 -0
  362. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.spec.ts +124 -0
  363. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.stories.ts +58 -0
  364. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.component.ts +88 -0
  365. package/projects/tgo-canopy-ui/components/overflow-menu/overflow-menu.model.ts +11 -0
  366. package/projects/tgo-canopy-ui/components/page-header/page-header.component.html +35 -0
  367. package/projects/tgo-canopy-ui/components/page-header/page-header.component.module.ts +12 -0
  368. package/projects/tgo-canopy-ui/components/page-header/page-header.component.scss +61 -0
  369. package/projects/tgo-canopy-ui/components/page-header/page-header.component.spec.ts +34 -0
  370. package/projects/tgo-canopy-ui/components/page-header/page-header.component.stories.ts +56 -0
  371. package/projects/tgo-canopy-ui/components/page-header/page-header.component.ts +64 -0
  372. package/projects/tgo-canopy-ui/components/paginator/paginator.component.html +10 -0
  373. package/projects/tgo-canopy-ui/components/paginator/paginator.component.module.ts +11 -0
  374. package/projects/tgo-canopy-ui/components/paginator/paginator.component.scss +159 -0
  375. package/projects/tgo-canopy-ui/components/paginator/paginator.component.spec.ts +29 -0
  376. package/projects/tgo-canopy-ui/components/paginator/paginator.component.stories.ts +36 -0
  377. package/projects/tgo-canopy-ui/components/paginator/paginator.component.ts +67 -0
  378. package/projects/tgo-canopy-ui/components/password-criteria/password.component.html +31 -0
  379. package/projects/tgo-canopy-ui/components/password-criteria/password.component.module.ts +22 -0
  380. package/projects/tgo-canopy-ui/components/password-criteria/password.component.scss +56 -0
  381. package/projects/tgo-canopy-ui/components/password-criteria/password.component.spec.ts +45 -0
  382. package/projects/tgo-canopy-ui/components/password-criteria/password.component.stories.ts +49 -0
  383. package/projects/tgo-canopy-ui/components/password-criteria/password.component.ts +106 -0
  384. package/projects/tgo-canopy-ui/components/password-strength/password-strength.component.html +19 -0
  385. package/projects/tgo-canopy-ui/components/password-strength/password-strength.component.module.ts +13 -0
  386. package/projects/tgo-canopy-ui/components/password-strength/password-strength.component.scss +54 -0
  387. package/projects/tgo-canopy-ui/components/password-strength/password-strength.component.spec.ts +40 -0
  388. package/projects/tgo-canopy-ui/components/password-strength/password-strength.component.stories.ts +50 -0
  389. package/projects/tgo-canopy-ui/components/password-strength/password-strength.component.ts +98 -0
  390. package/projects/tgo-canopy-ui/components/password-strength-demo/password-strength-demo.component.html +2 -0
  391. package/projects/tgo-canopy-ui/components/password-strength-demo/password-strength-demo.component.scss +0 -0
  392. package/projects/tgo-canopy-ui/components/password-strength-demo/password-strength-demo.component.spec.ts +28 -0
  393. package/projects/tgo-canopy-ui/components/password-strength-demo/password-strength-demo.component.stories.ts +40 -0
  394. package/projects/tgo-canopy-ui/components/password-strength-demo/password-strength-demo.component.ts +20 -0
  395. package/projects/tgo-canopy-ui/components/phone-input/join-string.pipe.spec.ts +9 -0
  396. package/projects/tgo-canopy-ui/components/phone-input/join-strings.pipe.ts +8 -0
  397. package/projects/tgo-canopy-ui/components/phone-input/phone-input.component.html +64 -0
  398. package/projects/tgo-canopy-ui/components/phone-input/phone-input.component.module.ts +35 -0
  399. package/projects/tgo-canopy-ui/components/phone-input/phone-input.component.scss +133 -0
  400. package/projects/tgo-canopy-ui/components/phone-input/phone-input.component.spec.ts +212 -0
  401. package/projects/tgo-canopy-ui/components/phone-input/phone-input.component.stories.ts +89 -0
  402. package/projects/tgo-canopy-ui/components/phone-input/phone-input.component.ts +427 -0
  403. package/projects/tgo-canopy-ui/components/phone-input/phone-input.model.ts +8 -0
  404. package/projects/tgo-canopy-ui/components/progress-bar/progress-bar.component.html +9 -0
  405. package/projects/tgo-canopy-ui/components/progress-bar/progress-bar.component.module.ts +12 -0
  406. package/projects/tgo-canopy-ui/components/progress-bar/progress-bar.component.scss +152 -0
  407. package/projects/tgo-canopy-ui/components/progress-bar/progress-bar.component.spec.ts +76 -0
  408. package/projects/tgo-canopy-ui/components/progress-bar/progress-bar.component.stories.ts +48 -0
  409. package/projects/tgo-canopy-ui/components/progress-bar/progress-bar.component.ts +82 -0
  410. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.component.html +26 -0
  411. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.component.module.ts +12 -0
  412. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.component.scss +41 -0
  413. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.component.spec.ts +102 -0
  414. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.component.stories.ts +69 -0
  415. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.component.ts +114 -0
  416. package/projects/tgo-canopy-ui/components/radial-progress/radial-progress.model.ts +13 -0
  417. package/projects/tgo-canopy-ui/components/radio-button/radio-button.component.html +16 -0
  418. package/projects/tgo-canopy-ui/components/radio-button/radio-button.component.module.ts +13 -0
  419. package/projects/tgo-canopy-ui/components/radio-button/radio-button.component.scss +175 -0
  420. package/projects/tgo-canopy-ui/components/radio-button/radio-button.component.spec.ts +141 -0
  421. package/projects/tgo-canopy-ui/components/radio-button/radio-button.component.stories.ts +126 -0
  422. package/projects/tgo-canopy-ui/components/radio-button/radio-button.component.ts +190 -0
  423. package/projects/tgo-canopy-ui/components/radio-button/radio-button.model.ts +4 -0
  424. package/projects/tgo-canopy-ui/components/rating/__snapshots__/rating.component.spec.ts.snap +47 -0
  425. package/projects/tgo-canopy-ui/components/rating/half-star.pipe.spec.ts +33 -0
  426. package/projects/tgo-canopy-ui/components/rating/half-star.pipe.ts +17 -0
  427. package/projects/tgo-canopy-ui/components/rating/rating.component.html +31 -0
  428. package/projects/tgo-canopy-ui/components/rating/rating.component.module.ts +12 -0
  429. package/projects/tgo-canopy-ui/components/rating/rating.component.scss +139 -0
  430. package/projects/tgo-canopy-ui/components/rating/rating.component.spec.ts +142 -0
  431. package/projects/tgo-canopy-ui/components/rating/rating.component.stories.ts +87 -0
  432. package/projects/tgo-canopy-ui/components/rating/rating.component.ts +97 -0
  433. package/projects/tgo-canopy-ui/components/scale/__snapshots__/scale.component.spec.ts.snap +42 -0
  434. package/projects/tgo-canopy-ui/components/scale/scale.component.html +7 -0
  435. package/projects/tgo-canopy-ui/components/scale/scale.component.module.ts +12 -0
  436. package/projects/tgo-canopy-ui/components/scale/scale.component.scss +71 -0
  437. package/projects/tgo-canopy-ui/components/scale/scale.component.spec.ts +125 -0
  438. package/projects/tgo-canopy-ui/components/scale/scale.component.stories.ts +60 -0
  439. package/projects/tgo-canopy-ui/components/scale/scale.component.ts +57 -0
  440. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.html +16 -0
  441. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.module.ts +12 -0
  442. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.scss +86 -0
  443. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.spec.ts +69 -0
  444. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.stories.ts +98 -0
  445. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.component.ts +69 -0
  446. package/projects/tgo-canopy-ui/components/segmented-bar/segmented-bar.model.ts +8 -0
  447. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.component.html +11 -0
  448. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.component.module.ts +22 -0
  449. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.component.scss +44 -0
  450. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.component.spec.ts +50 -0
  451. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.component.stories.ts +48 -0
  452. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.component.ts +54 -0
  453. package/projects/tgo-canopy-ui/components/segmented-button/segmented-button.model.ts +7 -0
  454. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.component.html +37 -0
  455. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.component.module.ts +24 -0
  456. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.component.scss +97 -0
  457. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.component.spec.ts +176 -0
  458. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.component.ts +110 -0
  459. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.model.ts +12 -0
  460. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.service.spec.ts +88 -0
  461. package/projects/tgo-canopy-ui/components/side-sheet/side-sheet.service.ts +28 -0
  462. package/projects/tgo-canopy-ui/components/side-sheet-demo/side-sheet-demo.component.html +5 -0
  463. package/projects/tgo-canopy-ui/components/side-sheet-demo/side-sheet-demo.component.scss +14 -0
  464. package/projects/tgo-canopy-ui/components/side-sheet-demo/side-sheet-demo.component.spec.ts +26 -0
  465. package/projects/tgo-canopy-ui/components/side-sheet-demo/side-sheet-demo.component.stories.ts +54 -0
  466. package/projects/tgo-canopy-ui/components/side-sheet-demo/side-sheet-demo.component.ts +98 -0
  467. package/projects/tgo-canopy-ui/components/side-sheet-demo/side-sheet-demo.module.ts +12 -0
  468. package/projects/tgo-canopy-ui/components/skeleton/skeleton.component.html +5 -0
  469. package/projects/tgo-canopy-ui/components/skeleton/skeleton.component.scss +0 -0
  470. package/projects/tgo-canopy-ui/components/skeleton/skeleton.component.spec.ts +75 -0
  471. package/projects/tgo-canopy-ui/components/skeleton/skeleton.component.stories.ts +47 -0
  472. package/projects/tgo-canopy-ui/components/skeleton/skeleton.component.ts +66 -0
  473. package/projects/tgo-canopy-ui/components/skeleton/skeleton.model.ts +3 -0
  474. package/projects/tgo-canopy-ui/components/slider/slider.component.html +75 -0
  475. package/projects/tgo-canopy-ui/components/slider/slider.component.module.ts +24 -0
  476. package/projects/tgo-canopy-ui/components/slider/slider.component.scss +223 -0
  477. package/projects/tgo-canopy-ui/components/slider/slider.component.spec.ts +103 -0
  478. package/projects/tgo-canopy-ui/components/slider/slider.component.stories.ts +87 -0
  479. package/projects/tgo-canopy-ui/components/slider/slider.component.ts +185 -0
  480. package/projects/tgo-canopy-ui/components/slider/slider.model.ts +4 -0
  481. package/projects/tgo-canopy-ui/components/snackbar/__snapshots__/snackbar.component.spec.ts.snap +44 -0
  482. package/projects/tgo-canopy-ui/components/snackbar/snackbar.component.html +33 -0
  483. package/projects/tgo-canopy-ui/components/snackbar/snackbar.component.module.ts +16 -0
  484. package/projects/tgo-canopy-ui/components/snackbar/snackbar.component.scss +45 -0
  485. package/projects/tgo-canopy-ui/components/snackbar/snackbar.component.spec.ts +214 -0
  486. package/projects/tgo-canopy-ui/components/snackbar/snackbar.component.stories.ts +159 -0
  487. package/projects/tgo-canopy-ui/components/snackbar/snackbar.component.ts +196 -0
  488. package/projects/tgo-canopy-ui/components/snackbar/snackbar.service.spec.ts +52 -0
  489. package/projects/tgo-canopy-ui/components/snackbar/snackbar.service.ts +37 -0
  490. package/projects/tgo-canopy-ui/components/spinner/spinner.component.html +6 -0
  491. package/projects/tgo-canopy-ui/components/spinner/spinner.component.scss +75 -0
  492. package/projects/tgo-canopy-ui/components/spinner/spinner.component.spec.ts +82 -0
  493. package/projects/tgo-canopy-ui/components/spinner/spinner.component.stories.ts +46 -0
  494. package/projects/tgo-canopy-ui/components/spinner/spinner.component.ts +59 -0
  495. package/projects/tgo-canopy-ui/components/spinner/spinner.module.ts +10 -0
  496. package/projects/tgo-canopy-ui/components/step/step.component.html +100 -0
  497. package/projects/tgo-canopy-ui/components/step/step.component.module.ts +11 -0
  498. package/projects/tgo-canopy-ui/components/step/step.component.scss +315 -0
  499. package/projects/tgo-canopy-ui/components/step/step.component.spec.ts +61 -0
  500. package/projects/tgo-canopy-ui/components/step/step.component.ts +134 -0
  501. package/projects/tgo-canopy-ui/components/stepper/stepper.component.html +79 -0
  502. package/projects/tgo-canopy-ui/components/stepper/stepper.component.module.ts +25 -0
  503. package/projects/tgo-canopy-ui/components/stepper/stepper.component.scss +144 -0
  504. package/projects/tgo-canopy-ui/components/stepper/stepper.component.spec.ts +64 -0
  505. package/projects/tgo-canopy-ui/components/stepper/stepper.component.stories.ts +84 -0
  506. package/projects/tgo-canopy-ui/components/stepper/stepper.component.ts +118 -0
  507. package/projects/tgo-canopy-ui/components/stepper/stepper.model.ts +10 -0
  508. package/projects/tgo-canopy-ui/components/table/sentence-case.pipe.ts +13 -0
  509. package/projects/tgo-canopy-ui/components/table/sentence-case.spec.ts +53 -0
  510. package/projects/tgo-canopy-ui/components/table/table.component.html +290 -0
  511. package/projects/tgo-canopy-ui/components/table/table.component.module.ts +33 -0
  512. package/projects/tgo-canopy-ui/components/table/table.component.scss +201 -0
  513. package/projects/tgo-canopy-ui/components/table/table.component.spec.ts +187 -0
  514. package/projects/tgo-canopy-ui/components/table/table.component.stories.ts +425 -0
  515. package/projects/tgo-canopy-ui/components/table/table.component.ts +235 -0
  516. package/projects/tgo-canopy-ui/components/table/table.model.ts +103 -0
  517. package/projects/tgo-canopy-ui/components/tabs/tab.directive.ts +33 -0
  518. package/projects/tgo-canopy-ui/components/tabs/tabs.component.html +19 -0
  519. package/projects/tgo-canopy-ui/components/tabs/tabs.component.module.ts +22 -0
  520. package/projects/tgo-canopy-ui/components/tabs/tabs.component.scss +234 -0
  521. package/projects/tgo-canopy-ui/components/tabs/tabs.component.spec.ts +85 -0
  522. package/projects/tgo-canopy-ui/components/tabs/tabs.component.stories.ts +73 -0
  523. package/projects/tgo-canopy-ui/components/tabs/tabs.component.ts +79 -0
  524. package/projects/tgo-canopy-ui/components/tabs/tabs.directive.spec.ts +90 -0
  525. package/projects/tgo-canopy-ui/components/tabs/tabs.model.ts +11 -0
  526. package/projects/tgo-canopy-ui/components/tag/__snapshots__/tag.component.spec.ts.snap +42 -0
  527. package/projects/tgo-canopy-ui/components/tag/tag.component.html +26 -0
  528. package/projects/tgo-canopy-ui/components/tag/tag.component.module.ts +15 -0
  529. package/projects/tgo-canopy-ui/components/tag/tag.component.scss +161 -0
  530. package/projects/tgo-canopy-ui/components/tag/tag.component.spec.ts +193 -0
  531. package/projects/tgo-canopy-ui/components/tag/tag.component.stories.ts +125 -0
  532. package/projects/tgo-canopy-ui/components/tag/tag.component.ts +213 -0
  533. package/projects/tgo-canopy-ui/components/toggle/toggle.component.html +24 -0
  534. package/projects/tgo-canopy-ui/components/toggle/toggle.component.module.ts +14 -0
  535. package/projects/tgo-canopy-ui/components/toggle/toggle.component.scss +202 -0
  536. package/projects/tgo-canopy-ui/components/toggle/toggle.component.spec.ts +197 -0
  537. package/projects/tgo-canopy-ui/components/toggle/toggle.component.stories.ts +97 -0
  538. package/projects/tgo-canopy-ui/components/toggle/toggle.component.ts +179 -0
  539. package/projects/tgo-canopy-ui/components/tooltip/tooltip.component.html +9 -0
  540. package/projects/tgo-canopy-ui/components/tooltip/tooltip.component.module.ts +10 -0
  541. package/projects/tgo-canopy-ui/components/tooltip/tooltip.component.spec.ts +53 -0
  542. package/projects/tgo-canopy-ui/components/tooltip/tooltip.component.stories.ts +235 -0
  543. package/projects/tgo-canopy-ui/components/tooltip/tooltip.component.ts +81 -0
  544. package/projects/tgo-canopy-ui/components/tooltip/tooltip.model.ts +6 -0
  545. package/projects/tgo-canopy-ui/components/validation-error/validation-error.component.html +29 -0
  546. package/projects/tgo-canopy-ui/components/validation-error/validation-error.component.scss +0 -0
  547. package/projects/tgo-canopy-ui/components/validation-error/validation-error.component.spec.ts +75 -0
  548. package/projects/tgo-canopy-ui/components/validation-error/validation-error.component.ts +53 -0
  549. package/projects/tgo-canopy-ui/components/validation-error/validation-error.module.ts +12 -0
  550. package/projects/tgo-canopy-ui/directives/digits-only.directive.spec.ts +121 -0
  551. package/projects/tgo-canopy-ui/directives/digits-only.directive.ts +42 -0
  552. package/projects/tgo-canopy-ui/directives/drag-drop.directive.spec.ts +84 -0
  553. package/projects/tgo-canopy-ui/directives/drag-drop.directive.ts +39 -0
  554. package/projects/tgo-canopy-ui/directives/ellipse-text.directive.spec.ts +57 -0
  555. package/projects/tgo-canopy-ui/directives/ellipse-text.directive.ts +27 -0
  556. package/projects/tgo-canopy-ui/directives/select-text.directive.spec.ts +54 -0
  557. package/projects/tgo-canopy-ui/directives/select-text.directive.ts +37 -0
  558. package/projects/tgo-canopy-ui/directives/step-line-width.directive.spec.ts +59 -0
  559. package/projects/tgo-canopy-ui/directives/step-line-width.directive.ts +31 -0
  560. package/projects/tgo-canopy-ui/foundations/colors/colors.component.html +4 -0
  561. package/projects/tgo-canopy-ui/foundations/colors/colors.component.module.ts +10 -0
  562. package/projects/tgo-canopy-ui/foundations/colors/colors.component.scss +318 -0
  563. package/projects/tgo-canopy-ui/foundations/colors/colors.component.spec.ts +47 -0
  564. package/projects/tgo-canopy-ui/foundations/colors/colors.component.ts +22 -0
  565. package/projects/tgo-canopy-ui/foundations/colors/colors.stories.ts +426 -0
  566. package/projects/tgo-canopy-ui/foundations/typography/typography.stories.ts +195 -0
  567. package/projects/tgo-canopy-ui/mocked-assets/images/some_progress.svg +4 -0
  568. package/projects/tgo-canopy-ui/models/colors.model.ts +88 -0
  569. package/projects/tgo-canopy-ui/models/screen-breakpoints.model.ts +4 -0
  570. package/projects/tgo-canopy-ui/pipes/data-property-getter.spec.ts +42 -0
  571. package/projects/tgo-canopy-ui/pipes/data-property-getter.ts +31 -0
  572. package/projects/tgo-canopy-ui/pipes/has-validation-error.pipe.spec.ts +32 -0
  573. package/projects/tgo-canopy-ui/pipes/has-validation-error.pipe.ts +20 -0
  574. package/projects/tgo-canopy-ui/pipes/name-initials.pipe.spec.ts +44 -0
  575. package/projects/tgo-canopy-ui/pipes/name-initials.pipe.ts +18 -0
  576. package/projects/tgo-canopy-ui/pipes/ui-translate.pipe.spec.ts +45 -0
  577. package/projects/tgo-canopy-ui/pipes/ui-translate.pipe.ts +71 -0
  578. package/projects/tgo-canopy-ui/polyfills.ts +51 -0
  579. package/projects/tgo-canopy-ui/providers/is-mobile.ts +11 -0
  580. package/projects/tgo-canopy-ui/public-api.ts +184 -0
  581. package/projects/tgo-canopy-ui/services/custom-event-manager.service.spec.ts +57 -0
  582. package/projects/tgo-canopy-ui/services/custom-event-manager.service.ts +28 -0
  583. package/projects/tgo-canopy-ui/test-utils/mock-file.spec.ts +44 -0
  584. package/projects/tgo-canopy-ui/test-utils/mock-file.ts +24 -0
  585. package/projects/tgo-canopy-ui/test.ts +20 -0
  586. package/projects/tgo-canopy-ui/utils/alert-bars.utils.spec.ts +47 -0
  587. package/projects/tgo-canopy-ui/utils/alert-bars.utils.ts +36 -0
  588. package/projects/tgo-canopy-ui/utils/autocomplete-utils.spec.ts +68 -0
  589. package/projects/tgo-canopy-ui/utils/autocomplete-utils.ts +66 -0
  590. package/projects/tgo-canopy-ui/utils/color-contrast.spec.ts +46 -0
  591. package/projects/tgo-canopy-ui/utils/color-contrast.ts +135 -0
  592. package/projects/tgo-canopy-ui/utils/localization/language.model.ts +14 -0
  593. package/projects/tgo-canopy-ui/utils/localization/language.service.mocks.ts +6 -0
  594. package/projects/tgo-canopy-ui/utils/localization/language.service.spec.ts +25 -0
  595. package/projects/tgo-canopy-ui/utils/localization/language.service.ts +32 -0
  596. package/projects/tgo-canopy-ui/utils/table.utils.spec.ts +47 -0
  597. package/projects/tgo-canopy-ui/utils/table.utils.ts +22 -0
  598. package/projects/tgo-canopy-ui/utils/transform-theme.ts +9 -0
  599. package/projects/tgo-canopy-ui/utils/transform.theme.spec.ts +16 -0
  600. package/projects/tgo-canopy-ui/utils/validators.utils.spec.ts +16 -0
  601. package/projects/tgo-canopy-ui/utils/validators.utils.ts +9 -0
  602. package/setupJest.ts +1 -0
  603. package/transloco.config.js +5 -0
  604. package/tsconfig.json +46 -0
  605. package/tsconfig.spec.json +17 -0
  606. package/tsconfig.ui.json +24 -0
  607. package/tsconfig.ui.prod.json +10 -0
  608. package/visual-tests/component-page-objects/avatar-component.ts +30 -0
  609. package/visual-tests/component-page-objects/base-component.ts +44 -0
  610. package/visual-tests/component-tests/avatar.spec.ts +32 -0
  611. package/visual-tests/component-tests/avatar.spec.ts-snapshots/Avatar-Component-Visual-Tests-should-allow-edit-for-the-avatar-1-chromium-linux.png +0 -0
  612. package/visual-tests/component-tests/avatar.spec.ts-snapshots/Avatar-Component-Visual-Tests-should-display-the-avatar-correctly-1-chromium-linux.png +0 -0
  613. package/visual-tests/playwright.config.ts +45 -0
  614. package/visual-tests/runConfig.ts +1 -0
  615. package/components/accordion/accordion.component.d.ts +0 -76
  616. package/components/accordion/accordion.component.module.d.ts +0 -12
  617. package/components/alert-banner/alert-banner.component.d.ts +0 -89
  618. package/components/alert-banner/alert-banner.component.module.d.ts +0 -10
  619. package/components/autocomplete/autocomplete.component.d.ts +0 -208
  620. package/components/autocomplete/autocomplete.component.module.d.ts +0 -21
  621. package/components/autocomplete/autocomplete.model.d.ts +0 -18
  622. package/components/autocomplete/includes.pipe.d.ts +0 -12
  623. package/components/autocomplete/transform-Item.pipe.d.ts +0 -11
  624. package/components/avatar/avatar.component.d.ts +0 -58
  625. package/components/avatar/avatar.component.module.d.ts +0 -12
  626. package/components/avatar/avatar.model.d.ts +0 -7
  627. package/components/badge/badge.component.d.ts +0 -58
  628. package/components/badge/badge.component.module.d.ts +0 -9
  629. package/components/badge/badge.model.d.ts +0 -27
  630. package/components/button/button.component.d.ts +0 -190
  631. package/components/button/button.component.module.d.ts +0 -13
  632. package/components/button/button.model.d.ts +0 -14
  633. package/components/card/card.component.d.ts +0 -46
  634. package/components/card/card.component.module.d.ts +0 -9
  635. package/components/checkbox/checkbox.component.d.ts +0 -147
  636. package/components/checkbox/checkbox.component.module.d.ts +0 -15
  637. package/components/confirm-dialog/confirm-dialog.component.d.ts +0 -25
  638. package/components/confirm-dialog/confirm-dialog.component.module.d.ts +0 -12
  639. package/components/confirm-dialog/confirm-dialog.model.d.ts +0 -9
  640. package/components/datepicker/datepicker.component.d.ts +0 -205
  641. package/components/datepicker/datepicker.component.module.d.ts +0 -18
  642. package/components/datepicker/no-date-format.directive.d.ts +0 -11
  643. package/components/deprecated-paginator/deprecated-paginator.component.d.ts +0 -38
  644. package/components/deprecated-paginator/deprecated-paginator.component.module.d.ts +0 -9
  645. package/components/deprecated-table/deprecated-table.component.d.ts +0 -91
  646. package/components/deprecated-table/deprecated-table.component.module.d.ts +0 -14
  647. package/components/deprecated-table/deprecated-table.model.d.ts +0 -45
  648. package/components/deprecated-table/directives/dynamic-component.directive.d.ts +0 -13
  649. package/components/dialog/dialog.component.d.ts +0 -108
  650. package/components/dialog/dialog.component.module.d.ts +0 -11
  651. package/components/dialog/dialog.service.d.ts +0 -13
  652. package/components/divider/divider.component.d.ts +0 -39
  653. package/components/divider/divider.component.module.d.ts +0 -9
  654. package/components/dropdown/dropdown.component.d.ts +0 -157
  655. package/components/dropdown/dropdown.component.module.d.ts +0 -17
  656. package/components/dropdown/dropdown.model.d.ts +0 -5
  657. package/components/elevation-shadow/elevation-shadow.component.d.ts +0 -26
  658. package/components/elevation-shadow/elevation-shadow.component.module.d.ts +0 -8
  659. package/components/elevation-shadow/elevation-shadow.constant.d.ts +0 -8
  660. package/components/empty-state/empty-state.component.d.ts +0 -124
  661. package/components/empty-state/empty-state.component.module.d.ts +0 -11
  662. package/components/field/field.component.d.ts +0 -238
  663. package/components/field/field.component.module.d.ts +0 -18
  664. package/components/field/field.model.d.ts +0 -1
  665. package/components/file-upload/file-upload.component.d.ts +0 -124
  666. package/components/file-upload/file-upload.component.module.d.ts +0 -14
  667. package/components/icon/icon.component.d.ts +0 -65
  668. package/components/icon/icon.component.module.d.ts +0 -10
  669. package/components/icon/icon.config.d.ts +0 -10
  670. package/components/icon/icon.model.d.ts +0 -7
  671. package/components/icon-label/icon-label.component.d.ts +0 -39
  672. package/components/icon-label/icon-label.component.module.d.ts +0 -9
  673. package/components/logo/logo.component.d.ts +0 -57
  674. package/components/logo/logo.component.module.d.ts +0 -8
  675. package/components/logo/logo.model.d.ts +0 -29
  676. package/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.d.ts +0 -22
  677. package/components/navbar/navbar.component.d.ts +0 -113
  678. package/components/navbar/navbar.component.module.d.ts +0 -20
  679. package/components/navbar/navbar.model.d.ts +0 -10
  680. package/components/overflow-menu/overflow-menu.component.d.ts +0 -55
  681. package/components/overflow-menu/overflow-menu.component.module.d.ts +0 -11
  682. package/components/overflow-menu/overflow-menu.model.d.ts +0 -10
  683. package/components/page-header/page-header.component.d.ts +0 -45
  684. package/components/page-header/page-header.component.module.d.ts +0 -10
  685. package/components/paginator/paginator.component.d.ts +0 -49
  686. package/components/paginator/paginator.component.module.d.ts +0 -9
  687. package/components/password-criteria/password.component.d.ts +0 -49
  688. package/components/password-criteria/password.component.module.d.ts +0 -13
  689. package/components/password-strength/password-strength.component.d.ts +0 -52
  690. package/components/password-strength/password-strength.component.module.d.ts +0 -11
  691. package/components/phone-input/join-strings.pipe.d.ts +0 -7
  692. package/components/phone-input/phone-input.component.d.ts +0 -154
  693. package/components/phone-input/phone-input.component.module.d.ts +0 -20
  694. package/components/phone-input/phone-input.model.d.ts +0 -8
  695. package/components/progress-bar/progress-bar.component.d.ts +0 -52
  696. package/components/progress-bar/progress-bar.component.module.d.ts +0 -9
  697. package/components/radial-progress/radial-progress.component.d.ts +0 -68
  698. package/components/radial-progress/radial-progress.component.module.d.ts +0 -10
  699. package/components/radial-progress/radial-progress.model.d.ts +0 -10
  700. package/components/radio-button/radio-button.component.d.ts +0 -116
  701. package/components/radio-button/radio-button.component.module.d.ts +0 -11
  702. package/components/radio-button/radio-button.model.d.ts +0 -4
  703. package/components/rating/half-star.pipe.d.ts +0 -14
  704. package/components/rating/rating.component.d.ts +0 -64
  705. package/components/rating/rating.component.module.d.ts +0 -10
  706. package/components/scale/scale.component.d.ts +0 -34
  707. package/components/scale/scale.component.module.d.ts +0 -8
  708. package/components/segmented-bar/segmented-bar.component.d.ts +0 -54
  709. package/components/segmented-bar/segmented-bar.component.module.d.ts +0 -10
  710. package/components/segmented-bar/segmented-bar.model.d.ts +0 -7
  711. package/components/segmented-button/segmented-button.component.d.ts +0 -23
  712. package/components/segmented-button/segmented-button.component.module.d.ts +0 -10
  713. package/components/segmented-button/segmented-button.model.d.ts +0 -6
  714. package/components/side-sheet/side-sheet.component.d.ts +0 -49
  715. package/components/side-sheet/side-sheet.component.module.d.ts +0 -14
  716. package/components/side-sheet/side-sheet.model.d.ts +0 -10
  717. package/components/side-sheet/side-sheet.service.d.ts +0 -14
  718. package/components/skeleton/skeleton.component.d.ts +0 -26
  719. package/components/skeleton/skeleton.model.d.ts +0 -2
  720. package/components/slider/slider.component.d.ts +0 -103
  721. package/components/slider/slider.component.module.d.ts +0 -14
  722. package/components/slider/slider.model.d.ts +0 -4
  723. package/components/snackbar/snackbar.component.d.ts +0 -111
  724. package/components/snackbar/snackbar.component.module.d.ts +0 -12
  725. package/components/snackbar/snackbar.service.d.ts +0 -12
  726. package/components/spinner/spinner.component.d.ts +0 -38
  727. package/components/spinner/spinner.module.d.ts +0 -8
  728. package/components/step/step.component.d.ts +0 -104
  729. package/components/step/step.component.module.d.ts +0 -9
  730. package/components/stepper/stepper.component.d.ts +0 -76
  731. package/components/stepper/stepper.component.module.d.ts +0 -15
  732. package/components/stepper/stepper.model.d.ts +0 -9
  733. package/components/table/sentence-case.pipe.d.ts +0 -7
  734. package/components/table/table.component.d.ts +0 -93
  735. package/components/table/table.component.module.d.ts +0 -19
  736. package/components/table/table.model.d.ts +0 -92
  737. package/components/tabs/tab.directive.d.ts +0 -18
  738. package/components/tabs/tabs.component.d.ts +0 -59
  739. package/components/tabs/tabs.component.module.d.ts +0 -11
  740. package/components/tabs/tabs.model.d.ts +0 -9
  741. package/components/tag/tag.component.d.ts +0 -129
  742. package/components/tag/tag.component.module.d.ts +0 -12
  743. package/components/toggle/toggle.component.d.ts +0 -105
  744. package/components/toggle/toggle.component.module.d.ts +0 -12
  745. package/components/tooltip/tooltip.component.d.ts +0 -44
  746. package/components/tooltip/tooltip.component.module.d.ts +0 -8
  747. package/components/tooltip/tooltip.model.d.ts +0 -6
  748. package/components/validation-error/validation-error.component.d.ts +0 -27
  749. package/components/validation-error/validation-error.module.d.ts +0 -10
  750. package/directives/digits-only.directive.d.ts +0 -15
  751. package/directives/drag-drop.directive.d.ts +0 -12
  752. package/directives/ellipse-text.directive.d.ts +0 -16
  753. package/directives/select-text.directive.d.ts +0 -19
  754. package/directives/step-line-width.directive.d.ts +0 -15
  755. package/esm2022/assets/i18n/da-dk.json +0 -77
  756. package/esm2022/assets/i18n/de.json +0 -77
  757. package/esm2022/assets/i18n/en.json +0 -100
  758. package/esm2022/assets/i18n/es.json +0 -77
  759. package/esm2022/assets/i18n/fr.json +0 -77
  760. package/esm2022/assets/i18n/it-it.json +0 -77
  761. package/esm2022/assets/i18n/ja-jp.json +0 -77
  762. package/esm2022/assets/i18n/nb-no.json +0 -77
  763. package/esm2022/assets/i18n/nl.json +0 -77
  764. package/esm2022/assets/i18n/pl-pl.json +0 -77
  765. package/esm2022/assets/i18n/pt-br.json +0 -77
  766. package/esm2022/assets/i18n/sv-se.json +0 -77
  767. package/esm2022/components/accordion/accordion.component.mjs +0 -105
  768. package/esm2022/components/accordion/accordion.component.module.mjs +0 -40
  769. package/esm2022/components/accordion/accordion.model.mjs +0 -2
  770. package/esm2022/components/alert-banner/alert-banner.component.mjs +0 -127
  771. package/esm2022/components/alert-banner/alert-banner.component.module.mjs +0 -20
  772. package/esm2022/components/alert-banner/alert-banner.model.mjs +0 -2
  773. package/esm2022/components/autocomplete/autocomplete.component.mjs +0 -496
  774. package/esm2022/components/autocomplete/autocomplete.component.module.mjs +0 -62
  775. package/esm2022/components/autocomplete/autocomplete.model.mjs +0 -22
  776. package/esm2022/components/autocomplete/includes.pipe.mjs +0 -21
  777. package/esm2022/components/autocomplete/transform-Item.pipe.mjs +0 -29
  778. package/esm2022/components/avatar/avatar.component.mjs +0 -91
  779. package/esm2022/components/avatar/avatar.component.module.mjs +0 -22
  780. package/esm2022/components/avatar/avatar.model.mjs +0 -12
  781. package/esm2022/components/badge/badge.component.mjs +0 -102
  782. package/esm2022/components/badge/badge.component.module.mjs +0 -19
  783. package/esm2022/components/badge/badge.model.mjs +0 -28
  784. package/esm2022/components/button/button.component.mjs +0 -352
  785. package/esm2022/components/button/button.component.module.mjs +0 -41
  786. package/esm2022/components/button/button.model.mjs +0 -2
  787. package/esm2022/components/card/card.component.mjs +0 -75
  788. package/esm2022/components/card/card.component.module.mjs +0 -19
  789. package/esm2022/components/card/card.model.mjs +0 -2
  790. package/esm2022/components/checkbox/checkbox.component.mjs +0 -228
  791. package/esm2022/components/checkbox/checkbox.component.module.mjs +0 -25
  792. package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +0 -48
  793. package/esm2022/components/confirm-dialog/confirm-dialog.component.module.mjs +0 -29
  794. package/esm2022/components/confirm-dialog/confirm-dialog.model.mjs +0 -2
  795. package/esm2022/components/datepicker/datepicker.component.mjs +0 -302
  796. package/esm2022/components/datepicker/datepicker.component.module.mjs +0 -60
  797. package/esm2022/components/datepicker/no-date-format.directive.mjs +0 -56
  798. package/esm2022/components/deprecated-paginator/deprecated-paginator.component.mjs +0 -55
  799. package/esm2022/components/deprecated-paginator/deprecated-paginator.component.module.mjs +0 -20
  800. package/esm2022/components/deprecated-table/deprecated-table.component.mjs +0 -158
  801. package/esm2022/components/deprecated-table/deprecated-table.component.module.mjs +0 -43
  802. package/esm2022/components/deprecated-table/deprecated-table.model.mjs +0 -13
  803. package/esm2022/components/deprecated-table/directives/dynamic-component.directive.mjs +0 -40
  804. package/esm2022/components/dialog/dialog.component.mjs +0 -193
  805. package/esm2022/components/dialog/dialog.component.module.mjs +0 -23
  806. package/esm2022/components/dialog/dialog.service.mjs +0 -32
  807. package/esm2022/components/divider/divider.component.mjs +0 -65
  808. package/esm2022/components/divider/divider.component.module.mjs +0 -19
  809. package/esm2022/components/divider/divider.model.mjs +0 -2
  810. package/esm2022/components/dropdown/dropdown.component.mjs +0 -228
  811. package/esm2022/components/dropdown/dropdown.component.module.mjs +0 -57
  812. package/esm2022/components/dropdown/dropdown.model.mjs +0 -2
  813. package/esm2022/components/elevation-shadow/elevation-shadow.component.mjs +0 -45
  814. package/esm2022/components/elevation-shadow/elevation-shadow.component.module.mjs +0 -18
  815. package/esm2022/components/elevation-shadow/elevation-shadow.constant.mjs +0 -9
  816. package/esm2022/components/empty-state/empty-state.component.mjs +0 -195
  817. package/esm2022/components/empty-state/empty-state.component.module.mjs +0 -21
  818. package/esm2022/components/empty-state/empty-state.model.mjs +0 -2
  819. package/esm2022/components/field/field.component.mjs +0 -409
  820. package/esm2022/components/field/field.component.module.mjs +0 -58
  821. package/esm2022/components/field/field.model.mjs +0 -2
  822. package/esm2022/components/file-upload/file-upload.component.mjs +0 -271
  823. package/esm2022/components/file-upload/file-upload.component.module.mjs +0 -40
  824. package/esm2022/components/icon/icon.component.mjs +0 -127
  825. package/esm2022/components/icon/icon.component.module.mjs +0 -21
  826. package/esm2022/components/icon/icon.config.mjs +0 -657
  827. package/esm2022/components/icon/icon.model.mjs +0 -2
  828. package/esm2022/components/icon-label/icon-label.component.mjs +0 -53
  829. package/esm2022/components/icon-label/icon-label.component.module.mjs +0 -20
  830. package/esm2022/components/logo/logo.component.mjs +0 -149
  831. package/esm2022/components/logo/logo.component.module.mjs +0 -18
  832. package/esm2022/components/logo/logo.model.mjs +0 -32
  833. package/esm2022/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.mjs +0 -75
  834. package/esm2022/components/navbar/navbar.component.mjs +0 -200
  835. package/esm2022/components/navbar/navbar.component.module.mjs +0 -67
  836. package/esm2022/components/navbar/navbar.model.mjs +0 -2
  837. package/esm2022/components/overflow-menu/overflow-menu.component.mjs +0 -73
  838. package/esm2022/components/overflow-menu/overflow-menu.component.module.mjs +0 -21
  839. package/esm2022/components/overflow-menu/overflow-menu.model.mjs +0 -2
  840. package/esm2022/components/page-header/page-header.component.mjs +0 -81
  841. package/esm2022/components/page-header/page-header.component.module.mjs +0 -20
  842. package/esm2022/components/paginator/paginator.component.mjs +0 -76
  843. package/esm2022/components/paginator/paginator.component.module.mjs +0 -19
  844. package/esm2022/components/password-criteria/password.component.mjs +0 -115
  845. package/esm2022/components/password-criteria/password.component.module.mjs +0 -39
  846. package/esm2022/components/password-strength/password-strength.component.mjs +0 -103
  847. package/esm2022/components/password-strength/password-strength.component.module.mjs +0 -21
  848. package/esm2022/components/phone-input/join-strings.pipe.mjs +0 -14
  849. package/esm2022/components/phone-input/phone-input.component.mjs +0 -363
  850. package/esm2022/components/phone-input/phone-input.component.module.mjs +0 -63
  851. package/esm2022/components/phone-input/phone-input.model.mjs +0 -2
  852. package/esm2022/components/progress-bar/progress-bar.component.mjs +0 -74
  853. package/esm2022/components/progress-bar/progress-bar.component.module.mjs +0 -20
  854. package/esm2022/components/radial-progress/radial-progress.component.mjs +0 -106
  855. package/esm2022/components/radial-progress/radial-progress.component.module.mjs +0 -20
  856. package/esm2022/components/radial-progress/radial-progress.model.mjs +0 -11
  857. package/esm2022/components/radio-button/radio-button.component.mjs +0 -176
  858. package/esm2022/components/radio-button/radio-button.component.module.mjs +0 -21
  859. package/esm2022/components/radio-button/radio-button.model.mjs +0 -2
  860. package/esm2022/components/rating/half-star.pipe.mjs +0 -23
  861. package/esm2022/components/rating/rating.component.mjs +0 -92
  862. package/esm2022/components/rating/rating.component.module.mjs +0 -20
  863. package/esm2022/components/scale/scale.component.mjs +0 -58
  864. package/esm2022/components/scale/scale.component.module.mjs +0 -18
  865. package/esm2022/components/segmented-bar/segmented-bar.component.mjs +0 -75
  866. package/esm2022/components/segmented-bar/segmented-bar.component.module.mjs +0 -20
  867. package/esm2022/components/segmented-bar/segmented-bar.model.mjs +0 -2
  868. package/esm2022/components/segmented-button/segmented-button.component.mjs +0 -53
  869. package/esm2022/components/segmented-button/segmented-button.component.module.mjs +0 -32
  870. package/esm2022/components/segmented-button/segmented-button.model.mjs +0 -2
  871. package/esm2022/components/side-sheet/side-sheet.component.mjs +0 -109
  872. package/esm2022/components/side-sheet/side-sheet.component.module.mjs +0 -43
  873. package/esm2022/components/side-sheet/side-sheet.model.mjs +0 -2
  874. package/esm2022/components/side-sheet/side-sheet.service.mjs +0 -31
  875. package/esm2022/components/skeleton/skeleton.component.mjs +0 -71
  876. package/esm2022/components/skeleton/skeleton.model.mjs +0 -2
  877. package/esm2022/components/slider/slider.component.mjs +0 -191
  878. package/esm2022/components/slider/slider.component.module.mjs +0 -43
  879. package/esm2022/components/slider/slider.model.mjs +0 -2
  880. package/esm2022/components/snackbar/snackbar.component.mjs +0 -208
  881. package/esm2022/components/snackbar/snackbar.component.module.mjs +0 -24
  882. package/esm2022/components/snackbar/snackbar.model.mjs +0 -2
  883. package/esm2022/components/snackbar/snackbar.service.mjs +0 -41
  884. package/esm2022/components/spinner/spinner.component.mjs +0 -62
  885. package/esm2022/components/spinner/spinner.model.mjs +0 -2
  886. package/esm2022/components/spinner/spinner.module.mjs +0 -18
  887. package/esm2022/components/step/step.component.mjs +0 -110
  888. package/esm2022/components/step/step.component.module.mjs +0 -19
  889. package/esm2022/components/stepper/stepper.component.mjs +0 -124
  890. package/esm2022/components/stepper/stepper.component.module.mjs +0 -44
  891. package/esm2022/components/stepper/stepper.model.mjs +0 -2
  892. package/esm2022/components/table/sentence-case.pipe.mjs +0 -19
  893. package/esm2022/components/table/table.component.mjs +0 -220
  894. package/esm2022/components/table/table.component.module.mjs +0 -58
  895. package/esm2022/components/table/table.model.mjs +0 -13
  896. package/esm2022/components/tabs/tab.directive.mjs +0 -42
  897. package/esm2022/components/tabs/tabs.component.mjs +0 -99
  898. package/esm2022/components/tabs/tabs.component.module.mjs +0 -33
  899. package/esm2022/components/tabs/tabs.model.mjs +0 -2
  900. package/esm2022/components/tag/tag.component.mjs +0 -201
  901. package/esm2022/components/tag/tag.component.module.mjs +0 -23
  902. package/esm2022/components/tag/tag.model.mjs +0 -2
  903. package/esm2022/components/toggle/toggle.component.mjs +0 -169
  904. package/esm2022/components/toggle/toggle.component.module.mjs +0 -22
  905. package/esm2022/components/toggle/toggle.model.mjs +0 -2
  906. package/esm2022/components/tooltip/tooltip.component.mjs +0 -79
  907. package/esm2022/components/tooltip/tooltip.component.module.mjs +0 -18
  908. package/esm2022/components/tooltip/tooltip.model.mjs +0 -8
  909. package/esm2022/components/validation-error/validation-error.component.mjs +0 -59
  910. package/esm2022/components/validation-error/validation-error.model.mjs +0 -2
  911. package/esm2022/components/validation-error/validation-error.module.mjs +0 -20
  912. package/esm2022/directives/digits-only.directive.mjs +0 -52
  913. package/esm2022/directives/drag-drop.directive.mjs +0 -55
  914. package/esm2022/directives/ellipse-text.directive.mjs +0 -37
  915. package/esm2022/directives/select-text.directive.mjs +0 -41
  916. package/esm2022/directives/step-line-width.directive.mjs +0 -38
  917. package/esm2022/models/application-theme.model.mjs +0 -2
  918. package/esm2022/models/colors.model.mjs +0 -78
  919. package/esm2022/models/screen-breakpoints.model.mjs +0 -6
  920. package/esm2022/pipes/data-property-getter.mjs +0 -33
  921. package/esm2022/pipes/has-validation-error.pipe.mjs +0 -27
  922. package/esm2022/pipes/name-initials.pipe.mjs +0 -25
  923. package/esm2022/pipes/ui-translate.pipe.mjs +0 -76
  924. package/esm2022/providers/is-mobile.mjs +0 -11
  925. package/esm2022/public-api.mjs +0 -184
  926. package/esm2022/testgorilla-tgo-ui.mjs +0 -5
  927. package/esm2022/utils/alert-bar.model.mjs +0 -2
  928. package/esm2022/utils/alert-bars.utils.mjs +0 -33
  929. package/esm2022/utils/autocomplete-utils.mjs +0 -61
  930. package/esm2022/utils/color-contrast.mjs +0 -131
  931. package/esm2022/utils/localization/language.model.mjs +0 -16
  932. package/esm2022/utils/localization/language.service.mjs +0 -33
  933. package/esm2022/utils/table.utils.mjs +0 -19
  934. package/fesm2022/testgorilla-tgo-ui.mjs +0 -11086
  935. package/fesm2022/testgorilla-tgo-ui.mjs.map +0 -1
  936. package/index.d.ts +0 -5
  937. package/models/colors.model.d.ts +0 -63
  938. package/models/screen-breakpoints.model.d.ts +0 -4
  939. package/pipes/data-property-getter.d.ts +0 -8
  940. package/pipes/has-validation-error.pipe.d.ts +0 -15
  941. package/pipes/name-initials.pipe.d.ts +0 -7
  942. package/pipes/ui-translate.pipe.d.ts +0 -28
  943. package/providers/is-mobile.d.ts +0 -2
  944. package/public-api.d.ts +0 -130
  945. package/utils/alert-bars.utils.d.ts +0 -7
  946. package/utils/autocomplete-utils.d.ts +0 -11
  947. package/utils/color-contrast.d.ts +0 -28
  948. package/utils/localization/language.model.d.ts +0 -14
  949. package/utils/localization/language.service.d.ts +0 -16
  950. package/utils/table.utils.d.ts +0 -6
  951. /package/{components/accordion/accordion.model.d.ts → projects/tgo-canopy-ui/components/accordion/accordion.model.ts} +0 -0
  952. /package/{components/alert-banner/alert-banner.model.d.ts → projects/tgo-canopy-ui/components/alert-banner/alert-banner.model.ts} +0 -0
  953. /package/{components/card/card.model.d.ts → projects/tgo-canopy-ui/components/card/card.model.ts} +0 -0
  954. /package/{components/divider/divider.model.d.ts → projects/tgo-canopy-ui/components/divider/divider.model.ts} +0 -0
  955. /package/{components/empty-state/empty-state.model.d.ts → projects/tgo-canopy-ui/components/empty-state/empty-state.model.ts} +0 -0
  956. /package/{components/snackbar/snackbar.model.d.ts → projects/tgo-canopy-ui/components/snackbar/snackbar.model.ts} +0 -0
  957. /package/{components/spinner/spinner.model.d.ts → projects/tgo-canopy-ui/components/spinner/spinner.model.ts} +0 -0
  958. /package/{components/tag/tag.model.d.ts → projects/tgo-canopy-ui/components/tag/tag.model.ts} +0 -0
  959. /package/{components/toggle/toggle.model.d.ts → projects/tgo-canopy-ui/components/toggle/toggle.model.ts} +0 -0
  960. /package/{components/validation-error/validation-error.model.d.ts → projects/tgo-canopy-ui/components/validation-error/validation-error.model.ts} +0 -0
  961. /package/{models/application-theme.model.d.ts → projects/tgo-canopy-ui/models/application-theme.model.ts} +0 -0
  962. /package/{utils/alert-bar.model.d.ts → projects/tgo-canopy-ui/utils/alert-bar.model.ts} +0 -0
@@ -0,0 +1,125 @@
1
+ import { DebugElement } from '@angular/core';
2
+ import { ScaleComponent } from './scale.component';
3
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
4
+ import { By } from '@angular/platform-browser';
5
+
6
+ const scaleSelectedItemClass = 'scale-item-selected';
7
+ const scaleSelectors = {
8
+ item: '.scale-item',
9
+ selectedItem: `.${scaleSelectedItemClass}`
10
+ };
11
+
12
+ describe('Scale Component', () => {
13
+ let component: ScaleComponent;
14
+ let fixture: ComponentFixture<ScaleComponent>;
15
+ let selectedIndexChangeSpy: jest.SpyInstance;
16
+
17
+ beforeEach(async () => {
18
+ await TestBed.configureTestingModule({
19
+ declarations: [ScaleComponent]
20
+ }).compileComponents();
21
+ });
22
+
23
+ beforeEach(() => {
24
+ fixture = TestBed.createComponent(ScaleComponent);
25
+ component = fixture.componentInstance;
26
+ selectedIndexChangeSpy = jest.spyOn(component.selectedIndexChange, 'emit');
27
+ });
28
+
29
+ it('should create the component', () => {
30
+ expect(component).toBeTruthy();
31
+ });
32
+
33
+ it('should render correctly', () => {
34
+ fixture.detectChanges();
35
+ expect(fixture).toMatchSnapshot();
36
+ });
37
+
38
+ describe('when selectedIndex is not provided', () => {
39
+ let items: DebugElement[];
40
+ beforeEach(() => {
41
+ fixture.detectChanges();
42
+ items = fixture.debugElement.queryAll(By.css(scaleSelectors.item));
43
+ });
44
+
45
+ it('should render all items unselected', () => {
46
+ const selectedItems = fixture.debugElement.queryAll(By.css(scaleSelectors.selectedItem));
47
+ expect(items.length).toBeGreaterThan(0);
48
+ expect(selectedItems.length).toEqual(0);
49
+ });
50
+
51
+ describe('when selectedIndex is changed', () => {
52
+ const newValue = 2;
53
+ beforeEach(() => {
54
+ items[newValue].nativeElement.click();
55
+ fixture.detectChanges();
56
+ });
57
+
58
+ it('should render one selected item', () => {
59
+ const selectedItems = fixture.debugElement.queryAll(By.css(scaleSelectors.selectedItem));
60
+ expect(selectedItems.length).toEqual(1);
61
+ });
62
+
63
+ it('should emit selectedIndexChange with new selectedIndex', () => {
64
+ expect(selectedIndexChangeSpy).toHaveBeenCalledWith(newValue);
65
+ });
66
+
67
+ describe('and same selected item is clicked again', () => {
68
+ beforeEach(() => {
69
+ items[newValue].nativeElement.click();
70
+ fixture.detectChanges();
71
+ });
72
+
73
+ it('should NOT deselect item', () => {
74
+ expect(items[newValue].nativeElement.classList).toContain(scaleSelectedItemClass);
75
+ });
76
+
77
+ it('should NOT emit another value by selectedIndexChange', () => {
78
+ expect(selectedIndexChangeSpy).toHaveBeenCalledWith(newValue);
79
+ });
80
+ });
81
+ });
82
+ });
83
+
84
+ describe('when selectedIndex is provided', () => {
85
+ let items: DebugElement[];
86
+ const selectedIndex = 4;
87
+ beforeEach(() => {
88
+ component.selectedIndex = selectedIndex;
89
+ fixture.detectChanges();
90
+ items = fixture.debugElement.queryAll(By.css(scaleSelectors.item));
91
+ });
92
+
93
+ it('should render selected items according to selectedIndex', () => {
94
+ expect(items[selectedIndex].nativeElement.classList).toContain(scaleSelectedItemClass);
95
+ });
96
+
97
+ describe('when selectedIndex is changed', () => {
98
+ const newValue = 2;
99
+ beforeEach(() => {
100
+ items[newValue].nativeElement.click();
101
+ fixture.detectChanges();
102
+ });
103
+
104
+ it('should render selected item according to new selectedIndex', () => {
105
+ expect(items[newValue].nativeElement.classList).toContain(scaleSelectedItemClass);
106
+ });
107
+
108
+ it('should emit selectedIndex change with new selectedIndex', () => {
109
+ expect(selectedIndexChangeSpy).toHaveBeenCalledWith(newValue);
110
+ });
111
+ });
112
+ });
113
+
114
+ describe('when length is less than 0', () => {
115
+ beforeEach(() => {
116
+ component.length = -2;
117
+ fixture.detectChanges();
118
+ });
119
+
120
+ it('should render 1 item', () => {
121
+ const items = fixture.debugElement.queryAll(By.css(scaleSelectors.item));
122
+ expect(items.length).toEqual(1);
123
+ });
124
+ });
125
+ });
@@ -0,0 +1,60 @@
1
+ import { Meta, moduleMetadata, Story } from '@storybook/angular';
2
+ import { ScaleComponent } from './scale.component';
3
+ import { CommonModule } from '@angular/common';
4
+ import { transformTheme } from '../../utils/transform-theme';
5
+
6
+ export default {
7
+ title: 'Scale',
8
+ component: ScaleComponent,
9
+ decorators: [
10
+ moduleMetadata({
11
+ declarations: [ScaleComponent],
12
+ imports: [CommonModule],
13
+ providers: [],
14
+ }),
15
+ ],
16
+ } as Meta;
17
+
18
+ const parameters = {
19
+ design: {
20
+ name: 'Figma design',
21
+ type: 'figma',
22
+ url: 'https://www.figma.com/file/Yyjp3wD1ZeFjvFcuF1Uuud/Assessment-Taking-Flow?type=design&node-id=12743-46949&mode=design&t=1VaucVaMTJH1sCOo-0',
23
+ },
24
+ controls: {
25
+ exclude: ['select', 'MIN_LENGTH', 'DEFAULT_LENGTH', 'items'],
26
+ },
27
+ };
28
+
29
+ const Template: Story = (args, { globals: { theme } }) => {
30
+ const _theme = transformTheme(theme);
31
+ return {
32
+ props: {
33
+ applicationTheme: _theme,
34
+ ...args,
35
+ },
36
+ };
37
+ };
38
+
39
+ export const WithValue = Template.bind({});
40
+
41
+ WithValue.args = {
42
+ selectedIndex: 2,
43
+ };
44
+
45
+ WithValue.parameters = parameters;
46
+
47
+ export const LargeRange = Template.bind({});
48
+
49
+ LargeRange.args = {
50
+ length: 10,
51
+ selectedIndex: 5,
52
+ };
53
+
54
+ LargeRange.parameters = parameters;
55
+
56
+ export const Default = Template.bind({});
57
+
58
+ Default.args = {};
59
+
60
+ Default.parameters = parameters;
@@ -0,0 +1,57 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';
2
+ import { ApplicationTheme } from '../../models/application-theme.model';
3
+
4
+ @Component({
5
+ selector: 'ui-scale',
6
+ templateUrl: './scale.component.html',
7
+ styleUrls: ['./scale.component.scss'],
8
+ changeDetection: ChangeDetectionStrategy.OnPush,
9
+ })
10
+ export class ScaleComponent {
11
+ private readonly MIN_LENGTH = 1;
12
+ private readonly DEFAULT_LENGTH = 5;
13
+ protected items: number[] = [];
14
+
15
+ /**
16
+ * The value representing the selected item of the scale.
17
+ * @type {number}
18
+ * @memberof ScaleComponent
19
+ */
20
+ @Input() selectedIndex: number;
21
+
22
+ /**
23
+ * The max number of items in the scale.
24
+ * @type {number}
25
+ * @memberof ScaleComponent
26
+ */
27
+ @Input() set length(length: number) {
28
+ this.items = Array(Math.max(length, this.MIN_LENGTH))
29
+ .fill(0)
30
+ .map((_, i) => i);
31
+ }
32
+
33
+ /**
34
+ *
35
+ * Defines the application theme
36
+ *
37
+ * @type {ApplicationTheme}
38
+ * @memberof ScaleComponent
39
+ */
40
+ @Input() applicationTheme: ApplicationTheme = 'light';
41
+
42
+ @Output() selectedIndexChange = new EventEmitter<number>();
43
+
44
+ constructor(
45
+ @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,
46
+ ) {
47
+ if (defaultAppTheme) {
48
+ this.applicationTheme = defaultAppTheme;
49
+ }
50
+ this.length = this.DEFAULT_LENGTH;
51
+ }
52
+
53
+ protected select(index: number): void {
54
+ this.selectedIndex = index;
55
+ this.selectedIndexChange.emit(this.selectedIndex);
56
+ }
57
+ }
@@ -0,0 +1,16 @@
1
+ <div class="segmented-bar-container" [attr.theme]="applicationTheme" [ngClass]="'segment-size-' + size" [style.width]="width">
2
+ <ng-container *ngFor="let segment of segments">
3
+ <div
4
+ class="segmented-bar"
5
+ *ngIf="segment.value"
6
+ [ngClass]="segment.color"
7
+ [ngStyle]="{ flex: segment.value }"
8
+ [matTooltip]="segment.tooltip ?? ''"
9
+ [matTooltipClass]="applicationTheme"
10
+ [attr.aria-label]="ariaLabel"
11
+ [attr.aria-required]="ariaRequired"
12
+ >
13
+ <span>{{ segment.value }}</span>
14
+ </div>
15
+ </ng-container>
16
+ </div>
@@ -0,0 +1,12 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { SegmentedBarComponent } from './segmented-bar.component';
4
+ import { MatTooltipModule } from '@angular/material/tooltip';
5
+ import { MatInputModule } from '@angular/material/input';
6
+
7
+ @NgModule({
8
+ declarations: [SegmentedBarComponent],
9
+ imports: [CommonModule, MatTooltipModule, MatInputModule],
10
+ exports: [SegmentedBarComponent],
11
+ })
12
+ export class SegmentedBarComponentModule {}
@@ -0,0 +1,86 @@
1
+ @use '../../theme/variables' as *;
2
+ @import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&display=swap");
3
+
4
+ .segmented-bar-container {
5
+ width: 100%;
6
+ display: flex;
7
+ flex-direction: row;
8
+
9
+ &.segment-size-small {
10
+ height: 16px;
11
+ }
12
+
13
+ &.segment-size-large {
14
+ height: 30px;
15
+ }
16
+
17
+ .segmented-bar {
18
+ color: $tgo-black;
19
+ font-weight: bold;
20
+ display: flex;
21
+ justify-content: center;
22
+ align-items: center;
23
+ background: $tgo-teal-default;
24
+
25
+ &.teal {
26
+ background: $tgo-teal-default;
27
+ }
28
+
29
+ &.rhubarb {
30
+ background: $tgo-error-default;
31
+ }
32
+
33
+ &.light-teal {
34
+ background: $tgo-teal-secondary;
35
+ }
36
+
37
+ &.grey {
38
+ background: $tgo-grey;
39
+ }
40
+ }
41
+
42
+ &[theme="dark"], &[theme="light"] {
43
+ &.segment-size-small {
44
+ font-size: 12px;
45
+ }
46
+
47
+ &.segment-size-large {
48
+ font-size: 14px;
49
+ }
50
+
51
+ .segmented-bar {
52
+ color: $black;
53
+ background: $success-30;
54
+
55
+ &.teal {
56
+ background: $success-30;
57
+ }
58
+
59
+ &.rhubarb {
60
+ background: $error-20;
61
+ }
62
+
63
+ &.light-teal {
64
+ background: $warning-20;
65
+ }
66
+
67
+ &.grey {
68
+ background: $grayscale-20;
69
+ }
70
+ }
71
+ }
72
+ }
73
+
74
+
75
+ ::ng-deep .mat-mdc-tooltip {
76
+ background-color: $tgo-petrol-60w;
77
+ font-family: "Open Sans", serif;
78
+ font-weight: normal;
79
+ font-size: 12px;
80
+ border-radius: 4px;
81
+ overflow: visible;
82
+ max-width: 248px;
83
+ padding: 6px 2px;
84
+ --mdc-plain-tooltip-container-color: none;
85
+ --mdc-plain-tooltip-supporting-text-color: $tgo-black;
86
+ }
@@ -0,0 +1,69 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+ import { SegmentedBarComponent } from './segmented-bar.component';
3
+ import { By } from '@angular/platform-browser';
4
+ import { MatTooltipModule } from '@angular/material/tooltip';
5
+ import { InjectionToken } from "@angular/core";
6
+ import { SliderComponent } from "../slider/slider.component";
7
+
8
+ describe('SegmentedBarComponent', () => {
9
+ let component: SegmentedBarComponent;
10
+ let fixture: ComponentFixture<SegmentedBarComponent>;
11
+ const CANOPYUI_DEFAULT_APPLICATION_THEME = new InjectionToken<string>('CANOPYUI_DEFAULT_APPLICATION_THEME');
12
+
13
+ beforeEach(() => {
14
+ TestBed.configureTestingModule({
15
+ declarations: [SegmentedBarComponent],
16
+ providers: [{ provide: CANOPYUI_DEFAULT_APPLICATION_THEME, useValue: 'dark' }], // optional provider
17
+ imports: [MatTooltipModule]
18
+ });
19
+
20
+ fixture = TestBed.createComponent(SegmentedBarComponent);
21
+ component = fixture.componentInstance;
22
+ });
23
+
24
+ it('should create the component', () => {
25
+ expect(component).toBeTruthy();
26
+ });
27
+
28
+ it('should apply ngClass based on size', () => {
29
+ component.size = 'small';
30
+ fixture.detectChanges();
31
+ const container = fixture.debugElement.query(By.css('.segmented-bar-container'));
32
+ expect(container.classes['segment-size-small']).toBe(true);
33
+ });
34
+
35
+ it('should set width using ngStyle', () => {
36
+ component.width = '200px';
37
+ fixture.detectChanges();
38
+ const container = fixture.debugElement.query(By.css('.segmented-bar-container'));
39
+ expect(container.styles['width']).toBe('200px');
40
+ });
41
+
42
+ it('should render segments with proper styles and values', () => {
43
+ component.segments = [
44
+ { color: 'teal', value: 2, tooltip: 'teal' },
45
+ { color: 'light-teal', value: 3, tooltip: 'light-teal' },
46
+ { color: 'rhubarb', value: 5, tooltip: 'rhubarb' },
47
+ ];
48
+ fixture.detectChanges();
49
+ const segments = fixture.debugElement.queryAll(By.css('.segmented-bar'));
50
+
51
+ expect(segments.length).toBe(3);
52
+
53
+ expect(segments[0].classes['teal']).toBe(true);
54
+ expect(segments[0].styles['flex']).toBe('2');
55
+ expect(segments[0].query(By.css('span')).nativeElement.textContent).toBe('2');
56
+ });
57
+
58
+ it('should handle empty segments array', () => {
59
+ component.segments = [];
60
+ fixture.detectChanges();
61
+ const container = fixture.debugElement.query(By.css('.segmented-bar-container'));
62
+ expect(container.queryAll(By.css('.segmented-bar')).length).toBe(0);
63
+ });
64
+
65
+ it('should default to light theme if no theme is injected', () => {
66
+ fixture.detectChanges();
67
+ expect(component.applicationTheme).toBe('light');
68
+ });
69
+ });
@@ -0,0 +1,98 @@
1
+ import { Meta, moduleMetadata, Story } from '@storybook/angular';
2
+ import { CommonModule } from '@angular/common';
3
+ import { SegmentedBarComponent } from './segmented-bar.component';
4
+ import { MatTooltipModule } from '@angular/material/tooltip';
5
+ import { transformTheme } from "../../utils/transform-theme";
6
+
7
+ export default {
8
+ title: 'Segmented Bar',
9
+ component: SegmentedBarComponent,
10
+ decorators: [
11
+ moduleMetadata({
12
+ declarations: [SegmentedBarComponent],
13
+ imports: [CommonModule, MatTooltipModule],
14
+ providers: [],
15
+ }),
16
+ ],
17
+ } as Meta;
18
+
19
+ const Template: Story = (args, { globals: { theme } }) => {
20
+ const _theme = transformTheme(theme);
21
+ return {
22
+ props: {
23
+ applicationTheme: _theme,
24
+ ...args,
25
+ },
26
+ };
27
+ };
28
+
29
+ const parameters = {
30
+ design: {
31
+ name: 'Figma design',
32
+ type: 'figma',
33
+ url: 'https://www.figma.com/file/FHZJ7ViJv6msJA5lJvPRIG/Component-library?type=design&node-id=13396-77691&mode=design&t=VGuLMZFB3q1OtVZa-4',
34
+ },
35
+ };
36
+
37
+ export const Default = Template.bind({});
38
+ Default.args = {
39
+ segments: [
40
+ { value: 1, color: 'teal' },
41
+ { value: 1, color: 'grey' },
42
+ { value: 1, color: 'light-teal' },
43
+ { value: 1, color: 'rhubarb' },
44
+ ],
45
+ };
46
+
47
+ Default.parameters = parameters;
48
+
49
+ export const WithValue = Template.bind({});
50
+ WithValue.args = {
51
+ segments: [
52
+ { value: 3, color: 'teal' },
53
+ { value: 1, color: 'grey' },
54
+ { value: 10, color: 'light-teal' },
55
+ { value: 4, color: 'rhubarb' },
56
+ ],
57
+ };
58
+
59
+ WithValue.parameters = parameters;
60
+
61
+ export const Small = Template.bind({});
62
+ Small.args = {
63
+ size: 'small',
64
+ segments: [
65
+ { value: 3, color: 'teal' },
66
+ { value: 1, color: 'grey' },
67
+ { value: 10, color: 'light-teal' },
68
+ { value: 4, color: 'rhubarb' },
69
+ ],
70
+ };
71
+
72
+ Small.parameters = parameters;
73
+
74
+ export const WithCustomWidth = Template.bind({});
75
+ WithCustomWidth.args = {
76
+ width: '500px',
77
+ segments: [
78
+ { value: 5, color: 'teal' },
79
+ { value: 1, color: 'grey' },
80
+ { value: 10, color: 'light-teal' },
81
+ { value: 4, color: 'rhubarb' },
82
+ ],
83
+ };
84
+
85
+ WithCustomWidth.parameters = parameters;
86
+
87
+ export const WithTooltip = Template.bind({});
88
+ WithTooltip.args = {
89
+ width: '500px',
90
+ segments: [
91
+ { value: 3, color: 'teal', tooltip: 'Value 3 teal' },
92
+ { value: 1, color: 'grey', tooltip: 'Value 1 grey' },
93
+ { value: 10, color: 'light-teal', tooltip: 'Value 10 light-teal' },
94
+ { value: 4, color: 'rhubarb', tooltip: 'Value 4 rhubarb' },
95
+ ],
96
+ };
97
+
98
+ WithTooltip.parameters = parameters;
@@ -0,0 +1,69 @@
1
+ import { Component, Inject, Input, Optional } from '@angular/core';
2
+ import { SegmentedBar, SegmentedBarVariant } from './segmented-bar.model';
3
+ import { ApplicationTheme } from "../../models/application-theme.model";
4
+
5
+ @Component({
6
+ selector: 'ui-segmented-bar',
7
+ templateUrl: './segmented-bar.component.html',
8
+ styleUrls: ['./segmented-bar.component.scss'],
9
+ })
10
+ export class SegmentedBarComponent {
11
+ /**
12
+ * The width of the segmented bar. Defaults to '100%'.
13
+ * You can use '100%' or '100px' for this field. 100 is just an example
14
+ * @default '100%'
15
+ * @type {string}
16
+ * @memberof SegmentedBarComponent
17
+ */
18
+ @Input() width = '100%';
19
+
20
+ /**
21
+ * The size variant of the segmented bar. Can be 'small' or 'large'.
22
+ * Defaults to 'large'.
23
+ * @default 'large'
24
+ * @type {SegmentedBarVariant}
25
+ * @memberof SegmentedBarComponent
26
+ */
27
+ @Input() size: SegmentedBarVariant = 'large';
28
+
29
+ /**
30
+ * The segments to be displayed in the segmented bar.
31
+ * @required true
32
+ * @type {SegmentedBar}
33
+ * @memberof SegmentedBarComponent
34
+ */
35
+ @Input({ required: true }) segments: SegmentedBar[] = [];
36
+
37
+ /**
38
+ *
39
+ * Defines the application theme
40
+ *
41
+ * @type {ApplicationTheme}
42
+ * @memberof SegmentedBarComponent
43
+ */
44
+ @Input() applicationTheme: ApplicationTheme = 'light';
45
+
46
+ /**
47
+ * A string representing the ARIA label for accessibility.
48
+ * This label is used to provide an accessible name for the input element.
49
+ * @type {string}
50
+ * @memberof SegmentedBarComponent
51
+ */
52
+ @Input() ariaLabel: string;
53
+
54
+ /**
55
+ * A string representing the ARIA requirement for accessibility.
56
+ * This attribute is used to indicate whether an input field is required for form submission.
57
+ * @type {boolean}
58
+ * @memberof SegmentedBarComponent
59
+ */
60
+ @Input() ariaRequired = false;
61
+
62
+ constructor(
63
+ @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,
64
+ ) {
65
+ if (defaultAppTheme) {
66
+ this.applicationTheme = defaultAppTheme;
67
+ }
68
+ }
69
+ }
@@ -0,0 +1,8 @@
1
+ export type SegmentedBarVariant = 'large' | 'small';
2
+ export type SegmentedBarColor = 'teal' | 'rhubarb' | 'light-teal' | 'grey';
3
+
4
+ export interface SegmentedBar {
5
+ value: number;
6
+ color: SegmentedBarColor;
7
+ tooltip?: string;
8
+ }
@@ -0,0 +1,11 @@
1
+ <mat-button-toggle-group class="segmented-button-container" [(value)]="value">
2
+ <mat-button-toggle
3
+ class="start-button"
4
+ [disableRipple]="true"
5
+ *ngFor="let button of buttonConfig"
6
+ [value]="button.value"
7
+ >
8
+ <ng-container *ngIf="button.template; else label" [ngTemplateOutlet]="button.template"></ng-container>
9
+ <ng-template #label>{{ button.label }}</ng-template>
10
+ </mat-button-toggle>
11
+ </mat-button-toggle-group>
@@ -0,0 +1,22 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { SegmentedButtonComponent } from './segmented-button.component';
4
+ import { MatButtonToggleModule } from "@angular/material/button-toggle";
5
+ import { FormsModule } from "@angular/forms";
6
+
7
+
8
+
9
+ @NgModule({
10
+ declarations: [
11
+ SegmentedButtonComponent
12
+ ],
13
+ exports: [
14
+ SegmentedButtonComponent
15
+ ],
16
+ imports: [
17
+ CommonModule,
18
+ MatButtonToggleModule,
19
+ FormsModule
20
+ ]
21
+ })
22
+ export class SegmentedButtonComponentModule { }
@@ -0,0 +1,44 @@
1
+ @use '../../theme/variables' as *;
2
+ @use '../../theme/typography' as *;
3
+
4
+ .segmented-button-container {
5
+ border-color: $grayscale-40;
6
+
7
+ &:first-child {
8
+ border-bottom-left-radius: 10px;
9
+ border-top-left-radius: 10px;
10
+ }
11
+
12
+ &:last-child {
13
+ border-bottom-right-radius: 10px;
14
+ border-top-right-radius: 10px;
15
+ }
16
+
17
+ .mat-button-toggle {
18
+ min-width: 80px;
19
+ min-height: 48px;
20
+ border-color: $grayscale-40;
21
+
22
+ ::ng-deep.mat-button-toggle-label-content {
23
+ color: $black;
24
+ @include font-style('label');
25
+ }
26
+
27
+ &:hover {
28
+ background: $brand-10;
29
+ }
30
+
31
+ &.mat-button-toggle-checked {
32
+ background: $brand-20;
33
+
34
+ ::ng-deep.mat-button-toggle-label-content {
35
+ font-weight: 700;
36
+ }
37
+
38
+ }
39
+
40
+ ::ng-deep.mat-button-toggle-focus-overlay {
41
+ display: none;
42
+ }
43
+ }
44
+ }