@tuki-io/tuki-widgets 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (117) hide show
  1. package/.editorconfig +16 -0
  2. package/.vscode/extensions.json +4 -0
  3. package/.vscode/launch.json +20 -0
  4. package/.vscode/tasks.json +42 -0
  5. package/README.md +27 -0
  6. package/angular.json +41 -0
  7. package/package.json +42 -0
  8. package/projects/tuki/widgets/README.md +24 -0
  9. package/projects/tuki/widgets/karma.conf.js +44 -0
  10. package/projects/tuki/widgets/ng-package.json +7 -0
  11. package/projects/tuki/widgets/package.json +13 -0
  12. package/projects/tuki/widgets/src/lib/widgets.component.spec.ts +23 -0
  13. package/projects/tuki/widgets/src/lib/widgets.component.ts +20 -0
  14. package/projects/tuki/widgets/src/lib/widgets.module.ts +16 -0
  15. package/projects/tuki/widgets/src/lib/widgets.service.spec.ts +16 -0
  16. package/projects/tuki/widgets/src/lib/widgets.service.ts +9 -0
  17. package/projects/tuki/widgets/src/public-api.ts +7 -0
  18. package/projects/tuki/widgets/src/test.ts +27 -0
  19. package/projects/tuki/widgets/styles/_variables.scss +90 -0
  20. package/projects/tuki/widgets/styles/form.scss +231 -0
  21. package/projects/tuki/widgets/styles/icons.scss +32 -0
  22. package/projects/tuki/widgets/styles/styles.scss +110 -0
  23. package/projects/tuki/widgets/styles/tables.scss +30 -0
  24. package/projects/tuki/widgets/tsconfig.lib.json +36 -0
  25. package/projects/tuki/widgets/tsconfig.lib.prod.json +10 -0
  26. package/projects/tuki/widgets/tsconfig.spec.json +17 -0
  27. package/projects/tuki/widgets/user-manage/ng-package.json +7 -0
  28. package/projects/tuki/widgets/user-manage/public-api.ts +6 -0
  29. package/projects/tuki/widgets/user-manage/src/app.constants.ts +38 -0
  30. package/projects/tuki/widgets/user-manage/src/classes/device.ts +225 -0
  31. package/projects/tuki/widgets/user-manage/src/classes/line.ts +117 -0
  32. package/projects/tuki/widgets/user-manage/src/classes/notification.ts +39 -0
  33. package/projects/tuki/widgets/user-manage/src/classes/pagination.ts +18 -0
  34. package/projects/tuki/widgets/user-manage/src/classes/simplified-user.ts +128 -0
  35. package/projects/tuki/widgets/user-manage/src/classes/table-data.ts +6 -0
  36. package/projects/tuki/widgets/user-manage/src/classes/user-interface.ts +225 -0
  37. package/projects/tuki/widgets/user-manage/src/classes/user-list.ts +40 -0
  38. package/projects/tuki/widgets/user-manage/src/classes/user.ts +8 -0
  39. package/projects/tuki/widgets/user-manage/src/common-functions.ts +16 -0
  40. package/projects/tuki/widgets/user-manage/src/environments/environment.prod.ts +9 -0
  41. package/projects/tuki/widgets/user-manage/src/environments/environment.ts +10 -0
  42. package/projects/tuki/widgets/user-manage/src/interseptors/auth.interceptor.ts +36 -0
  43. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.html +50 -0
  44. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.scss +3 -0
  45. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.ts +81 -0
  46. package/projects/tuki/widgets/user-manage/src/material.module.ts +85 -0
  47. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.html +33 -0
  48. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.scss +84 -0
  49. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.ts +46 -0
  50. package/projects/tuki/widgets/user-manage/src/removeKynFromIBM.service.ts +25 -0
  51. package/projects/tuki/widgets/user-manage/src/services/api.service.ts +89 -0
  52. package/projects/tuki/widgets/user-manage/src/services/notification.service.ts +68 -0
  53. package/projects/tuki/widgets/user-manage/src/services/removeKynFromIBM.service.ts +25 -0
  54. package/projects/tuki/widgets/user-manage/src/services/site-settings.service.ts +35 -0
  55. package/projects/tuki/widgets/user-manage/src/services/user.service.ts +120 -0
  56. package/projects/tuki/widgets/user-manage/src/services/users-search.service.ts +58 -0
  57. package/projects/tuki/widgets/user-manage/src/services/utils.service.ts +71 -0
  58. package/projects/tuki/widgets/user-manage/src/styles/_variables.scss +90 -0
  59. package/projects/tuki/widgets/user-manage/src/styles/form.scss +231 -0
  60. package/projects/tuki/widgets/user-manage/src/styles/icons.scss +32 -0
  61. package/projects/tuki/widgets/user-manage/src/styles/styles.scss +110 -0
  62. package/projects/tuki/widgets/user-manage/src/styles/tables.scss +30 -0
  63. package/projects/tuki/widgets/user-manage/src/user-details/notification.service.ts +68 -0
  64. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.html +32 -0
  65. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.scss +53 -0
  66. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.ts +19 -0
  67. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.html +291 -0
  68. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.scss +461 -0
  69. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.ts +163 -0
  70. package/projects/tuki/widgets/user-manage/src/user-manage.module.ts +53 -0
  71. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.component.html +6 -0
  72. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.component.scss +11 -0
  73. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.ts +13 -0
  74. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.html +26 -0
  75. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.scss +41 -0
  76. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.ts +41 -0
  77. package/projects/tuki/widgets/users-list/ng-package.json +6 -0
  78. package/projects/tuki/widgets/users-list/public-api.ts +8 -0
  79. package/projects/tuki/widgets/users-list/src/app.constants.ts +35 -0
  80. package/projects/tuki/widgets/users-list/src/classes/device.ts +225 -0
  81. package/projects/tuki/widgets/users-list/src/classes/line.ts +117 -0
  82. package/projects/tuki/widgets/users-list/src/classes/notification.ts +38 -0
  83. package/projects/tuki/widgets/users-list/src/classes/pagination.ts +18 -0
  84. package/projects/tuki/widgets/users-list/src/classes/simlified-user.ts +74 -0
  85. package/projects/tuki/widgets/users-list/src/classes/table-data.ts +6 -0
  86. package/projects/tuki/widgets/users-list/src/classes/user-interface.ts +225 -0
  87. package/projects/tuki/widgets/users-list/src/classes/user-list.ts +40 -0
  88. package/projects/tuki/widgets/users-list/src/classes/user.ts +8 -0
  89. package/projects/tuki/widgets/users-list/src/material.module.ts +84 -0
  90. package/projects/tuki/widgets/users-list/src/services/api.service.ts +87 -0
  91. package/projects/tuki/widgets/users-list/src/services/events-communication.service.ts +11 -0
  92. package/projects/tuki/widgets/users-list/src/services/notification.service.ts +68 -0
  93. package/projects/tuki/widgets/users-list/src/services/removeKynFromIBM.service.ts +25 -0
  94. package/projects/tuki/widgets/users-list/src/services/user.service.ts +117 -0
  95. package/projects/tuki/widgets/users-list/src/services/users-search.service.ts +58 -0
  96. package/projects/tuki/widgets/users-list/src/users-list.component.css +4 -0
  97. package/projects/tuki/widgets/users-list/src/users-list.component.css.map +1 -0
  98. package/projects/tuki/widgets/users-list/src/users-list.component.html +39 -0
  99. package/projects/tuki/widgets/users-list/src/users-list.component.scss +9 -0
  100. package/projects/tuki/widgets/users-list/src/users-list.component.ts +85 -0
  101. package/projects/tuki/widgets/users-list/src/users-list.module.ts +36 -0
  102. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.css +11 -0
  103. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.css.map +1 -0
  104. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.html +6 -0
  105. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.scss +11 -0
  106. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.ts +13 -0
  107. package/projects/tuki/widgets/users-list/src/utils/common-functions.ts +16 -0
  108. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.html +33 -0
  109. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.scss +84 -0
  110. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.ts +46 -0
  111. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.css +45 -0
  112. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.css.map +1 -0
  113. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.html +26 -0
  114. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.scss +41 -0
  115. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.ts +41 -0
  116. package/projects/tuki/widgets/users-list/src/utils/utils.service.ts +71 -0
  117. package/tsconfig.json +46 -0
