techlify-inventory-common 18.24.1 → 18.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/esm2022/lib/inventory-common/inventory-common-routing.module.mjs +2 -2
  2. package/esm2022/lib/inventory-common/product/product-view-page/product-view-page.component.mjs +4 -4
  3. package/esm2022/lib/inventory-common/product/product.module.mjs +5 -9
  4. package/esm2022/lib/inventory-common/reports/inventory-value-report/inventory-value-report.component.mjs +5 -3
  5. package/esm2022/lib/inventory-common/stock-issuances/stock-issuance-delete-button/stock-issuance-delete-button.component.mjs +8 -8
  6. package/esm2022/lib/inventory-common/stock-issuances/stock-issue-form/stock-issue-form/stock-issue-form.component.mjs +9 -9
  7. package/esm2022/lib/inventory-common/stock-issuances/stock-issue-list/stock-issue-list.component.mjs +179 -0
  8. package/esm2022/lib/inventory-common/stock-issuances/stock-issue-list/stock-issue-list.module.mjs +67 -0
  9. package/esm2022/lib/inventory-common/stock-issuances/stock-issue-routing.module.mjs +36 -0
  10. package/esm2022/lib/inventory-common/stock-issuances/stock-issue-view/stock-issue-view.component.mjs +68 -0
  11. package/esm2022/lib/inventory-common/stock-issuances/stock-issue.module.mjs +67 -0
  12. package/esm2022/lib/inventory-common/stock-issuances/stock-issue.service.mjs +18 -0
  13. package/esm2022/lib/inventory-common/stock-receipts/stock-receipt-view/stock-receipt-view.component.mjs +3 -3
  14. package/esm2022/lib/inventory-common/stock-receipts/stock-receipts-list-page/stock-receipts-list-page.component.mjs +18 -3
  15. package/esm2022/lib/inventory-common/stock-receipts/stock-receipts.module.mjs +7 -4
  16. package/esm2022/lib/inventory-common/supplier/supplier-branch-form/supplier-branch-form-button/supplier-branch-form-button.component.mjs +47 -0
  17. package/esm2022/lib/inventory-common/supplier/supplier-branch-form/supplier-branch-form.component.mjs +82 -0
  18. package/esm2022/lib/inventory-common/supplier/supplier-branch.service.mjs +18 -0
  19. package/esm2022/lib/inventory-common/supplier/supplier-branches-list/supplier-branches-list.component.mjs +78 -0
  20. package/esm2022/lib/inventory-common/supplier/supplier-view/supplier-view.component.mjs +4 -3
  21. package/esm2022/lib/inventory-common/supplier/supplier.module.mjs +18 -9
  22. package/esm2022/lib/inventory-common/supplier/suppliers-list/suppliers-list.component.mjs +2 -2
  23. package/esm2022/public-api.mjs +4 -4
  24. package/fesm2022/{techlify-inventory-common-category.module-DmlWI9xk.mjs → techlify-inventory-common-category.module-BkY9hkxM.mjs} +9 -9
  25. package/fesm2022/{techlify-inventory-common-category.module-DmlWI9xk.mjs.map → techlify-inventory-common-category.module-BkY9hkxM.mjs.map} +1 -1
  26. package/fesm2022/{techlify-inventory-common-measure.module-NTiKN2Rg.mjs → techlify-inventory-common-measure.module-Bx4ev2N2.mjs} +6 -6
  27. package/fesm2022/{techlify-inventory-common-measure.module-NTiKN2Rg.mjs.map → techlify-inventory-common-measure.module-Bx4ev2N2.mjs.map} +1 -1
  28. package/fesm2022/techlify-inventory-common-stock-issue-view.component-9J99m1Rw.mjs +66 -0
  29. package/fesm2022/techlify-inventory-common-stock-issue-view.component-9J99m1Rw.mjs.map +1 -0
  30. package/fesm2022/techlify-inventory-common-techlify-inventory-common-D7rXITcH.mjs +6347 -0
  31. package/fesm2022/techlify-inventory-common-techlify-inventory-common-D7rXITcH.mjs.map +1 -0
  32. package/fesm2022/techlify-inventory-common.mjs +1 -6290
  33. package/fesm2022/techlify-inventory-common.mjs.map +1 -1
  34. package/lib/inventory-common/product/product-view-page/product-view-page.component.d.ts +2 -2
  35. package/lib/inventory-common/product/product.module.d.ts +9 -10
  36. package/lib/inventory-common/stock-issuances/stock-issuance-delete-button/stock-issuance-delete-button.component.d.ts +3 -3
  37. package/lib/inventory-common/stock-issuances/stock-issue-form/stock-issue-form/stock-issue-form.component.d.ts +3 -3
  38. package/lib/inventory-common/stock-issuances/{stock-issuances-list/stock-issuances-list.component.d.ts → stock-issue-list/stock-issue-list.component.d.ts} +8 -6
  39. package/lib/inventory-common/stock-issuances/stock-issue-list/stock-issue-list.module.d.ts +17 -0
  40. package/lib/inventory-common/stock-issuances/stock-issue-routing.module.d.ts +7 -0
  41. package/lib/inventory-common/stock-issuances/stock-issue-view/stock-issue-view.component.d.ts +19 -0
  42. package/lib/inventory-common/stock-issuances/stock-issue.module.d.ts +19 -0
  43. package/lib/inventory-common/stock-issuances/stock-issue.service.d.ts +7 -0
  44. package/lib/inventory-common/stock-receipts/stock-receipts-list-page/stock-receipts-list-page.component.d.ts +3 -0
  45. package/lib/inventory-common/stock-receipts/stock-receipts.module.d.ts +1 -1
  46. package/lib/inventory-common/supplier/supplier-branch-form/supplier-branch-form-button/supplier-branch-form-button.component.d.ts +13 -0
  47. package/lib/inventory-common/supplier/supplier-branch-form/supplier-branch-form.component.d.ts +24 -0
  48. package/lib/inventory-common/supplier/supplier-branch.service.d.ts +7 -0
  49. package/lib/inventory-common/supplier/supplier-branches-list/supplier-branches-list.component.d.ts +18 -0
  50. package/lib/inventory-common/supplier/supplier.module.d.ts +17 -14
  51. package/package.json +1 -1
  52. package/public-api.d.ts +3 -3
  53. package/esm2022/lib/inventory-common/product/product-tax/product-tax-delete-button/product-tax-delete-button.component.mjs +0 -54
  54. package/esm2022/lib/inventory-common/product/product-tax/product-tax-form-button/product-tax-form-button.component.mjs +0 -77
  55. package/esm2022/lib/inventory-common/product/product-tax/product-tax-list/product-tax-list.component.mjs +0 -35
  56. package/esm2022/lib/inventory-common/product/product-tax/product-tax.module.mjs +0 -22
  57. package/esm2022/lib/inventory-common/product/product-tax/product-tax.service.mjs +0 -18
  58. package/esm2022/lib/inventory-common/stock-issuances/stock-issuance.service.mjs +0 -18
  59. package/esm2022/lib/inventory-common/stock-issuances/stock-issuances-list/stock-issuances-list.component.mjs +0 -170
  60. package/esm2022/lib/inventory-common/stock-issuances/stock-issuances-list/stock-issuances-list.module.mjs +0 -64
  61. package/esm2022/lib/inventory-common/stock-issuances/stock-issuances-routing.module.mjs +0 -31
  62. package/esm2022/lib/inventory-common/stock-issuances/stock-issuances.module.mjs +0 -67
  63. package/lib/inventory-common/product/product-tax/product-tax-delete-button/product-tax-delete-button.component.d.ts +0 -26
  64. package/lib/inventory-common/product/product-tax/product-tax-form-button/product-tax-form-button.component.d.ts +0 -21
  65. package/lib/inventory-common/product/product-tax/product-tax-list/product-tax-list.component.d.ts +0 -13
  66. package/lib/inventory-common/product/product-tax/product-tax.module.d.ts +0 -12
  67. package/lib/inventory-common/product/product-tax/product-tax.service.d.ts +0 -7
  68. package/lib/inventory-common/stock-issuances/stock-issuance.service.d.ts +0 -7
  69. package/lib/inventory-common/stock-issuances/stock-issuances-list/stock-issuances-list.module.d.ts +0 -17
  70. package/lib/inventory-common/stock-issuances/stock-issuances-routing.module.d.ts +0 -7
  71. package/lib/inventory-common/stock-issuances/stock-issuances.module.d.ts +0 -19
