From c8f61f58cf57394d5a234b0817de97e1393ce44f Mon Sep 17 00:00:00 2001 From: Sercan Yemen <117369+srcn@users.noreply.github.com> Date: Mon, 3 Jun 2024 10:00:17 +0300 Subject: [PATCH] Second pass on the new control flow syntax migration --- .../common/languages/languages.component.html | 4 +- .../common/languages/languages.component.ts | 4 +- .../common/messages/messages.component.html | 46 +- .../common/messages/messages.component.ts | 10 +- .../notifications.component.html | 53 +- .../notifications/notifications.component.ts | 10 +- .../quick-chat/quick-chat.component.html | 149 +- .../common/quick-chat/quick-chat.component.ts | 11 +- .../common/search/search.component.html | 255 +-- .../layout/common/search/search.component.ts | 4 +- .../common/settings/settings.component.html | 4 +- .../common/settings/settings.component.ts | 3 +- .../common/shortcuts/shortcuts.component.html | 154 +- .../common/shortcuts/shortcuts.component.ts | 4 +- .../layout/common/user/user.component.html | 15 +- src/app/layout/common/user/user.component.ts | 3 +- src/app/layout/layout.component.html | 44 +- src/app/layout/layout.component.ts | 3 +- .../layout/layouts/empty/empty.component.html | 4 +- .../layout/layouts/empty/empty.component.ts | 3 +- .../centered/centered.component.html | 16 +- .../horizontal/centered/centered.component.ts | 2 - .../enterprise/enterprise.component.html | 20 +- .../enterprise/enterprise.component.ts | 2 - .../material/material.component.html | 20 +- .../horizontal/material/material.component.ts | 2 - .../horizontal/modern/modern.component.html | 16 +- .../horizontal/modern/modern.component.ts | 2 - .../vertical/classic/classic.component.html | 4 +- .../vertical/classic/classic.component.ts | 2 - .../vertical/classy/classy.component.html | 28 +- .../vertical/classy/classy.component.ts | 2 - .../vertical/compact/compact.component.html | 4 +- .../vertical/compact/compact.component.ts | 2 - .../vertical/dense/dense.component.html | 4 +- .../layouts/vertical/dense/dense.component.ts | 2 - .../futuristic/futuristic.component.html | 4 +- .../futuristic/futuristic.component.ts | 2 - .../layouts/vertical/thin/thin.component.html | 4 +- .../layouts/vertical/thin/thin.component.ts | 2 - src/app/mock-api/apps/chat/data.ts | 10 +- .../academy/details/details.component.html | 60 +- .../apps/academy/details/details.component.ts | 4 +- .../apps/academy/list/list.component.html | 163 +- .../admin/apps/academy/list/list.component.ts | 10 +- .../apps/chat/chats/chats.component.html | 93 +- .../admin/apps/chat/chats/chats.component.ts | 4 +- .../contact-info/contact-info.component.html | 38 +- .../contact-info/contact-info.component.ts | 3 +- .../conversation/conversation.component.html | 104 +- .../conversation/conversation.component.ts | 10 +- .../chat/new-chat/new-chat.component.html | 52 +- .../apps/chat/new-chat/new-chat.component.ts | 3 +- .../apps/chat/profile/profile.component.html | 8 +- .../apps/chat/profile/profile.component.ts | 2 - .../contacts/details/details.component.html | 396 ++-- .../contacts/details/details.component.ts | 4 +- .../apps/contacts/list/list.component.html | 65 +- .../apps/contacts/list/list.component.ts | 11 +- .../inventory/list/inventory.component.html | 465 ++--- .../inventory/list/inventory.component.ts | 4 - .../details/details.component.html | 20 +- .../file-manager/details/details.component.ts | 3 +- .../file-manager/list/list.component.html | 107 +- .../apps/file-manager/list/list.component.ts | 3 - .../apps/help-center/faqs/faqs.component.html | 18 +- .../apps/help-center/faqs/faqs.component.ts | 9 +- .../guides/category/category.component.html | 12 +- .../guides/category/category.component.ts | 3 +- .../help-center/guides/guides.component.html | 57 +- .../help-center/guides/guides.component.ts | 3 +- .../help-center/help-center.component.html | 6 +- .../apps/help-center/help-center.component.ts | 2 - .../support/support.component.html | 63 +- .../help-center/support/support.component.ts | 3 +- .../mailbox/compose/compose.component.html | 50 +- .../apps/mailbox/compose/compose.component.ts | 2 - .../mailbox/details/details.component.html | 230 +- .../apps/mailbox/details/details.component.ts | 4 - .../apps/mailbox/list/list.component.html | 108 +- .../admin/apps/mailbox/list/list.component.ts | 4 +- .../mailbox/settings/settings.component.html | 38 +- .../mailbox/settings/settings.component.ts | 4 +- .../apps/notes/details/details.component.html | 49 +- .../apps/notes/details/details.component.ts | 4 +- .../apps/notes/labels/labels.component.html | 8 +- .../apps/notes/labels/labels.component.ts | 4 +- .../admin/apps/notes/list/list.component.html | 167 +- .../admin/apps/notes/list/list.component.ts | 4 +- .../scrumboard/board/board.component.html | 49 +- .../apps/scrumboard/board/board.component.ts | 4 +- .../scrumboard/boards/boards.component.html | 26 +- .../scrumboard/boards/boards.component.ts | 4 +- .../card/details/details.component.html | 21 +- .../card/details/details.component.ts | 4 +- .../apps/tasks/details/details.component.html | 163 +- .../apps/tasks/details/details.component.ts | 4 +- .../admin/apps/tasks/list/list.component.html | 163 +- .../admin/apps/tasks/list/list.component.ts | 11 +- .../analytics/analytics.component.html | 52 +- .../analytics/analytics.component.ts | 3 +- .../dashboards/crypto/crypto.component.html | 389 ++-- .../dashboards/crypto/crypto.component.ts | 4 - .../dashboards/finance/finance.component.html | 2 +- .../dashboards/project/project.component.html | 111 +- .../dashboards/project/project.component.ts | 4 +- .../admin/docs/changelog/changelog.html | 52 +- .../modules/admin/docs/changelog/changelog.ts | 4 +- .../directory-structure.html | 10 +- .../directory-structure.ts | 3 +- .../activities/activities.component.html | 120 +- .../pages/activities/activities.component.ts | 18 +- .../classic/forgot-password.component.html | 60 +- .../classic/forgot-password.component.ts | 2 - .../forgot-password.component.html | 60 +- .../forgot-password.component.ts | 2 - .../fullscreen/forgot-password.component.html | 60 +- .../fullscreen/forgot-password.component.ts | 2 - .../forgot-password.component.html | 68 +- .../forgot-password.component.ts | 2 - .../modern/forgot-password.component.html | 68 +- .../modern/forgot-password.component.ts | 2 - .../forgot-password.component.html | 60 +- .../forgot-password.component.ts | 2 - .../forgot-password.component.html | 60 +- .../split-screen/forgot-password.component.ts | 2 - .../classic/reset-password.component.html | 116 +- .../classic/reset-password.component.ts | 2 - .../reset-password.component.html | 116 +- .../reset-password.component.ts | 2 - .../fullscreen/reset-password.component.html | 116 +- .../fullscreen/reset-password.component.ts | 2 - .../reset-password.component.html | 116 +- .../reset-password.component.ts | 2 - .../modern/reset-password.component.html | 116 +- .../modern/reset-password.component.ts | 2 - .../reset-password.component.html | 116 +- .../reset-password.component.ts | 2 - .../reset-password.component.html | 116 +- .../split-screen/reset-password.component.ts | 2 - .../sign-in/classic/sign-in.component.html | 76 +- .../sign-in/classic/sign-in.component.ts | 2 - .../sign-in.component.html | 76 +- .../fullscreen-reversed/sign-in.component.ts | 2 - .../sign-in/fullscreen/sign-in.component.html | 76 +- .../sign-in/fullscreen/sign-in.component.ts | 2 - .../modern-reversed/sign-in.component.html | 76 +- .../modern-reversed/sign-in.component.ts | 2 - .../sign-in/modern/sign-in.component.html | 76 +- .../sign-in/modern/sign-in.component.ts | 2 - .../sign-in.component.html | 76 +- .../sign-in.component.ts | 2 - .../split-screen/sign-in.component.html | 76 +- .../sign-in/split-screen/sign-in.component.ts | 2 - .../sign-out/classic/sign-out.component.html | 8 +- .../sign-out/classic/sign-out.component.ts | 4 +- .../sign-out.component.html | 8 +- .../fullscreen-reversed/sign-out.component.ts | 4 +- .../fullscreen/sign-out.component.html | 8 +- .../sign-out/fullscreen/sign-out.component.ts | 4 +- .../modern-reversed/sign-out.component.html | 8 +- .../modern-reversed/sign-out.component.ts | 4 +- .../sign-out/modern/sign-out.component.html | 8 +- .../sign-out/modern/sign-out.component.ts | 4 +- .../sign-out.component.html | 8 +- .../sign-out.component.ts | 4 +- .../split-screen/sign-out.component.html | 8 +- .../split-screen/sign-out.component.ts | 4 +- .../sign-up/classic/sign-up.component.html | 86 +- .../sign-up/classic/sign-up.component.ts | 2 - .../sign-up.component.html | 86 +- .../fullscreen-reversed/sign-up.component.ts | 2 - .../sign-up/fullscreen/sign-up.component.html | 86 +- .../sign-up/fullscreen/sign-up.component.ts | 2 - .../modern-reversed/sign-up.component.html | 86 +- .../modern-reversed/sign-up.component.ts | 2 - .../sign-up/modern/sign-up.component.html | 86 +- .../sign-up/modern/sign-up.component.ts | 2 - .../sign-up.component.html | 86 +- .../sign-up.component.ts | 2 - .../split-screen/sign-up.component.html | 86 +- .../sign-up/split-screen/sign-up.component.ts | 2 - .../classic/unlock-session.component.html | 60 +- .../classic/unlock-session.component.ts | 2 - .../unlock-session.component.html | 60 +- .../unlock-session.component.ts | 2 - .../fullscreen/unlock-session.component.html | 60 +- .../fullscreen/unlock-session.component.ts | 2 - .../unlock-session.component.html | 60 +- .../unlock-session.component.ts | 2 - .../modern/unlock-session.component.html | 60 +- .../modern/unlock-session.component.ts | 2 - .../unlock-session.component.html | 60 +- .../unlock-session.component.ts | 2 - .../unlock-session.component.html | 60 +- .../split-screen/unlock-session.component.ts | 2 - .../classic/coming-soon.component.html | 56 +- .../classic/coming-soon.component.ts | 2 - .../coming-soon.component.html | 56 +- .../coming-soon.component.ts | 2 - .../fullscreen/coming-soon.component.html | 56 +- .../fullscreen/coming-soon.component.ts | 2 - .../coming-soon.component.html | 60 +- .../modern-reversed/coming-soon.component.ts | 2 - .../modern/coming-soon.component.html | 60 +- .../modern/coming-soon.component.ts | 2 - .../coming-soon.component.html | 56 +- .../coming-soon.component.ts | 2 - .../split-screen/coming-soon.component.html | 56 +- .../split-screen/coming-soon.component.ts | 2 - .../pricing/modern/modern.component.html | 64 +- .../pages/pricing/modern/modern.component.ts | 4 +- .../pricing/simple/simple.component.html | 64 +- .../pages/pricing/simple/simple.component.ts | 4 +- .../pages/pricing/table/table.component.html | 64 +- .../pages/pricing/table/table.component.ts | 4 +- .../pages/profile/profile.component.html | 2 +- .../plan-billing/plan-billing.component.html | 14 +- .../plan-billing/plan-billing.component.ts | 4 +- .../pages/settings/settings.component.html | 34 +- .../pages/settings/settings.component.ts | 5 +- .../pages/settings/team/team.component.html | 16 +- .../pages/settings/team/team.component.ts | 4 +- .../ui/animations/animations.component.html | 1856 +++++++++-------- .../ui/animations/animations.component.ts | 2 - .../admin/ui/cards/cards.component.html | 8 +- .../modules/admin/ui/cards/cards.component.ts | 3 +- .../confirmation-dialog.component.html | 48 +- .../confirmation-dialog.component.ts | 3 +- .../components/card/card.component.html | 30 +- .../components/card/card.component.ts | 2 - .../components/masonry/masonry.component.html | 40 +- .../components/masonry/masonry.component.ts | 2 - .../admin/ui/icons/icons.component.html | 16 +- .../modules/admin/ui/icons/icons.component.ts | 4 +- .../material-components.component.html | 4 +- .../material-components.component.ts | 3 +- .../layout-overview.component.ts | 85 +- .../forgot-password.component.html | 60 +- .../forgot-password.component.ts | 2 - .../reset-password.component.html | 116 +- .../reset-password.component.ts | 2 - .../auth/sign-in/sign-in.component.html | 76 +- .../modules/auth/sign-in/sign-in.component.ts | 2 - .../auth/sign-out/sign-out.component.html | 8 +- .../auth/sign-out/sign-out.component.ts | 4 +- .../auth/sign-up/sign-up.component.html | 86 +- .../modules/auth/sign-up/sign-up.component.ts | 2 - .../unlock-session.component.html | 60 +- .../unlock-session.component.ts | 2 - 250 files changed, 5294 insertions(+), 5523 deletions(-) diff --git a/src/app/layout/common/languages/languages.component.html b/src/app/layout/common/languages/languages.component.html index 4c1982e1..760d0354 100644 --- a/src/app/layout/common/languages/languages.component.html +++ b/src/app/layout/common/languages/languages.component.html @@ -7,7 +7,7 @@ - + @for (lang of availableLangs; track trackByFn($index, lang)) { - + } diff --git a/src/app/layout/common/languages/languages.component.ts b/src/app/layout/common/languages/languages.component.ts index 0f74ce68..5ca8959e 100644 --- a/src/app/layout/common/languages/languages.component.ts +++ b/src/app/layout/common/languages/languages.component.ts @@ -1,4 +1,4 @@ -import { NgFor, NgTemplateOutlet } from '@angular/common'; +import { NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -23,7 +23,7 @@ import { take } from 'rxjs'; changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'languages', standalone: true, - imports: [MatButtonModule, MatMenuModule, NgTemplateOutlet, NgFor], + imports: [MatButtonModule, MatMenuModule, NgTemplateOutlet], }) export class LanguagesComponent implements OnInit, OnDestroy { availableLangs: AvailableLangs; diff --git a/src/app/layout/common/messages/messages.component.html b/src/app/layout/common/messages/messages.component.html index e2cc13dc..87598ad0 100644 --- a/src/app/layout/common/messages/messages.component.html +++ b/src/app/layout/common/messages/messages.component.html @@ -1,6 +1,6 @@ @@ -53,15 +53,15 @@ class="bg-card relative flex flex-auto flex-col divide-y overflow-y-auto sm:max-h-120" > - + @for (message of messages; track trackByFn($index, message)) {
- + @if (message.link) { - + @if (!message.useRouter) { - + } - + @if (message.useRouter) { - - + } + } - + @if (!message.link) {
-
+ }
@@ -109,7 +109,7 @@ [ngClass]="{ 'bg-gray-400 dark:bg-gray-500 sm:opacity-0 sm:group-hover:opacity-100': message.read, - 'bg-primary': !message.read + 'bg-primary': !message.read, }" > @@ -131,7 +131,7 @@ - + @if (message.icon && !message.image) {
@@ -141,38 +141,38 @@ >
-
+ } - + @if (message.image) { - + }
- + @if (message.title) {
-
- + } + @if (message.description) {
-
+ }
{{ message.time | date: 'MMM dd, h:mm a' }}
- + } - + @if (!messages || !messages.length) {
@@ -193,7 +193,7 @@ When you have messages, they will appear here.
- + }
diff --git a/src/app/layout/common/messages/messages.component.ts b/src/app/layout/common/messages/messages.component.ts index 4e2c8a43..c003dafa 100644 --- a/src/app/layout/common/messages/messages.component.ts +++ b/src/app/layout/common/messages/messages.component.ts @@ -1,12 +1,6 @@ import { Overlay, OverlayRef } from '@angular/cdk/overlay'; import { TemplatePortal } from '@angular/cdk/portal'; -import { - DatePipe, - NgClass, - NgFor, - NgIf, - NgTemplateOutlet, -} from '@angular/common'; +import { DatePipe, NgClass, NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -35,10 +29,8 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ MatButtonModule, - NgIf, MatIconModule, MatTooltipModule, - NgFor, NgClass, NgTemplateOutlet, RouterLink, diff --git a/src/app/layout/common/notifications/notifications.component.html b/src/app/layout/common/notifications/notifications.component.html index 94a72a94..5dc96587 100644 --- a/src/app/layout/common/notifications/notifications.component.html +++ b/src/app/layout/common/notifications/notifications.component.html @@ -1,6 +1,6 @@ @@ -53,17 +53,18 @@ class="bg-card relative flex flex-auto flex-col divide-y overflow-y-auto sm:max-h-120" > - + @for ( + notification of notifications; + track trackByFn($index, notification) + ) {
- + @if (notification.link) { - + @if (!notification.useRouter) { - + } - + @if (notification.useRouter) { - - + } + } - + @if (!notification.link) {
-
+ }
@@ -113,7 +114,7 @@ [ngClass]="{ 'bg-gray-400 dark:bg-gray-500 sm:opacity-0 sm:group-hover:opacity-100': notification.read, - 'bg-primary': !notification.read + 'bg-primary': !notification.read, }" > @@ -135,9 +136,7 @@ - + @if (notification.icon && !notification.image) {
@@ -147,38 +146,38 @@ >
-
+ } - + @if (notification.image) { - + }
- + @if (notification.title) {
-
- + } + @if (notification.description) {
-
+ }
{{ notification.time | date: 'MMM dd, h:mm a' }}
- + } - + @if (!notifications || !notifications.length) {
@@ -199,7 +198,7 @@ When you have notifications, they will appear here.
- + }
diff --git a/src/app/layout/common/notifications/notifications.component.ts b/src/app/layout/common/notifications/notifications.component.ts index 9d42d120..a6cc2dec 100644 --- a/src/app/layout/common/notifications/notifications.component.ts +++ b/src/app/layout/common/notifications/notifications.component.ts @@ -1,12 +1,6 @@ import { Overlay, OverlayRef } from '@angular/cdk/overlay'; import { TemplatePortal } from '@angular/cdk/portal'; -import { - DatePipe, - NgClass, - NgFor, - NgIf, - NgTemplateOutlet, -} from '@angular/common'; +import { DatePipe, NgClass, NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -35,10 +29,8 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ MatButtonModule, - NgIf, MatIconModule, MatTooltipModule, - NgFor, NgClass, NgTemplateOutlet, RouterLink, diff --git a/src/app/layout/common/quick-chat/quick-chat.component.html b/src/app/layout/common/quick-chat/quick-chat.component.html index 0aad3db8..faedb1e5 100644 --- a/src/app/layout/common/quick-chat/quick-chat.component.html +++ b/src/app/layout/common/quick-chat/quick-chat.component.html @@ -6,7 +6,7 @@ [ngClass]="{ '-translate-x-full shadow sm:-translate-x-96 lg:-translate-x-80': opened, - 'translate-x-0': !opened + 'translate-x-0': !opened, }" > @@ -15,7 +15,7 @@ (click)="toggle()" > - + @if (!opened || (opened && !selectedChat)) {
- + } - + @if (opened && selectedChat) {
- + @if (chat.contact.avatar) { Contact avatar - - + } + @if (!chat.contact.avatar) {
{{ chat.contact.name.charAt(0) }}
-
+ }
{{ chat.contact.name }} @@ -66,7 +66,7 @@ >
- + }
@@ -78,9 +78,7 @@ [fuseScrollbarOptions]="{ wheelPropagation: false }" >
- + @for (chat of chats; track trackByFn($index, chat)) {
- + @if (chat.unreadCount > 0) {
-
- + } + @if (chat.contact.avatar) { Contact avatar - - + } + @if (!chat.contact.avatar) {
{{ chat.contact.name.charAt(0) }}
-
+ }
-
+ }
@@ -128,29 +126,25 @@
- + @if (chat) {
- + @for ( + message of chat.messages; + track trackByFn(i, message); + let i = $index; + let first = $first; + let last = $last + ) { - + @if ( + first || + (chat.messages[i - 1].createdAt + | date: 'd') !== + (message.createdAt | date: 'd') + ) {
@@ -165,7 +159,7 @@
- + }
@@ -188,24 +182,22 @@ 'bg-blue-500 text-blue-50': message.isMine, 'bg-gray-500 text-gray-50': - !message.isMine + !message.isMine, }" > - + @if ( + last || + chat.messages[i + 1].isMine !== + message.isMine + ) {
-
+ }
- + @if ( + first || + last || + chat.messages[i + 1].isMine !== + message.isMine || + chat.messages[i + 1].createdAt !== + message.createdAt + ) {
{{ @@ -244,9 +234,9 @@ | date: 'HH:mm' }}
-
+ }
-
+ }
@@ -274,28 +264,29 @@ -
+ } @else { +
+ +
+ Select a conversation +
+
+ } - -
- -
- Select a conversation -
-
-
diff --git a/src/app/layout/common/quick-chat/quick-chat.component.ts b/src/app/layout/common/quick-chat/quick-chat.component.ts index bbcbbd24..9292c27a 100644 --- a/src/app/layout/common/quick-chat/quick-chat.component.ts +++ b/src/app/layout/common/quick-chat/quick-chat.component.ts @@ -1,13 +1,6 @@ import { ScrollStrategy, ScrollStrategyOptions } from '@angular/cdk/overlay'; import { TextFieldModule } from '@angular/cdk/text-field'; -import { - DOCUMENT, - DatePipe, - NgClass, - NgFor, - NgIf, - NgTemplateOutlet, -} from '@angular/common'; +import { DOCUMENT, DatePipe, NgClass, NgTemplateOutlet } from '@angular/common'; import { AfterViewInit, Component, @@ -40,11 +33,9 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ NgClass, - NgIf, MatIconModule, MatButtonModule, FuseScrollbarDirective, - NgFor, NgTemplateOutlet, MatFormFieldModule, MatInputModule, diff --git a/src/app/layout/common/search/search.component.html b/src/app/layout/common/search/search.component.html index 736f0f11..04e4ed51 100644 --- a/src/app/layout/common/search/search.component.html +++ b/src/app/layout/common/search/search.component.html @@ -1,98 +1,106 @@ - - -
- - - - - No results found! - - - - {{ resultSet.label.toUpperCase() }} - - - - - - - - - - - - - - - - - - - - -
-
+ } + @if (opened) { +
+ + + + @if (resultSets && !resultSets.length) { + + No results found! + + } + @for ( + resultSet of resultSets; + track trackByFn($index, resultSet) + ) { + + {{ resultSet.label.toUpperCase() }} + + @for ( + result of resultSet.results; + track trackByFn($index, result) + ) { + + + @if (resultSet.id === 'contacts') { + + } + + @if (resultSet.id === 'pages') { + + } + + @if (resultSet.id === 'tasks') { + + } + + } + } + + +
+ } +} - +@if (appearance === 'basic') {
- - No results found! - - + @if (resultSets && !resultSets.length) { + + No results found! + + } + @for (resultSet of resultSets; track trackByFn($index, resultSet)) { {{ resultSet.label.toUpperCase() }} - + @for ( + result of resultSet.results; + track trackByFn($index, result) + ) { - + @if (resultSet.id === 'contacts') { - + } - + @if (resultSet.id === 'pages') { - + } - + @if (resultSet.id === 'tasks') { - + } - - + } + }
-
+} @@ -176,12 +184,15 @@
- - + @if (result.avatar) { + + } + @if (!result.avatar) { + + }
@@ -202,18 +213,18 @@
- + @if (result.completed) { - - + } + @if (!result.completed) { - + }
THEME
- + @for (theme of config.themes; track theme) {
-
+ }