@@ -0,0 +1,231 @@
1
+ @import "variables";
2
+
3
+ .mat-form-field {
4
+ padding: 0 0 5px 0;
5
+ width: 93%;
6
+ }
7
+ .mat-form-field.mat-form-field-disabled {
8
+ border-bottom: none;
9
+ }
10
+ .mat-error {
11
+ color: $error-color;
12
+ margin: 13px 0 0 0;
13
+ }
14
+ .select-box {
15
+ border-radius: 30px;
16
+ background: #F3F6F6;
17
+ border: 1px solid #E2E9EF;
18
+ height: 35px;
19
+ position: relative;
20
+
21
+ select {
22
+ border: none !important;
23
+ background: transparent;
24
+ height: 100%;
25
+ width: 92%;
26
+ margin: auto;
27
+ display: block;
28
+ }
29
+
30
+ }
31
+
32
+ option:focus, option:focus-visible {
33
+ border: none !important;
34
+ outline: none !important;
35
+ }
36
+ option {
37
+ height: 30px;
38
+ cursor: pointer;
39
+ color: $webex-pagination-txt;
40
+ }
41
+ option:hover {
42
+ background: $webex-pagination-hover-bg !important;
43
+ }
44
+ .mat-select {
45
+ height: 100%;
46
+ line-height: 35px;
47
+ }
48
+ .info-holder, .input-holder {
49
+ display: grid;
50
+ grid-template-columns: 30% 70%;
51
+ align-items: baseline;
52
+
53
+ &__name{
54
+ font-weight: 500;
55
+ font-size: 14px;
56
+ }
57
+ &__inputs{
58
+ & .input-holder{
59
+ display: grid;
60
+ grid-template-columns: 30% 70%;
61
+ align-items: baseline;
62
+ &__name{
63
+ font-weight: 400;
64
+ font-size: 14px;
65
+ }
66
+ }
67
+ }
68
+ }
69
+ .mat-form-field-wrapper {
70
+ height: 30px !important;
71
+ }
72
+ .mat-form-field-flex{
73
+ height: 30px !important;
74
+ }
75
+
76
+ .mat-form-field-appearance-outline .mat-form-field-outline{
77
+ height: 35px !important;
78
+ }
79
+
80
+ .mat-form-field-outline .mat-form-field-outline-thick{
81
+ height: 35px !important;
82
+ }
83
+
84
+ .mat-select{
85
+ line-height: 20px !important;
86
+ }
87
+ .mat-form-field-appearance-outline .mat-form-field-infix {
88
+ padding: 14px 12px 10px;
89
+ border-top: 0;
90
+ max-width: 300px;
91
+ }
92
+
93
+ .mat-tab-group{
94
+ font-family: "Inter", sans-serif;
95
+ }
96
+
97
+ .mat-tab-label{
98
+ font-weight: 500 !important;
99
+ font-size: 14px !important;
100
+ height: auto !important;
101
+ min-width: auto !important;
102
+ padding: 0 !important;
103
+ }
104
+
105
+ .mat-ink-bar{
106
+ background-color: rgba(0, 0, 0, 0.9) !important;
107
+ height: 3px !important;
108
+ }
109
+ .mat-form-field-wrapper{
110
+ padding-bottom: 0;
111
+ }
112
+
113
+ .mat-form-field{
114
+ padding: 0;
115
+ max-width: 300px;
116
+ }
117
+
118
+ .mat-divider{
119
+ margin: 12px 0;
120
+ }
121
+
122
+ /*
123
+
124
+ .input-holder {
125
+ background: #EDEDED;
126
+ padding: 32px 60px;
127
+ }
128
+
129
+ .form-hold {
130
+ padding: 24px 0;
131
+ display: flex;
132
+ flex-direction: column;
133
+ gap: 24px;
134
+ }
135
+
136
+ ::ng-deep .mat-form-field-appearance-outline .mat-form-field-infix {
137
+ padding: 14px 12px 10px;
138
+ border-top: 0;
139
+ max-width: 300px;
140
+ }
141
+
142
+ ::ng-deep .mat-tab-group{
143
+ font-family: "Inter", sans-serif;
144
+ }
145
+
146
+ ::ng-deep .mat-tab-label{
147
+ font-weight: 500 !important;
148
+ font-size: 14px !important;
149
+ height: auto !important;
150
+ min-width: auto !important;
151
+ padding: 0 !important;
152
+ }
153
+
154
+ ::ng-deep .mat-ink-bar{
155
+ background-color: rgba(0, 0, 0, 0.9) !important;
156
+ height: 3px !important;
157
+ }
158
+ .form-holder{
159
+ background: white;
160
+ display: grid;
161
+ grid-template-columns: 30% 70%;
162
+ border-radius: 8px;
163
+ border: rgba(0, 0, 0, 0.2) 1px solid;
164
+ padding: 24px;
165
+ &__name{
166
+ font-weight: 500;
167
+ font-size: 16px;
168
+ }
169
+ &__inputs{
170
+ & .input-holder{
171
+ display: grid;
172
+ grid-template-columns: 30% 70%;
173
+ align-items: baseline;
174
+ &__name{
175
+ font-weight: 400;
176
+ font-size: 14px;
177
+ }
178
+ }
179
+ }
180
+ }
181
+
182
+ ::ng-deep .mat-form-field-wrapper{
183
+ padding-bottom: 0;
184
+ }
185
+
186
+ ::ng-deep .mat-form-field{
187
+ padding: 0;
188
+ max-width: 300px;
189
+ }
190
+
191
+ .mat-divider{
192
+ margin: 12px 0;
193
+ }
194
+
195
+ .user-details-box {
196
+ background: white;
197
+ display: grid;
198
+ grid-template-columns: 30% 70%;
199
+ border-radius: 8px;
200
+ border: rgba(0, 0, 0, 0.2) 1px solid;
201
+ padding: 24px;
202
+ &__name{
203
+ font-weight: 500;
204
+ font-size: 16px;
205
+ }
206
+ &__inputs{
207
+ & .input-holder{
208
+ display: grid;
209
+ grid-template-columns: 30% 70%;
210
+ align-items: baseline;
211
+ &__name{
212
+ font-weight: 400;
213
+ font-size: 14px;
214
+ }
215
+ }
216
+ }
217
+ }
218
+
219
+ ::ng-deep .mat-form-field-wrapper{
220
+ padding-bottom: 0;
221
+ }
222
+
223
+ ::ng-deep .mat-form-field{
224
+ padding: 0;
225
+ max-width: 300px;
226
+ }
227
+
228
+ .mat-divider{
229
+ margin: 12px 0;
230
+ }
231
+ */
@@ -0,0 +1,32 @@
1
+ .fa:hover {
2
+ color: #0d56aa!important;
3
+ }
4
+ .mat-icon-button {
5
+ background: transparent;
6
+ }
7
+ .icon-webex-box {
8
+ width: 2rem;
9
+ height: 2rem;
10
+ font-size: .7rem;
11
+ line-height: 1rem;
12
+ display: inline-block;
13
+ background: $webex-icon-bg;
14
+ border-radius: 2rem;
15
+ line-height: 40px;
16
+ text-align: center;
17
+ }
18
+ .icon-webex {
19
+ filter: invert(12%) sepia(14%) saturate(4%) hue-rotate(354deg) brightness(103%) contrast(90%);
20
+ background-repeat: no-repeat;
21
+ background-position: center;
22
+ display: inline-block;
23
+ height: 1rem;
24
+ width: 1rem;
25
+ }
26
+ .icon-webex-user {
27
+ background-image: url('../assets/icons/icon_user.svg');
28
+ }
29
+ .icon-user-status {
30
+ display: inline-block;
31
+
32
+ }
@@ -0,0 +1,110 @@
1
+ @import '../../node_modules/font-awesome/scss/font-awesome';
2
+ @import 'variables';
3
+ @import 'icons';
4
+ @import 'form';
5
+ @import "tables";
6
+
7
+ *{
8
+ margin: 0;
9
+ }
10
+
11
+ body {
12
+ background: $webex-body-bg;
13
+ }
14
+ body, th, td {
15
+ font-family: $main-font;
16
+ font-size: 14px;
17
+ }
18
+ th {
19
+ color: rgba(0,0,0,.54);
20
+ text-align: left;
21
+ }
22
+ td {
23
+ box-sizing: border-box;
24
+ padding: 10px 5px 10px 0;
25
+ }
26
+ .content-box {
27
+ margin: auto;
28
+ position: relative;
29
+ width: 70%;
30
+
31
+ table {
32
+ width: 100%
33
+ }
34
+ }
35
+ .edit-icon-td {
36
+ width: 50px;
37
+ position: relative;
38
+
39
+ button {
40
+ position: absolute;
41
+ top: 4px;
42
+ }
43
+ }
44
+ .mat-progress-spinner circle, .mat-spinner circle {
45
+ stroke: #009fdb!important;
46
+ }
47
+ .data-loader {
48
+ position: absolute;
49
+ top: calc(50% - 25px);
50
+ left: calc(50% - 25px);
51
+ }
52
+ .flex-box {
53
+ display: flex;
54
+ justify-content: flex-start;
55
+ }
56
+ .mat-paginator {
57
+ background: transparent !important;
58
+ }
59
+ .mat-paginator-container {
60
+ min-height: 30px !important;
61
+ }
62
+ .mat-paginator-range-label {
63
+ margin: 0 10px 0 24px !important;
64
+ font-size: 15px !important;
65
+ }
66
+ .user-info-box {
67
+ background: white;
68
+ display: grid;
69
+ grid-template-columns: 30% 70%;
70
+ border-radius: 8px;
71
+ border: rgba(0, 0, 0, 0.2) 1px solid;
72
+ padding: 24px;
73
+ font-weight: 400;
74
+ font-size: 14px;
75
+
76
+ h3 {
77
+ display: block;
78
+ font-weight: 500;
79
+ font-size: 16px;
80
+ }
81
+ }
82
+ .mat-divider{
83
+ margin: 12px 0 !important;
84
+ }
85
+ .info-boxes-container {
86
+ padding: 24px 0;
87
+ display: flex;
88
+ flex-direction: column;
89
+ gap: 24px;
90
+ }
91
+ .header-box {
92
+ height: 60px;
93
+ width: 100%;
94
+ line-height: 60px;
95
+ background: white;
96
+ border-bottom: 1px solid #dedddd;
97
+
98
+ .header-back-block {
99
+ float: left;
100
+ }
101
+ .header-button-block {
102
+ float: right;
103
+ }
104
+ }
105
+ @media screen and (max-width: 1600px) {
106
+ .content-box {
107
+ width: 95%;
108
+ }
109
+ }
110
+
@@ -0,0 +1,30 @@
1
+ @import 'variables';
2
+
3
+ .webex-table {
4
+ width: 100%;
5
+ margin: auto;
6
+
7
+ tr {
8
+ border-bottom: 1px solid $webex-tr-border;
9
+ }
10
+ th {
11
+ background: $webex-table-th-bg;
12
+ color: $webex-table-th-txt;
13
+ font-size: $webex-table-th-size;
14
+ }
15
+ td {
16
+ background: $webex-table-td-bg;
17
+ color: $webex-table-td-txt;
18
+ font-size: $webex-table-td-size;
19
+ }
20
+ tr:hover td {
21
+ background: $webex-tr-hover-bg;
22
+ cursor: pointer;
23
+ }
24
+ th.mat-header-cell, td.mat-cell, td.mat-footer-cell {
25
+ border-bottom: 1px solid $webex-tr-border;
26
+ }
27
+ tr.mat-header-row {
28
+ height: 37px;
29
+ }
30
+ }
@@ -0,0 +1,68 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { Notification } from './classes/notification';
3
+ import { Subject } from 'rxjs';
4
+ const SUCCESS_TIME = 5000;
5
+ const INACTIVE_SESSION_MESSAGE = 'Your session was lost due to inactivity. Please login again';
6
+ const INACTIVE_SESSION = 'SESSION_INACTIVE';
7
+
8
+ @Injectable()
9
+ export class NotificationService {
10
+
11
+ public listChange = new Subject();
12
+
13
+ private max = 0;
14
+ private list: Notification[] = [];
15
+
16
+ constructor(
17
+ ) {
18
+ }
19
+
20
+ error(message: string, ttl?: number): void {
21
+ this.notify('error', message, ttl);
22
+ }
23
+
24
+ success(message: string, ttl?: number): void {
25
+ this.notify('success', message, (!ttl) ? SUCCESS_TIME : ttl);
26
+ }
27
+
28
+ warning(message: string, ttl?: number): void {
29
+ this.notify('warning', message, ttl);
30
+ }
31
+
32
+ info(message: string, ttl?: number): void {
33
+ this.notify('info', message, ttl);
34
+ }
35
+ private notify(type: string, message: string, ttl?: number): void {
36
+ const found = this.list.find((n: Notification) => n.message === message);
37
+ if (found) {
38
+ this.remove(found);
39
+ }
40
+ const notification = new Notification({
41
+ id: ++this.max,
42
+ type, message, ttl
43
+ });
44
+ if (notification.ttl > 0) {
45
+ notification.timerId = setTimeout(() => this.remove(notification, true), notification.ttl);
46
+ }
47
+ this.list.push(notification);
48
+ this.listChange.next(this.list);
49
+ }
50
+
51
+ remove(notification: Notification, auto?: boolean): void {
52
+ if (!auto && notification.timerId) {
53
+ // clear timeout in case of manual remove
54
+ clearInterval(notification.timerId);
55
+ }
56
+ this.list = this.list.filter(n => n.id !== notification.id);
57
+ this.listChange.next(this.list);
58
+ }
59
+
60
+ private removeInactiveSessionError(): void {
61
+ if (!this.list || !this.list.length) {
62
+ return;
63
+ }
64
+ this.list = this.list.filter(n => n.message !== INACTIVE_SESSION_MESSAGE && n.message !== INACTIVE_SESSION);
65
+ this.listChange.next(this.list);
66
+ }
67
+
68
+ }
@@ -0,0 +1,32 @@
1
+ <div class="info-holder">
2
+ <div class="content-box flex-box">
3
+ <div class="info-holder__user-image">
4
+ <img src="../../../assets/a24749b225874bb3e3a4cb5d2f42e82c.png" alt="" class="avatar">
5
+ </div>
6
+ <div class="info-holder__user-information">
7
+ <div class="info-holder__user-name">{{name}}</div>
8
+ <div class="info-holder__user-breadcrumbs">
9
+ <div class="is-active" *ngIf="false; else notActive">
10
+ <svg width="8" height="9" viewBox="0 0 8 9" fill="none" xmlns="http://www.w3.org/2000/svg">
11
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M4 8.5C6.20914 8.5 8 6.70914 8 4.5C8 2.29086 6.20914 0.5 4 0.5C1.79086 0.5 0 2.29086 0 4.5C0 6.70914 1.79086 8.5 4 8.5Z" fill="#1D805F"/>
12
+ </svg>
13
+ <div>Active</div>
14
+ </div>
15
+ <div class="icon-separator"></div>
16
+ <div class="email">{{email}}</div>
17
+ <div class="icon-separator"></div>
18
+ <div class="position">{{position}}</div>
19
+ </div>
20
+ </div>
21
+ </div>
22
+
23
+ </div>
24
+
25
+ <ng-template #notActive>
26
+ <div class="is-active">
27
+ <svg width="8" height="9" viewBox="0 0 8 9" fill="none" xmlns="http://www.w3.org/2000/svg">
28
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M4 8.5C6.20914 8.5 8 6.70914 8 4.5C8 2.29086 6.20914 0.5 4 0.5C1.79086 0.5 0 2.29086 0 4.5C0 6.70914 1.79086 8.5 4 8.5Z" fill="grey"/>
29
+ </svg>
30
+ <div>Not active</div>
31
+ </div>
32
+ </ng-template>
@@ -0,0 +1,53 @@
1
+ .info-holder {
2
+ display: flex;
3
+ gap: 16px;
4
+ align-items: center;
5
+ font-family: "Inter", sans-serif;
6
+ height: 102px;
7
+ width: 100%;
8
+ background: white;
9
+ margin: 0 0 30px 0;
10
+
11
+ &__user-image {
12
+ img {
13
+ width: 40px;
14
+ border-radius: 120px;
15
+ margin: 20px 0 0 0;
16
+ }
17
+ }
18
+
19
+ &__user-information {
20
+ padding: 10px;
21
+ margin: 10px;
22
+ gap: 10px;
23
+ display: flex;
24
+ flex-direction: column;
25
+ }
26
+
27
+ &__user-name {
28
+ font-size: 20px;
29
+ font-weight: 500;
30
+ }
31
+
32
+ &__user-breadcrumbs {
33
+ display: flex;
34
+ gap: 8px;
35
+ font-weight: 400;
36
+ font-size: 14px;
37
+ color: rgba(0, 0, 0, 0.7);
38
+ align-items: center;
39
+ }
40
+
41
+ .icon-separator {
42
+ height: 5px;
43
+ width: 5px;
44
+ background-color: rgba(0, 0, 0, 0.7);
45
+ border-radius: 50%;
46
+ }
47
+
48
+ .is-active {
49
+ display: flex;
50
+ gap: 8px;
51
+ align-items: center;
52
+ }
53
+ }
@@ -0,0 +1,19 @@
1
+ import { Component, Input } from '@angular/core';
2
+
3
+ @Component({
4
+ selector: 'app-user-info',
5
+ templateUrl: './user-info.component.html',
6
+ styleUrls: ['./user-info.component.scss']
7
+ })
8
+ export class UserInfoComponent {
9
+ @Input()
10
+ name!: string;
11
+ @Input()
12
+ active!: boolean;
13
+ @Input()
14
+ email!: string;
15
+ @Input()
16
+ position!: string;
17
+
18
+
19
+ }