@verisoft/ui-primeng 20.0.0 → 20.1.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 (219) hide show
  1. package/.eslintrc.json +43 -0
  2. package/assets/.gitkeep +0 -0
  3. package/jest.config.ts +22 -0
  4. package/ng-package.json +14 -0
  5. package/package.json +6 -18
  6. package/project.json +36 -0
  7. package/src/index.ts +34 -0
  8. package/src/lib/components/breadcrumb/breadcrumb.component.html +11 -0
  9. package/src/lib/components/breadcrumb/breadcrumb.component.scss +18 -0
  10. package/src/lib/components/breadcrumb/breadcrumb.component.spec.ts +21 -0
  11. package/src/lib/components/breadcrumb/breadcrumb.component.stories.ts +36 -0
  12. package/src/lib/components/breadcrumb/breadcrumb.component.ts +27 -0
  13. package/src/lib/components/breadcrumb/breadcrumb.pipe.ts +13 -0
  14. package/src/lib/components/breadcrumb/index.ts +1 -0
  15. package/src/lib/components/button/button-severity.pipe.ts +20 -0
  16. package/src/lib/components/button/button.component.html +20 -0
  17. package/src/lib/components/button/button.component.scss +0 -0
  18. package/src/lib/components/button/button.component.spec.ts +21 -0
  19. package/src/lib/components/button/button.component.ts +49 -0
  20. package/src/lib/components/button/index.ts +1 -0
  21. package/src/lib/components/calendar/calendar.component.html +53 -0
  22. package/src/lib/components/calendar/calendar.component.scss +0 -0
  23. package/src/lib/components/calendar/calendar.component.spec.ts +21 -0
  24. package/src/lib/components/calendar/calendar.component.ts +70 -0
  25. package/src/lib/components/calendar/index.ts +1 -0
  26. package/src/lib/components/checkbox/checkbox.component.html +20 -0
  27. package/src/lib/components/checkbox/checkbox.component.scss +15 -0
  28. package/src/lib/components/checkbox/checkbox.component.spec.ts +21 -0
  29. package/src/lib/components/checkbox/checkbox.component.stories.ts +72 -0
  30. package/src/lib/components/checkbox/checkbox.component.ts +46 -0
  31. package/src/lib/components/checkbox/index.ts +1 -0
  32. package/src/lib/components/confirm-dialog/confirm-dialog.component.html +51 -0
  33. package/src/lib/components/confirm-dialog/confirm-dialog.component.scss +3 -0
  34. package/src/lib/components/confirm-dialog/confirm-dialog.component.spec.ts +21 -0
  35. package/src/lib/components/confirm-dialog/confirm-dialog.component.stories.ts +74 -0
  36. package/src/lib/components/confirm-dialog/confirm-dialog.component.ts +73 -0
  37. package/src/lib/components/confirm-dialog/index.ts +1 -0
  38. package/src/lib/components/dropdown/dropdown.component.html +93 -0
  39. package/src/lib/components/dropdown/dropdown.component.scss +16 -0
  40. package/src/lib/components/dropdown/dropdown.component.spec.ts +21 -0
  41. package/src/lib/components/dropdown/dropdown.component.ts +139 -0
  42. package/src/lib/components/dropdown/index.ts +1 -0
  43. package/src/lib/components/dropdown-button/dropdown-button.component.html +1 -0
  44. package/src/lib/components/dropdown-button/dropdown-button.component.ts +20 -0
  45. package/src/lib/components/dropdown-button/index.ts +1 -0
  46. package/src/lib/components/errors/error.component.html +7 -0
  47. package/src/lib/components/errors/error.component.scss +3 -0
  48. package/src/lib/components/errors/error.component.ts +34 -0
  49. package/src/lib/components/errors/index.ts +1 -0
  50. package/src/lib/components/feature-list/directives/feature-list-column.directive.ts +32 -0
  51. package/src/lib/components/feature-list/directives/feature-list-filter-field.directive.ts +8 -0
  52. package/src/lib/components/feature-list/feature-list-filter.pipe.ts +21 -0
  53. package/src/lib/components/feature-list/feature-list-page.component.ts +32 -0
  54. package/src/lib/components/feature-list/feature-list-page.model.ts +42 -0
  55. package/src/lib/components/feature-list/feature-list.component.html +59 -0
  56. package/src/lib/components/feature-list/feature-list.component.scss +10 -0
  57. package/src/lib/components/feature-list/feature-list.component.ts +341 -0
  58. package/src/lib/components/feature-list/index.ts +5 -0
  59. package/src/lib/components/filter/directives/filter-field.directive.ts +34 -0
  60. package/src/lib/components/filter/filter.component.html +68 -0
  61. package/src/lib/components/filter/filter.component.scss +0 -0
  62. package/src/lib/components/filter/filter.component.spec.ts +21 -0
  63. package/src/lib/components/filter/filter.component.stories.ts +23 -0
  64. package/src/lib/components/filter/filter.component.ts +281 -0
  65. package/src/lib/components/filter/filter.model.ts +18 -0
  66. package/src/lib/components/filter/index.ts +2 -0
  67. package/src/lib/components/form-field/form-field.component.html +42 -0
  68. package/src/lib/components/form-field/form-field.component.scss +0 -0
  69. package/src/lib/components/form-field/form-field.component.spec.ts +21 -0
  70. package/src/lib/components/form-field/form-field.component.stories.ts +69 -0
  71. package/src/lib/components/form-field/form-field.component.ts +37 -0
  72. package/src/lib/components/form-field/index.ts +1 -0
  73. package/src/lib/components/header/header.component.html +84 -0
  74. package/src/lib/components/header/header.component.scss +0 -0
  75. package/src/lib/components/header/header.component.spec.ts +21 -0
  76. package/src/lib/components/header/header.component.stories.ts +24 -0
  77. package/src/lib/components/header/header.component.ts +65 -0
  78. package/src/lib/components/header/index.ts +2 -0
  79. package/src/lib/components/header/services/header-provider.service.ts +15 -0
  80. package/src/lib/components/icon/icon.component.html +2 -0
  81. package/src/lib/components/icon/icon.component.scss +51 -0
  82. package/src/lib/components/icon/icon.component.ts +86 -0
  83. package/src/lib/components/icon/index.ts +2 -0
  84. package/src/lib/components/input-group/index.ts +1 -0
  85. package/src/lib/components/input-group/input-group.component.html +34 -0
  86. package/src/lib/components/input-group/input-group.component.spec.ts +21 -0
  87. package/src/lib/components/input-group/input-group.component.ts +58 -0
  88. package/src/lib/components/loader/index.ts +1 -0
  89. package/src/lib/components/loader/loader.component.html +5 -0
  90. package/src/lib/components/loader/loader.component.scss +0 -0
  91. package/src/lib/components/loader/loader.component.spec.ts +21 -0
  92. package/src/lib/components/loader/loader.component.ts +16 -0
  93. package/src/lib/components/multiselect/index.ts +1 -0
  94. package/src/lib/components/multiselect/multiselect.component.html +67 -0
  95. package/src/lib/components/multiselect/multiselect.component.scss +0 -0
  96. package/src/lib/components/multiselect/multiselect.component.spec.ts +21 -0
  97. package/src/lib/components/multiselect/multiselect.component.ts +120 -0
  98. package/src/lib/components/number-input/index.ts +1 -0
  99. package/src/lib/components/number-input/number-input.component.html +22 -0
  100. package/src/lib/components/number-input/number-input.component.spec.ts +21 -0
  101. package/src/lib/components/number-input/number-input.component.ts +55 -0
  102. package/src/lib/components/page-header/index.ts +1 -0
  103. package/src/lib/components/page-header/page-header.component.html +35 -0
  104. package/src/lib/components/page-header/page-header.component.scss +0 -0
  105. package/src/lib/components/page-header/page-header.component.spec.ts +21 -0
  106. package/src/lib/components/page-header/page-header.component.ts +31 -0
  107. package/src/lib/components/password/index.ts +1 -0
  108. package/src/lib/components/password/password.component.html +24 -0
  109. package/src/lib/components/password/password.component.scss +0 -0
  110. package/src/lib/components/password/password.component.spec.ts +21 -0
  111. package/src/lib/components/password/password.component.ts +56 -0
  112. package/src/lib/components/radiobutton/index.ts +1 -0
  113. package/src/lib/components/radiobutton/radiobutton.component.html +34 -0
  114. package/src/lib/components/radiobutton/radiobutton.component.scss +6 -0
  115. package/src/lib/components/radiobutton/radiobutton.component.spec.ts +21 -0
  116. package/src/lib/components/radiobutton/radiobutton.component.stories.ts +71 -0
  117. package/src/lib/components/radiobutton/radiobutton.component.ts +61 -0
  118. package/src/lib/components/section/index.ts +1 -0
  119. package/src/lib/components/section/section.component.html +25 -0
  120. package/src/lib/components/section/section.component.scss +0 -0
  121. package/src/lib/components/section/section.component.spec.ts +21 -0
  122. package/src/lib/components/section/section.component.ts +31 -0
  123. package/src/lib/components/shared-components/.eslintrc.json +42 -0
  124. package/src/lib/components/shared-components/action-button-group/action-button-group.component.html +25 -0
  125. package/src/lib/components/shared-components/action-button-group/action-button-group.component.scss +0 -0
  126. package/src/lib/components/shared-components/action-button-group/action-button-group.component.spec.ts +21 -0
  127. package/src/lib/components/shared-components/action-button-group/action-button-group.component.ts +111 -0
  128. package/src/lib/components/shared-components/action-button-group/components/action-button/action-button.component.html +10 -0
  129. package/src/lib/components/shared-components/action-button-group/components/action-button/action-button.component.scss +0 -0
  130. package/src/lib/components/shared-components/action-button-group/components/action-button/action-button.component.spec.ts +21 -0
  131. package/src/lib/components/shared-components/action-button-group/components/action-button/action-button.component.ts +69 -0
  132. package/src/lib/components/shared-components/action-button-group/index.ts +2 -0
  133. package/src/lib/components/shared-components/dynamic-component/dynamic-component-factory.service.ts +142 -0
  134. package/src/lib/components/shared-components/dynamic-component/dynamic-component.component.ts +56 -0
  135. package/src/lib/components/shared-components/dynamic-component/index.ts +2 -0
  136. package/src/lib/components/shared-components/generic-field/generic-field.component.html +98 -0
  137. package/src/lib/components/shared-components/generic-field/generic-field.component.spec.ts +21 -0
  138. package/src/lib/components/shared-components/generic-field/generic-field.component.ts +90 -0
  139. package/src/lib/components/shared-components/generic-field/index.ts +1 -0
  140. package/src/lib/components/shared-components/generic-form/generic-form.component.html +46 -0
  141. package/src/lib/components/shared-components/generic-form/generic-form.component.spec.ts +21 -0
  142. package/src/lib/components/shared-components/generic-form/generic-form.component.ts +56 -0
  143. package/src/lib/components/shared-components/generic-form/generic-form.model.spec.ts +82 -0
  144. package/src/lib/components/shared-components/generic-form/generic-form.model.ts +68 -0
  145. package/src/lib/components/shared-components/generic-form/index.ts +2 -0
  146. package/src/lib/components/shared-components/index.ts +4 -0
  147. package/src/lib/components/side-menu/index.ts +2 -0
  148. package/src/lib/components/side-menu/side-menu.component.html +53 -0
  149. package/src/lib/components/side-menu/side-menu.component.scss +0 -0
  150. package/src/lib/components/side-menu/side-menu.component.spec.ts +21 -0
  151. package/src/lib/components/side-menu/side-menu.component.ts +96 -0
  152. package/src/lib/components/side-menu/side-menu.module.ts +66 -0
  153. package/src/lib/components/slider/index.ts +1 -0
  154. package/src/lib/components/slider/slider.component.html +19 -0
  155. package/src/lib/components/slider/slider.component.spec.ts +21 -0
  156. package/src/lib/components/slider/slider.component.ts +56 -0
  157. package/src/lib/components/snackbar/index.ts +2 -0
  158. package/src/lib/components/snackbar/services/snackbar.service.ts +45 -0
  159. package/src/lib/components/snackbar/snackbar.component.html +3 -0
  160. package/src/lib/components/snackbar/snackbar.component.scss +0 -0
  161. package/src/lib/components/snackbar/snackbar.component.spec.ts +21 -0
  162. package/src/lib/components/snackbar/snackbar.component.stories.ts +70 -0
  163. package/src/lib/components/snackbar/snackbar.component.ts +25 -0
  164. package/src/lib/components/stepper/index.ts +1 -0
  165. package/src/lib/components/stepper/stepper.component.html +35 -0
  166. package/src/lib/components/stepper/stepper.component.spec.ts +21 -0
  167. package/src/lib/components/stepper/stepper.component.ts +39 -0
  168. package/src/lib/components/switch/index.ts +1 -0
  169. package/src/lib/components/switch/switch.component.html +18 -0
  170. package/src/lib/components/switch/switch.component.scss +0 -0
  171. package/src/lib/components/switch/switch.component.spec.ts +21 -0
  172. package/src/lib/components/switch/switch.component.stories.ts +65 -0
  173. package/src/lib/components/switch/switch.component.ts +52 -0
  174. package/src/lib/components/tab-view/index.ts +2 -0
  175. package/src/lib/components/tab-view/tab-view-item.component.ts +22 -0
  176. package/src/lib/components/tab-view/tab-view.component.html +41 -0
  177. package/src/lib/components/tab-view/tab-view.component.ts +55 -0
  178. package/src/lib/components/table/index.ts +1 -0
  179. package/src/lib/components/table/table-filter.pipe.ts +59 -0
  180. package/src/lib/components/table/table.component.html +127 -0
  181. package/src/lib/components/table/table.component.scss +11 -0
  182. package/src/lib/components/table/table.component.spec.ts +21 -0
  183. package/src/lib/components/table/table.component.stories.ts +55 -0
  184. package/src/lib/components/table/table.component.ts +288 -0
  185. package/src/lib/components/table/table.models.ts +26 -0
  186. package/src/lib/components/tag/index.ts +2 -0
  187. package/src/lib/components/tag/tag.component.html +12 -0
  188. package/src/lib/components/tag/tag.component.scss +33 -0
  189. package/src/lib/components/tag/tag.component.ts +83 -0
  190. package/src/lib/components/textarea/index.ts +1 -0
  191. package/src/lib/components/textarea/textarea.component.html +40 -0
  192. package/src/lib/components/textarea/textarea.component.scss +5 -0
  193. package/src/lib/components/textarea/textarea.component.spec.ts +21 -0
  194. package/src/lib/components/textarea/textarea.component.stories.ts +98 -0
  195. package/src/lib/components/textarea/textarea.component.ts +62 -0
  196. package/src/lib/components/textfield/index.ts +1 -0
  197. package/src/lib/components/textfield/textfield.component.html +82 -0
  198. package/src/lib/components/textfield/textfield.component.scss +23 -0
  199. package/src/lib/components/textfield/textfield.component.spec.ts +21 -0
  200. package/src/lib/components/textfield/textfield.component.stories.ts +85 -0
  201. package/src/lib/components/textfield/textfield.component.ts +68 -0
  202. package/src/lib/components/tooltip/index.ts +1 -0
  203. package/src/lib/components/tooltip/tooltip.component.html +3 -0
  204. package/src/lib/components/tooltip/tooltip.component.ts +17 -0
  205. package/src/lib/icons.ts +36 -0
  206. package/src/lib/interceptors/http-error-message.interceptor.ts +35 -0
  207. package/src/lib/pages/not-found-page/not-found-page.component.html +26 -0
  208. package/src/lib/pages/not-found-page/not-found-page.component.scss +0 -0
  209. package/src/lib/pages/not-found-page/not-found-page.component.spec.ts +21 -0
  210. package/src/lib/pages/not-found-page/not-found-page.component.ts +16 -0
  211. package/src/tab-view.ts +1 -0
  212. package/src/test-setup.ts +8 -0
  213. package/tsconfig.json +29 -0
  214. package/tsconfig.lib.json +18 -0
  215. package/tsconfig.lib.prod.json +9 -0
  216. package/tsconfig.spec.json +16 -0
  217. package/fesm2022/verisoft-ui-primeng.mjs +0 -2866
  218. package/fesm2022/verisoft-ui-primeng.mjs.map +0 -1
  219. package/index.d.ts +0 -729
