taxtank-core 0.28.96 → 0.28.97
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.
- package/bundles/taxtank-core.umd.js +38 -20
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/models/user/user-roles.const.js +9 -6
- package/esm2015/lib/models/user/user.js +15 -4
- package/esm2015/lib/services/http/subscription/subscription.service.js +8 -2
- package/fesm2015/taxtank-core.js +34 -16
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/models/user/user-roles.const.d.ts +3 -0
- package/lib/models/user/user.d.ts +5 -2
- package/package.json +1 -1
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
import { UserRolesEnum } from '../../db/Enums/user-roles.enum';
|
|
2
|
+
/**
|
|
3
|
+
* role hierarchy
|
|
4
|
+
*/
|
|
2
5
|
export const USER_ROLES = {
|
|
3
|
-
ROLE_FIRM_OWNER: [UserRolesEnum.FIRM_OWNER],
|
|
4
|
-
ROLE_FIRM_MANAGER: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.
|
|
5
|
-
|
|
6
|
+
ROLE_FIRM_OWNER: [UserRolesEnum.FIRM_OWNER, UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
7
|
+
ROLE_FIRM_MANAGER: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
8
|
+
ROLE_EMPLOYEE: [UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
9
|
+
ROLE_ACCOUNTANT: [UserRolesEnum.ACCOUNTANT],
|
|
10
|
+
ROLE_ADVISOR: [UserRolesEnum.ADVISOR],
|
|
6
11
|
ROLE_CLIENT: [UserRolesEnum.CLIENT],
|
|
7
|
-
ROLE_USER: [UserRolesEnum.USER],
|
|
8
12
|
ROLE_USER_SUBSCRIPTION: [UserRolesEnum.SUBSCRIPTION],
|
|
9
13
|
ROLE_USER_WORK: [UserRolesEnum.WORK_TANK],
|
|
10
14
|
ROLE_USER_PROPERTY: [UserRolesEnum.PROPERTY_TANK],
|
|
11
15
|
ROLE_USER_SOLE: [UserRolesEnum.SOLE_TANK],
|
|
12
|
-
ROLE_PREVIOUS_ADMIN: [UserRolesEnum.SWITCH_USER]
|
|
13
16
|
};
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1yb2xlcy5jb25zdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9tb2RlbHMvdXNlci91c2VyLXJvbGVzLmNvbnN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUUvRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBcUM7SUFDMUQsZUFBZSxFQUFFLENBQUMsYUFBYSxDQUFDLFVBQVUsRUFBRSxhQUFhLENBQUMsWUFBWSxFQUFFLGFBQWEsQ0FBQyxVQUFVLEVBQUUsYUFBYSxDQUFDLE9BQU8sQ0FBQztJQUN4SCxpQkFBaUIsRUFBRSxDQUFDLGFBQWEsQ0FBQyxZQUFZLEVBQUUsYUFBYSxDQUFDLFVBQVUsRUFBRSxhQUFhLENBQUMsT0FBTyxDQUFDO0lBQ2hHLGFBQWEsRUFBRSxDQUFDLGFBQWEsQ0FBQyxVQUFVLEVBQUUsYUFBYSxDQUFDLE9BQU8sQ0FBQztJQUNoRSxlQUFlLEVBQUUsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDO0lBQzNDLFlBQVksRUFBRSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUM7SUFDckMsV0FBVyxFQUFFLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztJQUNuQyxzQkFBc0IsRUFBRSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7SUFDcEQsY0FBYyxFQUFFLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQztJQUN6QyxrQkFBa0IsRUFBRSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUM7SUFDakQsY0FBYyxFQUFFLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQztDQUMxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVXNlclJvbGVzRW51bSB9IGZyb20gJy4uLy4uL2RiL0VudW1zL3VzZXItcm9sZXMuZW51bSc7XG5cbi8qKlxuICogcm9sZSBoaWVyYXJjaHlcbiAqL1xuZXhwb3J0IGNvbnN0IFVTRVJfUk9MRVM6IHtba2V5OiBzdHJpbmddOiBVc2VyUm9sZXNFbnVtW119ID0ge1xuICBST0xFX0ZJUk1fT1dORVI6IFtVc2VyUm9sZXNFbnVtLkZJUk1fT1dORVIsIFVzZXJSb2xlc0VudW0uRklSTV9NQU5BR0VSLCBVc2VyUm9sZXNFbnVtLkFDQ09VTlRBTlQsIFVzZXJSb2xlc0VudW0uQURWSVNPUl0sXG4gIFJPTEVfRklSTV9NQU5BR0VSOiBbVXNlclJvbGVzRW51bS5GSVJNX01BTkFHRVIsIFVzZXJSb2xlc0VudW0uQUNDT1VOVEFOVCwgVXNlclJvbGVzRW51bS5BRFZJU09SXSxcbiAgUk9MRV9FTVBMT1lFRTogW1VzZXJSb2xlc0VudW0uQUNDT1VOVEFOVCwgVXNlclJvbGVzRW51bS5BRFZJU09SXSxcbiAgUk9MRV9BQ0NPVU5UQU5UOiBbVXNlclJvbGVzRW51bS5BQ0NPVU5UQU5UXSxcbiAgUk9MRV9BRFZJU09SOiBbVXNlclJvbGVzRW51bS5BRFZJU09SXSxcbiAgUk9MRV9DTElFTlQ6IFtVc2VyUm9sZXNFbnVtLkNMSUVOVF0sXG4gIFJPTEVfVVNFUl9TVUJTQ1JJUFRJT046IFtVc2VyUm9sZXNFbnVtLlNVQlNDUklQVElPTl0sXG4gIFJPTEVfVVNFUl9XT1JLOiBbVXNlclJvbGVzRW51bS5XT1JLX1RBTktdLFxuICBST0xFX1VTRVJfUFJPUEVSVFk6IFtVc2VyUm9sZXNFbnVtLlBST1BFUlRZX1RBTktdLFxuICBST0xFX1VTRVJfU09MRTogW1VzZXJSb2xlc0VudW0uU09MRV9UQU5LXSxcbn07XG4iXX0=
|
|
@@ -2,7 +2,7 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { User as BaseUser } from '../../db/Models/user/user';
|
|
3
3
|
import { UserStatusEnum } from '../../db/Enums/user-status.enum';
|
|
4
4
|
import { UserRolesEnum } from '../../db/Enums/user-roles.enum';
|
|
5
|
-
import { Address } from '../address
|
|
5
|
+
import { Address } from '../address';
|
|
6
6
|
import { USER_WORK_POSITION } from './user-work-position.const';
|
|
7
7
|
import { ClientDetails } from '../client/client-details';
|
|
8
8
|
import { EmployeeDetails } from '../employee/employee-details';
|
|
@@ -10,6 +10,9 @@ import { Type } from 'class-transformer';
|
|
|
10
10
|
import { Phone } from '../phone/phone';
|
|
11
11
|
import { ServiceSubscription } from '../service-subscription/service-subscription';
|
|
12
12
|
import { SoleDetails } from '../sole';
|
|
13
|
+
import intersection from 'lodash/intersection';
|
|
14
|
+
import flatten from 'lodash/flatten';
|
|
15
|
+
import { USER_ROLES } from './user-roles.const';
|
|
13
16
|
export class User extends BaseUser {
|
|
14
17
|
get fullName() {
|
|
15
18
|
return `${this.firstName} ${this.lastName}`;
|
|
@@ -36,8 +39,16 @@ export class User extends BaseUser {
|
|
|
36
39
|
return '';
|
|
37
40
|
}
|
|
38
41
|
}
|
|
39
|
-
|
|
40
|
-
|
|
42
|
+
/**
|
|
43
|
+
* search roles including hierarchy
|
|
44
|
+
*/
|
|
45
|
+
hasRoles(roles) {
|
|
46
|
+
roles = roles instanceof Array ? roles : [roles];
|
|
47
|
+
if (!roles.length) {
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
roles = flatten(roles.map((role) => USER_ROLES[role]));
|
|
51
|
+
return !!intersection(this.roles, roles).length;
|
|
41
52
|
}
|
|
42
53
|
isOnboarding() {
|
|
43
54
|
return this.status === UserStatusEnum.ON_BOARDING;
|
|
@@ -139,4 +150,4 @@ __decorate([
|
|
|
139
150
|
__decorate([
|
|
140
151
|
Type(() => User)
|
|
141
152
|
], User.prototype, "clients", void 0);
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/user/user.ts"],"names":[],"mappings":"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","sourcesContent":["import { User as BaseUser } from '../../db/Models/user/user';\nimport { UserStatusEnum } from '../../db/Enums/user-status.enum';\nimport { UserRolesEnum } from '../../db/Enums/user-roles.enum';\nimport { Address } from '../address/address';\nimport { USER_WORK_POSITION } from './user-work-position.const';\nimport { ClientDetails } from '../client/client-details';\nimport { EmployeeDetails } from '../employee/employee-details';\nimport { Type } from 'class-transformer';\nimport { Phone } from '../phone/phone';\nimport { ServiceSubscription } from '../service-subscription/service-subscription';\nimport { ServiceSubscriptionItem } from '../service-subscription/service-subscription-item';\nimport { Photoable } from '../../interfaces/photoable';\nimport { SoleDetails } from '../sole';\n\nexport class User extends BaseUser implements Photoable {\n  @Type(() => ServiceSubscription)\n  subscriptions: ServiceSubscription[];\n\n  @Type(() => ClientDetails)\n  clientDetails: ClientDetails;\n\n  @Type(() => EmployeeDetails)\n  employeeDetails: EmployeeDetails;\n\n  @Type(() => SoleDetails)\n  soleDetails: SoleDetails;\n\n  @Type(() => Address)\n  address: Address;\n\n  @Type(() => Phone)\n  phone: Phone;\n\n  @Type(() => Date)\n  createdAt: Date;\n\n  // @TODO Alex remove this hack\n  @Type(() => User)\n  clients: User[];\n\n  get fullName(): string {\n    return `${this.firstName} ${this.lastName}`;\n  }\n\n  get activeSubscription(): ServiceSubscription {\n    return this.subscriptions.find((ss: ServiceSubscription): boolean => ss.isActive);\n  }\n\n  get lastSubscription(): ServiceSubscription {\n    return this.subscriptions[this.subscriptions.length - 1];\n  }\n\n  /**\n   * @TODO refactor\n   *\n   */\n  get position(): string {\n    switch (true) {\n      case this.isFirmOwner():\n        return USER_WORK_POSITION[UserRolesEnum.FIRM_OWNER];\n      case this.isManager():\n        return USER_WORK_POSITION[UserRolesEnum.FIRM_MANAGER];\n      case this.isEmployee():\n        return USER_WORK_POSITION[UserRolesEnum.EMPLOYEE];\n      default:\n        return '';\n    }\n  }\n\n  hasRole(role: UserRolesEnum): boolean {\n    return this.roles.includes(role);\n  }\n\n  isOnboarding(): boolean {\n    return this.status === UserStatusEnum.ON_BOARDING;\n  }\n\n  hasSubscription(): boolean {\n    return this.roles.includes(UserRolesEnum.SUBSCRIPTION);\n  }\n\n  isLoggedIn(): boolean {\n    return this.id === +localStorage.getItem('userId');\n  }\n\n  isClient(): boolean {\n    return this.roles.includes(UserRolesEnum.CLIENT);\n  }\n\n  isEmployee(): boolean {\n    return this.isAccountant() || this.isAdvisor();\n  }\n\n  isAccountant(): boolean {\n    return this.roles.includes(UserRolesEnum.ACCOUNTANT);\n  }\n\n  isAdvisor(): boolean {\n    return this.roles.includes(UserRolesEnum.ADVISOR);\n  }\n\n  isImpersonator(): boolean {\n    return this.roles.includes(UserRolesEnum.SWITCH_USER);\n  }\n\n  /**\n   * Check if current user is firm owner\n   */\n  isFirmOwner(): boolean {\n    return this.roles.includes(UserRolesEnum.FIRM_OWNER);\n  }\n\n  /**\n   * Check if current user is firm manager\n   */\n  isManager(): boolean {\n    return this.roles.includes(UserRolesEnum.FIRM_MANAGER) || this.roles.includes(UserRolesEnum.FIRM_OWNER);\n  }\n\n  /**\n   * check if user has property tank access\n   */\n  hasPropertyTank(): boolean {\n    return this.roles ?\n      this.roles.includes(UserRolesEnum.PROPERTY_TANK) :\n      !!this.getSubscriptionRole(UserRolesEnum.PROPERTY_TANK);\n  }\n\n  /**\n   * check if user has property tank access\n   */\n  hasWorkTank(): boolean {\n    return this.roles ?\n      this.roles.includes(UserRolesEnum.WORK_TANK) :\n      !!this.getSubscriptionRole(UserRolesEnum.WORK_TANK);\n  }\n\n  /**\n   * Get user subscription role by provided role type\n   * @param roleType by which role should be returned\n   */\n  getSubscriptionRole(roleType: UserRolesEnum): ServiceSubscriptionItem {\n    /**\n     * Add @TODO for Alex to check if we should use getLastSubscription here\n     */\n    return this.activeSubscription?.items\n      .find((subscriptionItem: ServiceSubscriptionItem) => subscriptionItem.price.product.role.includes(roleType));\n  }\n\n  /**\n   * Get user's photo link\n   */\n  getPhoto(): string {\n    return this.photo;\n  }\n\n  /**\n   * get user's initials\n   */\n  getPhotoPlaceholder(): string {\n    return `${this.firstName[0].toUpperCase()}${this.lastName[0].toUpperCase()}`;\n  }\n}\n\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/user/user.ts"],"names":[],"mappings":"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","sourcesContent":["import { User as BaseUser } from '../../db/Models/user/user';\nimport { UserStatusEnum } from '../../db/Enums/user-status.enum';\nimport { UserRolesEnum } from '../../db/Enums/user-roles.enum';\nimport { Address } from '../address';\nimport { USER_WORK_POSITION } from './user-work-position.const';\nimport { ClientDetails } from '../client/client-details';\nimport { EmployeeDetails } from '../employee/employee-details';\nimport { Type } from 'class-transformer';\nimport { Phone } from '../phone/phone';\nimport { ServiceSubscription } from '../service-subscription/service-subscription';\nimport { ServiceSubscriptionItem } from '../service-subscription/service-subscription-item';\nimport { Photoable } from '../../interfaces/photoable';\nimport { SoleDetails } from '../sole';\nimport intersection from 'lodash/intersection';\nimport flatten from 'lodash/flatten';\nimport {USER_ROLES} from './user-roles.const';\n\nexport class User extends BaseUser implements Photoable {\n  @Type(() => ServiceSubscription)\n  subscriptions: ServiceSubscription[];\n\n  @Type(() => ClientDetails)\n  clientDetails: ClientDetails;\n\n  @Type(() => EmployeeDetails)\n  employeeDetails: EmployeeDetails;\n\n  @Type(() => SoleDetails)\n  soleDetails: SoleDetails;\n\n  @Type(() => Address)\n  address: Address;\n\n  @Type(() => Phone)\n  phone: Phone;\n\n  @Type(() => Date)\n  createdAt: Date;\n\n  // @TODO Alex remove this hack\n  @Type(() => User)\n  clients: User[];\n\n  get fullName(): string {\n    return `${this.firstName} ${this.lastName}`;\n  }\n\n  get activeSubscription(): ServiceSubscription {\n    return this.subscriptions.find((ss: ServiceSubscription): boolean => ss.isActive);\n  }\n\n  get lastSubscription(): ServiceSubscription {\n    return this.subscriptions[this.subscriptions.length - 1];\n  }\n\n  /**\n   * @TODO refactor\n   *\n   */\n  get position(): string {\n    switch (true) {\n      case this.isFirmOwner():\n        return USER_WORK_POSITION[UserRolesEnum.FIRM_OWNER];\n      case this.isManager():\n        return USER_WORK_POSITION[UserRolesEnum.FIRM_MANAGER];\n      case this.isEmployee():\n        return USER_WORK_POSITION[UserRolesEnum.EMPLOYEE];\n      default:\n        return '';\n    }\n  }\n\n  /**\n   * search roles including hierarchy\n   */\n  hasRoles(roles: UserRolesEnum | UserRolesEnum[]): boolean {\n    roles = roles instanceof Array ? roles : [roles];\n    if (!roles.length) {\n      return true;\n    }\n\n    roles = flatten(roles.map((role) => USER_ROLES[role]));\n    return !!intersection(this.roles, roles).length;\n  }\n\n  isOnboarding(): boolean {\n    return this.status === UserStatusEnum.ON_BOARDING;\n  }\n\n  hasSubscription(): boolean {\n    return this.roles.includes(UserRolesEnum.SUBSCRIPTION);\n  }\n\n  isLoggedIn(): boolean {\n    return this.id === +localStorage.getItem('userId');\n  }\n\n  isClient(): boolean {\n    return this.roles.includes(UserRolesEnum.CLIENT);\n  }\n\n  isEmployee(): boolean {\n    return this.isAccountant() || this.isAdvisor();\n  }\n\n  isAccountant(): boolean {\n    return this.roles.includes(UserRolesEnum.ACCOUNTANT);\n  }\n\n  isAdvisor(): boolean {\n    return this.roles.includes(UserRolesEnum.ADVISOR);\n  }\n\n  isImpersonator(): boolean {\n    return this.roles.includes(UserRolesEnum.SWITCH_USER);\n  }\n\n  /**\n   * Check if current user is firm owner\n   */\n  isFirmOwner(): boolean {\n    return this.roles.includes(UserRolesEnum.FIRM_OWNER);\n  }\n\n  /**\n   * Check if current user is firm manager\n   */\n  isManager(): boolean {\n    return this.roles.includes(UserRolesEnum.FIRM_MANAGER) || this.roles.includes(UserRolesEnum.FIRM_OWNER);\n  }\n\n  /**\n   * check if user has property tank access\n   */\n  hasPropertyTank(): boolean {\n    return this.roles ?\n      this.roles.includes(UserRolesEnum.PROPERTY_TANK) :\n      !!this.getSubscriptionRole(UserRolesEnum.PROPERTY_TANK);\n  }\n\n  /**\n   * check if user has property tank access\n   */\n  hasWorkTank(): boolean {\n    return this.roles ?\n      this.roles.includes(UserRolesEnum.WORK_TANK) :\n      !!this.getSubscriptionRole(UserRolesEnum.WORK_TANK);\n  }\n\n  /**\n   * Get user subscription role by provided role type\n   * @param roleType by which role should be returned\n   */\n  getSubscriptionRole(roleType: UserRolesEnum): ServiceSubscriptionItem {\n    /**\n     * Add @TODO for Alex to check if we should use getLastSubscription here\n     */\n    return this.activeSubscription?.items\n      .find((subscriptionItem: ServiceSubscriptionItem) => subscriptionItem.price.product.role.includes(roleType));\n  }\n\n  /**\n   * Get user's photo link\n   */\n  getPhoto(): string {\n    return this.photo;\n  }\n\n  /**\n   * get user's initials\n   */\n  getPhotoPlaceholder(): string {\n    return `${this.firstName[0].toUpperCase()}${this.lastName[0].toUpperCase()}`;\n  }\n}\n\n"]}
|
|
@@ -93,7 +93,13 @@ export class SubscriptionService {
|
|
|
93
93
|
}
|
|
94
94
|
listenSubscriptions() {
|
|
95
95
|
this.sseService.on(`serviceSubscriptions`)
|
|
96
|
-
.pipe(map((event) =>
|
|
96
|
+
.pipe(map((event) => {
|
|
97
|
+
// @TODO for some reason mercure return object when there is only one item
|
|
98
|
+
if (event['items'] instanceof Object) {
|
|
99
|
+
event['items'] = Object.values(event['items']);
|
|
100
|
+
}
|
|
101
|
+
return plainToClass(ServiceSubscription, event);
|
|
102
|
+
}))
|
|
97
103
|
.subscribe((subscription) => {
|
|
98
104
|
this._serviceSubscription = subscription;
|
|
99
105
|
this.serviceSubscriptionSubject.next(this._serviceSubscription);
|
|
@@ -116,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
116
122
|
type: Inject,
|
|
117
123
|
args: ['environment']
|
|
118
124
|
}] }]; } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"subscription.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/http/subscription/subscription.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\nimport {HttpClient} from '@angular/common/http';\nimport {Observable, ReplaySubject} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {loadStripe} from '@stripe/stripe-js';\nimport {plainToClass} from 'class-transformer';\nimport {ServiceSubscription} from '../../../models/service-subscription/service-subscription';\nimport {ServicePayment} from '../../../models/service-subscription/service-payment';\nimport {EventDispatcherService} from '../../event/event-dispatcher.service';\nimport {ServiceSubscriptionItem} from '../../../models/service-subscription/service-subscription-item';\nimport {AppEvent} from '../../../models/event/app-event';\nimport {AppEventTypeEnum} from '../../../models/event/app-event-type.enum';\nimport {SseService} from '../../event/sse.service';\nimport {ToastService} from '../../toast/toast.service';\n\n/**\n * @TODO Alex refactor\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class SubscriptionService {\n  _serviceSubscription: ServiceSubscription;\n  serviceSubscriptionSubject: ReplaySubject<ServiceSubscription> = new ReplaySubject<ServiceSubscription>(1);\n  stripe: any;\n  servicePaymentsSubject: ReplaySubject<ServicePayment[]> = new ReplaySubject<ServicePayment[]>(1);\n  _servicePayments: ServicePayment[];\n\n  constructor(\n    private http: HttpClient,\n    private eventDispatcherService: EventDispatcherService,\n    private sseService: SseService,\n    private toastService: ToastService,\n    @Inject('environment') private environment: any\n  ) {\n    this.listenSubscriptions();\n  }\n\n  getSubscription(force: boolean = false): Observable<ServiceSubscription> {\n    if (this._serviceSubscription === undefined || force) {\n      this._serviceSubscription = null;\n      this.http.get(`${this.environment.apiV2}/subscriptions/last`)\n        .pipe(\n          map((response: any) => {\n            return plainToClass(ServiceSubscription, response);\n          })\n        )\n        .subscribe((subsciption: ServiceSubscription) => {\n          this._serviceSubscription = subsciption;\n          this.serviceSubscriptionSubject.next(this._serviceSubscription);\n        });\n    }\n\n    return this.serviceSubscriptionSubject.asObservable();\n  }\n\n  /**\n   * redirect to stripe payment page\n   */\n  async checkoutRedirect(subscription: ServiceSubscription): Promise<any> {\n    const stripe: any = await loadStripe(this.environment.stripePk);\n\n    this.http.post(`${this.environment.apiV2}/stripe/checkout-session`, {\n      items: subscription.items,\n      successUrl: window.location.href,\n      cancelUrl: window.location.href\n    })\n      .subscribe((session: string) => {\n        // @Todo remove user TRIAL status\n        stripe.redirectToCheckout({sessionId: session});\n      });\n  }\n\n  /**\n   * redirect to stripe billing page\n   */\n  billingRedirect(returnUrl: string): void {\n    this.http.get(`${this.environment.apiV2}/stripe/billing-portal-session`, {\n      params: {returnUrl}\n    }).subscribe((response: any) => {\n      window.location.replace(response.url);\n    });\n  }\n\n  getPayments(): Observable<ServicePayment[]> {\n    if (!this._servicePayments) {\n      this.http.get(`${this.environment.apiV2}/service-payments`).subscribe((response: object[]) => {\n        this._servicePayments = response.map((item: object) => plainToClass(ServicePayment, item));\n        this.servicePaymentsSubject.next(this._servicePayments);\n      });\n    }\n\n    return this.servicePaymentsSubject.asObservable();\n  }\n\n  /**\n   * Get difference between current subscription and selected new subscription\n   */\n  getProrationCost(items: ServiceSubscriptionItem[]): Observable<number> {\n    return this.http.post(`${this.environment.apiV2}/subscriptions/proration-cost`, items).pipe(\n      map((prorationCost: number) => {\n        return prorationCost;\n      })\n    );\n  }\n\n  /**\n   * Change subscription plan\n   */\n  changeSubscription(items: ServiceSubscriptionItem[]): Observable<object> {\n    return this.http.put(`${this.environment.apiV2}/subscriptions/items`, items);\n  }\n\n  private listenSubscriptions(): void {\n    this.sseService.on(`serviceSubscriptions`)\n      .pipe(\n        map((event: object): ServiceSubscription => plainToClass(ServiceSubscription, event))\n      )\n      .subscribe((subscription: ServiceSubscription): void => {\n        this._serviceSubscription = subscription;\n        this.serviceSubscriptionSubject.next(this._serviceSubscription);\n        // @TODO vik remove timeout when user api moved to api platform\n        setTimeout(() => {\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.SERVICE_SUBSCRIPTION_UPDATED, null));\n          this.toastService.success('Subscription successfully updated');\n        }, 2000);\n      });\n  }\n}\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"subscription.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/http/subscription/subscription.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\nimport {HttpClient} from '@angular/common/http';\nimport {Observable, ReplaySubject} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {loadStripe} from '@stripe/stripe-js';\nimport {plainToClass} from 'class-transformer';\nimport {ServiceSubscription} from '../../../models/service-subscription/service-subscription';\nimport {ServicePayment} from '../../../models/service-subscription/service-payment';\nimport {EventDispatcherService} from '../../event/event-dispatcher.service';\nimport {ServiceSubscriptionItem} from '../../../models/service-subscription/service-subscription-item';\nimport {AppEvent} from '../../../models/event/app-event';\nimport {AppEventTypeEnum} from '../../../models/event/app-event-type.enum';\nimport {SseService} from '../../event/sse.service';\nimport {ToastService} from '../../toast/toast.service';\n\n/**\n * @TODO Alex refactor\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class SubscriptionService {\n  _serviceSubscription: ServiceSubscription;\n  serviceSubscriptionSubject: ReplaySubject<ServiceSubscription> = new ReplaySubject<ServiceSubscription>(1);\n  stripe: any;\n  servicePaymentsSubject: ReplaySubject<ServicePayment[]> = new ReplaySubject<ServicePayment[]>(1);\n  _servicePayments: ServicePayment[];\n\n  constructor(\n    private http: HttpClient,\n    private eventDispatcherService: EventDispatcherService,\n    private sseService: SseService,\n    private toastService: ToastService,\n    @Inject('environment') private environment: any\n  ) {\n    this.listenSubscriptions();\n  }\n\n  getSubscription(force: boolean = false): Observable<ServiceSubscription> {\n    if (this._serviceSubscription === undefined || force) {\n      this._serviceSubscription = null;\n      this.http.get(`${this.environment.apiV2}/subscriptions/last`)\n        .pipe(\n          map((response: any) => {\n            return plainToClass(ServiceSubscription, response);\n          })\n        )\n        .subscribe((subsciption: ServiceSubscription) => {\n          this._serviceSubscription = subsciption;\n          this.serviceSubscriptionSubject.next(this._serviceSubscription);\n        });\n    }\n\n    return this.serviceSubscriptionSubject.asObservable();\n  }\n\n  /**\n   * redirect to stripe payment page\n   */\n  async checkoutRedirect(subscription: ServiceSubscription): Promise<any> {\n    const stripe: any = await loadStripe(this.environment.stripePk);\n\n    this.http.post(`${this.environment.apiV2}/stripe/checkout-session`, {\n      items: subscription.items,\n      successUrl: window.location.href,\n      cancelUrl: window.location.href\n    })\n      .subscribe((session: string) => {\n        // @Todo remove user TRIAL status\n        stripe.redirectToCheckout({sessionId: session});\n      });\n  }\n\n  /**\n   * redirect to stripe billing page\n   */\n  billingRedirect(returnUrl: string): void {\n    this.http.get(`${this.environment.apiV2}/stripe/billing-portal-session`, {\n      params: {returnUrl}\n    }).subscribe((response: any) => {\n      window.location.replace(response.url);\n    });\n  }\n\n  getPayments(): Observable<ServicePayment[]> {\n    if (!this._servicePayments) {\n      this.http.get(`${this.environment.apiV2}/service-payments`).subscribe((response: object[]) => {\n        this._servicePayments = response.map((item: object) => plainToClass(ServicePayment, item));\n        this.servicePaymentsSubject.next(this._servicePayments);\n      });\n    }\n\n    return this.servicePaymentsSubject.asObservable();\n  }\n\n  /**\n   * Get difference between current subscription and selected new subscription\n   */\n  getProrationCost(items: ServiceSubscriptionItem[]): Observable<number> {\n    return this.http.post(`${this.environment.apiV2}/subscriptions/proration-cost`, items).pipe(\n      map((prorationCost: number) => {\n        return prorationCost;\n      })\n    );\n  }\n\n  /**\n   * Change subscription plan\n   */\n  changeSubscription(items: ServiceSubscriptionItem[]): Observable<object> {\n    return this.http.put(`${this.environment.apiV2}/subscriptions/items`, items);\n  }\n\n  private listenSubscriptions(): void {\n    this.sseService.on(`serviceSubscriptions`)\n      .pipe(\n        map((event: object): ServiceSubscription => {\n          // @TODO for some reason mercure return object when there is only one item\n          if (event['items'] instanceof Object) {\n            event['items'] = Object.values(event['items']);\n          }\n\n          return plainToClass(ServiceSubscription, event);\n        })\n      )\n      .subscribe((subscription: ServiceSubscription): void => {\n        this._serviceSubscription = subscription;\n        this.serviceSubscriptionSubject.next(this._serviceSubscription);\n        // @TODO vik remove timeout when user api moved to api platform\n        setTimeout(() => {\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.SERVICE_SUBSCRIPTION_UPDATED, null));\n          this.toastService.success('Subscription successfully updated');\n        }, 2000);\n      });\n  }\n}\n"]}
|
package/fesm2015/taxtank-core.js
CHANGED
|
@@ -18,6 +18,7 @@ import concat from 'lodash/concat';
|
|
|
18
18
|
import { __decorate, __awaiter } from 'tslib';
|
|
19
19
|
import * as moment$1 from 'moment';
|
|
20
20
|
import { DateRange, extendMoment } from 'moment-range';
|
|
21
|
+
import intersection from 'lodash/intersection';
|
|
21
22
|
import cloneDeep$1 from 'lodash/cloneDeep';
|
|
22
23
|
import { throwError as throwError$1 } from 'rxjs/internal/observable/throwError';
|
|
23
24
|
import clone from 'lodash/clone';
|
|
@@ -4162,6 +4163,22 @@ __decorate([
|
|
|
4162
4163
|
Type(() => Date)
|
|
4163
4164
|
], BasReport.prototype, "dateTo", void 0);
|
|
4164
4165
|
|
|
4166
|
+
/**
|
|
4167
|
+
* role hierarchy
|
|
4168
|
+
*/
|
|
4169
|
+
const USER_ROLES = {
|
|
4170
|
+
ROLE_FIRM_OWNER: [UserRolesEnum.FIRM_OWNER, UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
4171
|
+
ROLE_FIRM_MANAGER: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
4172
|
+
ROLE_EMPLOYEE: [UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
4173
|
+
ROLE_ACCOUNTANT: [UserRolesEnum.ACCOUNTANT],
|
|
4174
|
+
ROLE_ADVISOR: [UserRolesEnum.ADVISOR],
|
|
4175
|
+
ROLE_CLIENT: [UserRolesEnum.CLIENT],
|
|
4176
|
+
ROLE_USER_SUBSCRIPTION: [UserRolesEnum.SUBSCRIPTION],
|
|
4177
|
+
ROLE_USER_WORK: [UserRolesEnum.WORK_TANK],
|
|
4178
|
+
ROLE_USER_PROPERTY: [UserRolesEnum.PROPERTY_TANK],
|
|
4179
|
+
ROLE_USER_SOLE: [UserRolesEnum.SOLE_TANK],
|
|
4180
|
+
};
|
|
4181
|
+
|
|
4165
4182
|
class User extends User$1 {
|
|
4166
4183
|
get fullName() {
|
|
4167
4184
|
return `${this.firstName} ${this.lastName}`;
|
|
@@ -4188,8 +4205,16 @@ class User extends User$1 {
|
|
|
4188
4205
|
return '';
|
|
4189
4206
|
}
|
|
4190
4207
|
}
|
|
4191
|
-
|
|
4192
|
-
|
|
4208
|
+
/**
|
|
4209
|
+
* search roles including hierarchy
|
|
4210
|
+
*/
|
|
4211
|
+
hasRoles(roles) {
|
|
4212
|
+
roles = roles instanceof Array ? roles : [roles];
|
|
4213
|
+
if (!roles.length) {
|
|
4214
|
+
return true;
|
|
4215
|
+
}
|
|
4216
|
+
roles = flatten(roles.map((role) => USER_ROLES[role]));
|
|
4217
|
+
return !!intersection(this.roles, roles).length;
|
|
4193
4218
|
}
|
|
4194
4219
|
isOnboarding() {
|
|
4195
4220
|
return this.status === UserStatusEnum.ON_BOARDING;
|
|
@@ -10095,19 +10120,6 @@ class Occupation$1 extends AbstractModel {
|
|
|
10095
10120
|
class Occupation extends Occupation$1 {
|
|
10096
10121
|
}
|
|
10097
10122
|
|
|
10098
|
-
const USER_ROLES = {
|
|
10099
|
-
ROLE_FIRM_OWNER: [UserRolesEnum.FIRM_OWNER],
|
|
10100
|
-
ROLE_FIRM_MANAGER: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.FIRM_OWNER],
|
|
10101
|
-
ROLE_ACCOUNTANT: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.FIRM_OWNER, UserRolesEnum.ACCOUNTANT],
|
|
10102
|
-
ROLE_CLIENT: [UserRolesEnum.CLIENT],
|
|
10103
|
-
ROLE_USER: [UserRolesEnum.USER],
|
|
10104
|
-
ROLE_USER_SUBSCRIPTION: [UserRolesEnum.SUBSCRIPTION],
|
|
10105
|
-
ROLE_USER_WORK: [UserRolesEnum.WORK_TANK],
|
|
10106
|
-
ROLE_USER_PROPERTY: [UserRolesEnum.PROPERTY_TANK],
|
|
10107
|
-
ROLE_USER_SOLE: [UserRolesEnum.SOLE_TANK],
|
|
10108
|
-
ROLE_PREVIOUS_ADMIN: [UserRolesEnum.SWITCH_USER]
|
|
10109
|
-
};
|
|
10110
|
-
|
|
10111
10123
|
/**
|
|
10112
10124
|
* Class with basic information about registering user
|
|
10113
10125
|
*/
|
|
@@ -13079,7 +13091,13 @@ class SubscriptionService {
|
|
|
13079
13091
|
}
|
|
13080
13092
|
listenSubscriptions() {
|
|
13081
13093
|
this.sseService.on(`serviceSubscriptions`)
|
|
13082
|
-
.pipe(map((event) =>
|
|
13094
|
+
.pipe(map((event) => {
|
|
13095
|
+
// @TODO for some reason mercure return object when there is only one item
|
|
13096
|
+
if (event['items'] instanceof Object) {
|
|
13097
|
+
event['items'] = Object.values(event['items']);
|
|
13098
|
+
}
|
|
13099
|
+
return plainToClass(ServiceSubscription, event);
|
|
13100
|
+
}))
|
|
13083
13101
|
.subscribe((subscription) => {
|
|
13084
13102
|
this._serviceSubscription = subscription;
|
|
13085
13103
|
this.serviceSubscriptionSubject.next(this._serviceSubscription);
|