@symphony-talent/component-library 3.40.0 → 3.41.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.
- package/esm2020/lib/organisms/invoice-area/invoice-area.component.mjs +7 -8
- package/esm2020/lib/organisms/invoice-area/invoice-area.model.mjs +1 -1
- package/esm2020/lib/organisms/order-summary/order-summary.component.mjs +4 -4
- package/esm2020/lib/organisms/upload-resume-modal/upload-resume-modal.component.mjs +2 -2
- package/esm2020/lib/pages/modals/advertise-modal/advertise-modal.component.mjs +46 -31
- package/esm2020/projects/component-library/lib/organisms/invoice-area/invoice-area.component.mjs +7 -8
- package/esm2020/projects/component-library/lib/organisms/invoice-area/invoice-area.model.mjs +1 -1
- package/esm2020/projects/component-library/lib/organisms/order-summary/order-summary.component.mjs +4 -4
- package/esm2020/projects/component-library/lib/organisms/upload-resume-modal/upload-resume-modal.component.mjs +2 -2
- package/esm2020/projects/component-library/lib/pages/modals/advertise-modal/advertise-modal.component.mjs +46 -31
- package/fesm2015/symphony-talent-component-library-projects-component-library.mjs +51 -36
- package/fesm2015/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
- package/fesm2015/symphony-talent-component-library.mjs +51 -36
- package/fesm2015/symphony-talent-component-library.mjs.map +1 -1
- package/fesm2020/symphony-talent-component-library-projects-component-library.mjs +51 -36
- package/fesm2020/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
- package/fesm2020/symphony-talent-component-library.mjs +51 -36
- package/fesm2020/symphony-talent-component-library.mjs.map +1 -1
- package/lib/organisms/invoice-area/invoice-area.model.d.ts +2 -1
- package/lib/organisms/upload-resume-modal/upload-resume-modal.component.d.ts +1 -1
- package/package.json +1 -1
- package/projects/component-library/lib/organisms/invoice-area/invoice-area.model.d.ts +2 -1
- package/projects/component-library/lib/organisms/upload-resume-modal/upload-resume-modal.component.d.ts +1 -1
|
@@ -36,12 +36,15 @@ export class AdvertiseModalComponent {
|
|
|
36
36
|
ngOnInit() {
|
|
37
37
|
this.initialiseDefaultValues();
|
|
38
38
|
this.updateModalHeader();
|
|
39
|
-
this.
|
|
39
|
+
const selectedJobBoards = this.model.jobBoards.filter((jb) => jb.isSelected).length;
|
|
40
|
+
if (selectedJobBoards > 0) {
|
|
41
|
+
this.updateOrderSummary();
|
|
42
|
+
}
|
|
40
43
|
this.cancelContent = {
|
|
41
44
|
title: 'Are you sure you want to abandon your order?',
|
|
42
45
|
content: 'All selections will be deleted and you will have to start over.',
|
|
43
46
|
btnPrimary: 'Continue Order',
|
|
44
|
-
btnSecondary: 'Abandon Order'
|
|
47
|
+
btnSecondary: 'Abandon Order',
|
|
45
48
|
};
|
|
46
49
|
}
|
|
47
50
|
ngOnChanges(changes) {
|
|
@@ -52,29 +55,8 @@ export class AdvertiseModalComponent {
|
|
|
52
55
|
this.jobCount = this.model.jobsToAdvertise.length;
|
|
53
56
|
this.orderSummary = {
|
|
54
57
|
title: 'Your Order',
|
|
55
|
-
invoiceAreas: [
|
|
56
|
-
|
|
57
|
-
lineItems: [],
|
|
58
|
-
title: 'Pay-Per-Click',
|
|
59
|
-
total: {
|
|
60
|
-
textLeft: 'Cost Programatic Boards',
|
|
61
|
-
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
62
|
-
}
|
|
63
|
-
},
|
|
64
|
-
{
|
|
65
|
-
lineItems: [],
|
|
66
|
-
title: 'Job Boards',
|
|
67
|
-
total: {
|
|
68
|
-
textLeft: 'Cost Job Boards',
|
|
69
|
-
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
],
|
|
73
|
-
total: {
|
|
74
|
-
textLeft: '',
|
|
75
|
-
textRight: '$0',
|
|
76
|
-
label: 'Total:'
|
|
77
|
-
}
|
|
58
|
+
invoiceAreas: [],
|
|
59
|
+
total: {},
|
|
78
60
|
};
|
|
79
61
|
}
|
|
80
62
|
updateModalHeader() {
|
|
@@ -118,7 +100,8 @@ export class AdvertiseModalComponent {
|
|
|
118
100
|
this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.forEach(li => {
|
|
119
101
|
invoiceAreaTotal = invoiceAreaTotal + +li.textRight.replace('$', '');
|
|
120
102
|
});
|
|
121
|
-
this.orderSummary.invoiceAreas[invoiceAreaIndex].
|
|
103
|
+
this.orderSummary.invoiceAreas[invoiceAreaIndex].subTotal.textRight = `$${invoiceAreaTotal * this.model.jobsToAdvertise.length}`;
|
|
104
|
+
this.orderSummary.invoiceAreas[invoiceAreaIndex].total.textRight = `$${invoiceAreaTotal}`;
|
|
122
105
|
return invoiceAreaTotal * this.model.jobsToAdvertise.length;
|
|
123
106
|
}
|
|
124
107
|
calculateOrderTotal(payPerClickAreaTotal, jobBoardAreaTotal) {
|
|
@@ -127,14 +110,46 @@ export class AdvertiseModalComponent {
|
|
|
127
110
|
const jobToAdvertiseCount = this.model.jobsToAdvertise.length;
|
|
128
111
|
const orderSummaryText = `(${selectedJobBoards}) Boards x ${this.model.jobsToAdvertise.length} Jobs = (${selectedJobBoards * jobToAdvertiseCount}) Ads`;
|
|
129
112
|
this.orderSummary.total = {
|
|
130
|
-
label: 'Total
|
|
131
|
-
textLeft:
|
|
113
|
+
label: 'Current Total',
|
|
114
|
+
textLeft: '',
|
|
132
115
|
textRight: `$${payPerClickAreaTotal + jobBoardAreaTotal}`
|
|
133
116
|
};
|
|
134
117
|
}
|
|
135
118
|
updateOrderSummary() {
|
|
136
|
-
this.orderSummary
|
|
137
|
-
|
|
119
|
+
this.orderSummary = {
|
|
120
|
+
title: 'Your Order',
|
|
121
|
+
invoiceAreas: [
|
|
122
|
+
{
|
|
123
|
+
lineItems: [],
|
|
124
|
+
total: {
|
|
125
|
+
textLeft: 'Pay-Per-Click Sites, Subtotal Per Job:',
|
|
126
|
+
textRight: ``
|
|
127
|
+
},
|
|
128
|
+
subTotal: {
|
|
129
|
+
textLeft: 'Pay-Per-Click Sites Subtotal',
|
|
130
|
+
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
131
|
+
},
|
|
132
|
+
jobsToAdvertise: `x (${this.model.jobsToAdvertise.length}) Jobs Selected`
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
lineItems: [],
|
|
136
|
+
subTotal: {
|
|
137
|
+
textLeft: 'Job Boards Subtotal',
|
|
138
|
+
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
139
|
+
},
|
|
140
|
+
total: {
|
|
141
|
+
textLeft: 'Duration Job Boards, Subtotal Per Job:',
|
|
142
|
+
textRight: ``
|
|
143
|
+
},
|
|
144
|
+
jobsToAdvertise: `x (${this.model.jobsToAdvertise.length}) Jobs Selected`
|
|
145
|
+
}
|
|
146
|
+
],
|
|
147
|
+
total: {
|
|
148
|
+
textLeft: '',
|
|
149
|
+
textRight: '',
|
|
150
|
+
label: 'Current Total'
|
|
151
|
+
},
|
|
152
|
+
};
|
|
138
153
|
this.model.jobBoards.forEach(jb => {
|
|
139
154
|
if (jb.isSelected) {
|
|
140
155
|
if (jb.isPayPerClick) {
|
|
@@ -173,4 +188,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
|
|
|
173
188
|
}], keywordSearchChange: [{
|
|
174
189
|
type: Output
|
|
175
190
|
}] } });
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advertise-modal.component.js","sourceRoot":"","sources":["../../../../../../../../projects/component-library/src/lib/pages/modals/advertise-modal/advertise-modal.component.ts","../../../../../../../../projects/component-library/src/lib/pages/modals/advertise-modal/advertise-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { Icons } from '../../../atoms/icon/icon.enum';\nimport { OrderSummaryModel } from '../../../organisms/order-summary/order-summary.model';\nimport { H5WithIconModel } from '../../../molecules/h5-with-icon/h5-with-icon.model';\nimport {\n  AdvertiseModalModel,\n  PostingBoardsSelectionModel\n} from './advertise-modal.model';\nimport { InvoiceModel } from '../../../molecules/invoice-line-item/invoice-line-item.model';\nimport { ConfirmationModel } from '../../../organisms/confirmation-modal/confirmation-modal.model';\n\n@Component({\n  selector: 'symphony-advertise-modal',\n  templateUrl: './advertise-modal.component.html',\n  styleUrls: ['./advertise-modal.component.scss']\n})\nexport class AdvertiseModalComponent implements OnInit, OnChanges {\n  @Input() model: Partial<AdvertiseModalModel>;\n\n  @Output() buttonClicked = new EventEmitter<string>();\n  @Output() closeButtonClicked = new EventEmitter<string>();\n  @Output() postingBoardChange = new EventEmitter<\n    Partial<AdvertiseModalModel>\n  >();\n  @Output() keywordSearchChange = new EventEmitter<string>();\n\n  public filteredPostingBoardList: PostingBoardsSelectionModel[];\n  public orderSummary: OrderSummaryModel;\n  public subTitle: H5WithIconModel;\n  public fundsInfo: H5WithIconModel = {\n    icon: Icons.CONFIRMATION,\n    iconFirst: true,\n    text: 'Sufficient Funds',\n    iconColor: '#00D56B'\n  };\n  public cancelContent: ConfirmationModel;\n\n  public payPerClickBoards: InvoiceModel[] = [];\n  public jobBoards: InvoiceModel[] = [];\n  public jobCount: number = 0;\n  public modalTitle: string = '';\n  public isJobBoardNextButtonDisabled: boolean;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.initialiseDefaultValues();\n    this.updateModalHeader();\n    this.updateOrderSummary();\n    this.cancelContent = {\n      title: 'Are you sure you want to abandon your order?',\n      content:\n        'All selections will be deleted and you will have to start over.',\n      btnPrimary: 'Continue Order',\n      btnSecondary: 'Abandon Order'\n    };\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.filteredPostingBoardList = this.model.jobBoards;\n  }\n\n  initialiseDefaultValues() {\n    this.filteredPostingBoardList = this.model.jobBoards;\n    this.jobCount = this.model.jobsToAdvertise.length;\n    this.orderSummary = {\n      title: 'Your Order',\n      invoiceAreas: [\n        {\n          lineItems: [],\n          title: 'Pay-Per-Click',\n          total: {\n            textLeft: 'Cost Programatic Boards',\n            textRight: `x (${this.jobCount}) Jobs = $0`\n          }\n        },\n        {\n          lineItems: [],\n          title: 'Job Boards',\n          total: {\n            textLeft: 'Cost Job Boards',\n            textRight: `x (${this.jobCount}) Jobs = $0`\n          }\n        }\n      ],\n      total: {\n        textLeft: '',\n        textRight: '$0',\n        label: 'Total:'\n      }\n    };\n  }\n\n  updateModalHeader() {\n    let subTitleTooltip: string = '';\n    let jobNumber = 1;\n    this.model.jobsToAdvertise.forEach(job => {\n      subTitleTooltip = subTitleTooltip + `${job.jobTitle} [${job.id}]`;\n      if (jobNumber != this.model.jobsToAdvertise.length) {\n        subTitleTooltip = subTitleTooltip + '</br>';\n      }\n      jobNumber++;\n    });\n    this.subTitle = {\n      tooltipHtml: subTitleTooltip,\n      text: `${this.model.jobsToAdvertise.length} Jobs`,\n      iconFirst: false,\n      icon: Icons.INFO,\n      placement: 'right'\n    };\n  }\n\n  onKeywordSearch(keyword: string) {\n    this.keywordSearchChange.emit(keyword);\n  }\n\n  onButtonClick(text: string) {\n    this.buttonClicked.emit(text);\n  }\n\n  onCloseButtonClick() {\n    this.closeButtonClicked.emit();\n  }\n\n  onPostingBoardChange(selectedBoard: PostingBoardsSelectionModel) {\n    this.updateOrderSummary();\n  }\n\n  addLineItem(\n    invoiceAreaIndex: number,\n    selectedBoard: PostingBoardsSelectionModel\n  ) {\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.push({\n      textLeft: selectedBoard.boardName,\n      textRight: `$${selectedBoard.boardPrice}`\n    });\n  }\n\n  calculateInvoiceAreaTotal(invoiceAreaIndex: number): number {\n    let invoiceAreaTotal = 0;\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.forEach(li => {\n      invoiceAreaTotal = invoiceAreaTotal + +li.textRight.replace('$', '');\n    });\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].total.textRight = `x (${\n      this.model.jobsToAdvertise.length\n    }) Jobs = $${invoiceAreaTotal * this.model.jobsToAdvertise.length}`;\n    return invoiceAreaTotal * this.model.jobsToAdvertise.length;\n  }\n\n  calculateOrderTotal(payPerClickAreaTotal: number, jobBoardAreaTotal: number) {\n    const selectedJobBoards = this.model.jobBoards.filter(jb => jb.isSelected)\n      .length;\n\n    const jobToAdvertiseCount = this.model.jobsToAdvertise.length;\n\n    const orderSummaryText = `(${selectedJobBoards}) Boards x ${\n      this.model.jobsToAdvertise.length\n    } Jobs = (${selectedJobBoards * jobToAdvertiseCount}) Ads`;\n\n    this.orderSummary.total = {\n      label: 'Total:',\n      textLeft: orderSummaryText,\n      textRight: `$${payPerClickAreaTotal + jobBoardAreaTotal}`\n    };\n  }\n\n  updateOrderSummary() {\n    this.orderSummary.invoiceAreas[0].lineItems = [];\n    this.orderSummary.invoiceAreas[1].lineItems = [];\n    this.model.jobBoards.forEach(jb => {\n      if (jb.isSelected) {\n        if (jb.isPayPerClick) {\n          this.addLineItem(0, jb);\n        } else {\n          this.addLineItem(1, jb);\n        }\n      }\n    });\n\n    const payPerClickAreaTotal = this.calculateInvoiceAreaTotal(0);\n    const jobBoardAreaTotal = this.calculateInvoiceAreaTotal(1);\n    this.calculateOrderTotal(payPerClickAreaTotal, jobBoardAreaTotal);\n    if (this.model.jobBoards.filter(jb => jb.isSelected).length === 0) {\n      this.isJobBoardNextButtonDisabled = true;\n    } else {\n      this.isJobBoardNextButtonDisabled = false;\n    }\n    this.postingBoardChange.emit(this.model);\n  }\n}\n","<symphony-two-column-modal-template *ngIf=\"!model.navigation.showCancel\">\n  <symphony-h4\n    *ngIf=\"model.navigation.showJobBoardsSelection && !model.isLoading\"\n    sfx-modal-title\n    >Select Your Job Ad Buys</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.navigation.showOrderReview\" sfx-modal-title\n    >Review you Job Ad Buys</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.navigation.showConfirmation\" sfx-modal-title\n    >Confirmation of your Job Ad Buys</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.navigation.showProcessing\" sfx-modal-title\n    >Processing Order...</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.isLoading\" sfx-modal-title\n    >Loading Job Boards...</symphony-h4\n  >\n  <symphony-icon\n    sfx-close-button\n    [icon]=\"'si-close-modal'\"\n    (clicked)=\"onCloseButtonClick()\"\n  ></symphony-icon>\n  <symphony-h5-with-icon sfx-modal-subtitle [model]=\"subTitle\">\n  </symphony-h5-with-icon>\n\n  <symphony-two-column-body-template\n    *ngIf=\"!model.isLoading && model.navigation.showJobBoardsSelection\"\n    [showHeader]=\"true\"\n    sfx-modal-body-area\n  >\n    <symphony-input-text\n      sfx-left-col-header\n      [noMargin]=\"true\"\n      [placeholder]=\"'Search Ad Boards'\"\n      [icon]=\"'si-search-new'\"\n      (textChange)=\"onKeywordSearch($event)\"\n    >\n    </symphony-input-text>\n    <div class=\"right-col-header-inner\" sfx-right-col-header>\n      <symphony-h5-with-icon\n        sfx-right-col-header\n        *ngIf=\"model.showFunds\"\n        class=\"pull-right\"\n        [model]=\"fundsInfo\"\n      ></symphony-h5-with-icon>\n    </div>\n    <div sfx-left-column class=\"posting-boards sfx-pr-10\">\n      <symphony-advertise-postingboard-selection-list\n        [model]=\"model.jobBoards\"\n        (postingBoardChange)=\"onPostingBoardChange($event)\"\n      ></symphony-advertise-postingboard-selection-list>\n    </div>\n\n    <symphony-order-summary\n      sfx-right-column\n      [model]=\"orderSummary\"\n    ></symphony-order-summary>\n  </symphony-two-column-body-template>\n\n  <symphony-two-column-body-template\n    *ngIf=\"!model.isLoading && model.navigation.showOrderReview\"\n    sfx-modal-body-area\n  >\n    <div sfx-left-column class=\"posting-boards\">\n      <symphony-advertise-order-review></symphony-advertise-order-review>\n    </div>\n\n    <symphony-order-summary\n      sfx-right-column\n      [model]=\"orderSummary\"\n    ></symphony-order-summary>\n  </symphony-two-column-body-template>\n\n  <symphony-two-column-body-template\n    *ngIf=\"!model.isLoading && model.navigation.showConfirmation\"\n    sfx-modal-body-area\n  >\n    <symphony-order-summary\n      sfx-left-column\n      [model]=\"orderSummary\"\n    ></symphony-order-summary>\n    <div sfx-right-column class=\"posting-boards\">\n      <div class=\"stage\">\n        <div class=\"box bounce-7\">\n          <div class=\"complete-container\">\n            <symphony-h2>Your order is complete</symphony-h2>\n            <div class=\"success-icon-spacing\">\n              <symphony-icon\n                [icon]=\"'si-confirmation'\"\n                [iconColor]=\"'#00D56B'\"\n                [size]=\"'50px'\"\n              ></symphony-icon>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </symphony-two-column-body-template>\n\n  <div\n    *ngIf=\"!model.isLoading && model.navigation.showProcessing\"\n    sfx-modal-body-area\n    class=\"posting-boards sfx-p-30\"\n  >\n    <div class=\"processing-container\">\n      <symphony-paragraph\n        ><b>SmashFlyX</b> is submitting your order to your selected job boards.\n        Some orders happen immediately, while others take a little more time.\n        Check your order status if you don't recieve a confirmation in the next\n        24hours.</symphony-paragraph\n      >\n    </div>\n    <div class=\"sfx-mt-80\">\n      <symphony-sfx-loader></symphony-sfx-loader>\n    </div>\n  </div>\n\n  <div class=\"loader-container\" *ngIf=\"model.isLoading\" sfx-modal-body-area>\n    <symphony-sfx-loader></symphony-sfx-loader>\n  </div>\n\n  <symphony-button\n    *ngIf=\"model.navigation.showJobBoardsSelection\"\n    sfx-button-secondary\n    [text]=\"'Cancel'\"\n    [isSecondary]=\"true\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n  <symphony-button\n    *ngIf=\"model.navigation.showJobBoardsSelection\"\n    sfx-button-primary\n    [text]=\"'Review Order'\"\n    [disabled]=\"isJobBoardNextButtonDisabled\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n\n  <symphony-button\n    *ngIf=\"model.navigation.showOrderReview\"\n    sfx-button-back\n    [text]=\"'Edit Order'\"\n    [isSecondary]=\"true\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n  <symphony-button\n    *ngIf=\"model.navigation.showOrderReview\"\n    sfx-button-secondary\n    [text]=\"'Cancel'\"\n    [isSecondary]=\"true\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n  <symphony-button\n    *ngIf=\"model.navigation.showOrderReview\"\n    sfx-button-primary\n    [text]=\"'Buy'\"\n    [disabled]=\"false\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n\n  <symphony-button\n    *ngIf=\"model.navigation.showConfirmation\"\n    sfx-button-primary\n    [text]=\"'Finish & Close'\"\n    [disabled]=\"false\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n</symphony-two-column-modal-template>\n<symphony-confirmation-modal\n  *ngIf=\"!model.isLoading && model.navigation.showCancel\"\n  (buttonClicked)=\"onButtonClick($event)\"\n  (closeButtonClicked)=\"onCloseButtonClick()\"\n  [model]=\"cancelContent\"\n>\n</symphony-confirmation-modal>\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advertise-modal.component.js","sourceRoot":"","sources":["../../../../../../../../projects/component-library/src/lib/pages/modals/advertise-modal/advertise-modal.component.ts","../../../../../../../../projects/component-library/src/lib/pages/modals/advertise-modal/advertise-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { Icons } from '../../../atoms/icon/icon.enum';\nimport { OrderSummaryModel } from '../../../organisms/order-summary/order-summary.model';\nimport { H5WithIconModel } from '../../../molecules/h5-with-icon/h5-with-icon.model';\nimport {\n  AdvertiseModalModel,\n  PostingBoardsSelectionModel\n} from './advertise-modal.model';\nimport { InvoiceModel } from '../../../molecules/invoice-line-item/invoice-line-item.model';\nimport { ConfirmationModel } from '../../../organisms/confirmation-modal/confirmation-modal.model';\n\n@Component({\n  selector: 'symphony-advertise-modal',\n  templateUrl: './advertise-modal.component.html',\n  styleUrls: ['./advertise-modal.component.scss']\n})\nexport class AdvertiseModalComponent implements OnInit, OnChanges {\n  @Input() model: Partial<AdvertiseModalModel>;\n\n  @Output() buttonClicked = new EventEmitter<string>();\n  @Output() closeButtonClicked = new EventEmitter<string>();\n  @Output() postingBoardChange = new EventEmitter<\n    Partial<AdvertiseModalModel>\n  >();\n  @Output() keywordSearchChange = new EventEmitter<string>();\n\n  public filteredPostingBoardList: PostingBoardsSelectionModel[];\n  public orderSummary: OrderSummaryModel;\n  public subTitle: H5WithIconModel;\n  public fundsInfo: H5WithIconModel = {\n    icon: Icons.CONFIRMATION,\n    iconFirst: true,\n    text: 'Sufficient Funds',\n    iconColor: '#00D56B'\n  };\n  public cancelContent: ConfirmationModel;\n\n  public payPerClickBoards: InvoiceModel[] = [];\n  public jobBoards: InvoiceModel[] = [];\n  public jobCount: number = 0;\n  public modalTitle: string = '';\n  public isJobBoardNextButtonDisabled: boolean;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.initialiseDefaultValues();\n    this.updateModalHeader();\n    const selectedJobBoards = this.model.jobBoards.filter(\n      (jb) => jb.isSelected\n    ).length;\n    if (selectedJobBoards > 0) {\n      this.updateOrderSummary();\n    }\n    this.cancelContent = {\n      title: 'Are you sure you want to abandon your order?',\n      content:\n        'All selections will be deleted and you will have to start over.',\n      btnPrimary: 'Continue Order',\n      btnSecondary: 'Abandon Order',\n    };\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.filteredPostingBoardList = this.model.jobBoards;\n  }\n\n  initialiseDefaultValues() {\n    this.filteredPostingBoardList = this.model.jobBoards;\n    this.jobCount = this.model.jobsToAdvertise.length;\n    this.orderSummary = {\n      title: 'Your Order',\n      invoiceAreas: [],\n      total: {} as any,\n    }; \n  }\n\n  updateModalHeader() {\n    let subTitleTooltip: string = '';\n    let jobNumber = 1;\n    this.model.jobsToAdvertise.forEach(job => {\n      subTitleTooltip = subTitleTooltip + `${job.jobTitle} [${job.id}]`;\n      if (jobNumber != this.model.jobsToAdvertise.length) {\n        subTitleTooltip = subTitleTooltip + '</br>';\n      }\n      jobNumber++;\n    });\n    this.subTitle = {\n      tooltipHtml: subTitleTooltip,\n      text: `${this.model.jobsToAdvertise.length} Jobs`,\n      iconFirst: false,\n      icon: Icons.INFO,\n      placement: 'right'\n    };\n  }\n\n  onKeywordSearch(keyword: string) {\n    this.keywordSearchChange.emit(keyword);\n  }\n\n  onButtonClick(text: string) {\n    this.buttonClicked.emit(text);\n  }\n\n  onCloseButtonClick() {\n    this.closeButtonClicked.emit();\n  }\n\n  onPostingBoardChange(selectedBoard: PostingBoardsSelectionModel) {\n    this.updateOrderSummary();\n  }\n\n  addLineItem(\n    invoiceAreaIndex: number,\n    selectedBoard: PostingBoardsSelectionModel\n  ) {\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.push({\n      textLeft: selectedBoard.boardName,\n      textRight: `$${selectedBoard.boardPrice}`\n    });\n  }\n\n  calculateInvoiceAreaTotal(invoiceAreaIndex: number): number {\n    let invoiceAreaTotal = 0;\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.forEach(li => {\n      invoiceAreaTotal = invoiceAreaTotal + +li.textRight.replace('$', '');\n    });\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].subTotal.textRight = `$${invoiceAreaTotal * this.model.jobsToAdvertise.length}`;\n    this.orderSummary.invoiceAreas[invoiceAreaIndex].total.textRight = `$${invoiceAreaTotal}`;\n    return invoiceAreaTotal * this.model.jobsToAdvertise.length;\n  }\n\n  calculateOrderTotal(payPerClickAreaTotal: number, jobBoardAreaTotal: number) {\n    const selectedJobBoards = this.model.jobBoards.filter(jb => jb.isSelected)\n      .length;\n\n    const jobToAdvertiseCount = this.model.jobsToAdvertise.length;\n\n    const orderSummaryText = `(${selectedJobBoards}) Boards x ${\n      this.model.jobsToAdvertise.length\n    } Jobs = (${selectedJobBoards * jobToAdvertiseCount}) Ads`;\n\n    this.orderSummary.total = {\n      label: 'Current Total',\n      textLeft: '',\n      textRight: `$${payPerClickAreaTotal + jobBoardAreaTotal}`\n    };\n  }\n\n  updateOrderSummary() {\n    this.orderSummary = {\n      title: 'Your Order',\n      invoiceAreas: [\n        {\n          lineItems: [],\n          total: {\n            textLeft: 'Pay-Per-Click Sites, Subtotal Per Job:',\n            textRight: ``\n          },\n          subTotal: {\n            textLeft: 'Pay-Per-Click Sites Subtotal',\n            textRight: `x (${this.jobCount}) Jobs = $0`\n          },\n          jobsToAdvertise: `x (${\n            this.model.jobsToAdvertise.length\n          }) Jobs Selected`\n        },\n        {\n          lineItems: [],\n          subTotal: {\n            textLeft: 'Job Boards Subtotal',\n            textRight: `x (${this.jobCount}) Jobs = $0`\n          },\n          total: {\n            textLeft: 'Duration Job Boards, Subtotal Per Job:',\n            textRight: ``\n          },\n          jobsToAdvertise: `x (${\n            this.model.jobsToAdvertise.length\n          }) Jobs Selected`\n        }\n      ],\n      total: {\n        textLeft: '',\n        textRight: '',\n        label: 'Current Total'\n      },\n    };\n    this.model.jobBoards.forEach(jb => {\n      if (jb.isSelected) {\n        if (jb.isPayPerClick) {\n          this.addLineItem(0, jb);\n        } else {\n          this.addLineItem(1, jb);\n        }\n      }\n    });\n\n    const payPerClickAreaTotal = this.calculateInvoiceAreaTotal(0);\n    const jobBoardAreaTotal = this.calculateInvoiceAreaTotal(1);\n    this.calculateOrderTotal(payPerClickAreaTotal, jobBoardAreaTotal);\n    if (this.model.jobBoards.filter(jb => jb.isSelected).length === 0) {\n      this.isJobBoardNextButtonDisabled = true;\n    } else {\n      this.isJobBoardNextButtonDisabled = false;\n    }\n    this.postingBoardChange.emit(this.model);\n  }\n\n}\n","<symphony-two-column-modal-template *ngIf=\"!model.navigation.showCancel\">\n  <symphony-h4\n    *ngIf=\"model.navigation.showJobBoardsSelection && !model.isLoading\"\n    sfx-modal-title\n    >Select Your Job Ad Buys</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.navigation.showOrderReview\" sfx-modal-title\n    >Review you Job Ad Buys</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.navigation.showConfirmation\" sfx-modal-title\n    >Confirmation of your Job Ad Buys</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.navigation.showProcessing\" sfx-modal-title\n    >Processing Order...</symphony-h4\n  >\n  <symphony-h4 *ngIf=\"model.isLoading\" sfx-modal-title\n    >Loading Job Boards...</symphony-h4\n  >\n  <symphony-icon\n    sfx-close-button\n    [icon]=\"'si-close-modal'\"\n    (clicked)=\"onCloseButtonClick()\"\n  ></symphony-icon>\n  <symphony-h5-with-icon sfx-modal-subtitle [model]=\"subTitle\">\n  </symphony-h5-with-icon>\n\n  <symphony-two-column-body-template\n    *ngIf=\"!model.isLoading && model.navigation.showJobBoardsSelection\"\n    [showHeader]=\"true\"\n    sfx-modal-body-area\n  >\n    <symphony-input-text\n      sfx-left-col-header\n      [noMargin]=\"true\"\n      [placeholder]=\"'Search Ad Boards'\"\n      [icon]=\"'si-search-new'\"\n      (textChange)=\"onKeywordSearch($event)\"\n    >\n    </symphony-input-text>\n    <div class=\"right-col-header-inner\" sfx-right-col-header>\n      <symphony-h5-with-icon\n        sfx-right-col-header\n        *ngIf=\"model.showFunds\"\n        class=\"pull-right\"\n        [model]=\"fundsInfo\"\n      ></symphony-h5-with-icon>\n    </div>\n    <div sfx-left-column class=\"posting-boards sfx-pr-10\">\n      <symphony-advertise-postingboard-selection-list\n        [model]=\"model.jobBoards\"\n        (postingBoardChange)=\"onPostingBoardChange($event)\"\n      ></symphony-advertise-postingboard-selection-list>\n    </div>\n\n    <symphony-order-summary\n      sfx-right-column\n      [model]=\"orderSummary\"\n    ></symphony-order-summary>\n  </symphony-two-column-body-template>\n\n  <symphony-two-column-body-template\n    *ngIf=\"!model.isLoading && model.navigation.showOrderReview\"\n    sfx-modal-body-area\n  >\n    <div sfx-left-column class=\"posting-boards\">\n      <symphony-advertise-order-review></symphony-advertise-order-review>\n    </div>\n\n    <symphony-order-summary\n      sfx-right-column\n      [model]=\"orderSummary\"\n    ></symphony-order-summary>\n  </symphony-two-column-body-template>\n\n  <symphony-two-column-body-template\n    *ngIf=\"!model.isLoading && model.navigation.showConfirmation\"\n    sfx-modal-body-area\n  >\n    <symphony-order-summary\n      sfx-left-column\n      [model]=\"orderSummary\"\n    ></symphony-order-summary>\n    <div sfx-right-column class=\"posting-boards\">\n      <div class=\"stage\">\n        <div class=\"box bounce-7\">\n          <div class=\"complete-container\">\n            <symphony-h2>Your order is complete</symphony-h2>\n            <div class=\"success-icon-spacing\">\n              <symphony-icon\n                [icon]=\"'si-confirmation'\"\n                [iconColor]=\"'#00D56B'\"\n                [size]=\"'50px'\"\n              ></symphony-icon>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </symphony-two-column-body-template>\n\n  <div\n    *ngIf=\"!model.isLoading && model.navigation.showProcessing\"\n    sfx-modal-body-area\n    class=\"posting-boards sfx-p-30\"\n  >\n    <div class=\"processing-container\">\n      <symphony-paragraph\n        ><b>SmashFlyX</b> is submitting your order to your selected job boards.\n        Some orders happen immediately, while others take a little more time.\n        Check your order status if you don't recieve a confirmation in the next\n        24hours.</symphony-paragraph\n      >\n    </div>\n    <div class=\"sfx-mt-80\">\n      <symphony-sfx-loader></symphony-sfx-loader>\n    </div>\n  </div>\n\n  <div class=\"loader-container\" *ngIf=\"model.isLoading\" sfx-modal-body-area>\n    <symphony-sfx-loader></symphony-sfx-loader>\n  </div>\n\n  <symphony-button\n    *ngIf=\"model.navigation.showJobBoardsSelection\"\n    sfx-button-secondary\n    [text]=\"'Cancel'\"\n    [isSecondary]=\"true\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n  <symphony-button\n    *ngIf=\"model.navigation.showJobBoardsSelection\"\n    sfx-button-primary\n    [text]=\"'Review Order'\"\n    [disabled]=\"isJobBoardNextButtonDisabled\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n\n  <symphony-button\n    *ngIf=\"model.navigation.showOrderReview\"\n    sfx-button-back\n    [text]=\"'Edit Order'\"\n    [isSecondary]=\"true\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n  <symphony-button\n    *ngIf=\"model.navigation.showOrderReview\"\n    sfx-button-secondary\n    [text]=\"'Cancel'\"\n    [isSecondary]=\"true\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n  <symphony-button\n    *ngIf=\"model.navigation.showOrderReview\"\n    sfx-button-primary\n    [text]=\"'Buy'\"\n    [disabled]=\"false\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n\n  <symphony-button\n    *ngIf=\"model.navigation.showConfirmation\"\n    sfx-button-primary\n    [text]=\"'Finish & Close'\"\n    [disabled]=\"false\"\n    [isInverse]=\"true\"\n    (clicked)=\"onButtonClick($event)\"\n  ></symphony-button>\n</symphony-two-column-modal-template>\n<symphony-confirmation-modal\n  *ngIf=\"!model.isLoading && model.navigation.showCancel\"\n  (buttonClicked)=\"onButtonClick($event)\"\n  (closeButtonClicked)=\"onCloseButtonClick()\"\n  [model]=\"cancelContent\"\n>\n</symphony-confirmation-modal>\n"]}
|
|
@@ -3064,7 +3064,7 @@ class UploadResumeModalComponent {
|
|
|
3064
3064
|
this.docTypeDropdowChange.emit(selectedModel.value);
|
|
3065
3065
|
}
|
|
3066
3066
|
onResumeCheckSelect(updateResumeCheckEvent) {
|
|
3067
|
-
this.updateResumeChecked.emit(updateResumeCheckEvent
|
|
3067
|
+
this.updateResumeChecked.emit(updateResumeCheckEvent);
|
|
3068
3068
|
}
|
|
3069
3069
|
}
|
|
3070
3070
|
UploadResumeModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: UploadResumeModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -5052,15 +5052,15 @@ class InvoiceAreaComponent {
|
|
|
5052
5052
|
constructor() {
|
|
5053
5053
|
this.model = {
|
|
5054
5054
|
lineItems: [],
|
|
5055
|
-
|
|
5055
|
+
jobsToAdvertise: '',
|
|
5056
5056
|
};
|
|
5057
5057
|
}
|
|
5058
5058
|
}
|
|
5059
5059
|
InvoiceAreaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: InvoiceAreaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
5060
|
-
InvoiceAreaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: InvoiceAreaComponent, selector: "symphony-invoice-area", inputs: { model: "model" }, ngImport: i0, template: "<div class=\"job-type-summary sfx-px-20\">\n <
|
|
5060
|
+
InvoiceAreaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: InvoiceAreaComponent, selector: "symphony-invoice-area", inputs: { model: "model" }, ngImport: i0, template: "<div class=\"job-type-summary sfx-px-20\">\n <ul class=\"invoice-list list-unstyled sfx-mb-20\">\n <li class=\"invoice-line-item\" *ngFor=\"let lineItem of model.lineItems\">\n <symphony-invoice-line-item\n [model]=\"lineItem\"\n ></symphony-invoice-line-item>\n </li>\n </ul>\n <div class=\"sfx-mb-20\">\n <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n </div>\n <span>{{model.jobsToAdvertise}}</span>\n <div class=\"job-bold-txt\">\n <symphony-invoice-line-item\n [model]=\"model.subTotal\"\n ></symphony-invoice-line-item>\n </div>\n</div>", styles: [".job-type-summary{border-bottom:1px solid #d9d9d9;padding-bottom:.3rem}.job-bold-txt .body-copy-primary{font-family:neuzeit_groteskbold,sans-serif}\n"], components: [{ type: InvoiceLineItemComponent, selector: "symphony-invoice-line-item", inputs: ["model"] }], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
5061
5061
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: InvoiceAreaComponent, decorators: [{
|
|
5062
5062
|
type: Component,
|
|
5063
|
-
args: [{ selector: 'symphony-invoice-area', template: "<div class=\"job-type-summary sfx-px-20\">\n <
|
|
5063
|
+
args: [{ selector: 'symphony-invoice-area', encapsulation: ViewEncapsulation.None, template: "<div class=\"job-type-summary sfx-px-20\">\n <ul class=\"invoice-list list-unstyled sfx-mb-20\">\n <li class=\"invoice-line-item\" *ngFor=\"let lineItem of model.lineItems\">\n <symphony-invoice-line-item\n [model]=\"lineItem\"\n ></symphony-invoice-line-item>\n </li>\n </ul>\n <div class=\"sfx-mb-20\">\n <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n </div>\n <span>{{model.jobsToAdvertise}}</span>\n <div class=\"job-bold-txt\">\n <symphony-invoice-line-item\n [model]=\"model.subTotal\"\n ></symphony-invoice-line-item>\n </div>\n</div>", styles: [".job-type-summary{border-bottom:1px solid #d9d9d9;padding-bottom:.3rem}.job-bold-txt .body-copy-primary{font-family:neuzeit_groteskbold,sans-serif}\n"] }]
|
|
5064
5064
|
}], ctorParameters: function () { return []; }, propDecorators: { model: [{
|
|
5065
5065
|
type: Input
|
|
5066
5066
|
}] } });
|
|
@@ -5074,10 +5074,10 @@ class OrderSummaryComponent {
|
|
|
5074
5074
|
}
|
|
5075
5075
|
}
|
|
5076
5076
|
OrderSummaryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: OrderSummaryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
5077
|
-
OrderSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: OrderSummaryComponent, selector: "symphony-order-summary", inputs: { model: "model" }, ngImport: i0, template: "<section class=\"order-summary\">\n <symphony-h4>{{ model.title }}</symphony-h4>\n <ul class=\"invoice-area-list list-unstyled sfx-mb-20\">\n <li\n class=\"invoice-area-item\"\n *ngFor=\"let invoiceArea of model.invoiceAreas\"\n >\n <symphony-invoice-area [model]=\"invoiceArea\"></symphony-invoice-area>\n </li>\n </ul>\n <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n</section>\n", styles: [""], components: [{ type: H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: InvoiceAreaComponent, selector: "symphony-invoice-area", inputs: ["model"] }, { type: InvoiceLineItemComponent, selector: "symphony-invoice-line-item", inputs: ["model"] }], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
5077
|
+
OrderSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: OrderSummaryComponent, selector: "symphony-order-summary", inputs: { model: "model" }, ngImport: i0, template: "<section class=\"order-summary\">\n <symphony-h4>{{ model.title }}</symphony-h4>\n <ul class=\"invoice-area-list list-unstyled sfx-mb-20\">\n <li\n class=\"invoice-area-item\"\n *ngFor=\"let invoiceArea of model.invoiceAreas\"\n >\n <symphony-invoice-area [model]=\"invoiceArea\"></symphony-invoice-area>\n </li>\n </ul>\n <div class=\"total-wrap sfx-pb-10\" *ngIf=\"model.invoiceAreas.length > 0\">\n <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n </div>\n</section>\n", styles: [".total-wrap{border-bottom:1px solid #000}.total-wrap .text-right p{font-family:neuzeit_groteskbold,sans-serif}\n"], components: [{ type: H4Component, selector: "symphony-h4", inputs: ["text", "isSecondary"] }, { type: InvoiceAreaComponent, selector: "symphony-invoice-area", inputs: ["model"] }, { type: InvoiceLineItemComponent, selector: "symphony-invoice-line-item", inputs: ["model"] }], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
5078
5078
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: OrderSummaryComponent, decorators: [{
|
|
5079
5079
|
type: Component,
|
|
5080
|
-
args: [{ selector: 'symphony-order-summary', template: "<section class=\"order-summary\">\n <symphony-h4>{{ model.title }}</symphony-h4>\n <ul class=\"invoice-area-list list-unstyled sfx-mb-20\">\n <li\n class=\"invoice-area-item\"\n *ngFor=\"let invoiceArea of model.invoiceAreas\"\n >\n <symphony-invoice-area [model]=\"invoiceArea\"></symphony-invoice-area>\n </li>\n </ul>\n <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n</section>\n", styles: [""] }]
|
|
5080
|
+
args: [{ selector: 'symphony-order-summary', encapsulation: ViewEncapsulation.None, template: "<section class=\"order-summary\">\n <symphony-h4>{{ model.title }}</symphony-h4>\n <ul class=\"invoice-area-list list-unstyled sfx-mb-20\">\n <li\n class=\"invoice-area-item\"\n *ngFor=\"let invoiceArea of model.invoiceAreas\"\n >\n <symphony-invoice-area [model]=\"invoiceArea\"></symphony-invoice-area>\n </li>\n </ul>\n <div class=\"total-wrap sfx-pb-10\" *ngIf=\"model.invoiceAreas.length > 0\">\n <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n </div>\n</section>\n", styles: [".total-wrap{border-bottom:1px solid #000}.total-wrap .text-right p{font-family:neuzeit_groteskbold,sans-serif}\n"] }]
|
|
5081
5081
|
}], ctorParameters: function () { return []; }, propDecorators: { model: [{
|
|
5082
5082
|
type: Input
|
|
5083
5083
|
}] } });
|
|
@@ -5112,12 +5112,15 @@ class AdvertiseModalComponent {
|
|
|
5112
5112
|
ngOnInit() {
|
|
5113
5113
|
this.initialiseDefaultValues();
|
|
5114
5114
|
this.updateModalHeader();
|
|
5115
|
-
this.
|
|
5115
|
+
const selectedJobBoards = this.model.jobBoards.filter((jb) => jb.isSelected).length;
|
|
5116
|
+
if (selectedJobBoards > 0) {
|
|
5117
|
+
this.updateOrderSummary();
|
|
5118
|
+
}
|
|
5116
5119
|
this.cancelContent = {
|
|
5117
5120
|
title: 'Are you sure you want to abandon your order?',
|
|
5118
5121
|
content: 'All selections will be deleted and you will have to start over.',
|
|
5119
5122
|
btnPrimary: 'Continue Order',
|
|
5120
|
-
btnSecondary: 'Abandon Order'
|
|
5123
|
+
btnSecondary: 'Abandon Order',
|
|
5121
5124
|
};
|
|
5122
5125
|
}
|
|
5123
5126
|
ngOnChanges(changes) {
|
|
@@ -5128,29 +5131,8 @@ class AdvertiseModalComponent {
|
|
|
5128
5131
|
this.jobCount = this.model.jobsToAdvertise.length;
|
|
5129
5132
|
this.orderSummary = {
|
|
5130
5133
|
title: 'Your Order',
|
|
5131
|
-
invoiceAreas: [
|
|
5132
|
-
|
|
5133
|
-
lineItems: [],
|
|
5134
|
-
title: 'Pay-Per-Click',
|
|
5135
|
-
total: {
|
|
5136
|
-
textLeft: 'Cost Programatic Boards',
|
|
5137
|
-
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
5138
|
-
}
|
|
5139
|
-
},
|
|
5140
|
-
{
|
|
5141
|
-
lineItems: [],
|
|
5142
|
-
title: 'Job Boards',
|
|
5143
|
-
total: {
|
|
5144
|
-
textLeft: 'Cost Job Boards',
|
|
5145
|
-
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
5146
|
-
}
|
|
5147
|
-
}
|
|
5148
|
-
],
|
|
5149
|
-
total: {
|
|
5150
|
-
textLeft: '',
|
|
5151
|
-
textRight: '$0',
|
|
5152
|
-
label: 'Total:'
|
|
5153
|
-
}
|
|
5134
|
+
invoiceAreas: [],
|
|
5135
|
+
total: {},
|
|
5154
5136
|
};
|
|
5155
5137
|
}
|
|
5156
5138
|
updateModalHeader() {
|
|
@@ -5194,7 +5176,8 @@ class AdvertiseModalComponent {
|
|
|
5194
5176
|
this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.forEach(li => {
|
|
5195
5177
|
invoiceAreaTotal = invoiceAreaTotal + +li.textRight.replace('$', '');
|
|
5196
5178
|
});
|
|
5197
|
-
this.orderSummary.invoiceAreas[invoiceAreaIndex].
|
|
5179
|
+
this.orderSummary.invoiceAreas[invoiceAreaIndex].subTotal.textRight = `$${invoiceAreaTotal * this.model.jobsToAdvertise.length}`;
|
|
5180
|
+
this.orderSummary.invoiceAreas[invoiceAreaIndex].total.textRight = `$${invoiceAreaTotal}`;
|
|
5198
5181
|
return invoiceAreaTotal * this.model.jobsToAdvertise.length;
|
|
5199
5182
|
}
|
|
5200
5183
|
calculateOrderTotal(payPerClickAreaTotal, jobBoardAreaTotal) {
|
|
@@ -5203,14 +5186,46 @@ class AdvertiseModalComponent {
|
|
|
5203
5186
|
const jobToAdvertiseCount = this.model.jobsToAdvertise.length;
|
|
5204
5187
|
const orderSummaryText = `(${selectedJobBoards}) Boards x ${this.model.jobsToAdvertise.length} Jobs = (${selectedJobBoards * jobToAdvertiseCount}) Ads`;
|
|
5205
5188
|
this.orderSummary.total = {
|
|
5206
|
-
label: 'Total
|
|
5207
|
-
textLeft:
|
|
5189
|
+
label: 'Current Total',
|
|
5190
|
+
textLeft: '',
|
|
5208
5191
|
textRight: `$${payPerClickAreaTotal + jobBoardAreaTotal}`
|
|
5209
5192
|
};
|
|
5210
5193
|
}
|
|
5211
5194
|
updateOrderSummary() {
|
|
5212
|
-
this.orderSummary
|
|
5213
|
-
|
|
5195
|
+
this.orderSummary = {
|
|
5196
|
+
title: 'Your Order',
|
|
5197
|
+
invoiceAreas: [
|
|
5198
|
+
{
|
|
5199
|
+
lineItems: [],
|
|
5200
|
+
total: {
|
|
5201
|
+
textLeft: 'Pay-Per-Click Sites, Subtotal Per Job:',
|
|
5202
|
+
textRight: ``
|
|
5203
|
+
},
|
|
5204
|
+
subTotal: {
|
|
5205
|
+
textLeft: 'Pay-Per-Click Sites Subtotal',
|
|
5206
|
+
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
5207
|
+
},
|
|
5208
|
+
jobsToAdvertise: `x (${this.model.jobsToAdvertise.length}) Jobs Selected`
|
|
5209
|
+
},
|
|
5210
|
+
{
|
|
5211
|
+
lineItems: [],
|
|
5212
|
+
subTotal: {
|
|
5213
|
+
textLeft: 'Job Boards Subtotal',
|
|
5214
|
+
textRight: `x (${this.jobCount}) Jobs = $0`
|
|
5215
|
+
},
|
|
5216
|
+
total: {
|
|
5217
|
+
textLeft: 'Duration Job Boards, Subtotal Per Job:',
|
|
5218
|
+
textRight: ``
|
|
5219
|
+
},
|
|
5220
|
+
jobsToAdvertise: `x (${this.model.jobsToAdvertise.length}) Jobs Selected`
|
|
5221
|
+
}
|
|
5222
|
+
],
|
|
5223
|
+
total: {
|
|
5224
|
+
textLeft: '',
|
|
5225
|
+
textRight: '',
|
|
5226
|
+
label: 'Current Total'
|
|
5227
|
+
},
|
|
5228
|
+
};
|
|
5214
5229
|
this.model.jobBoards.forEach(jb => {
|
|
5215
5230
|
if (jb.isSelected) {
|
|
5216
5231
|
if (jb.isPayPerClick) {
|