package/.eslintrc.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "extends": ["../../../.eslintrc.base.json"],
3
+ "ignorePatterns": ["!**/*"],
4
+ "overrides": [
5
+ {
6
+ "files": ["*.ts"],
7
+ "extends": [
8
+ "plugin:@nx/angular",
9
+ "plugin:@angular-eslint/template/process-inline-templates"
10
+ ],
11
+ "rules": {
12
+ "@angular-eslint/directive-selector": [
13
+ "error",
14
+ {
15
+ "type": "attribute",
16
+ "prefix": "v",
17
+ "style": "camelCase"
18
+ }
19
+ ],
20
+ "@angular-eslint/component-selector": [
21
+ "error",
22
+ {
23
+ "type": "element",
24
+ "prefix": "v",
25
+ "style": "kebab-case"
26
+ }
27
+ ]
28
+ }
29
+ },
30
+ {
31
+ "files": ["*.html"],
32
+ "extends": ["plugin:@nx/angular-template"],
33
+ "rules": {}
34
+ },
35
+ {
36
+ "files": ["*.json"],
37
+ "parser": "jsonc-eslint-parser",
38
+ "rules": {
39
+ "@nx/dependency-checks": "error"
40
+ }
41
+ }
42
+ ]
43
+ }
File without changes
package/jest.config.ts ADDED
@@ -0,0 +1,22 @@
1
+ /* eslint-disable */
2
+ export default {
3
+ displayName: 'ui-primeng',
4
+ preset: '../../../jest.preset.js',
5
+ setupFilesAfterEnv: ['<rootDir>/src/test-setup.ts'],
6
+ coverageDirectory: '../../../coverage/src/libs/ui-primeng',
7
+ transform: {
8
+ '^.+\\.(ts|mjs|js|html)$': [
9
+ 'jest-preset-angular',
10
+ {
11
+ tsconfig: '<rootDir>/tsconfig.spec.json',
12
+ stringifyContentPathRegex: '\\.(html|svg)$',
13
+ },
14
+ ],
15
+ },
16
+ transformIgnorePatterns: ['node_modules/(?!.*\\.mjs$)'],
17
+ snapshotSerializers: [
18
+ 'jest-preset-angular/build/serializers/no-ng-attributes',
19
+ 'jest-preset-angular/build/serializers/ng-snapshot',
20
+ 'jest-preset-angular/build/serializers/html-comment',
21
+ ],
22
+ };
@@ -0,0 +1,14 @@
1
+ {
2
+ "$schema": "../../../node_modules/ng-packagr/ng-package.schema.json",
3
+ "dest": "../../../dist/src/libs/ui-primeng",
4
+ "lib": {
5
+ "entryFile": "src/index.ts"
6
+ },
7
+ "assets": [
8
+ "./assets/",
9
+ "README.md"
10
+ ],
11
+ "allowedNonPeerDependencies": [
12
+ "uuid"
13
+ ]
14
+ }
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@verisoft/ui-primeng",
3
- "version": "20.0.0",
3
+ "version": "20.1.1",
4
4
  "peerDependencies": {
5
- "@verisoft/core": "~20.0.0",
6
- "@verisoft/ui-core": "~20.0.0",
5
+ "@verisoft/core": "~20.1.1",
6
+ "@verisoft/ui-core": "~20.1.1",
7
7
  "@angular/core": "~20.2.0",
8
8
  "@angular/common": "~20.2.0",
9
9
  "@angular/forms": "~20.2.0",
@@ -14,19 +14,7 @@
14
14
  "rxjs": "~7.8.0"
15
15
  },