@@ -5,7 +5,7 @@ import { Location } from '@angular/common';
5
5
  import { ProductLocationListComponent } from '../product-location/product-location-list/product-location-list.component';
6
6
  import { StockTransferListComponent } from '../../stock-transfer/stock-transfer-list/stock-transfer-list.component';
7
7
  import { StockReceiptsListPageComponent } from '../../stock-receipts/stock-receipts-list-page/stock-receipts-list-page.component';
8
- import { StockIssuancesListComponent } from '../../stock-issuances/stock-issuances-list/stock-issuances-list.component';
8
+ import { StockIssueListComponent } from '../../stock-issuances/stock-issue-list/stock-issue-list.component';
9
9
  import * as i0 from "@angular/core";
10
10
  export declare class ProductViewPageComponent implements OnInit {
11
11
  private productService;
@@ -17,7 +17,7 @@ export declare class ProductViewPageComponent implements OnInit {
17
17
  productLocationList: ProductLocationListComponent;
18
18
  stockTransferList: StockTransferListComponent;
19
19
  stockReceiptsListPage: StockReceiptsListPageComponent;
20
- stockIssueListPage: StockIssuancesListComponent;
20
+ stockIssueListPage: StockIssueListComponent;
21
21
  constructor(productService: ProductService, activatedRoute: ActivatedRoute, location: Location);
22
22
  ngOnInit(): void;
23
23
  /**
@@ -16,17 +16,16 @@ import * as i14 from "ngx-techlify-core";
16
16
  import * as i15 from "../stock-receipts/stock-receipt-form/stock-receipt-form.module";
17
17
  import * as i16 from "../stock-issuances/stock-issue-form/stock-issue-form.module";
18
18
  import * as i17 from "../stock-receipts/stock-receipts.module";
19
- import * as i18 from "../stock-issuances/stock-issuances-list/stock-issuances-list.module";
20
- import * as i19 from "./product-tax/product-tax.module";
21
- import * as i20 from "@angular/material/progress-bar";
22
- import * as i21 from "ngx-infinite-scroll";
23
- import * as i22 from "@angular/flex-layout";
24
- import * as i23 from "@angular/forms";
25
- import * as i24 from "./product-location/product-location-list/product-location-list.component";
26
- import * as i25 from "../stock-transfer/stock-transfer-list/stock-transfer-list.component";
27
- import * as i26 from "../shared/export-to-excel-button/export-to-excel-button.component";
19
+ import * as i18 from "../stock-issuances/stock-issue-list/stock-issue-list.module";
20
+ import * as i19 from "@angular/material/progress-bar";
21
+ import * as i20 from "ngx-infinite-scroll";
22
+ import * as i21 from "@angular/flex-layout";
23
+ import * as i22 from "@angular/forms";
24
+ import * as i23 from "./product-location/product-location-list/product-location-list.component";
25
+ import * as i24 from "../stock-transfer/stock-transfer-list/stock-transfer-list.component";
26
+ import * as i25 from "../shared/export-to-excel-button/export-to-excel-button.component";
28
27
  export declare class ProductModule {
29
28
  static ɵfac: i0.ɵɵFactoryDeclaration<ProductModule, never>;
30
- static ɵmod: i0.ɵɵNgModuleDeclaration<ProductModule, [typeof i1.ProductListComponent, typeof i2.ProductFormComponent, typeof i3.ProductNavBarComponent, typeof i4.ProductMeasuresListComponent, typeof i5.ProductMeasureFormComponent, typeof i6.ProductViewPageComponent, typeof i7.ProductFormButtonComponent, typeof i8.ProductDeleteButtonComponent, typeof i9.ProductBasicInfoComponent, typeof i10.ProductImportPageComponent, typeof i11.ProductBatchUpdateFormComponent], [typeof i12.CommonModule, typeof i13.ProductRoutingModule, typeof i14.SearchableSelectorModule, typeof i14.TimelineFilterModule, typeof i15.StockReceiptFormModule, typeof i16.StockIssueFormModule, typeof i14.ImportCsvModule, typeof i17.StockReceiptsModule, typeof i18.StockIssuancesListModule, typeof i19.ProductTaxModule, typeof i14.MaterialModule, typeof i20.MatProgressBarModule, typeof i21.InfiniteScrollModule, typeof i22.FlexModule, typeof i23.ReactiveFormsModule, typeof i23.FormsModule, typeof i14.ColumnSelectorModule, typeof i24.ProductLocationListComponent, typeof i25.StockTransferListComponent, typeof i26.ExportToExcelButtonComponent], [typeof i2.ProductFormComponent, typeof i9.ProductBasicInfoComponent, typeof i7.ProductFormButtonComponent, typeof i11.ProductBatchUpdateFormComponent]>;
29
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ProductModule, [typeof i1.ProductListComponent, typeof i2.ProductFormComponent, typeof i3.ProductNavBarComponent, typeof i4.ProductMeasuresListComponent, typeof i5.ProductMeasureFormComponent, typeof i6.ProductViewPageComponent, typeof i7.ProductFormButtonComponent, typeof i8.ProductDeleteButtonComponent, typeof i9.ProductBasicInfoComponent, typeof i10.ProductImportPageComponent, typeof i11.ProductBatchUpdateFormComponent], [typeof i12.CommonModule, typeof i13.ProductRoutingModule, typeof i14.SearchableSelectorModule, typeof i14.TimelineFilterModule, typeof i15.StockReceiptFormModule, typeof i16.StockIssueFormModule, typeof i14.ImportCsvModule, typeof i17.StockReceiptsModule, typeof i18.StockIssueListModule, typeof i14.MaterialModule, typeof i19.MatProgressBarModule, typeof i20.InfiniteScrollModule, typeof i21.FlexModule, typeof i22.ReactiveFormsModule, typeof i22.FormsModule, typeof i14.ColumnSelectorModule, typeof i23.ProductLocationListComponent, typeof i24.StockTransferListComponent, typeof i25.ExportToExcelButtonComponent], [typeof i2.ProductFormComponent, typeof i9.ProductBasicInfoComponent, typeof i7.ProductFormButtonComponent, typeof i11.ProductBatchUpdateFormComponent]>;
31
30
  static ɵinj: i0.ɵɵInjectorDeclaration<ProductModule>;
32
31
  }
@@ -1,16 +1,16 @@
1
1
  import { EventEmitter, TemplateRef } from '@angular/core';
2
2
  import { MatDialog } from '@angular/material/dialog';
3
- import { StockIssuanceService } from '../stock-issuance.service';
3
+ import { StockIssueService } from '../stock-issue.service';
4
4
  import { AlertService } from 'ngx-techlify-core';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class StockIssuanceDeleteButtonComponent {
7
7
  private matDialog;
8
- private stockIssuanceService;
8
+ private stockIssueService;
9
9
  private alertService;
10
10
  stockIssuance: any;
11
11
  deleted: EventEmitter<any>;
12
12
  isDeleting: boolean;
13
- constructor(matDialog: MatDialog, stockIssuanceService: StockIssuanceService, alertService: AlertService);
13
+ constructor(matDialog: MatDialog, stockIssueService: StockIssueService, alertService: AlertService);
14
14
  showDeleteConfirmModel(templateRef: TemplateRef<any>): void;
15
15
  delete(): void;
16
16
  static ɵfac: i0.ɵɵFactoryDeclaration<StockIssuanceDeleteButtonComponent, never>;
@@ -1,12 +1,12 @@
1
1
  import { EventEmitter, OnInit } from '@angular/core';
2
2
  import { AlertService, DateUtils, FormValidatorService, SearchableSelectorComponent, TechlifyFormComponentInterface } from 'ngx-techlify-core';
3
3
  import { FormBuilder } from '@angular/forms';
4
- import { StockIssuanceService } from '../../stock-issuance.service';
4
+ import { StockIssueService } from '../../stock-issue.service';
5
5
  import { LocationService } from '../../../location/location.service';
6
6
  import * as i0 from "@angular/core";
7
7
  export declare class StockIssueFormComponent extends TechlifyFormComponentInterface implements OnInit {
8
8
  private formBuilder;
9
- private stockIssuanceService;
9
+ private stockIssueService;
10
10
  private alertService;
11
11
  private dateUtils;
12
12
  private locationService;
@@ -22,7 +22,7 @@ export declare class StockIssueFormComponent extends TechlifyFormComponentInterf
22
22
  private locationsCountValue;
23
23
  batchesApiUrl: string;
24
24
  isBatchPatched: boolean;
25
- constructor(formValidatorService: FormValidatorService, formBuilder: FormBuilder, stockIssuanceService: StockIssuanceService, alertService: AlertService, dateUtils: DateUtils, locationService: LocationService);
25
+ constructor(formValidatorService: FormValidatorService, formBuilder: FormBuilder, stockIssueService: StockIssueService, alertService: AlertService, dateUtils: DateUtils, locationService: LocationService);
26
26
  ngOnInit(): void;
27
27
  patchFormData(): void;
28
28
  patchFormProducts(stockIssuance: any): void;
@@ -2,12 +2,12 @@ import { EventEmitter, OnInit } from '@angular/core';
2
2
  import { ColumnConfig, TechlifyFeatureService, TechlifyListingControllerInterface, TimelineValue } from 'ngx-techlify-core';
3
3
  import { FormBuilder } from '@angular/forms';
4
4
  import { Sort } from '@angular/material/sort';
5
- import { StockIssuanceService } from '../stock-issuance.service';
5
+ import { StockIssueService } from '../stock-issue.service';
6
6
  import { ActivatedRoute } from '@angular/router';
7
7
  import * as i0 from "@angular/core";
8
- export declare class StockIssuancesListComponent extends TechlifyListingControllerInterface implements OnInit {
8
+ export declare class StockIssueListComponent extends TechlifyListingControllerInterface implements OnInit {
9
9
  private formBuilder;
10
- private stockIssuanceService;
10
+ private stockIssueService;
11
11
  private activatedRoute;
12
12
  private featureService;
13
13
  product: any;
@@ -21,7 +21,9 @@ export declare class StockIssuancesListComponent extends TechlifyListingControll
21
21
  columnConfig: ColumnConfig[];
22
22
  selectedColumns: ColumnConfig[];
23
23
  get displayedColumns(): string[];
24
- constructor(formBuilder: FormBuilder, stockIssuanceService: StockIssuanceService, activatedRoute: ActivatedRoute, featureService: TechlifyFeatureService);
24
+ get totalQuantity(): number;
25
+ get footerColumns(): string[];
26
+ constructor(formBuilder: FormBuilder, stockIssueService: StockIssueService, activatedRoute: ActivatedRoute, featureService: TechlifyFeatureService);
25
27
  ngOnInit(): void;
26
28
  loadData(): void;
27
29
  onSortChange(sort: Sort): void;
@@ -30,6 +32,6 @@ export declare class StockIssuancesListComponent extends TechlifyListingControll
30
32
  private subscribeToRouteChanges;
31
33
  onDurationChange(timelineValue: TimelineValue): void;
32
34
  private loadFeatures;
33
- static ɵfac: i0.ɵɵFactoryDeclaration<StockIssuancesListComponent, never>;
34
- static ɵcmp: i0.ɵɵComponentDeclaration<StockIssuancesListComponent, "app-stock-issuances-list", never, { "product": { "alias": "product"; "required": false; }; "issuableType": { "alias": "issuableType"; "required": false; }; "issuableId": { "alias": "issuableId"; "required": false; }; "label": { "alias": "label"; "required": false; }; "showActions": { "alias": "showActions"; "required": false; }; "showFilters": { "alias": "showFilters"; "required": false; }; }, { "listUpdated": "listUpdated"; }, never, never, false, never>;
35
+ static ɵfac: i0.ɵɵFactoryDeclaration<StockIssueListComponent, never>;
36
+ static ɵcmp: i0.ɵɵComponentDeclaration<StockIssueListComponent, "app-stock-issue-list", never, { "product": { "alias": "product"; "required": false; }; "issuableType": { "alias": "issuableType"; "required": false; }; "issuableId": { "alias": "issuableId"; "required": false; }; "label": { "alias": "label"; "required": false; }; "showActions": { "alias": "showActions"; "required": false; }; "showFilters": { "alias": "showFilters"; "required": false; }; }, { "listUpdated": "listUpdated"; }, never, never, false, never>;
35
37
  }
@@ -0,0 +1,17 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./stock-issue-list.component";
3
+ import * as i2 from "@angular/common";
4
+ import * as i3 from "ngx-techlify-core";
5
+ import * as i4 from "../../techlify-filter/techlify-filter.module";
6
+ import * as i5 from "../stock-issue-form/stock-issue-form.module";
7
+ import * as i6 from "ngx-infinite-scroll";
8
+ import * as i7 from "../stock-issuance-delete-button/stock-issuance-delete-button.module";
9
+ import * as i8 from "@angular/material/progress-bar";
10
+ import * as i9 from "@angular/router";
11
+ import * as i10 from "@angular/forms";
12
+ import * as i11 from "../../product/widgets/product-category-badges/product-category-badges.component";
13
+ export declare class StockIssueListModule {
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<StockIssueListModule, never>;
15
+ static ɵmod: i0.ɵɵNgModuleDeclaration<StockIssueListModule, [typeof i1.StockIssueListComponent], [typeof i2.CommonModule, typeof i3.MaterialModule, typeof i4.TechlifyFilterModule, typeof i5.StockIssueFormModule, typeof i6.InfiniteScrollModule, typeof i7.StockIssuanceDeleteButtonModule, typeof i8.MatProgressBarModule, typeof i9.RouterModule, typeof i3.SearchableSelectorModule, typeof i3.TimelineFilterModule, typeof i10.ReactiveFormsModule, typeof i11.ProductCategoryBadgesComponent, typeof i3.ColumnSelectorModule, typeof i3.TechlifyIconModule], [typeof i1.StockIssueListComponent]>;
16
+ static ɵinj: i0.ɵɵInjectorDeclaration<StockIssueListModule>;
17
+ }
@@ -0,0 +1,7 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "@angular/router";
3
+ export declare class StockIssueRoutingModule {
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<StockIssueRoutingModule, never>;
5
+ static ɵmod: i0.ɵɵNgModuleDeclaration<StockIssueRoutingModule, never, [typeof i1.RouterModule], [typeof i1.RouterModule]>;
6
+ static ɵinj: i0.ɵɵInjectorDeclaration<StockIssueRoutingModule>;
7
+ }
@@ -0,0 +1,19 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { Location } from '@angular/common';
3
+ import { ActivatedRoute } from '@angular/router';
4
+ import { StockIssueService } from '../stock-issue.service';
5
+ import * as i0 from "@angular/core";
6
+ export declare class StockIssueViewComponent implements OnInit {
7
+ private activatedRoute;
8
+ private service;
9
+ private location;
10
+ id: number;
11
+ isLoading: boolean;
12
+ stockIssue: any;
13
+ constructor(activatedRoute: ActivatedRoute, service: StockIssueService, location: Location);
14
+ ngOnInit(): void;
15
+ loadData(): void;
16
+ redirectBack(): void;
17
+ static ɵfac: i0.ɵɵFactoryDeclaration<StockIssueViewComponent, never>;
18
+ static ɵcmp: i0.ɵɵComponentDeclaration<StockIssueViewComponent, "app-stock-issue-view", never, {}, {}, never, never, true, never>;
19
+ }
@@ -0,0 +1,19 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "@angular/common";
3
+ import * as i2 from "./stock-issue-routing.module";
4
+ import * as i3 from "@angular/material/card";
5
+ import * as i4 from "../techlify-filter/techlify-filter.module";
6
+ import * as i5 from "ngx-infinite-scroll";
7
+ import * as i6 from "@angular/material/progress-bar";
8
+ import * as i7 from "@angular/material/sort";
9
+ import * as i8 from "@angular/material/table";
10
+ import * as i9 from "../stock-receipts/stock-receipt-form/stock-receipt-form.module";
11
+ import * as i10 from "./stock-issue-form/stock-issue-form.module";
12
+ import * as i11 from "@angular/material/dialog";
13
+ import * as i12 from "@angular/material/button";
14
+ import * as i13 from "./stock-issue-list/stock-issue-list.module";
15
+ export declare class StockIssueModule {
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<StockIssueModule, never>;
17
+ static ɵmod: i0.ɵɵNgModuleDeclaration<StockIssueModule, never, [typeof i1.CommonModule, typeof i2.StockIssueRoutingModule, typeof i3.MatCardModule, typeof i4.TechlifyFilterModule, typeof i5.InfiniteScrollModule, typeof i6.MatProgressBarModule, typeof i7.MatSortModule, typeof i8.MatTableModule, typeof i9.StockReceiptFormModule, typeof i10.StockIssueFormModule, typeof i11.MatDialogModule, typeof i12.MatButtonModule, typeof i13.StockIssueListModule], never>;
18
+ static ɵinj: i0.ɵɵInjectorDeclaration<StockIssueModule>;
19
+ }
@@ -0,0 +1,7 @@
1
+ import { HttpService, TechlifyServiceBaseClass } from 'ngx-techlify-core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class StockIssueService extends TechlifyServiceBaseClass {
4
+ constructor(httpService: HttpService);
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<StockIssueService, never>;
6
+ static ɵprov: i0.ɵɵInjectableDeclaration<StockIssueService>;
7
+ }
@@ -18,6 +18,9 @@ export declare class StockReceiptsListPageComponent extends TechlifyListingContr
18
18
  columnConfig: ColumnConfig[];
19
19
  selectedColumns: ColumnConfig[];
20
20
  get displayedColumns(): string[];
21
+ get totalPurchasePrice(): number;
22
+ get totalValue(): number;
23
+ get footerColumns(): string[];
21
24
  constructor(stockReceiptService: StockReceiptService, formBuilder: FormBuilder, activatedRoute: ActivatedRoute, router: Router, featureService: TechlifyFeatureService);
22
25
  ngOnInit(): void;
23
26
  loadData(): void;
@@ -17,6 +17,6 @@ import * as i15 from "./stock-receipt-form/stock-receipt-form.module";
17
17
  import * as i16 from "../product/widgets/product-category-badges/product-category-badges.component";
18
18
  export declare class StockReceiptsModule {
19
19
  static ɵfac: i0.ɵɵFactoryDeclaration<StockReceiptsModule, never>;
20
- static ɵmod: i0.ɵɵNgModuleDeclaration<StockReceiptsModule, [typeof i1.StockReceiptsListPageComponent, typeof i2.StockReceiptDeleteButtonComponent, typeof i3.StockReceiptViewComponent], [typeof i4.CommonModule, typeof i5.StockReceiptsRoutingModule, typeof i6.MatCardModule, typeof i7.TechlifyFilterModule, typeof i8.MatTableModule, typeof i9.MatFormFieldModule, typeof i10.SearchableSelectorModule, typeof i10.TimelineFilterModule, typeof i11.ReactiveFormsModule, typeof i12.PayeeSelectorModule, typeof i13.MatProgressBarModule, typeof i14.InfiniteScrollModule, typeof i10.MaterialModule, typeof i15.StockReceiptFormModule, typeof i16.ProductCategoryBadgesComponent, typeof i10.ColumnSelectorModule, typeof i10.EntityFilesViewAllModule, typeof i10.TechlifyFeatureModule], [typeof i2.StockReceiptDeleteButtonComponent, typeof i1.StockReceiptsListPageComponent]>;
20
+ static ɵmod: i0.ɵɵNgModuleDeclaration<StockReceiptsModule, [typeof i1.StockReceiptsListPageComponent, typeof i2.StockReceiptDeleteButtonComponent, typeof i3.StockReceiptViewComponent], [typeof i4.CommonModule, typeof i5.StockReceiptsRoutingModule, typeof i6.MatCardModule, typeof i7.TechlifyFilterModule, typeof i8.MatTableModule, typeof i9.MatFormFieldModule, typeof i10.SearchableSelectorModule, typeof i10.TimelineFilterModule, typeof i11.ReactiveFormsModule, typeof i12.PayeeSelectorModule, typeof i13.MatProgressBarModule, typeof i14.InfiniteScrollModule, typeof i10.MaterialModule, typeof i15.StockReceiptFormModule, typeof i16.ProductCategoryBadgesComponent, typeof i10.ColumnSelectorModule, typeof i10.EntityFilesViewAllModule, typeof i10.TechlifyFeatureModule, typeof i10.NoteModule], [typeof i2.StockReceiptDeleteButtonComponent, typeof i1.StockReceiptsListPageComponent]>;
21
21
  static ɵinj: i0.ɵɵInjectorDeclaration<StockReceiptsModule>;
22
22
  }
@@ -0,0 +1,13 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { MatDialog } from '@angular/material/dialog';
3
+ import * as i0 from "@angular/core";
4
+ export declare class SupplierBranchFormButtonComponent {
5
+ dialog: MatDialog;
6
+ branch: any;
7
+ supplierId: number | null;
8
+ saved: EventEmitter<any>;
9
+ constructor(dialog: MatDialog);
10
+ open(): void;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<SupplierBranchFormButtonComponent, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<SupplierBranchFormButtonComponent, "app-supplier-branch-form-button", never, { "branch": { "alias": "branch"; "required": false; }; "supplierId": { "alias": "supplierId"; "required": false; }; }, { "saved": "saved"; }, never, never, true, never>;
13
+ }
@@ -0,0 +1,24 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { FormBuilder } from '@angular/forms';
3
+ import { AlertService, FormValidatorService, TechlifyFormComponentInterface } from 'ngx-techlify-core';
4
+ import { SupplierBranchService } from '../supplier-branch.service';
5
+ import { MatDialogRef } from '@angular/material/dialog';
6
+ import * as i0 from "@angular/core";
7
+ export declare class SupplierBranchFormComponent extends TechlifyFormComponentInterface implements OnInit {
8
+ private formBuilder;
9
+ private alertService;
10
+ private supplierBranchService;
11
+ data: any;
12
+ dialogRef: MatDialogRef<SupplierBranchFormComponent>;
13
+ isWorking: boolean;
14
+ errorMessages: {
15
+ title: {
16
+ required: string;
17
+ };
18
+ };
19
+ constructor(formValidatorService: FormValidatorService, formBuilder: FormBuilder, alertService: AlertService, supplierBranchService: SupplierBranchService, data: any, dialogRef: MatDialogRef<SupplierBranchFormComponent>);
20
+ ngOnInit(): void;
21
+ save(): void;
22
+ static ɵfac: i0.ɵɵFactoryDeclaration<SupplierBranchFormComponent, never>;
23
+ static ɵcmp: i0.ɵɵComponentDeclaration<SupplierBranchFormComponent, "app-supplier-branch-form", never, {}, {}, never, never, false, never>;
24
+ }
@@ -0,0 +1,7 @@
1
+ import { HttpService, TechlifyServiceBaseClass } from 'ngx-techlify-core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class SupplierBranchService extends TechlifyServiceBaseClass {
4
+ constructor(httpService: HttpService);
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<SupplierBranchService, never>;
6
+ static ɵprov: i0.ɵɵInjectableDeclaration<SupplierBranchService>;
7
+ }
@@ -0,0 +1,18 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { FormBuilder } from '@angular/forms';
3
+ import { ErrorHandlerService, TechlifyListingControllerInterface } from 'ngx-techlify-core';
4
+ import { SupplierBranchService } from '../supplier-branch.service';
5
+ import * as i0 from "@angular/core";
6
+ export declare class SupplierBranchesListComponent extends TechlifyListingControllerInterface implements OnInit {
7
+ private fb;
8
+ private errorHandlerService;
9
+ private service;
10
+ supplierId: number | null;
11
+ displayedColumns: string[];
12
+ constructor(fb: FormBuilder, errorHandlerService: ErrorHandlerService, service: SupplierBranchService);
13
+ ngOnInit(): void;
14
+ loadData(): Promise<void>;
15
+ assignFilter(column: any, direction: any): any;
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<SupplierBranchesListComponent, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<SupplierBranchesListComponent, "app-supplier-branches-list", never, { "supplierId": { "alias": "supplierId"; "required": false; }; }, {}, never, never, false, never>;
18
+ }
@@ -4,21 +4,24 @@ import * as i2 from "./supplier-view/supplier-view.component";
4
4
  import * as i3 from "./suppliers-list/suppliers-list.component";
5
5
  import * as i4 from "./supplier-form/supplier-form.component";
6
6
  import * as i5 from "./supplier-information/supplier-information.component";
7
- import * as i6 from "@angular/common";
8
- import * as i7 from "./supplier-routing.module";
9
- import * as i8 from "../material.module";
10
- import * as i9 from "ngx-techlify-core";
11
- import * as i10 from "@angular/flex-layout";
12
- import * as i11 from "@angular/forms";
13
- import * as i12 from "ngx-infinite-scroll";
14
- import * as i13 from "ngx-permissions";
15
- import * as i14 from "./supplier-form/supplier-form-button/supplier-form-button.component";
16
- import * as i15 from "./supplier-delete-button/supplier-delete-button.component";
17
- import * as i16 from "../stock-receipts/stock-receipts.module";
18
- import * as i17 from "../incident/incident-list/incident-list.component";
19
- import * as i18 from "../rating/rating-list/rating-list.component";
7
+ import * as i6 from "./supplier-branches-list/supplier-branches-list.component";
8
+ import * as i7 from "./supplier-branch-form/supplier-branch-form.component";
9
+ import * as i8 from "@angular/common";
10
+ import * as i9 from "./supplier-routing.module";
11
+ import * as i10 from "../material.module";
12
+ import * as i11 from "ngx-techlify-core";
13
+ import * as i12 from "@angular/flex-layout";
14
+ import * as i13 from "@angular/forms";
15
+ import * as i14 from "ngx-infinite-scroll";
16
+ import * as i15 from "ngx-permissions";
17
+ import * as i16 from "./supplier-form/supplier-form-button/supplier-form-button.component";
18
+ import * as i17 from "./supplier-delete-button/supplier-delete-button.component";
19
+ import * as i18 from "../stock-receipts/stock-receipts.module";
20
+ import * as i19 from "../incident/incident-list/incident-list.component";
21
+ import * as i20 from "../rating/rating-list/rating-list.component";
22
+ import * as i21 from "./supplier-branch-form/supplier-branch-form-button/supplier-branch-form-button.component";
20
23
  export declare class SupplierModule {
21
24
  static ɵfac: i0.ɵɵFactoryDeclaration<SupplierModule, never>;
22
- static ɵmod: i0.ɵɵNgModuleDeclaration<SupplierModule, [typeof i1.SupplierComponent, typeof i2.SupplierViewComponent, typeof i3.SuppliersListComponent, typeof i4.SupplierFormComponent, typeof i5.SupplierInformationComponent], [typeof i6.CommonModule, typeof i7.SupplierRoutingModule, typeof i8.MaterialModule, typeof i9.SearchableSelectorModule, typeof i9.AuditLogForModelModule, typeof i9.NoteModule, typeof i10.FlexModule, typeof i11.ReactiveFormsModule, typeof i12.InfiniteScrollModule, typeof i13.NgxPermissionsModule, typeof i14.SupplierFormButtonComponent, typeof i15.SupplierDeleteButtonComponent, typeof i16.StockReceiptsModule, typeof i17.IncidentListComponent, typeof i18.RatingListComponent], never>;
25
+ static ɵmod: i0.ɵɵNgModuleDeclaration<SupplierModule, [typeof i1.SupplierComponent, typeof i2.SupplierViewComponent, typeof i3.SuppliersListComponent, typeof i4.SupplierFormComponent, typeof i5.SupplierInformationComponent, typeof i6.SupplierBranchesListComponent, typeof i7.SupplierBranchFormComponent], [typeof i8.CommonModule, typeof i9.SupplierRoutingModule, typeof i10.MaterialModule, typeof i11.SearchableSelectorModule, typeof i11.AuditLogForModelModule, typeof i11.NoteModule, typeof i12.FlexModule, typeof i13.ReactiveFormsModule, typeof i14.InfiniteScrollDirective, typeof i15.NgxPermissionsModule, typeof i16.SupplierFormButtonComponent, typeof i17.SupplierDeleteButtonComponent, typeof i18.StockReceiptsModule, typeof i19.IncidentListComponent, typeof i20.RatingListComponent, typeof i21.SupplierBranchFormButtonComponent], never>;
23
26
  static ɵinj: i0.ɵɵInjectorDeclaration<SupplierModule>;
24
27
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "techlify-inventory-common",
3
- "version": "18.24.1",
3
+ "version": "18.26.0",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^18.2.13",
6
6
  "@angular/core": "^18.2.13"
package/public-api.d.ts CHANGED
@@ -16,9 +16,9 @@ export * from './lib/inventory-common/product/product-form.service';
16
16
  export * from './lib/inventory-common/product/product-batch-update-form/product-batch-update-form.component';
17
17
  export * from './lib/inventory-common/product/product-import-page/product-import-page.component';
18
18
  export * from './lib/inventory-common/product/product-view-page/product-view-page.component';
19
- export * from './lib/inventory-common/stock-issuances/stock-issuances.module';
20
- export * from './lib/inventory-common/stock-issuances/stock-issuances-list/stock-issuances-list.component';
21
- export * from './lib/inventory-common/stock-issuances/stock-issuances-list/stock-issuances-list.module';
19
+ export * from './lib/inventory-common/stock-issuances/stock-issue.module';
20
+ export * from './lib/inventory-common/stock-issuances/stock-issue-list/stock-issue-list.component';
21
+ export * from './lib/inventory-common/stock-issuances/stock-issue-list/stock-issue-list.module';
22
22
  export * from './lib/inventory-common/stock-issuances/stock-issue-form/stock-issue-form.module';
23
23
  export * from './lib/inventory-common/stock-issuances/stock-issue-form/stock-issue-form-button/stock-issue-form-button.component';
24
24
  export * from './lib/inventory-common/stock-receipts/stock-receipts.module';
@@ -1,54 +0,0 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/material/dialog";
4
- import * as i2 from "../product-tax.service";
5
- import * as i3 from "ngx-techlify-core";
6
- import * as i4 from "@angular/material/button";
7
- import * as i5 from "@angular/material/icon";
8
- export class ProductTaxDeleteButtonComponent {
9
- matDialog;
10
- productTaxService;
11
- alertService;
12
- productTax;
13
- deleted = new EventEmitter();
14
- isDeleting;
15
- constructor(matDialog, productTaxService, alertService) {
16
- this.matDialog = matDialog;
17
- this.productTaxService = productTaxService;
18
- this.alertService = alertService;
19
- }
20
- /**
21
- * Delete the product.
22
- */
23
- delete() {
24
- this.isDeleting = true;
25
- this.productTaxService.delete(this.productTax).subscribe({
26
- next: () => {
27
- this.matDialog?.closeAll();
28
- this.deleted.emit();
29
- this.isDeleting = false;
30
- this.alertService.addAlert('Product tax deleted successfully!', 'success');
31
- },
32
- error: () => (this.isDeleting = false),
33
- });
34
- }
35
- /**
36
- * Show delete product dialog.
37
- *
38
- * @param templateRef
39
- */
40
- showDeleteDialog(templateRef) {
41
- this.matDialog.open(templateRef, { width: '500px' });
42
- }
43
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ProductTaxDeleteButtonComponent, deps: [{ token: i1.MatDialog }, { token: i2.ProductTaxService }, { token: i3.AlertService }], target: i0.ɵɵFactoryTarget.Component });
44
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ProductTaxDeleteButtonComponent, selector: "app-product-tax-delete-button", inputs: { productTax: "productTax" }, outputs: { deleted: "deleted" }, ngImport: i0, template: "<mat-icon class=\"cursor-pointer text-secondary\" (click)=\"showDeleteDialog(deleteConfirmDialog)\"> delete </mat-icon>\n\n<ng-template #deleteConfirmDialog>\n <h3 mat-dialog-title>Delete Product Tax</h3>\n <div mat-dialog-content>Are you sure? You want to delete the product tax?</div>\n <div mat-dialog-actions class=\"d-flex justify-content-end gap-1 mb-2\">\n <button [disabled]=\"isDeleting\" type=\"button\" mat-raised-button color=\"warn\" (click)=\"delete()\">Delete</button>\n <button [disabled]=\"isDeleting\" type=\"button\" mat-flat-button mat-dialog-close>Cancel</button>\n </div>\n</ng-template>\n", dependencies: [{ kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], preserveWhitespaces: true });
45
- }
46
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ProductTaxDeleteButtonComponent, decorators: [{
47
- type: Component,
48
- args: [{ selector: 'app-product-tax-delete-button', template: "<mat-icon class=\"cursor-pointer text-secondary\" (click)=\"showDeleteDialog(deleteConfirmDialog)\"> delete </mat-icon>\n\n<ng-template #deleteConfirmDialog>\n <h3 mat-dialog-title>Delete Product Tax</h3>\n <div mat-dialog-content>Are you sure? You want to delete the product tax?</div>\n <div mat-dialog-actions class=\"d-flex justify-content-end gap-1 mb-2\">\n <button [disabled]=\"isDeleting\" type=\"button\" mat-raised-button color=\"warn\" (click)=\"delete()\">Delete</button>\n <button [disabled]=\"isDeleting\" type=\"button\" mat-flat-button mat-dialog-close>Cancel</button>\n </div>\n</ng-template>\n" }]
49
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.ProductTaxService }, { type: i3.AlertService }], propDecorators: { productTax: [{
50
- type: Input
51
- }], deleted: [{
52
- type: Output
53
- }] } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC10YXgtZGVsZXRlLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnZlbnRvcnktY29tbW9uL3NyYy9saWIvaW52ZW50b3J5LWNvbW1vbi9wcm9kdWN0L3Byb2R1Y3QtdGF4L3Byb2R1Y3QtdGF4LWRlbGV0ZS1idXR0b24vcHJvZHVjdC10YXgtZGVsZXRlLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnZlbnRvcnktY29tbW9uL3NyYy9saWIvaW52ZW50b3J5LWNvbW1vbi9wcm9kdWN0L3Byb2R1Y3QtdGF4L3Byb2R1Y3QtdGF4LWRlbGV0ZS1idXR0b24vcHJvZHVjdC10YXgtZGVsZXRlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFlLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBU3BGLE1BQU0sT0FBTywrQkFBK0I7SUFPaEM7SUFDQTtJQUNBO0lBUkQsVUFBVSxDQUFNO0lBQ2YsT0FBTyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFFdkMsVUFBVSxDQUFXO0lBRXJCLFlBQ1UsU0FBb0IsRUFDcEIsaUJBQW9DLEVBQ3BDLFlBQTBCO1FBRjFCLGNBQVMsR0FBVCxTQUFTLENBQVc7UUFDcEIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUNwQyxpQkFBWSxHQUFaLFlBQVksQ0FBYztJQUNqQyxDQUFDO0lBRUo7O09BRUc7SUFDSCxNQUFNO1FBQ0osSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7UUFDdkIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQ3ZELElBQUksRUFBRSxHQUFHLEVBQUU7Z0JBQ1QsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLEVBQUUsQ0FBQztnQkFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7Z0JBQ3hCLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLG1DQUFtQyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBQzdFLENBQUM7WUFDRCxLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztTQUN2QyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILGdCQUFnQixDQUFDLFdBQTZCO1FBQzVDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7d0dBbkNVLCtCQUErQjs0RkFBL0IsK0JBQStCLDRJQ1Q1QywrbUJBVUE7OzRGRERhLCtCQUErQjtrQkFKM0MsU0FBUzsrQkFDRSwrQkFBK0I7eUlBSWhDLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0ksT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IEFsZXJ0U2VydmljZSB9IGZyb20gJ25neC10ZWNobGlmeS1jb3JlJztcbmltcG9ydCB7IFByb2R1Y3RUYXhTZXJ2aWNlIH0gZnJvbSAnLi4vcHJvZHVjdC10YXguc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1wcm9kdWN0LXRheC1kZWxldGUtYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2R1Y3QtdGF4LWRlbGV0ZS1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxufSlcbmV4cG9ydCBjbGFzcyBQcm9kdWN0VGF4RGVsZXRlQnV0dG9uQ29tcG9uZW50IHtcbiAgQElucHV0KCkgcHJvZHVjdFRheDogYW55O1xuICBAT3V0cHV0KCkgZGVsZXRlZCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBpc0RlbGV0aW5nITogYm9vbGVhbjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIG1hdERpYWxvZzogTWF0RGlhbG9nLFxuICAgIHByaXZhdGUgcHJvZHVjdFRheFNlcnZpY2U6IFByb2R1Y3RUYXhTZXJ2aWNlLFxuICAgIHByaXZhdGUgYWxlcnRTZXJ2aWNlOiBBbGVydFNlcnZpY2VcbiAgKSB7fVxuXG4gIC8qKlxuICAgKiBEZWxldGUgdGhlIHByb2R1Y3QuXG4gICAqL1xuICBkZWxldGUoKSB7XG4gICAgdGhpcy5pc0RlbGV0aW5nID0gdHJ1ZTtcbiAgICB0aGlzLnByb2R1Y3RUYXhTZXJ2aWNlLmRlbGV0ZSh0aGlzLnByb2R1Y3RUYXgpLnN1YnNjcmliZSh7XG4gICAgICBuZXh0OiAoKSA9PiB7XG4gICAgICAgIHRoaXMubWF0RGlhbG9nPy5jbG9zZUFsbCgpO1xuICAgICAgICB0aGlzLmRlbGV0ZWQuZW1pdCgpO1xuICAgICAgICB0aGlzLmlzRGVsZXRpbmcgPSBmYWxzZTtcbiAgICAgICAgdGhpcy5hbGVydFNlcnZpY2UuYWRkQWxlcnQoJ1Byb2R1Y3QgdGF4IGRlbGV0ZWQgc3VjY2Vzc2Z1bGx5IScsICdzdWNjZXNzJyk7XG4gICAgICB9LFxuICAgICAgZXJyb3I6ICgpID0+ICh0aGlzLmlzRGVsZXRpbmcgPSBmYWxzZSksXG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogU2hvdyBkZWxldGUgcHJvZHVjdCBkaWFsb2cuXG4gICAqXG4gICAqIEBwYXJhbSB0ZW1wbGF0ZVJlZlxuICAgKi9cbiAgc2hvd0RlbGV0ZURpYWxvZyh0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55Pikge1xuICAgIHRoaXMubWF0RGlhbG9nLm9wZW4odGVtcGxhdGVSZWYsIHsgd2lkdGg6ICc1MDBweCcgfSk7XG4gIH1cbn1cbiIsIjxtYXQtaWNvbiBjbGFzcz1cImN1cnNvci1wb2ludGVyIHRleHQtc2Vjb25kYXJ5XCIgKGNsaWNrKT1cInNob3dEZWxldGVEaWFsb2coZGVsZXRlQ29uZmlybURpYWxvZylcIj4gZGVsZXRlIDwvbWF0LWljb24+XG5cbjxuZy10ZW1wbGF0ZSAjZGVsZXRlQ29uZmlybURpYWxvZz5cbiAgPGgzIG1hdC1kaWFsb2ctdGl0bGU+RGVsZXRlIFByb2R1Y3QgVGF4PC9oMz5cbiAgPGRpdiBtYXQtZGlhbG9nLWNvbnRlbnQ+QXJlIHlvdSBzdXJlPyBZb3Ugd2FudCB0byBkZWxldGUgdGhlIHByb2R1Y3QgdGF4PzwvZGl2PlxuICA8ZGl2IG1hdC1kaWFsb2ctYWN0aW9ucyBjbGFzcz1cImQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtZW5kIGdhcC0xIG1iLTJcIj5cbiAgICA8YnV0dG9uIFtkaXNhYmxlZF09XCJpc0RlbGV0aW5nXCIgdHlwZT1cImJ1dHRvblwiIG1hdC1yYWlzZWQtYnV0dG9uIGNvbG9yPVwid2FyblwiIChjbGljayk9XCJkZWxldGUoKVwiPkRlbGV0ZTwvYnV0dG9uPlxuICAgIDxidXR0b24gW2Rpc2FibGVkXT1cImlzRGVsZXRpbmdcIiB0eXBlPVwiYnV0dG9uXCIgbWF0LWZsYXQtYnV0dG9uIG1hdC1kaWFsb2ctY2xvc2U+Q2FuY2VsPC9idXR0b24+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
@@ -1,77 +0,0 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { TechlifyFormComponentInterface } from 'ngx-techlify-core';
3
- import { Validators } from '@angular/forms';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/dialog";
6
- import * as i2 from "../product-tax.service";
7
- import * as i3 from "ngx-techlify-core";
8
- import * as i4 from "@angular/forms";
9
- import * as i5 from "@angular/common";
10
- import * as i6 from "@angular/material/button";
11
- import * as i7 from "@angular/material/form-field";
12
- import * as i8 from "@angular/material/icon";
13
- export class ProductTaxFormButtonComponent extends TechlifyFormComponentInterface {
14
- matDialog;
15
- productTaxService;
16
- formBuilder;
17
- alertService;
18
- product;
19
- saved = new EventEmitter();
20
- isSaving;
21
- constructor(matDialog, productTaxService, formValidatorService, formBuilder, alertService) {
22
- super(formValidatorService);
23
- this.matDialog = matDialog;
24
- this.productTaxService = productTaxService;
25
- this.formBuilder = formBuilder;
26
- this.alertService = alertService;
27
- this.errorMessages = {
28
- tax_id: {
29
- required: 'The tax field is required.',
30
- },
31
- };
32
- this.form = this.formBuilder.group({
33
- product_id: [''],
34
- tax_id: ['', Validators.required],
35
- });
36
- }
37
- ngOnInit() {
38
- if (this.product) {
39
- this.form.get('product_id')?.setValue(this.product?.id);
40
- }
41
- }
42
- showForm(templateRef) {
43
- this.matDialog.open(templateRef, { width: '400px' });
44
- }
45
- save() {
46
- this.form.markAllAsTouched();
47
- if (this.form.invalid) {
48
- this.alertService.addAlert('Please check the form for errors.', 'error');
49
- return;
50
- }
51
- const data = { ...this.form.value };
52
- const params = {
53
- with: 'tax.type',
54
- };
55
- this.isSaving = true;
56
- this.productTaxService.store(data, params).subscribe({
57
- next: (response) => {
58
- this.isSaving = false;
59
- this.matDialog.closeAll();
60
- this.alertService.addAlert('Product tax saved successfully!', 'success');
61
- this.saved.emit(response?.item);
62
- },
63
- error: () => (this.isSaving = false),
64
- });
65
- }
66
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ProductTaxFormButtonComponent, deps: [{ token: i1.MatDialog }, { token: i2.ProductTaxService }, { token: i3.FormValidatorService }, { token: i4.FormBuilder }, { token: i3.AlertService }], target: i0.ɵɵFactoryTarget.Component });
67
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ProductTaxFormButtonComponent, selector: "app-product-tax-form-button", inputs: { product: "product" }, outputs: { saved: "saved" }, usesInheritance: true, ngImport: i0, template: "<mat-icon color=\"primary\" class=\"cursor-pointer\" (click)=\"showForm(formTemplate)\"> add </mat-icon>\n\n<ng-template #formTemplate>\n <form [formGroup]=\"form\" (submit)=\"save()\" mat-dialog-content class=\"d-flex flex-column gap-2\">\n <h3 class=\"text-dark\">Add tax for {{ product?.name }}</h3>\n <mat-form-field>\n <mat-label>Tax</mat-label>\n <app-searchable-selector\n formControlName=\"tax_id\"\n required\n apiUrl=\"api/taxes\"\n [enableSearch]=\"false\"\n ></app-searchable-selector>\n <mat-error *ngIf=\"isFieldValid('tax_id')\">\n {{ getErrorMessage('tax_id') }}\n </mat-error>\n </mat-form-field>\n\n <div class=\"d-flex justify-content-end align-items-center gap-3\">\n <button [disabled]=\"isSaving\" type=\"submit\" mat-raised-button color=\"primary\">Save</button>\n <button [disabled]=\"isSaving\" type=\"button\" mat-flat-button mat-dialog-close>Cancel</button>\n </div>\n </form>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.SearchableSelectorComponent, selector: "app-searchable-selector", inputs: ["valueField", "titleField", "subtitleField", "apiUrl", "multiple", "selectedValue", "enableSearch", "add", "addConfig", "edit", "editConfig", "sort", "sortBy", "searchField", "itemComponent", "items", "apiDataProperty", "cache", "perPage", "inDataSearch", "panelWidth", "focusSearchOnOpen", "required", "disabled", "value"], outputs: ["selectedValueChange", "selectionChange", "itemsChange"] }], preserveWhitespaces: true });
68
- }
69
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ProductTaxFormButtonComponent, decorators: [{
70
- type: Component,
71
- args: [{ selector: 'app-product-tax-form-button', template: "<mat-icon color=\"primary\" class=\"cursor-pointer\" (click)=\"showForm(formTemplate)\"> add </mat-icon>\n\n<ng-template #formTemplate>\n <form [formGroup]=\"form\" (submit)=\"save()\" mat-dialog-content class=\"d-flex flex-column gap-2\">\n <h3 class=\"text-dark\">Add tax for {{ product?.name }}</h3>\n <mat-form-field>\n <mat-label>Tax</mat-label>\n <app-searchable-selector\n formControlName=\"tax_id\"\n required\n apiUrl=\"api/taxes\"\n [enableSearch]=\"false\"\n ></app-searchable-selector>\n <mat-error *ngIf=\"isFieldValid('tax_id')\">\n {{ getErrorMessage('tax_id') }}\n </mat-error>\n </mat-form-field>\n\n <div class=\"d-flex justify-content-end align-items-center gap-3\">\n <button [disabled]=\"isSaving\" type=\"submit\" mat-raised-button color=\"primary\">Save</button>\n <button [disabled]=\"isSaving\" type=\"button\" mat-flat-button mat-dialog-close>Cancel</button>\n </div>\n </form>\n</ng-template>\n" }]
72
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.ProductTaxService }, { type: i3.FormValidatorService }, { type: i4.FormBuilder }, { type: i3.AlertService }], propDecorators: { product: [{
73
- type: Input
74
- }], saved: [{
75
- type: Output
76
- }] } });
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC10YXgtZm9ybS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW52ZW50b3J5LWNvbW1vbi9zcmMvbGliL2ludmVudG9yeS1jb21tb24vcHJvZHVjdC9wcm9kdWN0LXRheC9wcm9kdWN0LXRheC1mb3JtLWJ1dHRvbi9wcm9kdWN0LXRheC1mb3JtLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnZlbnRvcnktY29tbW9uL3NyYy9saWIvaW52ZW50b3J5LWNvbW1vbi9wcm9kdWN0L3Byb2R1Y3QtdGF4L3Byb2R1Y3QtdGF4LWZvcm0tYnV0dG9uL3Byb2R1Y3QtdGF4LWZvcm0tYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFFNUYsT0FBTyxFQUFzQyw4QkFBOEIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3ZHLE9BQU8sRUFBZSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7Ozs7OztBQU96RCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsOEJBQThCO0lBT3RFO0lBQ0M7SUFFQTtJQUNBO0lBVkQsT0FBTyxDQUFNO0lBQ1osS0FBSyxHQUFzQixJQUFJLFlBQVksRUFBRSxDQUFDO0lBRXhELFFBQVEsQ0FBVztJQUVuQixZQUNTLFNBQW9CLEVBQ25CLGlCQUFvQyxFQUM1QyxvQkFBMEMsRUFDbEMsV0FBd0IsRUFDeEIsWUFBMEI7UUFFbEMsS0FBSyxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFOckIsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUNuQixzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBRXBDLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQ3hCLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBR2xDLElBQUksQ0FBQyxhQUFhLEdBQUc7WUFDbkIsTUFBTSxFQUFFO2dCQUNOLFFBQVEsRUFBRSw0QkFBNEI7YUFDdkM7U0FDRixDQUFDO1FBRUYsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztZQUNqQyxVQUFVLEVBQUUsQ0FBQyxFQUFFLENBQUM7WUFDaEIsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLFVBQVUsQ0FBQyxRQUFRLENBQUM7U0FDbEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsRUFBRSxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMxRCxDQUFDO0lBQ0gsQ0FBQztJQUVELFFBQVEsQ0FBQyxXQUE2QjtRQUNwQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsSUFBSTtRQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUM3QixJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDdEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsbUNBQW1DLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDekUsT0FBTztRQUNULENBQUM7UUFFRCxNQUFNLElBQUksR0FBUSxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN6QyxNQUFNLE1BQU0sR0FBUTtZQUNsQixJQUFJLEVBQUUsVUFBVTtTQUNqQixDQUFDO1FBQ0YsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7UUFFckIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQ25ELElBQUksRUFBRSxDQUFDLFFBQWEsRUFBRSxFQUFFO2dCQUN0QixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztnQkFDdEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztnQkFDMUIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsaUNBQWlDLEVBQUUsU0FBUyxDQUFDLENBQUM7Z0JBQ3pFLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNsQyxDQUFDO1lBQ0QsS0FBSyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7U0FDckMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzt3R0ExRFUsNkJBQTZCOzRGQUE3Qiw2QkFBNkIsdUpDVjFDLGsvQkF3QkE7OzRGRGRhLDZCQUE2QjtrQkFKekMsU0FBUzsrQkFDRSw2QkFBNkI7c01BSTlCLE9BQU87c0JBQWYsS0FBSztnQkFDSSxLQUFLO3NCQUFkLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IEFsZXJ0U2VydmljZSwgRm9ybVZhbGlkYXRvclNlcnZpY2UsIFRlY2hsaWZ5Rm9ybUNvbXBvbmVudEludGVyZmFjZSB9IGZyb20gJ25neC10ZWNobGlmeS1jb3JlJztcbmltcG9ydCB7IEZvcm1CdWlsZGVyLCBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgUHJvZHVjdFRheFNlcnZpY2UgfSBmcm9tICcuLi9wcm9kdWN0LXRheC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLXByb2R1Y3QtdGF4LWZvcm0tYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2R1Y3QtdGF4LWZvcm0tYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgUHJvZHVjdFRheEZvcm1CdXR0b25Db21wb25lbnQgZXh0ZW5kcyBUZWNobGlmeUZvcm1Db21wb25lbnRJbnRlcmZhY2UgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwcm9kdWN0OiBhbnk7XG4gIEBPdXRwdXQoKSBzYXZlZDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgaXNTYXZpbmchOiBib29sZWFuO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBtYXREaWFsb2c6IE1hdERpYWxvZyxcbiAgICBwcml2YXRlIHByb2R1Y3RUYXhTZXJ2aWNlOiBQcm9kdWN0VGF4U2VydmljZSxcbiAgICBmb3JtVmFsaWRhdG9yU2VydmljZTogRm9ybVZhbGlkYXRvclNlcnZpY2UsXG4gICAgcHJpdmF0ZSBmb3JtQnVpbGRlcjogRm9ybUJ1aWxkZXIsXG4gICAgcHJpdmF0ZSBhbGVydFNlcnZpY2U6IEFsZXJ0U2VydmljZVxuICApIHtcbiAgICBzdXBlcihmb3JtVmFsaWRhdG9yU2VydmljZSk7XG4gICAgdGhpcy5lcnJvck1lc3NhZ2VzID0ge1xuICAgICAgdGF4X2lkOiB7XG4gICAgICAgIHJlcXVpcmVkOiAnVGhlIHRheCBmaWVsZCBpcyByZXF1aXJlZC4nLFxuICAgICAgfSxcbiAgICB9O1xuXG4gICAgdGhpcy5mb3JtID0gdGhpcy5mb3JtQnVpbGRlci5ncm91cCh7XG4gICAgICBwcm9kdWN0X2lkOiBbJyddLFxuICAgICAgdGF4X2lkOiBbJycsIFZhbGlkYXRvcnMucmVxdWlyZWRdLFxuICAgIH0pO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgaWYgKHRoaXMucHJvZHVjdCkge1xuICAgICAgdGhpcy5mb3JtLmdldCgncHJvZHVjdF9pZCcpPy5zZXRWYWx1ZSh0aGlzLnByb2R1Y3Q/LmlkKTtcbiAgICB9XG4gIH1cblxuICBzaG93Rm9ybSh0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55Pikge1xuICAgIHRoaXMubWF0RGlhbG9nLm9wZW4odGVtcGxhdGVSZWYsIHsgd2lkdGg6ICc0MDBweCcgfSk7XG4gIH1cblxuICBzYXZlKCkge1xuICAgIHRoaXMuZm9ybS5tYXJrQWxsQXNUb3VjaGVkKCk7XG4gICAgaWYgKHRoaXMuZm9ybS5pbnZhbGlkKSB7XG4gICAgICB0aGlzLmFsZXJ0U2VydmljZS5hZGRBbGVydCgnUGxlYXNlIGNoZWNrIHRoZSBmb3JtIGZvciBlcnJvcnMuJywgJ2Vycm9yJyk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgZGF0YTogYW55ID0geyAuLi50aGlzLmZvcm0udmFsdWUgfTtcbiAgICBjb25zdCBwYXJhbXM6IGFueSA9IHtcbiAgICAgIHdpdGg6ICd0YXgudHlwZScsXG4gICAgfTtcbiAgICB0aGlzLmlzU2F2aW5nID0gdHJ1ZTtcblxuICAgIHRoaXMucHJvZHVjdFRheFNlcnZpY2Uuc3RvcmUoZGF0YSwgcGFyYW1zKS5zdWJzY3JpYmUoe1xuICAgICAgbmV4dDogKHJlc3BvbnNlOiBhbnkpID0+IHtcbiAgICAgICAgdGhpcy5pc1NhdmluZyA9IGZhbHNlO1xuICAgICAgICB0aGlzLm1hdERpYWxvZy5jbG9zZUFsbCgpO1xuICAgICAgICB0aGlzLmFsZXJ0U2VydmljZS5hZGRBbGVydCgnUHJvZHVjdCB0YXggc2F2ZWQgc3VjY2Vzc2Z1bGx5IScsICdzdWNjZXNzJyk7XG4gICAgICAgIHRoaXMuc2F2ZWQuZW1pdChyZXNwb25zZT8uaXRlbSk7XG4gICAgICB9LFxuICAgICAgZXJyb3I6ICgpID0+ICh0aGlzLmlzU2F2aW5nID0gZmFsc2UpLFxuICAgIH0pO1xuICB9XG59XG4iLCI8bWF0LWljb24gY29sb3I9XCJwcmltYXJ5XCIgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiIChjbGljayk9XCJzaG93Rm9ybShmb3JtVGVtcGxhdGUpXCI+IGFkZCA8L21hdC1pY29uPlxuXG48bmctdGVtcGxhdGUgI2Zvcm1UZW1wbGF0ZT5cbiAgPGZvcm0gW2Zvcm1Hcm91cF09XCJmb3JtXCIgKHN1Ym1pdCk9XCJzYXZlKClcIiBtYXQtZGlhbG9nLWNvbnRlbnQgY2xhc3M9XCJkLWZsZXggZmxleC1jb2x1bW4gZ2FwLTJcIj5cbiAgICA8aDMgY2xhc3M9XCJ0ZXh0LWRhcmtcIj5BZGQgdGF4IGZvciB7eyBwcm9kdWN0Py5uYW1lIH19PC9oMz5cbiAgICA8bWF0LWZvcm0tZmllbGQ+XG4gICAgICA8bWF0LWxhYmVsPlRheDwvbWF0LWxhYmVsPlxuICAgICAgPGFwcC1zZWFyY2hhYmxlLXNlbGVjdG9yXG4gICAgICAgIGZvcm1Db250cm9sTmFtZT1cInRheF9pZFwiXG4gICAgICAgIHJlcXVpcmVkXG4gICAgICAgIGFwaVVybD1cImFwaS90YXhlc1wiXG4gICAgICAgIFtlbmFibGVTZWFyY2hdPVwiZmFsc2VcIlxuICAgICAgPjwvYXBwLXNlYXJjaGFibGUtc2VsZWN0b3I+XG4gICAgICA8bWF0LWVycm9yICpuZ0lmPVwiaXNGaWVsZFZhbGlkKCd0YXhfaWQnKVwiPlxuICAgICAgICB7eyBnZXRFcnJvck1lc3NhZ2UoJ3RheF9pZCcpIH19XG4gICAgICA8L21hdC1lcnJvcj5cbiAgICA8L21hdC1mb3JtLWZpZWxkPlxuXG4gICAgPGRpdiBjbGFzcz1cImQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtZW5kIGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtM1wiPlxuICAgICAgPGJ1dHRvbiBbZGlzYWJsZWRdPVwiaXNTYXZpbmdcIiB0eXBlPVwic3VibWl0XCIgbWF0LXJhaXNlZC1idXR0b24gY29sb3I9XCJwcmltYXJ5XCI+U2F2ZTwvYnV0dG9uPlxuICAgICAgPGJ1dHRvbiBbZGlzYWJsZWRdPVwiaXNTYXZpbmdcIiB0eXBlPVwiYnV0dG9uXCIgbWF0LWZsYXQtYnV0dG9uIG1hdC1kaWFsb2ctY2xvc2U+Q2FuY2VsPC9idXR0b24+XG4gICAgPC9kaXY+XG4gIDwvZm9ybT5cbjwvbmctdGVtcGxhdGU+XG4iXX0=