diff --git a/src/app/layout/common/settings/settings.component.ts b/src/app/layout/common/settings/settings.component.ts index 57239b60..85a45716 100644 --- a/src/app/layout/common/settings/settings.component.ts +++ b/src/app/layout/common/settings/settings.component.ts @@ -1,4 +1,4 @@ -import { NgClass, NgFor } from '@angular/common'; +import { NgClass } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @@ -40,7 +40,6 @@ import { Subject, takeUntil } from 'rxjs'; MatIconModule, FuseDrawerComponent, MatButtonModule, - NgFor, NgClass, MatTooltipModule, ], diff --git a/src/app/layout/common/shortcuts/shortcuts.component.html b/src/app/layout/common/shortcuts/shortcuts.component.html index 31878ffc..7cd3166a 100644 --- a/src/app/layout/common/shortcuts/shortcuts.component.html +++ b/src/app/layout/common/shortcuts/shortcuts.component.html @@ -22,21 +22,20 @@
Shortcuts - + @if (mode !== 'view') { - - Add new - - Editing + @if (mode === 'add') { + - Add new + } + @if (mode === 'modify' || mode === 'edit') { + - Editing + } - + }
- + @if (mode === 'view') { - + } - + @if (mode === 'modify') { - + } - + @if (mode === 'add') { - + } - + @if (mode === 'edit') { - + }
- + @if (mode === 'view' || mode === 'modify') {
- + @for ( + shortcut of shortcuts; + track trackByFn($index, shortcut) + ) {
- + @if (mode === 'modify') {
-
+ } - - - + @if (!shortcut.useRouter) { + + + + } - - - + @if (shortcut.useRouter) { + + + + }
- + @if (mode === 'modify') { + + } @@ -180,11 +185,11 @@
-
+ }
- + @if (!shortcuts || !shortcuts.length) {
@@ -205,11 +210,11 @@ When you have shortcuts, they will appear here.
- - + } + } - + @if (mode === 'add' || mode === 'edit') {
Label @@ -235,15 +240,16 @@
- + @if (mode === 'edit') { + + }
-
+ }
diff --git a/src/app/layout/common/shortcuts/shortcuts.component.ts b/src/app/layout/common/shortcuts/shortcuts.component.ts index edbff73b..c2947569 100644 --- a/src/app/layout/common/shortcuts/shortcuts.component.ts +++ b/src/app/layout/common/shortcuts/shortcuts.component.ts @@ -1,6 +1,6 @@ import { Overlay, OverlayRef } from '@angular/cdk/overlay'; import { TemplatePortal } from '@angular/cdk/portal'; -import { NgClass, NgFor, NgIf, NgTemplateOutlet } from '@angular/common'; +import { NgClass, NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -40,9 +40,7 @@ import { Subject, takeUntil } from 'rxjs'; imports: [ MatButtonModule, MatIconModule, - NgIf, MatTooltipModule, - NgFor, NgClass, NgTemplateOutlet, RouterLink, diff --git a/src/app/layout/common/user/user.component.html b/src/app/layout/common/user/user.component.html index dd986b0c..ef5bd747 100644 --- a/src/app/layout/common/user/user.component.html +++ b/src/app/layout/common/user/user.component.html @@ -1,15 +1,12 @@ -
+ }
@@ -88,7 +88,9 @@
- + @if (true) { + + }
diff --git a/src/app/layout/layouts/horizontal/centered/centered.component.ts b/src/app/layout/layouts/horizontal/centered/centered.component.ts index 6296e3b9..46db6688 100644 --- a/src/app/layout/layouts/horizontal/centered/centered.component.ts +++ b/src/app/layout/layouts/horizontal/centered/centered.component.ts @@ -1,4 +1,3 @@ -import { NgIf } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @@ -28,7 +27,6 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ FuseLoadingBarComponent, - NgIf, FuseVerticalNavigationComponent, FuseHorizontalNavigationComponent, MatButtonModule, diff --git a/src/app/layout/layouts/horizontal/enterprise/enterprise.component.html b/src/app/layout/layouts/horizontal/enterprise/enterprise.component.html index 989ffdbd..ab3f2b0e 100644 --- a/src/app/layout/layouts/horizontal/enterprise/enterprise.component.html +++ b/src/app/layout/layouts/horizontal/enterprise/enterprise.component.html @@ -2,7 +2,7 @@ - +@if (isScreenSmall) { - +}
- + @if (!isScreenSmall) {
Logo image
-
+ } - + @if (isScreenSmall) { - + }
- + @if (!isScreenSmall) {
@@ -96,7 +96,7 @@ >
- + }
@@ -106,7 +106,9 @@ > - + @if (true) { + + }
diff --git a/src/app/layout/layouts/horizontal/enterprise/enterprise.component.ts b/src/app/layout/layouts/horizontal/enterprise/enterprise.component.ts index c965b415..f2f727b3 100644 --- a/src/app/layout/layouts/horizontal/enterprise/enterprise.component.ts +++ b/src/app/layout/layouts/horizontal/enterprise/enterprise.component.ts @@ -1,4 +1,3 @@ -import { NgIf } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @@ -29,7 +28,6 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ FuseLoadingBarComponent, - NgIf, FuseVerticalNavigationComponent, MatButtonModule, MatIconModule, diff --git a/src/app/layout/layouts/horizontal/material/material.component.html b/src/app/layout/layouts/horizontal/material/material.component.html index f08d2824..07c75a11 100644 --- a/src/app/layout/layouts/horizontal/material/material.component.html +++ b/src/app/layout/layouts/horizontal/material/material.component.html @@ -2,7 +2,7 @@ - +@if (isScreenSmall) { -
+}
- + @if (!isScreenSmall) {
Logo image
-
+ } - + @if (isScreenSmall) { - + }
- + @if (!isScreenSmall) {
@@ -90,7 +90,7 @@ [navigation]="navigation.horizontal" >
-
+ }
@@ -101,7 +101,9 @@ > - + @if (true) { + + } diff --git a/src/app/layout/layouts/horizontal/material/material.component.ts b/src/app/layout/layouts/horizontal/material/material.component.ts index 0368ae18..fff00cfb 100644 --- a/src/app/layout/layouts/horizontal/material/material.component.ts +++ b/src/app/layout/layouts/horizontal/material/material.component.ts @@ -1,4 +1,3 @@ -import { NgIf } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @@ -28,7 +27,6 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ FuseLoadingBarComponent, - NgIf, FuseVerticalNavigationComponent, MatButtonModule, MatIconModule, diff --git a/src/app/layout/layouts/horizontal/modern/modern.component.html b/src/app/layout/layouts/horizontal/modern/modern.component.html index d151301c..8b4714a2 100644 --- a/src/app/layout/layouts/horizontal/modern/modern.component.html +++ b/src/app/layout/layouts/horizontal/modern/modern.component.html @@ -2,7 +2,7 @@ - +@if (isScreenSmall) { - +}
@@ -30,7 +30,7 @@
- + @if (!isScreenSmall) {
- + } + +
diff --git a/src/app/modules/admin/apps/academy/list/list.component.ts b/src/app/modules/admin/apps/academy/list/list.component.ts index ee8575eb..34234f33 100644 --- a/src/app/modules/admin/apps/academy/list/list.component.ts +++ b/src/app/modules/admin/apps/academy/list/list.component.ts @@ -1,11 +1,5 @@ import { CdkScrollable } from '@angular/cdk/scrolling'; -import { - I18nPluralPipe, - NgClass, - NgFor, - NgIf, - PercentPipe, -} from '@angular/common'; +import { I18nPluralPipe, NgClass, PercentPipe } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -43,11 +37,9 @@ import { BehaviorSubject, Subject, combineLatest, takeUntil } from 'rxjs'; MatFormFieldModule, MatSelectModule, MatOptionModule, - NgFor, MatIconModule, MatInputModule, MatSlideToggleModule, - NgIf, NgClass, MatTooltipModule, MatProgressBarModule, diff --git a/src/app/modules/admin/apps/chat/chats/chats.component.html b/src/app/modules/admin/apps/chat/chats/chats.component.html index 928cf84a..8350adb2 100644 --- a/src/app/modules/admin/apps/chat/chats/chats.component.html +++ b/src/app/modules/admin/apps/chat/chats/chats.component.html @@ -8,20 +8,20 @@ #drawer > - + @if (drawerComponent === 'new-chat') { - + } - + @if (drawerComponent === 'profile') { - + } - + @if (chats && chats.length > 0) {
@@ -35,20 +35,20 @@ (click)="openProfile()" >
- + @if (profile.avatar) { Profile avatar - - + } + @if (!profile.avatar) {
{{ profile.name.charAt(0) }}
-
+ }
{{ profile.name }} @@ -152,15 +152,11 @@
- - + @if (filteredChats.length > 0) { + @for ( + chat of filteredChats; + track trackByFn($index, chat) + ) {
- + @if (chat.unreadCount > 0) {
-
- + } + @if (chat.contact.avatar) { Contact avatar - - + } + @if (!chat.contact.avatar) {
@@ -206,7 +196,7 @@ chat.contact.name.charAt(0) }}
-
+ }
{{ chat.lastMessageAt }}
- + @if (chat.muted) { - + }
-
-
+ } + } @else { +
+ +
+ No chats +
+
+ }
- - - - + } @else {
@@ -267,21 +270,23 @@ No chats
- + } + + - + @if (chats && chats.length > 0) {
-
+ }
diff --git a/src/app/modules/admin/apps/chat/chats/chats.component.ts b/src/app/modules/admin/apps/chat/chats/chats.component.ts index 0f05a2cc..bce3cea9 100644 --- a/src/app/modules/admin/apps/chat/chats/chats.component.ts +++ b/src/app/modules/admin/apps/chat/chats/chats.component.ts @@ -1,4 +1,4 @@ -import { NgClass, NgFor, NgIf } from '@angular/common'; +import { NgClass } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -28,7 +28,6 @@ import { Subject, takeUntil } from 'rxjs'; standalone: true, imports: [ MatSidenavModule, - NgIf, NewChatComponent, ProfileComponent, MatButtonModule, @@ -36,7 +35,6 @@ import { Subject, takeUntil } from 'rxjs'; MatMenuModule, MatFormFieldModule, MatInputModule, - NgFor, NgClass, RouterLink, RouterOutlet, diff --git a/src/app/modules/admin/apps/chat/contact-info/contact-info.component.html b/src/app/modules/admin/apps/chat/contact-info/contact-info.component.html index 89620975..8a5f2e15 100644 --- a/src/app/modules/admin/apps/chat/contact-info/contact-info.component.html +++ b/src/app/modules/admin/apps/chat/contact-info/contact-info.component.html @@ -13,20 +13,20 @@
- + @if (chat.contact.avatar) { - - + } + @if (!chat.contact.avatar) {
{{ chat.contact.name.charAt(0) }}
-
+ }
{{ chat.contact.name }}
@@ -38,24 +38,22 @@
Media
- + @for (media of chat.contact.attachments.media; track media) { - + }
Details
- + @if (chat.contact.details.emails.length) {
Email
{{ chat.contact.details.emails[0].email }}
-
- + } + @if (chat.contact.details.phoneNumbers.length) {
Phone number @@ -66,31 +64,31 @@ }}
-
- + } + @if (chat.contact.details.title) {
Title
{{ chat.contact.details.title }}
-
- + } + @if (chat.contact.details.company) {
Company
{{ chat.contact.details.company }}
-
- + } + @if (chat.contact.details.birthday) {
Birthday
{{ chat.contact.details.birthday }}
-
- + } + @if (chat.contact.details.address) {
Address
{{ chat.contact.details.address }}
-
+ }
diff --git a/src/app/modules/admin/apps/chat/contact-info/contact-info.component.ts b/src/app/modules/admin/apps/chat/contact-info/contact-info.component.ts index 16a1d304..c4983c10 100644 --- a/src/app/modules/admin/apps/chat/contact-info/contact-info.component.ts +++ b/src/app/modules/admin/apps/chat/contact-info/contact-info.component.ts @@ -1,4 +1,3 @@ -import { NgFor, NgIf } from '@angular/common'; import { ChangeDetectionStrategy, Component, @@ -16,7 +15,7 @@ import { Chat } from 'app/modules/admin/apps/chat/chat.types'; encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, - imports: [MatButtonModule, MatIconModule, NgIf, NgFor], + imports: [MatButtonModule, MatIconModule], }) export class ContactInfoComponent { @Input() chat: Chat; diff --git a/src/app/modules/admin/apps/chat/conversation/conversation.component.html b/src/app/modules/admin/apps/chat/conversation/conversation.component.html index 5422c393..b5722941 100644 --- a/src/app/modules/admin/apps/chat/conversation/conversation.component.html +++ b/src/app/modules/admin/apps/chat/conversation/conversation.component.html @@ -1,7 +1,7 @@
- + @if (chat) { - + @if (chat.contact.avatar) { Contact avatar - - + } + @if (!chat.contact.avatar) {
{{ chat.contact.name.charAt(0) }}
-
+ }
- + @if (!chat.muted) { Mute notifications - - + } + @if (chat.muted) { Unmute notifications - + }
- + }
@@ -184,24 +179,22 @@ 'bg-blue-500 text-blue-50': message.isMine, 'bg-gray-500 text-gray-50': - !message.isMine + !message.isMine, }" > - + @if ( + last || + chat.messages[i + 1].isMine !== + message.isMine + ) {
-
+ }
- + @if ( + first || + last || + chat.messages[i + 1].isMine !== + message.isMine || + chat.messages[i + 1].createdAt !== + message.createdAt + ) {
{{ message.createdAt | date: 'HH:mm' }}
-
+ } - + } @@ -279,10 +270,7 @@ - - - - + } @else {
@@ -296,7 +284,9 @@ Select a conversation or start a new chat
-
+ } + + diff --git a/src/app/modules/admin/apps/chat/conversation/conversation.component.ts b/src/app/modules/admin/apps/chat/conversation/conversation.component.ts index 96fd7c0f..f9169c0a 100644 --- a/src/app/modules/admin/apps/chat/conversation/conversation.component.ts +++ b/src/app/modules/admin/apps/chat/conversation/conversation.component.ts @@ -1,11 +1,5 @@ import { TextFieldModule } from '@angular/cdk/text-field'; -import { - DatePipe, - NgClass, - NgFor, - NgIf, - NgTemplateOutlet, -} from '@angular/common'; +import { DatePipe, NgClass, NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -38,14 +32,12 @@ import { Subject, takeUntil } from 'rxjs'; changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ - NgIf, MatSidenavModule, ContactInfoComponent, MatButtonModule, RouterLink, MatIconModule, MatMenuModule, - NgFor, NgClass, NgTemplateOutlet, MatFormFieldModule, diff --git a/src/app/modules/admin/apps/chat/new-chat/new-chat.component.html b/src/app/modules/admin/apps/chat/new-chat/new-chat.component.html index 3fa9312a..0cac9361 100644 --- a/src/app/modules/admin/apps/chat/new-chat/new-chat.component.html +++ b/src/app/modules/admin/apps/chat/new-chat/new-chat.component.html @@ -14,28 +14,23 @@
- - + @if (contacts.length) { + @for ( + contact of contacts; + track trackByFn(i, contact); + let i = $index + ) { - + @if ( + i === 0 || + contact.name.charAt(0) !== contacts[i - 1].name.charAt(0) + ) {
{{ contact.name.charAt(0) }}
-
+ }
- + @if (contact.avatar) { Contact avatar - - + } + @if (!contact.avatar) {
{{ contact.name.charAt(0) }}
-
+ }
@@ -67,16 +62,15 @@
- - + } + } @else { +
+ There are no contacts! +
+ } - -
- There are no contacts! -
-
diff --git a/src/app/modules/admin/apps/chat/new-chat/new-chat.component.ts b/src/app/modules/admin/apps/chat/new-chat/new-chat.component.ts index b960eae3..7e522694 100644 --- a/src/app/modules/admin/apps/chat/new-chat/new-chat.component.ts +++ b/src/app/modules/admin/apps/chat/new-chat/new-chat.component.ts @@ -1,4 +1,3 @@ -import { NgFor, NgIf } from '@angular/common'; import { ChangeDetectionStrategy, Component, @@ -20,7 +19,7 @@ import { Subject, takeUntil } from 'rxjs'; encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, - imports: [MatButtonModule, MatIconModule, NgIf, NgFor], + imports: [MatButtonModule, MatIconModule], }) export class NewChatComponent implements OnInit, OnDestroy { @Input() drawer: MatDrawer; diff --git a/src/app/modules/admin/apps/chat/profile/profile.component.html b/src/app/modules/admin/apps/chat/profile/profile.component.html index 77b3e9b0..6b5e331a 100644 --- a/src/app/modules/admin/apps/chat/profile/profile.component.html +++ b/src/app/modules/admin/apps/chat/profile/profile.component.html @@ -27,20 +27,20 @@ Change Profile Photo - + @if (profile.avatar) { - - + } + @if (!profile.avatar) {
{{ profile.name.charAt(0) }}
-
+ } diff --git a/src/app/modules/admin/apps/chat/profile/profile.component.ts b/src/app/modules/admin/apps/chat/profile/profile.component.ts index a49c0d92..532f7831 100644 --- a/src/app/modules/admin/apps/chat/profile/profile.component.ts +++ b/src/app/modules/admin/apps/chat/profile/profile.component.ts @@ -1,4 +1,3 @@ -import { NgIf } from '@angular/common'; import { ChangeDetectionStrategy, Component, @@ -26,7 +25,6 @@ import { Subject, takeUntil } from 'rxjs'; imports: [ MatButtonModule, MatIconModule, - NgIf, MatFormFieldModule, MatInputModule, FormsModule, diff --git a/src/app/modules/admin/apps/contacts/details/details.component.html b/src/app/modules/admin/apps/contacts/details/details.component.html index 96afef1b..b86f4aec 100644 --- a/src/app/modules/admin/apps/contacts/details/details.component.html +++ b/src/app/modules/admin/apps/contacts/details/details.component.html @@ -1,17 +1,17 @@
- + @if (!editMode) {
- + @if (contact.background) { - + }
- -
- {{ contact.name.charAt(0) }} -
+ @if (contact.avatar) { + + } + @if (!contact.avatar) { +
+ {{ contact.name.charAt(0) }} +
+ }
@@ -73,16 +75,13 @@
- + @if (contact.tags.length) {
- + @for ( + tag of contact.tags | fuseFindByKey: 'id' : tags; + track trackByFn($index, tag) + ) {
@@ -91,13 +90,13 @@ >{{ tag.title }}
-
+ }
-
+ }
- + @if (contact.title) {
-
+ } - + @if (contact.company) {
+ @if (contact.emails.length) {
- + @for ( + email of contact.emails; + track trackByFn($index, email) + ) {
{{ email.email }} -
- - {{ - email.label - }} -
+ @if (email.label) { +
+ + {{ + email.label + }} +
+ }
-
+ }
- + } - + @if (contact.phoneNumbers.length) {
- + @for ( + phoneNumber of contact.phoneNumbers; + track trackByFn($index, phoneNumber) + ) {
-
- - {{ - phoneNumber.label - }} -
+ @if (phoneNumber.label) { +
+ + {{ + phoneNumber.label + }} +
+ }
-
+ }
-
+ } - + @if (contact.address) {
-
+ } - + @if (contact.birthday) {
-
+ } - + @if (contact.notes) {
-
+ }
- + } - + @if (editMode) {
- + @if (contact.background) { - + }
- -
- {{ contact.name.charAt(0) }} -
+ @if (contact.avatar) { + + } + @if (!contact.avatar) { +
+ {{ contact.name.charAt(0) }} +
+ }
@@ -385,14 +384,12 @@
- - + @if (contact.tags.length) { + @for ( + tag of contact.tags + | fuseFindByKey: 'id' : tags; + track trackByFn($index, tag) + ) {
@@ -401,15 +398,15 @@ >{{ tag.title }}
-
-
+ } + }
- + @if (contact.tags.length) { Edit - + } - + @if (!contact.tags.length) { Add - + } @@ -466,33 +463,33 @@ mat-icon-button (click)="toggleTagsEditMode()" > - - + @if (!tagsEditMode) { + + } + @if (tagsEditMode) { + + }
- - + @if (!tagsEditMode) { + @for ( + tag of filteredTags; + track trackByFn($index, tag) + ) {
+ @if (tagsEditMode) {
- + @for ( + tag of filteredTags; + track trackByFn($index, tag) + ) {
@@ -563,36 +558,39 @@
-
+ }
- + } -
- -
- Create "{{ - newTagInput.value - }}" + matRipple + > + +
+ Create "{{ + newTagInput.value + }}" +
-
+ }
@@ -642,25 +640,21 @@
- + @for ( + email of contactForm.get('emails')['controls']; + track trackByFn(i, email); + let i = $index; + let first = $first; + let last = $last + ) {
- Email + @if (first) { + Email + } - + @if (!(first && last)) {
-
+ }
-
+ }
- + @for ( + phoneNumber of contactForm.get('phoneNumbers')[ + 'controls' + ]; + track trackByFn(i, phoneNumber); + let i = $index; + let first = $first; + let last = $last + ) {
- Phone + @if (first) { + Phone + } + @for ( + country of countries; + track trackByFn($index, country) + ) { @@ -833,16 +823,16 @@ > - + } - Label + @if (first) { + Label + } - + @if (!(first && last)) {
-
+ }
-
+ }
- + }
diff --git a/src/app/modules/admin/apps/contacts/details/details.component.ts b/src/app/modules/admin/apps/contacts/details/details.component.ts index 2b0892eb..d20f2b9c 100644 --- a/src/app/modules/admin/apps/contacts/details/details.component.ts +++ b/src/app/modules/admin/apps/contacts/details/details.component.ts @@ -1,7 +1,7 @@ import { Overlay, OverlayRef } from '@angular/cdk/overlay'; import { TemplatePortal } from '@angular/cdk/portal'; import { TextFieldModule } from '@angular/cdk/text-field'; -import { DatePipe, NgClass, NgFor, NgIf } from '@angular/common'; +import { DatePipe, NgClass } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -52,12 +52,10 @@ import { Subject, debounceTime, takeUntil } from 'rxjs'; changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ - NgIf, MatButtonModule, MatTooltipModule, RouterLink, MatIconModule, - NgFor, FormsModule, ReactiveFormsModule, MatRippleModule, diff --git a/src/app/modules/admin/apps/contacts/list/list.component.html b/src/app/modules/admin/apps/contacts/list/list.component.html index c1ad70cc..d1ba64bf 100644 --- a/src/app/modules/admin/apps/contacts/list/list.component.html +++ b/src/app/modules/admin/apps/contacts/list/list.component.html @@ -30,16 +30,16 @@ Contacts
- + @if (contactsCount > 0) { {{ contactsCount }} - + } {{ contactsCount | i18nPlural : { '=0': 'No contacts', '=1': 'contact', - other: 'contacts' + other: 'contacts', } }}
@@ -85,29 +85,25 @@
- - - + @if (contacts$ | async; as contacts) { + @if (contacts.length) { + @for ( + contact of contacts; + track trackByFn(i, contact); + let i = $index + ) { - + @if ( + i === 0 || + contact.name.charAt(0) !== + contacts[i - 1].name.charAt(0) + ) {
{{ contact.name.charAt(0) }}
-
+ }
- + @if (contact.avatar) { Contact avatar - - + } + @if (!contact.avatar) {
{{ contact.name.charAt(0) }}
-
+ }
- - - + } + } @else { +
+ There are no contacts! +
+ } + } - -
- There are no contacts! -
-
diff --git a/src/app/modules/admin/apps/contacts/list/list.component.ts b/src/app/modules/admin/apps/contacts/list/list.component.ts index 0aff048f..c9942ca0 100644 --- a/src/app/modules/admin/apps/contacts/list/list.component.ts +++ b/src/app/modules/admin/apps/contacts/list/list.component.ts @@ -1,11 +1,4 @@ -import { - AsyncPipe, - DOCUMENT, - I18nPluralPipe, - NgClass, - NgFor, - NgIf, -} from '@angular/common'; +import { AsyncPipe, DOCUMENT, I18nPluralPipe, NgClass } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -56,14 +49,12 @@ import { imports: [ MatSidenavModule, RouterOutlet, - NgIf, MatFormFieldModule, MatIconModule, MatInputModule, FormsModule, ReactiveFormsModule, MatButtonModule, - NgFor, NgClass, RouterLink, AsyncPipe, diff --git a/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.html b/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.html index 7b5b251b..d201c768 100644 --- a/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.html +++ b/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.html @@ -6,9 +6,11 @@ class="relative flex flex-0 flex-col border-b px-6 py-8 sm:flex-row sm:items-center sm:justify-between md:px-8" > -
- -
+ @if (isLoading) { +
+ +
+ }
Inventory
@@ -49,8 +51,8 @@
- - + @if (products$ | async; as products) { + @if (products.length > 0) {
- - + @if (products$ | async; as products) { + @for ( + product of products; + track trackByFn($index, product) + ) {
@@ -102,20 +102,22 @@
- -
- NO THUMB -
+ @if (product.thumbnail) { + + } + @if (!product.thumbnail) { +
+ NO THUMB +
+ }
@@ -146,55 +148,58 @@ {{ product.stock }}
-
+ @if (product.stock < 20) {
-
+ class="ml-2 flex h-4 w-1 items-end overflow-hidden rounded bg-red-200" + > +
+
+ } -
+ @if ( + product.stock >= 20 && + product.stock < 30 + ) {
-
+ class="ml-2 flex h-4 w-1 items-end overflow-hidden rounded bg-orange-200" + > +
+ + } -
+ @if (product.stock >= 30) {
-
+ class="ml-2 flex h-4 w-1 items-end overflow-hidden rounded bg-green-100" + > +
+ + } @@ -217,21 +222,17 @@
- + @if (selectedProduct?.id === product.id) { - + }
-
- + } + } - - + } @else { +
+ There are no products! +
+ } + }
@@ -263,14 +270,11 @@
- + @if ( + selectedProductForm.get( + 'images' + ).value.length + ) { - - + } @else { NO IMAGE - + }
-
- - - {{ - selectedProductForm.get( - 'currentImageIndex' - ).value + 1 - }} - of - {{ - selectedProductForm.get( - 'images' - ).value.length - }} - - -
+ + + {{ + selectedProductForm.get( + 'currentImageIndex' + ).value + 1 + }} + of + {{ + selectedProductForm.get( + 'images' + ).value.length + }} + + +
+ }
- + @for ( + category of categories; + track category + ) { @@ -418,17 +420,16 @@ - + @for ( + brand of brands; + track brand + ) { {{ brand.name }} - + } @@ -436,17 +437,16 @@ - + @for ( + vendor of vendors; + track vendor + ) { {{ vendor.name }} - + }
@@ -570,20 +570,22 @@ toggleTagsEditMode() " > - - + @if (!tagsEditMode) { + + } + @if (tagsEditMode) { + + } @@ -591,15 +593,14 @@ class="h-44 overflow-y-auto border-t border-gray-300 leading-none dark:border-gray-500" > - - + @if (!tagsEditMode) { + @for ( + tag of filteredTags; + track trackByFn( + $index, + tag + ) + ) { {{ tag.title }} - - + } + } - + @if (tagsEditMode) {
- + @for ( + tag of filteredTags; + track trackByFn( + $index, + tag + ) + ) { - -
- Create "{{ - newTagInput.value - }}" + matRipple + > + +
+ Create "{{ + newTagInput.value + }}" +
-
+ } @@ -714,38 +716,33 @@ Delete
-
- - - Product updated - - - - An error occurred, try - again! - -
+ @if (flashMessage) { +
+ @if (flashMessage === 'success') { + + Product updated + } + @if (flashMessage === 'error') { + + An error occurred, try + again! + } +
+ }
- - -
- There are no products! -
-
diff --git a/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.ts b/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.ts index 98181569..0ee98b5d 100644 --- a/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.ts +++ b/src/app/modules/admin/apps/ecommerce/inventory/list/inventory.component.ts @@ -2,8 +2,6 @@ import { AsyncPipe, CurrencyPipe, NgClass, - NgFor, - NgIf, NgTemplateOutlet, } from '@angular/common'; import { @@ -87,7 +85,6 @@ import { animations: fuseAnimations, standalone: true, imports: [ - NgIf, MatProgressBarModule, MatFormFieldModule, MatIconModule, @@ -96,7 +93,6 @@ import { ReactiveFormsModule, MatButtonModule, MatSortModule, - NgFor, NgTemplateOutlet, MatPaginatorModule, NgClass, diff --git a/src/app/modules/admin/apps/file-manager/details/details.component.html b/src/app/modules/admin/apps/file-manager/details/details.component.html index 9f6a67ad..0c999699 100644 --- a/src/app/modules/admin/apps/file-manager/details/details.component.html +++ b/src/app/modules/admin/apps/file-manager/details/details.component.html @@ -11,18 +11,18 @@
- + @if (item.type === 'folder') { - - + } + @if (item.type !== 'folder') { - + }
@@ -61,12 +61,12 @@
Size
{{ item.size }}
- + @if (item.contents) {
Contents
{{ item.contents }}
-
+ } @@ -81,14 +81,14 @@
- + @if (item.description) {
{{ item.description }}
-
- + } + @if (!item.description) {
Click here to add a description
-
+ }
diff --git a/src/app/modules/admin/apps/file-manager/details/details.component.ts b/src/app/modules/admin/apps/file-manager/details/details.component.ts index 2c37608b..a2e002ec 100644 --- a/src/app/modules/admin/apps/file-manager/details/details.component.ts +++ b/src/app/modules/admin/apps/file-manager/details/details.component.ts @@ -1,4 +1,3 @@ -import { NgIf } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -22,7 +21,7 @@ import { Subject, takeUntil } from 'rxjs'; encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, - imports: [MatButtonModule, RouterLink, MatIconModule, NgIf], + imports: [MatButtonModule, RouterLink, MatIconModule], }) export class FileManagerDetailsComponent implements OnInit, OnDestroy { item: Item; diff --git a/src/app/modules/admin/apps/file-manager/list/list.component.html b/src/app/modules/admin/apps/file-manager/list/list.component.html index c4568828..0e4fa70c 100644 --- a/src/app/modules/admin/apps/file-manager/list/list.component.html +++ b/src/app/modules/admin/apps/file-manager/list/list.component.html @@ -34,12 +34,12 @@
- + @if (!items.path.length) { {{ items.folders.length }} folders, {{ items.files.length }} files - + } - + @if (items.path.length) {
Home
/
- - + @for ( + path of items.path; + track trackByFn($index, path); + let last = $last + ) { + @if (!last) { {{ path.name }} - - + } + @if (last) {
{{ path.name }}
-
- + } + @if (!last) {
/
-
-
+ } + }
-
+ }
@@ -88,26 +86,20 @@ - + @if ( + items && + (items.folders.length > 0 || items.files.length > 0) + ) {
- + @if (items.folders.length > 0) {
Folders
- + @for ( + folder of items.folders; + track trackByFn($index, folder) + ) {
@@ -118,7 +110,7 @@ " [routerLink]="[ './details/', - folder.id + folder.id, ]" mat-icon-button > @@ -133,7 +125,7 @@ class="absolute inset-0 z-10 flex cursor-pointer flex-col p-4" [routerLink]="[ '/apps/file-manager/folders/', - folder.id + folder.id, ]" >
@@ -160,9 +152,7 @@ > {{ folder.name }}
- + @if (folder.contents) {
@@ -170,31 +160,29 @@ folder.contents }}
-
+ }
- + }
-
+ } - + @if (items.files.length > 0) {
Files
- + @for ( + file of items.files; + track trackByFn($index, file) + ) {
@@ -248,26 +236,21 @@ > {{ file.name }}
- + @if (file.contents) {
{{ file.contents }}
-
+ }
- + }
-
+ } - - - - + } @else {
@@ -281,7 +264,9 @@ There are no items!
-
+ } + + diff --git a/src/app/modules/admin/apps/file-manager/list/list.component.ts b/src/app/modules/admin/apps/file-manager/list/list.component.ts index f93f831d..e32e3937 100644 --- a/src/app/modules/admin/apps/file-manager/list/list.component.ts +++ b/src/app/modules/admin/apps/file-manager/list/list.component.ts @@ -1,4 +1,3 @@ -import { NgFor, NgIf } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -35,9 +34,7 @@ import { Subject, takeUntil } from 'rxjs'; imports: [ MatSidenavModule, RouterOutlet, - NgIf, RouterLink, - NgFor, MatButtonModule, MatIconModule, MatTooltipModule, diff --git a/src/app/modules/admin/apps/help-center/faqs/faqs.component.html b/src/app/modules/admin/apps/help-center/faqs/faqs.component.html index cb98e64d..9f69e419 100644 --- a/src/app/modules/admin/apps/help-center/faqs/faqs.component.html +++ b/src/app/modules/admin/apps/help-center/faqs/faqs.component.html @@ -15,18 +15,20 @@ > Frequently Asked Questions - + @for ( + faqCategory of faqCategories; + track trackByFn($index, faqCategory) + ) {
{{ faqCategory.title }}
- + @for ( + faq of faqCategory.faqs; + track trackByFn($index, faq) + ) { {{ faq.answer }} - + } -
+ } diff --git a/src/app/modules/admin/apps/help-center/faqs/faqs.component.ts b/src/app/modules/admin/apps/help-center/faqs/faqs.component.ts index 828596d1..43809c9a 100644 --- a/src/app/modules/admin/apps/help-center/faqs/faqs.component.ts +++ b/src/app/modules/admin/apps/help-center/faqs/faqs.component.ts @@ -1,4 +1,3 @@ -import { NgFor } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatExpansionModule } from '@angular/material/expansion'; @@ -13,13 +12,7 @@ import { Subject, takeUntil } from 'rxjs'; templateUrl: './faqs.component.html', encapsulation: ViewEncapsulation.None, standalone: true, - imports: [ - MatButtonModule, - RouterLink, - MatIconModule, - NgFor, - MatExpansionModule, - ], + imports: [MatButtonModule, RouterLink, MatIconModule, MatExpansionModule], }) export class HelpCenterFaqsComponent implements OnInit, OnDestroy { faqCategories: FaqCategory[]; diff --git a/src/app/modules/admin/apps/help-center/guides/category/category.component.html b/src/app/modules/admin/apps/help-center/guides/category/category.component.html index 83313ea5..269cbcc6 100644 --- a/src/app/modules/admin/apps/help-center/guides/category/category.component.html +++ b/src/app/modules/admin/apps/help-center/guides/category/category.component.html @@ -17,19 +17,17 @@
- + @for ( + guide of guideCategory.guides; + track trackByFn($index, guide) + ) { {{ guide.title }} - + }
diff --git a/src/app/modules/admin/apps/help-center/guides/category/category.component.ts b/src/app/modules/admin/apps/help-center/guides/category/category.component.ts index 93b67df1..8d561151 100644 --- a/src/app/modules/admin/apps/help-center/guides/category/category.component.ts +++ b/src/app/modules/admin/apps/help-center/guides/category/category.component.ts @@ -1,4 +1,3 @@ -import { NgFor } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @@ -12,7 +11,7 @@ import { Subject, takeUntil } from 'rxjs'; templateUrl: './category.component.html', encapsulation: ViewEncapsulation.None, standalone: true, - imports: [MatButtonModule, RouterLink, MatIconModule, NgFor], + imports: [MatButtonModule, RouterLink, MatIconModule], }) export class HelpCenterGuidesCategoryComponent implements OnInit, OnDestroy { guideCategory: GuideCategory; diff --git a/src/app/modules/admin/apps/help-center/guides/guides.component.html b/src/app/modules/admin/apps/help-center/guides/guides.component.html index 85e05828..aedcdba9 100644 --- a/src/app/modules/admin/apps/help-center/guides/guides.component.html +++ b/src/app/modules/admin/apps/help-center/guides/guides.component.html @@ -19,12 +19,10 @@
- + @for ( + guideCategory of guideCategories; + track trackByFn($index, guideCategory) + ) {
{{ guideCategory.title }} - + @for ( + guide of guideCategory.guides; + track trackByFn($index, guide) + ) { {{ guide.title }} - - - View All + guideCategory.visibleGuides + ) { + - - + View All + + + }
-
+ }
diff --git a/src/app/modules/admin/apps/help-center/guides/guides.component.ts b/src/app/modules/admin/apps/help-center/guides/guides.component.ts index 42b86e3d..362d8ad0 100644 --- a/src/app/modules/admin/apps/help-center/guides/guides.component.ts +++ b/src/app/modules/admin/apps/help-center/guides/guides.component.ts @@ -1,4 +1,3 @@ -import { NgFor, NgIf } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatButtonModule } from '@angular/material/button'; import { MatIconModule } from '@angular/material/icon'; @@ -12,7 +11,7 @@ import { Subject, takeUntil } from 'rxjs'; templateUrl: './guides.component.html', encapsulation: ViewEncapsulation.None, standalone: true, - imports: [MatButtonModule, RouterLink, MatIconModule, NgFor, NgIf], + imports: [MatButtonModule, RouterLink, MatIconModule], }) export class HelpCenterGuidesComponent implements OnInit, OnDestroy { guideCategories: GuideCategory[]; diff --git a/src/app/modules/admin/apps/help-center/help-center.component.html b/src/app/modules/admin/apps/help-center/help-center.component.html index 34474e3f..ce754046 100644 --- a/src/app/modules/admin/apps/help-center/help-center.component.html +++ b/src/app/modules/admin/apps/help-center/help-center.component.html @@ -134,16 +134,14 @@ getting started - + @for (faq of faqCategory.faqs; track trackByFn($index, faq)) { {{ faq.question }} {{ faq.answer }} - + } diff --git a/src/app/modules/admin/apps/help-center/help-center.component.ts b/src/app/modules/admin/apps/help-center/help-center.component.ts index 988d9c2e..be6d88db 100644 --- a/src/app/modules/admin/apps/help-center/help-center.component.ts +++ b/src/app/modules/admin/apps/help-center/help-center.component.ts @@ -1,4 +1,3 @@ -import { NgFor } from '@angular/common'; import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core'; import { MatExpansionModule } from '@angular/material/expansion'; import { MatFormFieldModule } from '@angular/material/form-field'; @@ -20,7 +19,6 @@ import { Subject, takeUntil } from 'rxjs'; MatIconModule, RouterLink, MatExpansionModule, - NgFor, ], }) export class HelpCenterComponent implements OnInit, OnDestroy { diff --git a/src/app/modules/admin/apps/help-center/support/support.component.html b/src/app/modules/admin/apps/help-center/support/support.component.html index ba2e5516..4bffc869 100644 --- a/src/app/modules/admin/apps/help-center/support/support.component.html +++ b/src/app/modules/admin/apps/help-center/support/support.component.html @@ -20,14 +20,15 @@ class="bg-card mt-8 rounded-2xl p-6 pb-7 shadow sm:mt-12 sm:p-10 sm:pb-7" > - - {{ alert.message }} - + @if (alert) { + + {{ alert.message }} + + }
Name - - Required - + @if (supportForm.get('name').hasError('required')) { + Required + } @@ -65,18 +64,12 @@ [required]="true" /> Email - - Required - - - Enter a valid email address - + @if (supportForm.get('email').hasError('required')) { + Required + } + @if (supportForm.get('email').hasError('email')) { + Enter a valid email address + } @@ -86,13 +79,9 @@ [required]="true" /> Subject - - Required - + @if (supportForm.get('subject').hasError('required')) { + Required + } @@ -104,13 +93,9 @@ cdkTextareaAutosize > Message - - Required - + @if (supportForm.get('message').hasError('required')) { + Required + }
diff --git a/src/app/modules/admin/apps/help-center/support/support.component.ts b/src/app/modules/admin/apps/help-center/support/support.component.ts index bebc4601..40ba7387 100644 --- a/src/app/modules/admin/apps/help-center/support/support.component.ts +++ b/src/app/modules/admin/apps/help-center/support/support.component.ts @@ -1,5 +1,5 @@ import { TextFieldModule } from '@angular/cdk/text-field'; -import { NgIf } from '@angular/common'; + import { Component, OnInit, ViewChild, ViewEncapsulation } from '@angular/core'; import { FormsModule, @@ -28,7 +28,6 @@ import { HelpCenterService } from 'app/modules/admin/apps/help-center/help-cente MatButtonModule, RouterLink, MatIconModule, - NgIf, FuseAlertComponent, FormsModule, ReactiveFormsModule, diff --git a/src/app/modules/admin/apps/mailbox/compose/compose.component.html b/src/app/modules/admin/apps/mailbox/compose/compose.component.html index 8e7ccf95..6af0188a 100644 --- a/src/app/modules/admin/apps/mailbox/compose/compose.component.html +++ b/src/app/modules/admin/apps/mailbox/compose/compose.component.html @@ -22,34 +22,40 @@ To
- - Cc - - - Bcc - + @if (!copyFields.cc) { + + Cc + + } + @if (!copyFields.bcc) { + + Bcc + + }
- - Cc - - + @if (copyFields.cc) { + + Cc + + + } - - Bcc - - + @if (copyFields.bcc) { + + Bcc + + + } diff --git a/src/app/modules/admin/apps/mailbox/compose/compose.component.ts b/src/app/modules/admin/apps/mailbox/compose/compose.component.ts index 95376519..9e9be263 100644 --- a/src/app/modules/admin/apps/mailbox/compose/compose.component.ts +++ b/src/app/modules/admin/apps/mailbox/compose/compose.component.ts @@ -1,4 +1,3 @@ -import { NgIf } from '@angular/common'; import { Component, OnInit, ViewEncapsulation } from '@angular/core'; import { FormsModule, @@ -26,7 +25,6 @@ import { QuillEditorComponent } from 'ngx-quill'; ReactiveFormsModule, MatFormFieldModule, MatInputModule, - NgIf, QuillEditorComponent, ], }) diff --git a/src/app/modules/admin/apps/mailbox/details/details.component.html b/src/app/modules/admin/apps/mailbox/details/details.component.html index 29409fae..aa722819 100644 --- a/src/app/modules/admin/apps/mailbox/details/details.component.html +++ b/src/app/modules/admin/apps/mailbox/details/details.component.html @@ -1,7 +1,7 @@
- + @if (mail) {
@@ -28,9 +28,7 @@ - + @for (label of labels; track trackByFn($index, label)) {
-
+ }
@@ -56,7 +54,7 @@ > @@ -66,7 +64,7 @@ - - + @if (mail.unread) { + + } + @if (!mail.unread) { + + } - - + @if ( + getCurrentFolder() !== 'spam' && + getCurrentFolder() !== 'drafts' + ) { + + } + @if (getCurrentFolder() === 'spam') { + + } - + @if (getCurrentFolder() !== 'trash') { + + }
@@ -149,25 +141,23 @@ {{ mail.subject }}
- + @if (mail.labels && mail.labels.length > 0) {
- + @for ( + label of mail.labels | fuseFindByKey: 'id' : labels; + track label + ) {
{{ label.title }}
-
+ }
-
+ }
@@ -205,9 +195,7 @@
to
me
- + @if (mail.ccCount + mail.bccCount > 0) {
and {{ @@ -227,7 +215,7 @@ >
-
+ }
- + @if (mail.cc) {
- + } - + @if (mail.bcc) {
- + }
- + @if (mail.attachments && mail.attachments.length > 0) {
@@ -365,42 +351,43 @@
- + @for ( + attachment of mail.attachments; + track attachment + ) {
- -
+ @if ( + attachment.type.startsWith('image/') + ) { + + } + @if ( + attachment.type.startsWith( + 'application/' + ) + ) {
- {{ - attachment.type - .split('/')[1] - .trim() - .toUpperCase() - }} +
+ {{ + attachment.type + .split('/')[1] + .trim() + .toUpperCase() + }} +
-
+ }
- + }
- + }
@@ -432,7 +419,7 @@ class="flex w-full border-t bg-gray-50 p-6 dark:bg-transparent" > - + @if (!replyFormActive) {
-
+ } - + @if (replyFormActive) {
- + @if (note.tasks) {
- + @for (task of note.tasks; track trackByFn($index, task)) {
-
+ }
-
+ } - + @if (note.labels && note.labels.length) {
- + @for ( + label of note.labels; + track trackByFn($index, label) + ) {
@@ -99,11 +98,11 @@ (click)="toggleLabelOnNote(note, label)" >
-
+ }
-
+ } - + @if (!note.id) {
-
+ } - + @if (note.id) {
@@ -161,8 +160,8 @@ > - - + @if (labels$ | async; as labels) { + @for (label of labels; track label) { - - + } + }
- + }
-
+ }
diff --git a/src/app/modules/admin/apps/notes/details/details.component.ts b/src/app/modules/admin/apps/notes/details/details.component.ts index f9e4abff..4a7cf0a5 100644 --- a/src/app/modules/admin/apps/notes/details/details.component.ts +++ b/src/app/modules/admin/apps/notes/details/details.component.ts @@ -1,5 +1,5 @@ import { TextFieldModule } from '@angular/cdk/text-field'; -import { AsyncPipe, NgClass, NgFor, NgIf } from '@angular/common'; +import { AsyncPipe, NgClass } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -39,12 +39,10 @@ import { changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ - NgIf, MatButtonModule, MatIconModule, FormsModule, TextFieldModule, - NgFor, MatCheckboxModule, NgClass, MatRippleModule, diff --git a/src/app/modules/admin/apps/notes/labels/labels.component.html b/src/app/modules/admin/apps/notes/labels/labels.component.html index 0ee743b7..fe34395b 100644 --- a/src/app/modules/admin/apps/notes/labels/labels.component.html +++ b/src/app/modules/admin/apps/notes/labels/labels.component.html @@ -29,8 +29,8 @@
- - + @if (labels$ | async; as labels) { + @for (label of labels; track trackByFn($index, label)) {
diff --git a/src/app/modules/admin/apps/notes/labels/labels.component.ts b/src/app/modules/admin/apps/notes/labels/labels.component.ts index 17b86432..29414609 100644 --- a/src/app/modules/admin/apps/notes/labels/labels.component.ts +++ b/src/app/modules/admin/apps/notes/labels/labels.component.ts @@ -1,4 +1,4 @@ -import { AsyncPipe, NgFor, NgIf } from '@angular/common'; +import { AsyncPipe } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -36,8 +36,6 @@ import { MatIconModule, MatFormFieldModule, MatInputModule, - NgIf, - NgFor, FormsModule, AsyncPipe, ], diff --git a/src/app/modules/admin/apps/notes/list/list.component.html b/src/app/modules/admin/apps/notes/list/list.component.html index 3ee324af..ef380bd5 100644 --- a/src/app/modules/admin/apps/notes/list/list.component.html +++ b/src/app/modules/admin/apps/notes/list/list.component.html @@ -16,7 +16,8 @@ [ngClass]="{ 'bg-gray-200 text-primary dark:bg-gray-700 dark:text-primary-400': filterStatus === 'notes', - 'text-hint hover:bg-hover': filterStatus !== 'notes' + 'text-hint hover:bg-hover': + filterStatus !== 'notes', }" (click)="resetFilter()" matRipple @@ -37,7 +38,7 @@ 'bg-gray-200 text-primary dark:bg-gray-700 dark:text-primary-400': filterStatus === 'archived', 'text-hint hover:bg-hover': - filterStatus !== 'archived' + filterStatus !== 'archived', }" (click)="filterByArchived()" matRipple @@ -52,17 +53,15 @@
- - + @if (labels$ | async; as labels) { + @for (label of labels; track trackByFn($index, label)) {
-
-
+ } + }
- - + @if (notes$ | async; as notes) { + @if (notes.length) { - + @for ( + column of columns; + track trackByFn($index, column) + ) {
- + @for ( + note of column.items; + track trackByFn($index, note) + ) {
- + @if (note.image) { - + }
- + @if (note.title) {
{{ note.title }}
-
+ } - + @if (note.content) {
+ @if (note.tasks) {
- + @for ( + task of note.tasks; + track trackByFn( + $index, + task + ) + ) {
- + @if ( + !task.completed + ) {
@@ -247,24 +233,22 @@ class="h-4 w-4 rounded-full border-2" >
-
- + } + @if ( + task.completed + ) { - + }
{{ @@ -272,22 +256,21 @@ }}
- + }
-
+ } - + @if (note.labels) {
- + @for ( + label of note.labels; + track trackByFn( + $index, + label + ) + ) {
@@ -295,21 +278,32 @@ label.title }}
-
+ }
-
+ }
-
+ }
-
+ }
-
-
- - - + } @else { +
+ +
+ There are no notes! +
+
+ } + } @else {
@@ -319,24 +313,11 @@ Loading...
- + } + + - -
- -
- There are no notes! -
-
-
diff --git a/src/app/modules/admin/apps/notes/list/list.component.ts b/src/app/modules/admin/apps/notes/list/list.component.ts index fa47241f..10ef03f5 100644 --- a/src/app/modules/admin/apps/notes/list/list.component.ts +++ b/src/app/modules/admin/apps/notes/list/list.component.ts @@ -1,4 +1,4 @@ -import { AsyncPipe, NgClass, NgFor, NgIf } from '@angular/common'; +import { AsyncPipe, NgClass } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -42,8 +42,6 @@ import { MatRippleModule, NgClass, MatIconModule, - NgIf, - NgFor, MatButtonModule, MatFormFieldModule, MatInputModule, diff --git a/src/app/modules/admin/apps/scrumboard/board/board.component.html b/src/app/modules/admin/apps/scrumboard/board/board.component.html index bfe2eff5..4563d20d 100644 --- a/src/app/modules/admin/apps/scrumboard/board/board.component.html +++ b/src/app/modules/admin/apps/scrumboard/board/board.component.html @@ -43,9 +43,7 @@
- + @for (list of board.lists; track trackByFn($index, list)) {
-
+ } - + @for (board of boards; track trackByFn($index, board)) {
- + @if (board.members?.length) {
- + @for ( + member of board.members.slice(0, 5); + track trackByFn($index, member) + ) { Member avatar - - + } + @if (board.members.length > 5) {
@@ -60,9 +58,9 @@ +{{ board.members.slice(5).length }}
-
+ }
-
+ }
Edited:
@@ -71,7 +69,7 @@
- + }
@@ -65,10 +65,12 @@ [svgIcon]="'heroicons_solid:calendar'" > - {{ - card.dueDate | date: 'longDate' - }} - Not set + @if (card.dueDate) { + {{ card.dueDate | date: 'longDate' }} + } + @if (!card.dueDate) { + Not set + }
diff --git a/src/app/modules/admin/apps/scrumboard/card/details/details.component.ts b/src/app/modules/admin/apps/scrumboard/card/details/details.component.ts index c0a64a13..e63fca07 100644 --- a/src/app/modules/admin/apps/scrumboard/card/details/details.component.ts +++ b/src/app/modules/admin/apps/scrumboard/card/details/details.component.ts @@ -1,5 +1,5 @@ import { TextFieldModule } from '@angular/cdk/text-field'; -import { DatePipe, NgClass, NgFor, NgIf } from '@angular/common'; +import { DatePipe, NgClass } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, @@ -52,9 +52,7 @@ import { Subject, debounceTime, takeUntil, tap } from 'rxjs'; MatInputModule, TextFieldModule, NgClass, - NgIf, MatDatepickerModule, - NgFor, MatCheckboxModule, DatePipe, ], diff --git a/src/app/modules/admin/apps/tasks/details/details.component.html b/src/app/modules/admin/apps/tasks/details/details.component.html index aa325667..75b4f59a 100644 --- a/src/app/modules/admin/apps/tasks/details/details.component.html +++ b/src/app/modules/admin/apps/tasks/details/details.component.html @@ -8,17 +8,17 @@
@@ -82,13 +82,11 @@
Tags
- - + @if (task.tags.length) { + @for ( + tag of task.tags | fuseFindByKey: 'id' : tags; + track trackByFn($index, tag) + ) {
@@ -97,14 +95,14 @@ >{{ tag.title }}
-
-
+ } + }
- + @if (task.tags.length) { Edit - + } - + @if (!task.tags.length) { Add - + } @@ -157,31 +155,31 @@ mat-icon-button (click)="toggleTagsEditMode()" > - - + @if (!tagsEditMode) { + + } + @if (tagsEditMode) { + + }
- - + @if (!tagsEditMode) { + @for ( + tag of filteredTags; + track trackByFn($index, tag) + ) {
-
-
+ } + } - + @if (tagsEditMode) {
- + @for ( + tag of filteredTags; + track trackByFn($index, tag) + ) {
-
+ }
-
+ } -
- -
- Create "{{ newTagInput.value }}" + matRipple + > + +
+ Create "{{ + newTagInput.value + }}" +
-
+ }
@@ -290,21 +287,21 @@ 'bg-gray-200 text-gray-800 dark:bg-gray-500 dark:text-gray-100': task.priority === 1, 'bg-red-200 text-red-800 dark:bg-red-500 dark:text-red-100': - task.priority === 2 + task.priority === 2, }" [matMenuTriggerFor]="priorityMenu" > - + @if (task.priority === 0) { Low - + } - + @if (task.priority === 1) { Normal - + } - + @if (task.priority === 2) { High - + }
@@ -388,7 +385,7 @@ 'bg-green-200 text-green-800 dark:bg-green-500 dark:text-green-100': task.dueDate && !isOverdue(), 'bg-red-200 text-red-800 dark:bg-red-500 dark:text-red-100': - task.dueDate && isOverdue() + task.dueDate && isOverdue(), }" (click)="dueDatePicker.open()" > @@ -397,12 +394,12 @@ [svgIcon]="'heroicons_solid:calendar'" > - {{ - task.dueDate | date: 'longDate' - }} - Not set + @if (task.dueDate) { + {{ task.dueDate | date: 'longDate' }} + } + @if (!task.dueDate) { + Not set + }