gunsmith-common 2.2.3 → 2.2.5
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/esm2020/gunsmith-common.mjs +4 -4
- package/esm2020/notification/fade-out.animation.mjs +10 -10
- package/esm2020/notification/index.mjs +4 -4
- package/esm2020/notification/notification-bar/notification-bar.component.mjs +43 -43
- package/esm2020/notification/notification-message.mjs +3 -3
- package/esm2020/notification/notification-type.enum.mjs +6 -6
- package/esm2020/notification/notification.module.mjs +26 -26
- package/esm2020/notification/notification.service.mjs +21 -21
- package/esm2020/public_api.mjs +13 -13
- package/esm2020/shared/controls/package-selector/package-selector.component.mjs +172 -172
- package/esm2020/shared/directives/disable-control.directive.mjs +24 -24
- package/esm2020/shared/directives/index.mjs +3 -3
- package/esm2020/shared/directives/refinish-details-validators.mjs +45 -45
- package/esm2020/shared/pipes/enum.pipe.mjs +16 -16
- package/esm2020/shared/pipes/file-name.pipe.mjs +16 -16
- package/esm2020/shared/pipes/frame-material.pipe.mjs +24 -24
- package/esm2020/shared/pipes/index.mjs +6 -6
- package/esm2020/shared/pipes/new-line.pipe.mjs +16 -16
- package/esm2020/shared/pipes/phone.pipe.mjs +19 -19
- package/esm2020/shared/services/coating.service.mjs +63 -63
- package/esm2020/shared/services/configuration.service.mjs +29 -29
- package/esm2020/shared/services/customer.service.mjs +47 -47
- package/esm2020/shared/services/dealer.service.mjs +45 -45
- package/esm2020/shared/services/file-upload.service.mjs +39 -39
- package/esm2020/shared/services/firearm-series.service.mjs +45 -45
- package/esm2020/shared/services/firearm.service.mjs +48 -48
- package/esm2020/shared/services/gun-part.service.mjs +52 -52
- package/esm2020/shared/services/index.mjs +27 -27
- package/esm2020/shared/services/inventory.service.mjs +38 -38
- package/esm2020/shared/services/material.service.mjs +30 -30
- package/esm2020/shared/services/milling-type.service.mjs +53 -53
- package/esm2020/shared/services/optic.service.mjs +42 -42
- package/esm2020/shared/services/package.service.mjs +47 -47
- package/esm2020/shared/services/product.service.mjs +29 -29
- package/esm2020/shared/services/purchase-order.service.mjs +87 -87
- package/esm2020/shared/services/refinish-code.service.mjs +35 -35
- package/esm2020/shared/services/state.service.mjs +26 -26
- package/esm2020/shared/services/status-history.service.mjs +40 -40
- package/esm2020/shared/services/totals.service.mjs +50 -50
- package/esm2020/shared/services/user.service.mjs +26 -26
- package/esm2020/shared/services/vendor.service.mjs +42 -42
- package/esm2020/shared/services/waitlist-customer.service.mjs +38 -38
- package/esm2020/shared/services/waitlist-project.service.mjs +38 -38
- package/esm2020/shared/services/waitlist.service.mjs +86 -86
- package/esm2020/shared/services/work-holiday.service.mjs +32 -32
- package/esm2020/shared/services/work-order.service.mjs +195 -187
- package/esm2020/shared/shared.module.mjs +67 -67
- package/esm2020/shared/types/bundle-item.mjs +6 -6
- package/esm2020/shared/types/change-order-status.mjs +9 -9
- package/esm2020/shared/types/coating-value.mjs +6 -6
- package/esm2020/shared/types/coating.mjs +8 -8
- package/esm2020/shared/types/configuration.mjs +3 -3
- package/esm2020/shared/types/customer.mjs +6 -6
- package/esm2020/shared/types/dealer-contact.mjs +3 -3
- package/esm2020/shared/types/dealer-coupon.mjs +3 -3
- package/esm2020/shared/types/dealer.mjs +8 -8
- package/esm2020/shared/types/filter-options.mjs +9 -9
- package/esm2020/shared/types/firearm-series-optic.mjs +9 -9
- package/esm2020/shared/types/firearm-series.mjs +10 -10
- package/esm2020/shared/types/firearm.mjs +6 -6
- package/esm2020/shared/types/frame-material.mjs +8 -8
- package/esm2020/shared/types/gun-caliber.mjs +7 -7
- package/esm2020/shared/types/gun-part-option.mjs +3 -3
- package/esm2020/shared/types/gun-part.mjs +11 -11
- package/esm2020/shared/types/index.mjs +68 -67
- package/esm2020/shared/types/inventory-item.mjs +6 -6
- package/esm2020/shared/types/j-file.mjs +3 -3
- package/esm2020/shared/types/material.mjs +6 -6
- package/esm2020/shared/types/milling-detail.mjs +7 -7
- package/esm2020/shared/types/milling-item.mjs +3 -3
- package/esm2020/shared/types/milling-type.mjs +6 -6
- package/esm2020/shared/types/mount-type.mjs +9 -9
- package/esm2020/shared/types/optic-status.mjs +7 -7
- package/esm2020/shared/types/optic.mjs +7 -7
- package/esm2020/shared/types/package-item.mjs +3 -3
- package/esm2020/shared/types/package-optional-item.mjs +3 -3
- package/esm2020/shared/types/package-total.mjs +3 -3
- package/esm2020/shared/types/package-variation-option.mjs +3 -3
- package/esm2020/shared/types/package-variation.mjs +6 -6
- package/esm2020/shared/types/package.mjs +10 -10
- package/esm2020/shared/types/product.mjs +3 -3
- package/esm2020/shared/types/project-type.mjs +7 -7
- package/esm2020/shared/types/purchase-order-refinish-item.mjs +3 -3
- package/esm2020/shared/types/purchase-order-status.mjs +8 -8
- package/esm2020/shared/types/purchase-order.mjs +9 -9
- package/esm2020/shared/types/rear-sight-position.mjs +6 -6
- package/esm2020/shared/types/refinish-code.mjs +3 -3
- package/esm2020/shared/types/refinish-detail.mjs +3 -3
- package/esm2020/shared/types/report-milling-item.mjs +3 -3
- package/esm2020/shared/types/report-refinish-item.mjs +3 -3
- package/esm2020/shared/types/shield-rms-options.mjs +6 -6
- package/esm2020/shared/types/sight-type.mjs +7 -7
- package/esm2020/shared/types/state.mjs +3 -3
- package/esm2020/shared/types/total-item.mjs +3 -3
- package/esm2020/shared/types/total.mjs +3 -3
- package/esm2020/shared/types/vendor-contact.mjs +3 -3
- package/esm2020/shared/types/vendor.mjs +7 -7
- package/esm2020/shared/types/waitlist-action.mjs +9 -9
- package/esm2020/shared/types/waitlist-gun-package-detail.mjs +7 -7
- package/esm2020/shared/types/waitlist-gun.mjs +12 -12
- package/esm2020/shared/types/waitlist-history.mjs +3 -3
- package/esm2020/shared/types/waitlist-item.mjs +12 -12
- package/esm2020/shared/types/waitlist-status.mjs +15 -15
- package/esm2020/shared/types/work-change-order.mjs +3 -3
- package/esm2020/shared/types/work-holiday.mjs +3 -3
- package/esm2020/shared/types/work-order-action.mjs +7 -7
- package/esm2020/shared/types/work-order-history.mjs +3 -3
- package/esm2020/shared/types/work-order-inventory-item.mjs +3 -3
- package/esm2020/shared/types/work-order-list-item.mjs +3 -0
- package/esm2020/shared/types/work-order-package-detail.mjs +7 -7
- package/esm2020/shared/types/work-order-refinish-item.mjs +3 -3
- package/esm2020/shared/types/work-order-status.mjs +18 -18
- package/esm2020/shared/types/work-order-type.mjs +8 -8
- package/esm2020/shared/types/work-order.mjs +18 -18
- package/esm2020/shared/utils/coating-helpers.mjs +22 -22
- package/esm2020/shared/utils/enum-object.mjs +10 -10
- package/esm2020/shared/utils/finish-date-calculator.mjs +30 -30
- package/esm2020/shared/utils/index.mjs +5 -5
- package/esm2020/shared/utils/invalid-form-control-toucher.mjs +7 -7
- package/fesm2015/gunsmith-common.mjs +2019 -2008
- package/fesm2015/gunsmith-common.mjs.map +1 -1
- package/fesm2020/gunsmith-common.mjs +1965 -1954
- package/fesm2020/gunsmith-common.mjs.map +1 -1
- package/gunsmith-common-2.2.5.tgz +0 -0
- package/gunsmith-common.d.ts +5 -5
- package/notification/fade-out.animation.d.ts +2 -2
- package/notification/index.d.ts +3 -3
- package/notification/notification-bar/notification-bar.component.d.ts +18 -18
- package/notification/notification-message.d.ts +6 -6
- package/notification/notification-type.enum.d.ts +4 -4
- package/notification/notification.module.d.ts +8 -8
- package/notification/notification.service.d.ts +12 -12
- package/package.json +1 -1
- package/public_api.d.ts +9 -9
- package/shared/controls/package-selector/package-selector.component.d.ts +39 -39
- package/shared/directives/disable-control.directive.d.ts +9 -9
- package/shared/directives/index.d.ts +2 -2
- package/shared/directives/refinish-details-validators.d.ts +4 -4
- package/shared/pipes/enum.pipe.d.ts +7 -7
- package/shared/pipes/file-name.pipe.d.ts +7 -7
- package/shared/pipes/frame-material.pipe.d.ts +11 -11
- package/shared/pipes/index.d.ts +5 -5
- package/shared/pipes/new-line.pipe.d.ts +7 -7
- package/shared/pipes/phone.pipe.d.ts +7 -7
- package/shared/services/coating.service.d.ts +22 -22
- package/shared/services/configuration.service.d.ts +14 -14
- package/shared/services/customer.service.d.ts +17 -17
- package/shared/services/dealer.service.d.ts +19 -19
- package/shared/services/file-upload.service.d.ts +14 -14
- package/shared/services/firearm-series.service.d.ts +18 -18
- package/shared/services/firearm.service.d.ts +20 -20
- package/shared/services/gun-part.service.d.ts +18 -18
- package/shared/services/index.d.ts +26 -26
- package/shared/services/inventory.service.d.ts +15 -15
- package/shared/services/material.service.d.ts +13 -13
- package/shared/services/milling-type.service.d.ts +18 -18
- package/shared/services/optic.service.d.ts +17 -17
- package/shared/services/package.service.d.ts +16 -16
- package/shared/services/product.service.d.ts +15 -15
- package/shared/services/purchase-order.service.d.ts +27 -27
- package/shared/services/refinish-code.service.d.ts +16 -16
- package/shared/services/state.service.d.ts +13 -13
- package/shared/services/status-history.service.d.ts +14 -14
- package/shared/services/totals.service.d.ts +15 -15
- package/shared/services/user.service.d.ts +12 -12
- package/shared/services/vendor.service.d.ts +17 -17
- package/shared/services/waitlist-customer.service.d.ts +15 -15
- package/shared/services/waitlist-project.service.d.ts +17 -17
- package/shared/services/waitlist.service.d.ts +25 -25
- package/shared/services/work-holiday.service.d.ts +15 -15
- package/shared/services/work-order.service.d.ts +53 -51
- package/shared/shared.module.d.ts +16 -16
- package/shared/types/bundle-item.d.ts +11 -11
- package/shared/types/change-order-status.d.ts +7 -7
- package/shared/types/coating-value.d.ts +6 -6
- package/shared/types/coating.d.ts +11 -11
- package/shared/types/configuration.d.ts +11 -11
- package/shared/types/customer.d.ts +14 -14
- package/shared/types/dealer-contact.d.ts +9 -9
- package/shared/types/dealer-coupon.d.ts +5 -5
- package/shared/types/dealer.d.ts +24 -24
- package/shared/types/filter-options.d.ts +6 -6
- package/shared/types/firearm-series-optic.d.ts +12 -12
- package/shared/types/firearm-series.d.ts +11 -11
- package/shared/types/firearm.d.ts +10 -10
- package/shared/types/frame-material.d.ts +6 -6
- package/shared/types/gun-caliber.d.ts +5 -5
- package/shared/types/gun-part-option.d.ts +9 -9
- package/shared/types/gun-part.d.ts +13 -13
- package/shared/types/index.d.ts +67 -66
- package/shared/types/inventory-item.d.ts +9 -9
- package/shared/types/j-file.d.ts +5 -5
- package/shared/types/material.d.ts +6 -6
- package/shared/types/milling-detail.d.ts +19 -19
- package/shared/types/milling-item.d.ts +8 -8
- package/shared/types/milling-type.d.ts +10 -10
- package/shared/types/mount-type.d.ts +7 -7
- package/shared/types/optic-status.d.ts +5 -5
- package/shared/types/optic.d.ts +7 -7
- package/shared/types/package-item.d.ts +9 -9
- package/shared/types/package-optional-item.d.ts +6 -6
- package/shared/types/package-total.d.ts +5 -5
- package/shared/types/package-variation-option.d.ts +10 -10
- package/shared/types/package-variation.d.ts +8 -8
- package/shared/types/package.d.ts +14 -14
- package/shared/types/product.d.ts +7 -7
- package/shared/types/project-type.d.ts +5 -5
- package/shared/types/purchase-order-refinish-item.d.ts +18 -18
- package/shared/types/purchase-order-status.d.ts +6 -6
- package/shared/types/purchase-order.d.ts +11 -11
- package/shared/types/rear-sight-position.d.ts +4 -4
- package/shared/types/refinish-code.d.ts +8 -8
- package/shared/types/refinish-detail.d.ts +13 -13
- package/shared/types/report-milling-item.d.ts +16 -16
- package/shared/types/report-refinish-item.d.ts +20 -20
- package/shared/types/shield-rms-options.d.ts +4 -4
- package/shared/types/sight-type.d.ts +5 -5
- package/shared/types/state.d.ts +4 -4
- package/shared/types/total-item.d.ts +4 -4
- package/shared/types/total.d.ts +5 -5
- package/shared/types/vendor-contact.d.ts +9 -9
- package/shared/types/vendor.d.ts +20 -20
- package/shared/types/waitlist-action.d.ts +7 -7
- package/shared/types/waitlist-gun-package-detail.d.ts +10 -10
- package/shared/types/waitlist-gun.d.ts +24 -24
- package/shared/types/waitlist-history.d.ts +8 -8
- package/shared/types/waitlist-item.d.ts +25 -25
- package/shared/types/waitlist-status.d.ts +13 -13
- package/shared/types/work-change-order.d.ts +10 -10
- package/shared/types/work-holiday.d.ts +4 -4
- package/shared/types/work-order-action.d.ts +5 -5
- package/shared/types/work-order-history.d.ts +8 -8
- package/shared/types/work-order-inventory-item.d.ts +7 -7
- package/shared/types/work-order-list-item.d.ts +15 -0
- package/shared/types/work-order-package-detail.d.ts +10 -10
- package/shared/types/work-order-refinish-item.d.ts +18 -18
- package/shared/types/work-order-status.d.ts +16 -16
- package/shared/types/work-order-type.d.ts +6 -6
- package/shared/types/work-order.d.ts +33 -33
- package/shared/utils/coating-helpers.d.ts +5 -5
- package/shared/utils/enum-object.d.ts +5 -5
- package/shared/utils/finish-date-calculator.d.ts +2 -2
- package/shared/utils/index.d.ts +4 -4
- package/shared/utils/invalid-form-control-toucher.d.ts +2 -2
|
@@ -1,172 +1,172 @@
|
|
|
1
|
-
import { Component, Injector, Input } from '@angular/core';
|
|
2
|
-
import { FormBuilder, NgControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';
|
|
3
|
-
import { PackageService } from '../../services';
|
|
4
|
-
import { ProjectType } from '../../types';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "../../services";
|
|
7
|
-
import * as i2 from "@angular/forms";
|
|
8
|
-
import * as i3 from "@progress/kendo-angular-dropdowns";
|
|
9
|
-
import * as i4 from "@angular/common";
|
|
10
|
-
export class PackageSelectorComponent {
|
|
11
|
-
constructor(packageService, fb, inj) {
|
|
12
|
-
this.packageService = packageService;
|
|
13
|
-
this.fb = fb;
|
|
14
|
-
this.inj = inj;
|
|
15
|
-
this.packages = [];
|
|
16
|
-
this.packageVariations = [];
|
|
17
|
-
this.packageOptionalItems = [];
|
|
18
|
-
this.onChangeSubs = [];
|
|
19
|
-
this.onTouched = () => { };
|
|
20
|
-
this.touched = false;
|
|
21
|
-
this.disabled = false;
|
|
22
|
-
this.createForm();
|
|
23
|
-
}
|
|
24
|
-
ngOnChanges(changes) {
|
|
25
|
-
if ((changes.firearmId?.currentValue && this.projectType === ProjectType.Firearm) ||
|
|
26
|
-
(changes.projectType?.currentValue === ProjectType.Firearm && this.firearmId)) {
|
|
27
|
-
this.getPackages();
|
|
28
|
-
this.packageForm.reset();
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
this.packages = [];
|
|
32
|
-
this.packageForm.reset();
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
ngAfterViewInit() {
|
|
36
|
-
const outerControl = this.inj.get(NgControl).control;
|
|
37
|
-
const prevMarkAsTouched = outerControl.markAsTouched;
|
|
38
|
-
outerControl.markAsTouched = (...args) => {
|
|
39
|
-
this.packageForm.markAllAsTouched();
|
|
40
|
-
prevMarkAsTouched.bind(outerControl)(...args);
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
ngOnDestroy() {
|
|
44
|
-
for (let sub of this.onChangeSubs) {
|
|
45
|
-
sub.unsubscribe();
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
getPackages() {
|
|
49
|
-
this.packageService.readPackagesByFirearm(this.firearmId)
|
|
50
|
-
.subscribe(packages => {
|
|
51
|
-
this.packages = packages;
|
|
52
|
-
if (this.packageForm.controls.package.value) {
|
|
53
|
-
let packagez = this.packages.find(p => p.id === this.packageForm.controls.package.value.id);
|
|
54
|
-
this.setPackageOptions(packagez);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
createForm() {
|
|
59
|
-
this.packageForm = this.fb.group({
|
|
60
|
-
package: null,
|
|
61
|
-
optionalItems: this.fb.control([]),
|
|
62
|
-
variations: this.fb.array([])
|
|
63
|
-
});
|
|
64
|
-
this.packageForm.controls.package.valueChanges
|
|
65
|
-
.subscribe(value => {
|
|
66
|
-
this.packageForm.controls.optionalItems.reset();
|
|
67
|
-
this.packageOptionalItems = [];
|
|
68
|
-
this.variations.clear({ emitEvent: false });
|
|
69
|
-
this.packageVariations = [];
|
|
70
|
-
if (value?.id) {
|
|
71
|
-
this.setPackageOptions(value);
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
if (this.packageDetail) {
|
|
75
|
-
this.packageDetail.variations = null;
|
|
76
|
-
this.packageDetail.optionalItems = null;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
get variations() { return this.packageForm.controls.variations; }
|
|
82
|
-
setPackageOptions(packagez) {
|
|
83
|
-
this.packageOptionalItems = packagez.optionalItems;
|
|
84
|
-
this.packageVariations = packagez.variations;
|
|
85
|
-
this.variations.clear({ emitEvent: false });
|
|
86
|
-
for (let v of this.packageVariations) {
|
|
87
|
-
let selectedVariation = this.packageDetail?.variations?.find(pv => pv.packageVariationId === v.id);
|
|
88
|
-
this.variations.push(this.fb.control(selectedVariation, Validators.required), { emitEvent: false });
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
setValue(packageDetail) {
|
|
92
|
-
this.packageForm.reset(packageDetail);
|
|
93
|
-
}
|
|
94
|
-
validate(control) {
|
|
95
|
-
if (this.packageForm.valid) {
|
|
96
|
-
return null;
|
|
97
|
-
}
|
|
98
|
-
let errors = {};
|
|
99
|
-
for (let v of this.variations.controls) {
|
|
100
|
-
if (v.invalid) {
|
|
101
|
-
return v.errors;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
return errors;
|
|
105
|
-
}
|
|
106
|
-
addControlErrors(allErrors, controlName) {
|
|
107
|
-
const errors = { ...allErrors };
|
|
108
|
-
const controlErrors = this.packageForm.controls[controlName].errors;
|
|
109
|
-
if (controlErrors) {
|
|
110
|
-
errors[controlName] = controlErrors;
|
|
111
|
-
}
|
|
112
|
-
return errors;
|
|
113
|
-
}
|
|
114
|
-
writeValue(packageDetail) {
|
|
115
|
-
if (packageDetail) {
|
|
116
|
-
this.packageDetail = Object.assign({}, packageDetail);
|
|
117
|
-
this.setValue(packageDetail);
|
|
118
|
-
}
|
|
119
|
-
else {
|
|
120
|
-
this.packageForm.reset();
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
registerOnChange(onChange) {
|
|
124
|
-
const sub = this.packageForm.valueChanges.subscribe(onChange);
|
|
125
|
-
this.onChangeSubs.push(sub);
|
|
126
|
-
}
|
|
127
|
-
registerOnTouched(onTouched) {
|
|
128
|
-
this.onTouched = onTouched;
|
|
129
|
-
}
|
|
130
|
-
setDisabledState(isDisabled) {
|
|
131
|
-
this.disabled = isDisabled;
|
|
132
|
-
if (isDisabled) {
|
|
133
|
-
this.packageForm.disable();
|
|
134
|
-
}
|
|
135
|
-
else {
|
|
136
|
-
this.packageForm.enable();
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
PackageSelectorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PackageSelectorComponent, deps: [{ token: i1.PackageService }, { token: i2.FormBuilder }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
141
|
-
PackageSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PackageSelectorComponent, selector: "cgw-package-selector", inputs: { firearmId: "firearmId", projectType: "projectType" }, providers: [
|
|
142
|
-
{
|
|
143
|
-
provide: NG_VALUE_ACCESSOR,
|
|
144
|
-
multi: true,
|
|
145
|
-
useExisting: PackageSelectorComponent
|
|
146
|
-
},
|
|
147
|
-
{
|
|
148
|
-
provide: NG_VALIDATORS,
|
|
149
|
-
multi: true,
|
|
150
|
-
useExisting: PackageSelectorComponent
|
|
151
|
-
}
|
|
152
|
-
], usesOnChanges: true, ngImport: i0, template: "<div [formGroup]=\"packageForm\">\
|
|
153
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PackageSelectorComponent, decorators: [{
|
|
154
|
-
type: Component,
|
|
155
|
-
args: [{ selector: 'cgw-package-selector', providers: [
|
|
156
|
-
{
|
|
157
|
-
provide: NG_VALUE_ACCESSOR,
|
|
158
|
-
multi: true,
|
|
159
|
-
useExisting: PackageSelectorComponent
|
|
160
|
-
},
|
|
161
|
-
{
|
|
162
|
-
provide: NG_VALIDATORS,
|
|
163
|
-
multi: true,
|
|
164
|
-
useExisting: PackageSelectorComponent
|
|
165
|
-
}
|
|
166
|
-
], template: "<div [formGroup]=\"packageForm\">\
|
|
167
|
-
}], ctorParameters: function () { return [{ type: i1.PackageService }, { type: i2.FormBuilder }, { type: i0.Injector }]; }, propDecorators: { firearmId: [{
|
|
168
|
-
type: Input
|
|
169
|
-
}], projectType: [{
|
|
170
|
-
type: Input
|
|
171
|
-
}] } });
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"package-selector.component.js","sourceRoot":"","sources":["../../../../../../projects/gunsmith-common/src/shared/controls/package-selector/package-selector.component.ts","../../../../../../projects/gunsmith-common/src/shared/controls/package-selector/package-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, FormArray, FormBuilder, FormGroup, NgControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator, Validators } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { PackageService } from '../../services';\r\nimport { Package, PackageVariation, PackageOptionalItem, WaitlistGunPackageDetail, WorkOrderPackageDetail, ProjectType } from '../../types';\r\n\r\n@Component({\r\n  selector: 'cgw-package-selector',\r\n  templateUrl: './package-selector.component.html',\r\n  styleUrls: ['./package-selector.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: PackageSelectorComponent\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      multi: true,\r\n      useExisting: PackageSelectorComponent\r\n    }\r\n  ]\r\n})\r\nexport class PackageSelectorComponent implements ControlValueAccessor, Validator, OnChanges, OnDestroy, AfterViewInit {\r\n\r\n  @Input()\r\n  firearmId: number;\r\n\r\n  @Input()\r\n  projectType: ProjectType;\r\n\r\n  packages: Package[] = [];\r\n  packageVariations: PackageVariation[] = [];\r\n  packageOptionalItems: PackageOptionalItem[] = [];\r\n\r\n  packageDetail: WaitlistGunPackageDetail | WorkOrderPackageDetail;\r\n\r\n  packageForm: FormGroup;\r\n\r\n  onChangeSubs: Subscription[] = [];\r\n  onTouched = () => { };\r\n\r\n  touched = false;\r\n  disabled = false;\r\n\r\n  constructor(\r\n    private packageService: PackageService,\r\n    private fb: FormBuilder,\r\n    private inj: Injector\r\n  ) {\r\n    this.createForm();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.firearmId?.currentValue && this.projectType === ProjectType.Firearm) ||\r\n      (changes.projectType?.currentValue === ProjectType.Firearm && this.firearmId)) {\r\n      this.getPackages();\r\n      this.packageForm.reset();\r\n    }\r\n    else {\r\n      this.packages = [];\r\n      this.packageForm.reset();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const outerControl = this.inj.get(NgControl).control;\r\n    const prevMarkAsTouched = outerControl.markAsTouched;\r\n    outerControl.markAsTouched = (...args: any) => {\r\n      this.packageForm.markAllAsTouched();\r\n      prevMarkAsTouched.bind(outerControl)(...args);\r\n    };\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    for (let sub of this.onChangeSubs) {\r\n      sub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  getPackages(): void {\r\n    this.packageService.readPackagesByFirearm(this.firearmId)\r\n      .subscribe(packages => {\r\n        this.packages = packages;\r\n        if (this.packageForm.controls.package.value) {\r\n          let packagez = this.packages.find(p => p.id === this.packageForm.controls.package.value.id);\r\n          this.setPackageOptions(packagez);\r\n        }\r\n      });\r\n  }\r\n\r\n  createForm(): void {\r\n    this.packageForm = this.fb.group({\r\n      package: null,\r\n      optionalItems: this.fb.control([]),\r\n      variations: this.fb.array([])\r\n    })\r\n\r\n    this.packageForm.controls.package.valueChanges\r\n      .subscribe(value => {\r\n        this.packageForm.controls.optionalItems.reset();\r\n        this.packageOptionalItems = [];\r\n\r\n        this.variations.clear({ emitEvent: false });\r\n        this.packageVariations = [];\r\n\r\n        if (value?.id) {\r\n          this.setPackageOptions(value);\r\n        }\r\n        else {\r\n          if (this.packageDetail) {\r\n            this.packageDetail.variations = null;\r\n            this.packageDetail.optionalItems = null;\r\n          }\r\n        }\r\n      })\r\n  }\r\n\r\n  get variations() { return this.packageForm.controls.variations as FormArray }\r\n\r\n  setPackageOptions(packagez: Package) {\r\n    this.packageOptionalItems = packagez.optionalItems;\r\n    this.packageVariations = packagez.variations;\r\n\r\n    this.variations.clear({emitEvent: false});\r\n    for (let v of this.packageVariations) {\r\n      let selectedVariation = this.packageDetail?.variations?.find(pv => pv.packageVariationId === v.id);\r\n      this.variations.push(this.fb.control(selectedVariation, Validators.required), {emitEvent: false});\r\n    }\r\n  }\r\n\r\n  setValue(packageDetail: WaitlistGunPackageDetail | WorkOrderPackageDetail) {\r\n    this.packageForm.reset(packageDetail);\r\n  }\r\n\r\n  validate(control: AbstractControl): ValidationErrors {\r\n    if (this.packageForm.valid) {\r\n      return null;\r\n    }\r\n\r\n    let errors: any = {};\r\n\r\n    for (let v of this.variations.controls) {\r\n      if (v.invalid) {\r\n        return v.errors;\r\n      }\r\n    }\r\n\r\n    return errors;\r\n  }\r\n\r\n  addControlErrors(allErrors: any, controlName: string) {\r\n\r\n    const errors = { ...allErrors };\r\n\r\n    const controlErrors = this.packageForm.controls[controlName].errors;\r\n\r\n    if (controlErrors) {\r\n      errors[controlName] = controlErrors;\r\n    }\r\n\r\n    return errors;\r\n  }\r\n\r\n  writeValue(packageDetail: WaitlistGunPackageDetail | WorkOrderPackageDetail): void {\r\n    if (packageDetail) {\r\n      this.packageDetail = Object.assign({},packageDetail);\r\n      this.setValue(packageDetail);\r\n    }\r\n    else {\r\n      this.packageForm.reset();\r\n    }\r\n  }\r\n\r\n  registerOnChange(onChange: any): void {\r\n    const sub = this.packageForm.valueChanges.subscribe(onChange);\r\n    this.onChangeSubs.push(sub);\r\n  }\r\n\r\n  registerOnTouched(onTouched: any): void {\r\n    this.onTouched = onTouched;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    if (isDisabled) {\r\n      this.packageForm.disable();\r\n    }\r\n    else {\r\n      this.packageForm.enable();\r\n    }\r\n  }\r\n}\r\n","<div [formGroup]=\"packageForm\">\r\n  <div class=\"row mb-2\">\r\n    <div class=\"col\">\r\n      <label for=\"waitlist-gun-package\">Package - <span class=\"fst-italic fs-7\">Select a model to list available packages</span></label>\r\n      <kendo-dropdownlist [data]=\"packages\"\r\n                          [defaultItem]=\"{name: 'No Package', id: null}\"\r\n                          id=\"waitlist-gun-package\"\r\n                          formControlName=\"package\"\r\n                          textField=\"name\"\r\n                          valueField=\"id\"\r\n                          size=\"small\"></kendo-dropdownlist>\r\n    </div>\r\n  </div>\r\n  <div formArrayName=\"variations\" *ngFor=\"let variationControl of variations.controls; let i = index\">\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col\">\r\n        <label [for]=\"'waitlist-gun-package-variation-' + i\">{{packageVariations[i]?.name}}</label>\r\n        <kendo-dropdownlist [data]=\"packageVariations[i]?.options\"\r\n                            [id]=\"'waitlist-gun-package-variation-' + i\"\r\n                            textField=\"optionName\"\r\n                            [formControl]=\"variationControl\"\r\n                            valueField=\"id\"\r\n                            size=\"small\"></kendo-dropdownlist>\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"variationControl.invalid && (variationControl.dirty || variationControl.touched)\" class=\"error-container text-danger\">\r\n      <div *ngIf=\"variationControl.errors.required\">\r\n        {{packageVariations[i]?.name}} is required.\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"row mb-2\" *ngIf=\"packageOptionalItems?.length\">\r\n    <div class=\"col\">\r\n      <label for=\"waitlist-gun-package-addons\">Add-ons (Additional charges will apply)</label>\r\n      <kendo-multiselect id=\"waitlist-gun-package-addons\"\r\n                         [data]=\"packageOptionalItems\"\r\n                         formControlName=\"optionalItems\"\r\n                         textField=\"name\"\r\n                         valueField=\"inventoryItemId\"\r\n                         size=\"small\"></kendo-multiselect>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
1
|
+
import { Component, Injector, Input } from '@angular/core';
|
|
2
|
+
import { FormBuilder, NgControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';
|
|
3
|
+
import { PackageService } from '../../services';
|
|
4
|
+
import { ProjectType } from '../../types';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "@progress/kendo-angular-dropdowns";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
export class PackageSelectorComponent {
|
|
11
|
+
constructor(packageService, fb, inj) {
|
|
12
|
+
this.packageService = packageService;
|
|
13
|
+
this.fb = fb;
|
|
14
|
+
this.inj = inj;
|
|
15
|
+
this.packages = [];
|
|
16
|
+
this.packageVariations = [];
|
|
17
|
+
this.packageOptionalItems = [];
|
|
18
|
+
this.onChangeSubs = [];
|
|
19
|
+
this.onTouched = () => { };
|
|
20
|
+
this.touched = false;
|
|
21
|
+
this.disabled = false;
|
|
22
|
+
this.createForm();
|
|
23
|
+
}
|
|
24
|
+
ngOnChanges(changes) {
|
|
25
|
+
if ((changes.firearmId?.currentValue && this.projectType === ProjectType.Firearm) ||
|
|
26
|
+
(changes.projectType?.currentValue === ProjectType.Firearm && this.firearmId)) {
|
|
27
|
+
this.getPackages();
|
|
28
|
+
this.packageForm.reset();
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
this.packages = [];
|
|
32
|
+
this.packageForm.reset();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
ngAfterViewInit() {
|
|
36
|
+
const outerControl = this.inj.get(NgControl).control;
|
|
37
|
+
const prevMarkAsTouched = outerControl.markAsTouched;
|
|
38
|
+
outerControl.markAsTouched = (...args) => {
|
|
39
|
+
this.packageForm.markAllAsTouched();
|
|
40
|
+
prevMarkAsTouched.bind(outerControl)(...args);
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
ngOnDestroy() {
|
|
44
|
+
for (let sub of this.onChangeSubs) {
|
|
45
|
+
sub.unsubscribe();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
getPackages() {
|
|
49
|
+
this.packageService.readPackagesByFirearm(this.firearmId)
|
|
50
|
+
.subscribe(packages => {
|
|
51
|
+
this.packages = packages;
|
|
52
|
+
if (this.packageForm.controls.package.value) {
|
|
53
|
+
let packagez = this.packages.find(p => p.id === this.packageForm.controls.package.value.id);
|
|
54
|
+
this.setPackageOptions(packagez);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
createForm() {
|
|
59
|
+
this.packageForm = this.fb.group({
|
|
60
|
+
package: null,
|
|
61
|
+
optionalItems: this.fb.control([]),
|
|
62
|
+
variations: this.fb.array([])
|
|
63
|
+
});
|
|
64
|
+
this.packageForm.controls.package.valueChanges
|
|
65
|
+
.subscribe(value => {
|
|
66
|
+
this.packageForm.controls.optionalItems.reset();
|
|
67
|
+
this.packageOptionalItems = [];
|
|
68
|
+
this.variations.clear({ emitEvent: false });
|
|
69
|
+
this.packageVariations = [];
|
|
70
|
+
if (value?.id) {
|
|
71
|
+
this.setPackageOptions(value);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
if (this.packageDetail) {
|
|
75
|
+
this.packageDetail.variations = null;
|
|
76
|
+
this.packageDetail.optionalItems = null;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
get variations() { return this.packageForm.controls.variations; }
|
|
82
|
+
setPackageOptions(packagez) {
|
|
83
|
+
this.packageOptionalItems = packagez.optionalItems;
|
|
84
|
+
this.packageVariations = packagez.variations;
|
|
85
|
+
this.variations.clear({ emitEvent: false });
|
|
86
|
+
for (let v of this.packageVariations) {
|
|
87
|
+
let selectedVariation = this.packageDetail?.variations?.find(pv => pv.packageVariationId === v.id);
|
|
88
|
+
this.variations.push(this.fb.control(selectedVariation, Validators.required), { emitEvent: false });
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
setValue(packageDetail) {
|
|
92
|
+
this.packageForm.reset(packageDetail);
|
|
93
|
+
}
|
|
94
|
+
validate(control) {
|
|
95
|
+
if (this.packageForm.valid) {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
let errors = {};
|
|
99
|
+
for (let v of this.variations.controls) {
|
|
100
|
+
if (v.invalid) {
|
|
101
|
+
return v.errors;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return errors;
|
|
105
|
+
}
|
|
106
|
+
addControlErrors(allErrors, controlName) {
|
|
107
|
+
const errors = { ...allErrors };
|
|
108
|
+
const controlErrors = this.packageForm.controls[controlName].errors;
|
|
109
|
+
if (controlErrors) {
|
|
110
|
+
errors[controlName] = controlErrors;
|
|
111
|
+
}
|
|
112
|
+
return errors;
|
|
113
|
+
}
|
|
114
|
+
writeValue(packageDetail) {
|
|
115
|
+
if (packageDetail) {
|
|
116
|
+
this.packageDetail = Object.assign({}, packageDetail);
|
|
117
|
+
this.setValue(packageDetail);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
this.packageForm.reset();
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
registerOnChange(onChange) {
|
|
124
|
+
const sub = this.packageForm.valueChanges.subscribe(onChange);
|
|
125
|
+
this.onChangeSubs.push(sub);
|
|
126
|
+
}
|
|
127
|
+
registerOnTouched(onTouched) {
|
|
128
|
+
this.onTouched = onTouched;
|
|
129
|
+
}
|
|
130
|
+
setDisabledState(isDisabled) {
|
|
131
|
+
this.disabled = isDisabled;
|
|
132
|
+
if (isDisabled) {
|
|
133
|
+
this.packageForm.disable();
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
this.packageForm.enable();
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
PackageSelectorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PackageSelectorComponent, deps: [{ token: i1.PackageService }, { token: i2.FormBuilder }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
141
|
+
PackageSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PackageSelectorComponent, selector: "cgw-package-selector", inputs: { firearmId: "firearmId", projectType: "projectType" }, providers: [
|
|
142
|
+
{
|
|
143
|
+
provide: NG_VALUE_ACCESSOR,
|
|
144
|
+
multi: true,
|
|
145
|
+
useExisting: PackageSelectorComponent
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
provide: NG_VALIDATORS,
|
|
149
|
+
multi: true,
|
|
150
|
+
useExisting: PackageSelectorComponent
|
|
151
|
+
}
|
|
152
|
+
], usesOnChanges: true, ngImport: i0, template: "<div [formGroup]=\"packageForm\">\n <div class=\"row mb-2\">\n <div class=\"col\">\n <label for=\"waitlist-gun-package\">Package - <span class=\"fst-italic fs-7\">Select a model to list available packages</span></label>\n <kendo-dropdownlist [data]=\"packages\"\n [defaultItem]=\"{name: 'No Package', id: null}\"\n id=\"waitlist-gun-package\"\n formControlName=\"package\"\n textField=\"name\"\n valueField=\"id\"\n size=\"small\"></kendo-dropdownlist>\n </div>\n </div>\n <div formArrayName=\"variations\" *ngFor=\"let variationControl of variations.controls; let i = index\">\n <div class=\"row mb-2\">\n <div class=\"col\">\n <label [for]=\"'waitlist-gun-package-variation-' + i\">{{packageVariations[i]?.name}}</label>\n <kendo-dropdownlist [data]=\"packageVariations[i]?.options\"\n [id]=\"'waitlist-gun-package-variation-' + i\"\n textField=\"optionName\"\n [formControl]=\"variationControl\"\n valueField=\"id\"\n size=\"small\"></kendo-dropdownlist>\n </div>\n </div>\n <div *ngIf=\"variationControl.invalid && (variationControl.dirty || variationControl.touched)\" class=\"error-container text-danger\">\n <div *ngIf=\"variationControl.errors.required\">\n {{packageVariations[i]?.name}} is required.\n </div>\n </div>\n </div>\n <div class=\"row mb-2\" *ngIf=\"packageOptionalItems?.length\">\n <div class=\"col\">\n <label for=\"waitlist-gun-package-addons\">Add-ons (Additional charges will apply)</label>\n <kendo-multiselect id=\"waitlist-gun-package-addons\"\n [data]=\"packageOptionalItems\"\n formControlName=\"optionalItems\"\n textField=\"name\"\n valueField=\"inventoryItemId\"\n size=\"small\"></kendo-multiselect>\n </div>\n </div>\n</div>\n", styles: [""], components: [{ type: i3.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["iconClass", "loading", "data", "value", "textField", "valueField", "popupSettings", "listHeight", "defaultItem", "disabled", "itemDisabled", "readonly", "filterable", "virtual", "ignoreCase", "delay", "valuePrimitive", "tabindex", "tabIndex", "size", "rounded", "fillMode", "id"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }, { type: i3.MultiSelectComponent, selector: "kendo-multiselect", inputs: ["focusableId", "autoClose", "loading", "data", "value", "valueField", "textField", "tabindex", "tabIndex", "size", "rounded", "fillMode", "placeholder", "disabled", "itemDisabled", "checkboxes", "readonly", "filterable", "virtual", "popupSettings", "listHeight", "valuePrimitive", "clearButton", "tagMapper", "allowCustom", "valueNormalizer"], outputs: ["filterChange", "valueChange", "open", "opened", "close", "closed", "focus", "blur", "removeTag"], exportAs: ["kendoMultiSelect"] }], directives: [{ type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
153
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PackageSelectorComponent, decorators: [{
|
|
154
|
+
type: Component,
|
|
155
|
+
args: [{ selector: 'cgw-package-selector', providers: [
|
|
156
|
+
{
|
|
157
|
+
provide: NG_VALUE_ACCESSOR,
|
|
158
|
+
multi: true,
|
|
159
|
+
useExisting: PackageSelectorComponent
|
|
160
|
+
},
|
|
161
|
+
{
|
|
162
|
+
provide: NG_VALIDATORS,
|
|
163
|
+
multi: true,
|
|
164
|
+
useExisting: PackageSelectorComponent
|
|
165
|
+
}
|
|
166
|
+
], template: "<div [formGroup]=\"packageForm\">\n <div class=\"row mb-2\">\n <div class=\"col\">\n <label for=\"waitlist-gun-package\">Package - <span class=\"fst-italic fs-7\">Select a model to list available packages</span></label>\n <kendo-dropdownlist [data]=\"packages\"\n [defaultItem]=\"{name: 'No Package', id: null}\"\n id=\"waitlist-gun-package\"\n formControlName=\"package\"\n textField=\"name\"\n valueField=\"id\"\n size=\"small\"></kendo-dropdownlist>\n </div>\n </div>\n <div formArrayName=\"variations\" *ngFor=\"let variationControl of variations.controls; let i = index\">\n <div class=\"row mb-2\">\n <div class=\"col\">\n <label [for]=\"'waitlist-gun-package-variation-' + i\">{{packageVariations[i]?.name}}</label>\n <kendo-dropdownlist [data]=\"packageVariations[i]?.options\"\n [id]=\"'waitlist-gun-package-variation-' + i\"\n textField=\"optionName\"\n [formControl]=\"variationControl\"\n valueField=\"id\"\n size=\"small\"></kendo-dropdownlist>\n </div>\n </div>\n <div *ngIf=\"variationControl.invalid && (variationControl.dirty || variationControl.touched)\" class=\"error-container text-danger\">\n <div *ngIf=\"variationControl.errors.required\">\n {{packageVariations[i]?.name}} is required.\n </div>\n </div>\n </div>\n <div class=\"row mb-2\" *ngIf=\"packageOptionalItems?.length\">\n <div class=\"col\">\n <label for=\"waitlist-gun-package-addons\">Add-ons (Additional charges will apply)</label>\n <kendo-multiselect id=\"waitlist-gun-package-addons\"\n [data]=\"packageOptionalItems\"\n formControlName=\"optionalItems\"\n textField=\"name\"\n valueField=\"inventoryItemId\"\n size=\"small\"></kendo-multiselect>\n </div>\n </div>\n</div>\n", styles: [""] }]
|
|
167
|
+
}], ctorParameters: function () { return [{ type: i1.PackageService }, { type: i2.FormBuilder }, { type: i0.Injector }]; }, propDecorators: { firearmId: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], projectType: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}] } });
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"package-selector.component.js","sourceRoot":"","sources":["../../../../../../projects/gunsmith-common/src/shared/controls/package-selector/package-selector.component.ts","../../../../../../projects/gunsmith-common/src/shared/controls/package-selector/package-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, FormArray, FormBuilder, FormGroup, NgControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator, Validators } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { PackageService } from '../../services';\nimport { Package, PackageVariation, PackageOptionalItem, WaitlistGunPackageDetail, WorkOrderPackageDetail, ProjectType } from '../../types';\n\n@Component({\n  selector: 'cgw-package-selector',\n  templateUrl: './package-selector.component.html',\n  styleUrls: ['./package-selector.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: PackageSelectorComponent\n    },\n    {\n      provide: NG_VALIDATORS,\n      multi: true,\n      useExisting: PackageSelectorComponent\n    }\n  ]\n})\nexport class PackageSelectorComponent implements ControlValueAccessor, Validator, OnChanges, OnDestroy, AfterViewInit {\n\n  @Input()\n  firearmId: number;\n\n  @Input()\n  projectType: ProjectType;\n\n  packages: Package[] = [];\n  packageVariations: PackageVariation[] = [];\n  packageOptionalItems: PackageOptionalItem[] = [];\n\n  packageDetail: WaitlistGunPackageDetail | WorkOrderPackageDetail;\n\n  packageForm: FormGroup;\n\n  onChangeSubs: Subscription[] = [];\n  onTouched = () => { };\n\n  touched = false;\n  disabled = false;\n\n  constructor(\n    private packageService: PackageService,\n    private fb: FormBuilder,\n    private inj: Injector\n  ) {\n    this.createForm();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if ((changes.firearmId?.currentValue && this.projectType === ProjectType.Firearm) ||\n      (changes.projectType?.currentValue === ProjectType.Firearm && this.firearmId)) {\n      this.getPackages();\n      this.packageForm.reset();\n    }\n    else {\n      this.packages = [];\n      this.packageForm.reset();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    const outerControl = this.inj.get(NgControl).control;\n    const prevMarkAsTouched = outerControl.markAsTouched;\n    outerControl.markAsTouched = (...args: any) => {\n      this.packageForm.markAllAsTouched();\n      prevMarkAsTouched.bind(outerControl)(...args);\n    };\n  }\n\n  ngOnDestroy(): void {\n    for (let sub of this.onChangeSubs) {\n      sub.unsubscribe();\n    }\n  }\n\n  getPackages(): void {\n    this.packageService.readPackagesByFirearm(this.firearmId)\n      .subscribe(packages => {\n        this.packages = packages;\n        if (this.packageForm.controls.package.value) {\n          let packagez = this.packages.find(p => p.id === this.packageForm.controls.package.value.id);\n          this.setPackageOptions(packagez);\n        }\n      });\n  }\n\n  createForm(): void {\n    this.packageForm = this.fb.group({\n      package: null,\n      optionalItems: this.fb.control([]),\n      variations: this.fb.array([])\n    })\n\n    this.packageForm.controls.package.valueChanges\n      .subscribe(value => {\n        this.packageForm.controls.optionalItems.reset();\n        this.packageOptionalItems = [];\n\n        this.variations.clear({ emitEvent: false });\n        this.packageVariations = [];\n\n        if (value?.id) {\n          this.setPackageOptions(value);\n        }\n        else {\n          if (this.packageDetail) {\n            this.packageDetail.variations = null;\n            this.packageDetail.optionalItems = null;\n          }\n        }\n      })\n  }\n\n  get variations() { return this.packageForm.controls.variations as FormArray }\n\n  setPackageOptions(packagez: Package) {\n    this.packageOptionalItems = packagez.optionalItems;\n    this.packageVariations = packagez.variations;\n\n    this.variations.clear({emitEvent: false});\n    for (let v of this.packageVariations) {\n      let selectedVariation = this.packageDetail?.variations?.find(pv => pv.packageVariationId === v.id);\n      this.variations.push(this.fb.control(selectedVariation, Validators.required), {emitEvent: false});\n    }\n  }\n\n  setValue(packageDetail: WaitlistGunPackageDetail | WorkOrderPackageDetail) {\n    this.packageForm.reset(packageDetail);\n  }\n\n  validate(control: AbstractControl): ValidationErrors {\n    if (this.packageForm.valid) {\n      return null;\n    }\n\n    let errors: any = {};\n\n    for (let v of this.variations.controls) {\n      if (v.invalid) {\n        return v.errors;\n      }\n    }\n\n    return errors;\n  }\n\n  addControlErrors(allErrors: any, controlName: string) {\n\n    const errors = { ...allErrors };\n\n    const controlErrors = this.packageForm.controls[controlName].errors;\n\n    if (controlErrors) {\n      errors[controlName] = controlErrors;\n    }\n\n    return errors;\n  }\n\n  writeValue(packageDetail: WaitlistGunPackageDetail | WorkOrderPackageDetail): void {\n    if (packageDetail) {\n      this.packageDetail = Object.assign({},packageDetail);\n      this.setValue(packageDetail);\n    }\n    else {\n      this.packageForm.reset();\n    }\n  }\n\n  registerOnChange(onChange: any): void {\n    const sub = this.packageForm.valueChanges.subscribe(onChange);\n    this.onChangeSubs.push(sub);\n  }\n\n  registerOnTouched(onTouched: any): void {\n    this.onTouched = onTouched;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    if (isDisabled) {\n      this.packageForm.disable();\n    }\n    else {\n      this.packageForm.enable();\n    }\n  }\n}\n","<div [formGroup]=\"packageForm\">\n  <div class=\"row mb-2\">\n    <div class=\"col\">\n      <label for=\"waitlist-gun-package\">Package - <span class=\"fst-italic fs-7\">Select a model to list available packages</span></label>\n      <kendo-dropdownlist [data]=\"packages\"\n                          [defaultItem]=\"{name: 'No Package', id: null}\"\n                          id=\"waitlist-gun-package\"\n                          formControlName=\"package\"\n                          textField=\"name\"\n                          valueField=\"id\"\n                          size=\"small\"></kendo-dropdownlist>\n    </div>\n  </div>\n  <div formArrayName=\"variations\" *ngFor=\"let variationControl of variations.controls; let i = index\">\n    <div class=\"row mb-2\">\n      <div class=\"col\">\n        <label [for]=\"'waitlist-gun-package-variation-' + i\">{{packageVariations[i]?.name}}</label>\n        <kendo-dropdownlist [data]=\"packageVariations[i]?.options\"\n                            [id]=\"'waitlist-gun-package-variation-' + i\"\n                            textField=\"optionName\"\n                            [formControl]=\"variationControl\"\n                            valueField=\"id\"\n                            size=\"small\"></kendo-dropdownlist>\n      </div>\n    </div>\n    <div *ngIf=\"variationControl.invalid && (variationControl.dirty || variationControl.touched)\" class=\"error-container text-danger\">\n      <div *ngIf=\"variationControl.errors.required\">\n        {{packageVariations[i]?.name}} is required.\n      </div>\n    </div>\n  </div>\n  <div class=\"row mb-2\" *ngIf=\"packageOptionalItems?.length\">\n    <div class=\"col\">\n      <label for=\"waitlist-gun-package-addons\">Add-ons (Additional charges will apply)</label>\n      <kendo-multiselect id=\"waitlist-gun-package-addons\"\n                         [data]=\"packageOptionalItems\"\n                         formControlName=\"optionalItems\"\n                         textField=\"name\"\n                         valueField=\"inventoryItemId\"\n                         size=\"small\"></kendo-multiselect>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { Directive, Input } from '@angular/core';
|
|
2
|
-
import { NgControl } from '@angular/forms';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/forms";
|
|
5
|
-
export class DisableControlDirective {
|
|
6
|
-
constructor(ngControl) {
|
|
7
|
-
this.ngControl = ngControl;
|
|
8
|
-
}
|
|
9
|
-
set disableControl(condition) {
|
|
10
|
-
const action = condition ? 'disable' : 'enable';
|
|
11
|
-
this.ngControl.control[action]();
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
DisableControlDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DisableControlDirective, deps: [{ token: i1.NgControl }], target: i0.ɵɵFactoryTarget.Directive });
|
|
15
|
-
DisableControlDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: DisableControlDirective, selector: "[disableControl]", inputs: { disableControl: "disableControl" }, ngImport: i0 });
|
|
16
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DisableControlDirective, decorators: [{
|
|
17
|
-
type: Directive,
|
|
18
|
-
args: [{
|
|
19
|
-
selector: '[disableControl]'
|
|
20
|
-
}]
|
|
21
|
-
}], ctorParameters: function () { return [{ type: i1.NgControl }]; }, propDecorators: { disableControl: [{
|
|
22
|
-
type: Input
|
|
23
|
-
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { NgControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/forms";
|
|
5
|
+
export class DisableControlDirective {
|
|
6
|
+
constructor(ngControl) {
|
|
7
|
+
this.ngControl = ngControl;
|
|
8
|
+
}
|
|
9
|
+
set disableControl(condition) {
|
|
10
|
+
const action = condition ? 'disable' : 'enable';
|
|
11
|
+
this.ngControl.control[action]();
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
DisableControlDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DisableControlDirective, deps: [{ token: i1.NgControl }], target: i0.ɵɵFactoryTarget.Directive });
|
|
15
|
+
DisableControlDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: DisableControlDirective, selector: "[disableControl]", inputs: { disableControl: "disableControl" }, ngImport: i0 });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DisableControlDirective, decorators: [{
|
|
17
|
+
type: Directive,
|
|
18
|
+
args: [{
|
|
19
|
+
selector: '[disableControl]'
|
|
20
|
+
}]
|
|
21
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl }]; }, propDecorators: { disableControl: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzYWJsZS1jb250cm9sLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2d1bnNtaXRoLWNvbW1vbi9zcmMvc2hhcmVkL2RpcmVjdGl2ZXMvZGlzYWJsZS1jb250cm9sLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUszQyxNQUFNLE9BQU8sdUJBQXVCO0lBT2xDLFlBQW9CLFNBQW9CO1FBQXBCLGNBQVMsR0FBVCxTQUFTLENBQVc7SUFBSSxDQUFDO0lBTjdDLElBQWEsY0FBYyxDQUFDLFNBQWtCO1FBQzVDLE1BQU0sTUFBTSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUM7UUFDaEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztJQUNuQyxDQUFDOztxSEFKVSx1QkFBdUI7eUdBQXZCLHVCQUF1Qjs0RkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCO2dHQUVjLGNBQWM7c0JBQTFCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ0NvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tkaXNhYmxlQ29udHJvbF0nXG59KVxuZXhwb3J0IGNsYXNzIERpc2FibGVDb250cm9sRGlyZWN0aXZlIHtcbiAgQElucHV0KCkgc2V0IGRpc2FibGVDb250cm9sKGNvbmRpdGlvbjogYm9vbGVhbikge1xuICAgIGNvbnN0IGFjdGlvbiA9IGNvbmRpdGlvbiA/ICdkaXNhYmxlJyA6ICdlbmFibGUnO1xuICAgIHRoaXMubmdDb250cm9sLmNvbnRyb2xbYWN0aW9uXSgpO1xuICB9XG5cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG5nQ29udHJvbDogTmdDb250cm9sKSB7IH1cblxufVxuIl19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from './disable-control.directive';
|
|
2
|
-
export * from './refinish-details-validators';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from './disable-control.directive';
|
|
2
|
+
export * from './refinish-details-validators';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ndW5zbWl0aC1jb21tb24vc3JjL3NoYXJlZC9kaXJlY3RpdmVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGlzYWJsZS1jb250cm9sLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3JlZmluaXNoLWRldGFpbHMtdmFsaWRhdG9ycyc7XG4iXX0=
|