@symphony-talent/component-library 3.41.0 → 3.42.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.
@@ -87,7 +87,10 @@ export class AdvertiseModalComponent {
87
87
  this.closeButtonClicked.emit();
88
88
  }
89
89
  onPostingBoardChange(selectedBoard) {
90
- this.updateOrderSummary();
90
+ const selectedJobBoards = this.model.jobBoards.filter((jb) => jb.isSelected).length;
91
+ if (selectedJobBoards > 0) {
92
+ this.updateOrderSummary();
93
+ }
91
94
  }
92
95
  addLineItem(invoiceAreaIndex, selectedBoard) {
93
96
  this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.push({
@@ -188,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
188
191
  }], keywordSearchChange: [{
189
192
  type: Output
190
193
  }] } });
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"]}
194
+ //# 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    const selectedJobBoards = this.model.jobBoards.filter(\n      (jb) => jb.isSelected\n    ).length;\n    if (selectedJobBoards > 0) {\n      this.updateOrderSummary();\n    }\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"]}
@@ -87,7 +87,10 @@ export class AdvertiseModalComponent {
87
87
  this.closeButtonClicked.emit();
88
88
  }
89
89
  onPostingBoardChange(selectedBoard) {
90
- this.updateOrderSummary();
90
+ const selectedJobBoards = this.model.jobBoards.filter((jb) => jb.isSelected).length;
91
+ if (selectedJobBoards > 0) {
92
+ this.updateOrderSummary();
93
+ }
91
94
  }
92
95
  addLineItem(invoiceAreaIndex, selectedBoard) {
93
96
  this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.push({
@@ -188,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
188
191
  }], keywordSearchChange: [{
189
192
  type: Output
190
193
  }] } });
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"]}
194
+ //# 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    const selectedJobBoards = this.model.jobBoards.filter(\n      (jb) => jb.isSelected\n    ).length;\n    if (selectedJobBoards > 0) {\n      this.updateOrderSummary();\n    }\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"]}
@@ -5163,7 +5163,10 @@ class AdvertiseModalComponent {
5163
5163
  this.closeButtonClicked.emit();
5164
5164
  }
5165
5165
  onPostingBoardChange(selectedBoard) {
5166
- this.updateOrderSummary();
5166
+ const selectedJobBoards = this.model.jobBoards.filter((jb) => jb.isSelected).length;
5167
+ if (selectedJobBoards > 0) {
5168
+ this.updateOrderSummary();
5169
+ }
5167
5170
  }
5168
5171
  addLineItem(invoiceAreaIndex, selectedBoard) {
5169
5172
  this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.push({