@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.
Files changed (23) hide show
  1. package/esm2020/lib/organisms/invoice-area/invoice-area.component.mjs +7 -8
  2. package/esm2020/lib/organisms/invoice-area/invoice-area.model.mjs +1 -1
  3. package/esm2020/lib/organisms/order-summary/order-summary.component.mjs +4 -4
  4. package/esm2020/lib/organisms/upload-resume-modal/upload-resume-modal.component.mjs +2 -2
  5. package/esm2020/lib/pages/modals/advertise-modal/advertise-modal.component.mjs +46 -31
  6. package/esm2020/projects/component-library/lib/organisms/invoice-area/invoice-area.component.mjs +7 -8
  7. package/esm2020/projects/component-library/lib/organisms/invoice-area/invoice-area.model.mjs +1 -1
  8. package/esm2020/projects/component-library/lib/organisms/order-summary/order-summary.component.mjs +4 -4
  9. package/esm2020/projects/component-library/lib/organisms/upload-resume-modal/upload-resume-modal.component.mjs +2 -2
  10. package/esm2020/projects/component-library/lib/pages/modals/advertise-modal/advertise-modal.component.mjs +46 -31
  11. package/fesm2015/symphony-talent-component-library-projects-component-library.mjs +51 -36
  12. package/fesm2015/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
  13. package/fesm2015/symphony-talent-component-library.mjs +51 -36
  14. package/fesm2015/symphony-talent-component-library.mjs.map +1 -1
  15. package/fesm2020/symphony-talent-component-library-projects-component-library.mjs +51 -36
  16. package/fesm2020/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
  17. package/fesm2020/symphony-talent-component-library.mjs +51 -36
  18. package/fesm2020/symphony-talent-component-library.mjs.map +1 -1
  19. package/lib/organisms/invoice-area/invoice-area.model.d.ts +2 -1
  20. package/lib/organisms/upload-resume-modal/upload-resume-modal.component.d.ts +1 -1
  21. package/package.json +1 -1
  22. package/projects/component-library/lib/organisms/invoice-area/invoice-area.model.d.ts +2 -1
  23. 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.updateOrderSummary();
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].total.textRight = `x (${this.model.jobsToAdvertise.length}) Jobs = $${invoiceAreaTotal * this.model.jobsToAdvertise.length}`;
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: orderSummaryText,
113
+ label: 'Current Total',
114
+ textLeft: '',
132
115
  textRight: `$${payPerClickAreaTotal + jobBoardAreaTotal}`
133
116
  };
134
117
  }
135
118
  updateOrderSummary() {
136
- this.orderSummary.invoiceAreas[0].lineItems = [];
137
- this.orderSummary.invoiceAreas[1].lineItems = [];
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.label);
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
- title: '',
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 <div class=\"job-type-title\">\n <symphony-h5 [text]=\"model.title\"></symphony-h5>\n </div>\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 <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n</div>\n", styles: [".job-type-summary{border-bottom:1px solid #d9d9d9}\n"], components: [{ type: H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: InvoiceLineItemComponent, selector: "symphony-invoice-line-item", inputs: ["model"] }], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
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 <div class=\"job-type-title\">\n <symphony-h5 [text]=\"model.title\"></symphony-h5>\n </div>\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 <symphony-invoice-line-item\n [model]=\"model.total\"\n ></symphony-invoice-line-item>\n</div>\n", styles: [".job-type-summary{border-bottom:1px solid #d9d9d9}\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.updateOrderSummary();
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].total.textRight = `x (${this.model.jobsToAdvertise.length}) Jobs = $${invoiceAreaTotal * this.model.jobsToAdvertise.length}`;
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: orderSummaryText,
5189
+ label: 'Current Total',
5190
+ textLeft: '',
5208
5191
  textRight: `$${payPerClickAreaTotal + jobBoardAreaTotal}`
5209
5192
  };
5210
5193
  }
5211
5194
  updateOrderSummary() {
5212
- this.orderSummary.invoiceAreas[0].lineItems = [];
5213
- this.orderSummary.invoiceAreas[1].lineItems = [];
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) {