16
16
  "dependencies": {
17
- "uuid": "^11.0.0",
18
- "tslib": "^2.3.0"
17
+ "uuid": "^11.0.0"
19
18
  },
20
- "sideEffects": false,
21
- "module": "fesm2022/verisoft-ui-primeng.mjs",
22
- "typings": "index.d.ts",
23
- "exports": {
24
- "./package.json": {
25
- "default": "./package.json"
26
- },
27
- ".": {
28
- "types": "./index.d.ts",
29
- "default": "./fesm2022/verisoft-ui-primeng.mjs"
30
- }
31
- }
32
- }
19
+ "sideEffects": false
20
+ }
package/project.json ADDED
@@ -0,0 +1,36 @@
1
+ {
2
+ "name": "ui-primeng",
3
+ "$schema": "../../../node_modules/nx/schemas/project-schema.json",
4
+ "sourceRoot": "src/libs/ui-primeng/src",
5
+ "prefix": "verisoft",
6
+ "projectType": "library",
7
+ "tags": [],
8
+ "targets": {
9
+ "build": {
10
+ "executor": "@nx/angular:package",
11
+ "outputs": ["{workspaceRoot}/dist/{projectRoot}"],
12
+ "options": {
13
+ "project": "src/libs/ui-primeng/ng-package.json"
14
+ },
15
+ "configurations": {
16
+ "production": {
17
+ "tsConfig": "src/libs/ui-primeng/tsconfig.lib.prod.json"
18
+ },
19
+ "development": {
20
+ "tsConfig": "src/libs/ui-primeng/tsconfig.lib.json"
21
+ }
22
+ },
23
+ "defaultConfiguration": "production"
24
+ },
25
+ "test": {
26
+ "executor": "@nx/jest:jest",
27
+ "outputs": ["{workspaceRoot}/coverage/{projectRoot}"],
28
+ "options": {
29
+ "jestConfig": "src/libs/ui-primeng/jest.config.ts"
30
+ }
31
+ },
32
+ "lint": {
33
+ "executor": "@nx/eslint:lint"
34
+ }
35
+ }
36
+ }
package/src/index.ts ADDED
@@ -0,0 +1,34 @@
1
+ export * from './lib/components/input-group';
2
+ export * from './lib/components/textfield';
3
+ export * from './lib/components/breadcrumb';
4
+ export * from './lib/components/checkbox';
5
+ export * from './lib/components/calendar';
6
+ export * from './lib/components/form-field';
7
+ export * from './lib/components/password';
8
+ export * from './lib/components/section';
9
+ export * from './lib/components/button/button.component';
10
+ export * from './lib/components/dropdown-button';
11
+ export * from './lib/components/radiobutton';
12
+ export * from './lib/components/number-input';
13
+ export * from './lib/components/header';
14
+ export * from './lib/components/textarea';
15
+ export * from './lib/components/loader';
16
+ export * from './lib/components/snackbar';
17
+ export * from './lib/components/side-menu';
18
+ export * from './lib/components/table';
19
+ export * from './lib/components/page-header';
20
+ export * from './lib/components/stepper';
21
+ export * from './lib/components/dropdown';
22
+ export * from './lib/components/multiselect';
23
+ export * from './lib/components/slider';
24
+ export * from './lib/components/confirm-dialog';
25
+ export * from './lib/components/switch';
26
+ export * from './lib/interceptors/http-error-message.interceptor';
27
+ export * from './lib/components/tab-view';
28
+ export * from './lib/components/shared-components';
29
+ export * from './lib/components/filter';
30
+ export * from './lib/components/feature-list';
31
+ export * from './lib/components/tooltip';
32
+ export * from './lib/components/tag';
33
+ export * from './lib/components/icon';
34
+ export * from './lib/icons';
@@ -0,0 +1,11 @@
1
+ <div class="v-breadcrumb card flex justify-content-center">
2
+ @if (useHomeRoute) {
3
+ <p-breadcrumb
4
+ class="max-w-full"
5
+ [model]="items | menuItem"
6
+ [home]="home"
7
+ ></p-breadcrumb>
8
+ } @else {
9
+ <p-breadcrumb class="max-w-full" [model]="items | menuItem"></p-breadcrumb>
10
+ }
11
+ </div>
@@ -0,0 +1,18 @@
1
+ p-breadcrumb > nav {
2
+ border: none;
3
+ > ol {
4
+ align-items: stretch;
5
+ font-weight: 600;
6
+ font-size: 1rem;
7
+ }
8
+ a[aria-current='page'] > span {
9
+ color: var(--primary-color) !important;
10
+ }
11
+ }
12
+ .p-menuitem-link {
13
+ gap: 0.5rem;
14
+ text-align: center;
15
+ }
16
+ .p-menuitem-text {
17
+ align-self: baseline;
18
+ }
@@ -0,0 +1,21 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+ import { BreadcrumbComponent } from './breadcrumb.component';
3
+
4
+ describe('BreadcrumbComponent', () => {
5
+ let component: BreadcrumbComponent;
6
+ let fixture: ComponentFixture<BreadcrumbComponent>;
7
+
8
+ beforeEach(async () => {
9
+ await TestBed.configureTestingModule({
10
+ imports: [BreadcrumbComponent],
11
+ }).compileComponents();
12
+
13
+ fixture = TestBed.createComponent(BreadcrumbComponent);
14
+ component = fixture.componentInstance;
15
+ fixture.detectChanges();
16
+ });
17
+
18
+ it('should create', () => {
19
+ expect(component).toBeTruthy();
20
+ });
21
+ });
@@ -0,0 +1,36 @@
1
+ import { ActivatedRoute } from '@angular/router';
2
+ import { moduleMetadata, type Meta, type StoryObj } from '@storybook/angular';
3
+ import { within, expect } from '@storybook/test';
4
+ import { BreadcrumbComponent } from './breadcrumb.component';
5
+
6
+ const meta: Meta<BreadcrumbComponent> = {
7
+ component: BreadcrumbComponent,
8
+ title: 'BreadcrumbComponent',
9
+ decorators: [
10
+ moduleMetadata({
11
+ providers: [
12
+ {
13
+ provide: ActivatedRoute,
14
+ useValue: ActivatedRoute,
15
+ },
16
+ ],
17
+ }),
18
+ ],
19
+ };
20
+ export default meta;
21
+ type Story = StoryObj<BreadcrumbComponent>;
22
+ export const Primary: Story = {
23
+ args: {
24
+ homeRoute: '123',
25
+ useHomeRoute: true,
26
+ items: [
27
+ { label: 'Contract', routerLink: '123' },
28
+ { label: 'List', routerLink: './list' },
29
+ ],
30
+ },
31
+ play: async ({ canvasElement }: any) => {
32
+ const canvas = within(canvasElement);
33
+ expect(canvas.getByText('Contract')).toBeTruthy();
34
+ expect(canvas.getByText('List')).toBeTruthy();
35
+ },
36
+ };
@@ -0,0 +1,27 @@
1
+
2
+ import {
3
+ Component,
4
+ } from '@angular/core';
5
+ import {
6
+ BREADCRUMB_COMPONENT_TOKEN,
7
+ BreadcrumbCoreComponent,
8
+ } from '@verisoft/ui-core';
9
+ import { BreadcrumbModule } from 'primeng/breadcrumb';
10
+ import { ConvertMenuItemPipe } from './breadcrumb.pipe';
11
+
12
+ @Component({
13
+ selector: 'v-breadcrumb',
14
+ imports: [
15
+ BreadcrumbModule,
16
+ ConvertMenuItemPipe
17
+ ],
18
+ templateUrl: './breadcrumb.component.html',
19
+ styleUrl: './breadcrumb.component.scss',
20
+ providers: [
21
+ {
22
+ provide: BREADCRUMB_COMPONENT_TOKEN,
23
+ useExisting: BreadcrumbComponent
24
+ },
25
+ ]
26
+ })
27
+ export class BreadcrumbComponent extends BreadcrumbCoreComponent { }
@@ -0,0 +1,13 @@
1
+ import { Pipe, PipeTransform } from "@angular/core";
2
+ import { MenuItem as VerisoftMenuItem } from "@verisoft/ui-core";
3
+ import { MenuItem as PrimeMenuItem } from "primeng/api";
4
+
5
+ @Pipe({
6
+ name: 'menuItem',
7
+ standalone: true,
8
+ })
9
+ export class ConvertMenuItemPipe implements PipeTransform {
10
+ transform(items: VerisoftMenuItem[]): PrimeMenuItem[] {
11
+ return items.map(i => i as PrimeMenuItem);
12
+ }
13
+ }
@@ -0,0 +1 @@
1
+ export * from './breadcrumb.component';
@@ -0,0 +1,20 @@
1
+ import { Pipe, PipeTransform } from '@angular/core';
2
+ import { ControlSeverity, ControlSeverityType } from '@verisoft/ui-core';
3
+ import { ButtonSeverity } from 'primeng/button';
4
+
5
+ @Pipe({
6
+ name: 'buttonSeverity'
7
+ })
8
+ export class ButtonSeverityPipe implements PipeTransform {
9
+ transform(severity: ControlSeverityType | undefined | null): ButtonSeverity {
10
+ if (severity === undefined || severity === null) {
11
+ return null;
12
+ }
13
+
14
+ if (severity === ControlSeverity.warning) {
15
+ return 'warn';
16
+ }
17
+
18
+ return severity;
19
+ }
20
+ }
@@ -0,0 +1,20 @@
1
+ <div class="v-button d-inline-block"
2
+ (click)="fireClick($event)">
3
+ <a
4
+ [routerLink]="routerLink ? routerLink : undefined"
5
+ [queryParams]="queryParams ? queryParams : undefined"
6
+ >
7
+ <p-button
8
+ [disabled]="disabled"
9
+ [icon]="icon"
10
+ [badge]="badge"
11
+ [outlined]="outlined"
12
+ [rounded]="rounded"
13
+ [raised]="raised"
14
+ [label]="label"
15
+ [size]="$any(size)"
16
+ [severity]="severity | buttonSeverity"
17
+ [iconPos]="iconPos"
18
+ />
19
+ </a>
20
+ </div>
@@ -0,0 +1,21 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+ import { ButtonComponent } from './button.component';
3
+
4
+ describe('ButtonComponent', () => {
5
+ let component: ButtonComponent;
6
+ let fixture: ComponentFixture<ButtonComponent>;
7
+
8
+ beforeEach(async () => {
9
+ await TestBed.configureTestingModule({
10
+ imports: [ButtonComponent],
11
+ }).compileComponents();
12
+
13
+ fixture = TestBed.createComponent(ButtonComponent);
14
+ component = fixture.componentInstance;
15
+ fixture.detectChanges();
16
+ });
17
+
18
+ it('should create', () => {
19
+ expect(component).toBeTruthy();
20
+ });
21
+ });
@@ -0,0 +1,49 @@
1
+
2
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
3
+ import { Params, RouterModule } from '@angular/router';
4
+ import {
5
+ BUTTON_COMPONENT_TOKEN,
6
+ ButtonCore,
7
+ ControlSeverityType,
8
+ FieldSizeType,
9
+ IconPosition,
10
+ IconPositionType,
11
+ } from '@verisoft/ui-core';
12
+ import { ButtonModule } from 'primeng/button';
13
+ import { RippleModule } from 'primeng/ripple';
14
+ import { ButtonSeverityPipe } from "./button-severity.pipe";
15
+
16
+ @Component({
17
+ selector: 'v-button',
18
+ imports: [ButtonModule, RippleModule, RouterModule, ButtonSeverityPipe],
19
+ templateUrl: './button.component.html',
20
+ styleUrl: './button.component.scss',
21
+ changeDetection: ChangeDetectionStrategy.OnPush,
22
+ providers: [
23
+ {
24
+ provide: BUTTON_COMPONENT_TOKEN,
25
+ useExisting: ButtonComponent,
26
+ },
27
+ ]
28
+ })
29
+ export class ButtonComponent implements ButtonCore {
30
+ @Input() label?: string;
31
+ @Input() icon?: string;
32
+ @Input() badge?: string;
33
+ @Input() iconPos: IconPositionType = IconPosition.right;
34
+ @Input() disabled!: boolean;
35
+ @Input() rounded!: boolean;
36
+ @Input() outlined!: boolean;
37
+ @Input() raised!: boolean;
38
+ @Input() severity?: ControlSeverityType;
39
+ @Input() routerLink!: any[];
40
+ @Input() size: FieldSizeType | undefined;
41
+ @Input() queryParams?: Params;
42
+
43
+ fireClick(event: Event): void {
44
+ if (this.disabled) {
45
+ event.stopPropagation();
46
+ event.stopImmediatePropagation();
47
+ }
48
+ }
49
+ }
@@ -0,0 +1 @@
1
+ export * from './button.component';
@@ -0,0 +1,53 @@
1
+ <div class="v-calendar w-100">
2
+ @if (label && !floatLabel) {
3
+ <v-form-field
4
+ class="w-100"
5
+ [label]="label"
6
+ [tooltip]="tooltip"
7
+ [required]="isRequired()"
8
+ [display]="formDisplay"
9
+ >
10
+ <p-date-picker
11
+ appendTo="body"
12
+ [style]="{'width':'100%'}"
13
+ [inputStyle]="{'width':'100%'}"
14
+ [formControl]="formControl"
15
+ [showClear]="clearable"
16
+ [dataType]="'string'"
17
+ [selectionMode]="selectionMode"
18
+ [icon]="icon"
19
+ [maxDate]="maxDate"
20
+ [id]="inputId"
21
+ [showButtonBar]="true"
22
+ [placeholder]="placeholder"
23
+ [required]="isRequired()"
24
+ [minDate]="minDate"
25
+ [showIcon]="formControl && !formControl.value"
26
+ iconDisplay="input"
27
+ />
28
+ </v-form-field>
29
+ <v-validation-message [ngControl]="ngControl"></v-validation-message>
30
+ }
31
+ @if (floatLabel) {
32
+ <p-floatLabel>
33
+ <p-date-picker
34
+ appendTo="body"
35
+ [style]="{'width':'100%'}"
36
+ [inputStyle]="{'width':'100%'}"
37
+ [formControl]="formControl"
38
+ [showClear]="clearable"
39
+ [maxDate]="maxDate"
40
+ [id]="inputId"
41
+ [icon]="icon"
42
+ [selectionMode]="selectionMode"
43
+ [showButtonBar]="true"
44
+ [placeholder]="placeholder"
45
+ [required]="isRequired()"
46
+ [minDate]="minDate"
47
+ iconDisplay="input"
48
+ />
49
+ <label [for]="inputId" [innerHTML]="floatLabel"></label>
50
+ </p-floatLabel>
51
+ }
52
+ </div>
53
+
@@ -0,0 +1,21 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+ import { CalendarComponent } from './calendar.component';
3
+
4
+ describe('CalendarComponent', () => {
5
+ let component: CalendarComponent;
6
+ let fixture: ComponentFixture<CalendarComponent>;
7
+
8
+ beforeEach(async () => {
9
+ await TestBed.configureTestingModule({
10
+ imports: [CalendarComponent],
11
+ }).compileComponents();
12
+
13
+ fixture = TestBed.createComponent(CalendarComponent);
14
+ component = fixture.componentInstance;
15
+ fixture.detectChanges();
16
+ });
17
+
18
+ it('should create', () => {
19
+ expect(component).toBeTruthy();
20
+ });
21
+ });
@@ -0,0 +1,70 @@
1
+
2
+ import {
3
+ ChangeDetectionStrategy,
4
+ Component,
5
+ forwardRef,
6
+ Input,
7
+ Optional,
8
+ Self,
9
+ } from '@angular/core';
10
+ import {
11
+ ControlValueAccessor,
12
+ NgControl,
13
+ ReactiveFormsModule,
14
+ } from '@angular/forms';
15
+ import {
16
+ BaseFormInputComponent,
17
+ BaseInputControls,
18
+ CALENDAR_COMPONENT_TOKEN,
19
+ CalendarCore,
20
+ } from '@verisoft/ui-core';
21
+ import { DatePicker } from 'primeng/datepicker';
22
+ import { FloatLabelModule } from 'primeng/floatlabel';
23
+ import { Icons } from '../../icons';
24
+ import { ErrorComponent } from '../errors';
25
+ import { FormFieldComponent } from '../form-field';
26
+
27
+ @Component({
28
+ selector: 'v-calendar',
29
+ imports: [
30
+ ReactiveFormsModule,
31
+ DatePicker,
32
+ FormFieldComponent,
33
+ FloatLabelModule,
34
+ ErrorComponent
35
+ ],
36
+ templateUrl: './calendar.component.html',
37
+ styleUrl: './calendar.component.scss',
38
+ changeDetection: ChangeDetectionStrategy.OnPush,
39
+ providers: [
40
+ {
41
+ provide: BaseInputControls,
42
+ useExisting: forwardRef(() => CalendarComponent),
43
+ },
44
+ {
45
+ provide: CALENDAR_COMPONENT_TOKEN,
46
+ useExisting: CalendarComponent,
47
+ },
48
+ ]
49
+ })
50
+ export class CalendarComponent
51
+ extends BaseFormInputComponent
52
+ implements ControlValueAccessor, CalendarCore
53
+ {
54
+ constructor(@Optional() @Self() ngControl: NgControl) {
55
+ super(ngControl);
56
+ }
57
+
58
+ @Input() maxDate!: Date;
59
+ @Input() icon = Icons.calendar;
60
+ @Input() minDate!: Date;
61
+ @Input() header!: string;
62
+ @Input() footer!: string;
63
+ @Input() floatLabel: string | undefined;
64
+ @Input() selectionMode: 'single' | 'multiple' | 'range' | undefined =
65
+ 'single';
66
+
67
+ icons = Icons;
68
+
69
+ override formDisplay: "flex" | "block" = "block";
70
+ }
@@ -0,0 +1 @@
1
+ export * from './calendar.component';
@@ -0,0 +1,20 @@
1
+ <div class="v-checkbox d-flex align-items-center mt-2">
2
+ <v-form-field
3
+ class="w-100"
4
+ [label]="label"
5
+ [tooltip]="tooltip"
6
+ [required]="isRequired()"
7
+ [testId]="testId"
8
+ [display]="formDisplay"
9
+ >
10
+ <p-checkbox
11
+ [ngClass]="{ 'checkbox-error': ngControl?.invalid && ngControl?.dirty && ngControl?.value === false }"
12
+ [formControl]="formControl"
13
+ [required]="required"
14
+ [binary]="true"
15
+ [readonly]="readonly"
16
+ [indeterminate]="indeterminate()"
17
+ />
18
+ <v-validation-message [ngControl]="ngControl"></v-validation-message>
19
+ </v-form-field>
20
+ </div>
@@ -0,0 +1,15 @@
1
+ p-echeckbox.ng-dirty.ng-invalid {
2
+ .p-checkbox>.p-checkbox-box {
3
+ border-color: var(--error-color);
4
+ }
5
+
6
+ .p-checkbox-label {
7
+ color: var(--error-color);
8
+ }
9
+ }
10
+
11
+ .checkbox-error {
12
+ .p-checkbox-box.p-highlight {
13
+ background: var(--error-color);
14
+ }
15
+ }
@@ -0,0 +1,21 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+ import { CheckboxComponent } from './checkbox.component';
3
+
4
+ describe('CheckboxComponent', () => {
5
+ let component: CheckboxComponent;
6
+ let fixture: ComponentFixture<CheckboxComponent>;
7
+
8
+ beforeEach(async () => {
9
+ await TestBed.configureTestingModule({
10
+ imports: [CheckboxComponent],
11
+ }).compileComponents();
12
+
13
+ fixture = TestBed.createComponent(CheckboxComponent);
14
+ component = fixture.componentInstance;
15
+ fixture.detectChanges();
16
+ });
17
+
18
+ it('should create', () => {
19
+ expect(component).toBeTruthy();
20
+ });
21
+ });