@symphony-talent/component-library 3.41.0 → 3.44.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/atoms/input-chips/input-chips.module.mjs +5 -5
  2. package/esm2020/lib/molecules/advertise-postingboard-selection-item/advertise-postingboard-selection-item.component.mjs +3 -3
  3. package/esm2020/lib/molecules/phaser-card/phaser-card.component.mjs +24 -5
  4. package/esm2020/lib/pages/modals/advertise-modal/advertise-modal.component.mjs +5 -2
  5. package/esm2020/lib/pages/modals/advertise-modal/advertise-modal.model.mjs +1 -1
  6. package/esm2020/projects/component-library/lib/atoms/input-chips/input-chips.module.mjs +5 -5
  7. package/esm2020/projects/component-library/lib/molecules/advertise-postingboard-selection-item/advertise-postingboard-selection-item.component.mjs +3 -3
  8. package/esm2020/projects/component-library/lib/molecules/phaser-card/phaser-card.component.mjs +24 -5
  9. package/esm2020/projects/component-library/lib/pages/modals/advertise-modal/advertise-modal.component.mjs +5 -2
  10. package/esm2020/projects/component-library/lib/pages/modals/advertise-modal/advertise-modal.model.mjs +1 -1
  11. package/fesm2015/symphony-talent-component-library-projects-component-library.mjs +31 -9
  12. package/fesm2015/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
  13. package/fesm2015/symphony-talent-component-library.mjs +31 -9
  14. package/fesm2015/symphony-talent-component-library.mjs.map +1 -1
  15. package/fesm2020/symphony-talent-component-library-projects-component-library.mjs +31 -9
  16. package/fesm2020/symphony-talent-component-library-projects-component-library.mjs.map +1 -1
  17. package/fesm2020/symphony-talent-component-library.mjs +31 -9
  18. package/fesm2020/symphony-talent-component-library.mjs.map +1 -1
  19. package/lib/molecules/phaser-card/phaser-card.component.d.ts +9 -1
  20. package/lib/pages/modals/advertise-modal/advertise-modal.model.d.ts +1 -0
  21. package/package.json +1 -1
  22. package/projects/component-library/lib/molecules/phaser-card/phaser-card.component.d.ts +9 -1
  23. package/projects/component-library/lib/pages/modals/advertise-modal/advertise-modal.model.d.ts +1 -0
@@ -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"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWR2ZXJ0aXNlLW1vZGFsLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9wYWdlcy9tb2RhbHMvYWR2ZXJ0aXNlLW1vZGFsL2FkdmVydGlzZS1tb2RhbC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBZHZlcnRpc2VNb2RhbE1vZGVsIHtcbiAgc2hvd0Z1bmRzOiBib29sZWFuO1xuICBqb2JzVG9BZHZlcnRpc2U6IEFkdmVydGlzZUpvYk1vZGVsW107XG4gIGpvYkJvYXJkczogUG9zdGluZ0JvYXJkc1NlbGVjdGlvbk1vZGVsW107XG4gIGhhc0pvYkJvYXJkc0xvYWRpbmdGYWlsZWQ6IGJvb2xlYW47XG4gIG5hdmlnYXRpb246IEFkdmVydGlzZU1vZGFsTmF2aWdhdGlvbjtcbiAgaXNMb2FkaW5nOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkdmVydGlzZUpvYk1vZGVsIHtcbiAgaWQ6IG51bWJlcjtcbiAgam9iVGl0bGU6IHN0cmluZztcbn1cbmV4cG9ydCBpbnRlcmZhY2UgUG9zdGluZ0JvYXJkc1NlbGVjdGlvbk1vZGVsIHtcbiAgaWQ6IG51bWJlcjtcbiAgYm9hcmROYW1lOiBzdHJpbmc7XG4gIGJvYXJkUHJpY2U6IG51bWJlcjtcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbiAgaXNFZGl0YWJsZTogYm9vbGVhbjtcbiAgaXNJbkVkaXRNb2RlOiBib29sZWFuO1xuICBib2FyZEdyb3VwOiBzdHJpbmc7XG4gIGlzUGF5UGVyQ2xpY2s6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWR2ZXJ0aXNlTW9kYWxOYXZpZ2F0aW9uIHtcbiAgc2hvd0pvYkJvYXJkc1NlbGVjdGlvbjogYm9vbGVhbjtcbiAgc2hvd09yZGVyUmV2aWV3OiBib29sZWFuO1xuICBzaG93T3JkZXJQcm9jZXNzaW5nOiBib29sZWFuO1xuICBzaG93Q29uZmlybWF0aW9uOiBib29sZWFuO1xuICBzaG93Q2FuY2VsOiBib29sZWFuO1xuICBzaG93UHJvY2Vzc2luZzogYm9vbGVhbjtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWR2ZXJ0aXNlLW1vZGFsLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9wYWdlcy9tb2RhbHMvYWR2ZXJ0aXNlLW1vZGFsL2FkdmVydGlzZS1tb2RhbC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBZHZlcnRpc2VNb2RhbE1vZGVsIHtcbiAgc2hvd0Z1bmRzOiBib29sZWFuO1xuICBqb2JzVG9BZHZlcnRpc2U6IEFkdmVydGlzZUpvYk1vZGVsW107XG4gIGpvYkJvYXJkczogUG9zdGluZ0JvYXJkc1NlbGVjdGlvbk1vZGVsW107XG4gIGhhc0pvYkJvYXJkc0xvYWRpbmdGYWlsZWQ6IGJvb2xlYW47XG4gIG5hdmlnYXRpb246IEFkdmVydGlzZU1vZGFsTmF2aWdhdGlvbjtcbiAgaXNMb2FkaW5nOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkdmVydGlzZUpvYk1vZGVsIHtcbiAgaWQ6IG51bWJlcjtcbiAgam9iVGl0bGU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQb3N0aW5nQm9hcmRzU2VsZWN0aW9uTW9kZWwge1xuICBpZDogbnVtYmVyO1xuICBib2FyZE5hbWU6IHN0cmluZztcbiAgYm9hcmRQcmljZTogbnVtYmVyO1xuICBpc1NlbGVjdGVkOiBib29sZWFuO1xuICBpc0VkaXRhYmxlOiBib29sZWFuO1xuICBpc0luRWRpdE1vZGU6IGJvb2xlYW47XG4gIGJvYXJkR3JvdXA6IHN0cmluZztcbiAgaXNQYXlQZXJDbGljazogYm9vbGVhbjtcbiAgaXNWaXNpYmxlOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkdmVydGlzZU1vZGFsTmF2aWdhdGlvbiB7XG4gIHNob3dKb2JCb2FyZHNTZWxlY3Rpb246IGJvb2xlYW47XG4gIHNob3dPcmRlclJldmlldzogYm9vbGVhbjtcbiAgc2hvd09yZGVyUHJvY2Vzc2luZzogYm9vbGVhbjtcbiAgc2hvd0NvbmZpcm1hdGlvbjogYm9vbGVhbjtcbiAgc2hvd0NhbmNlbDogYm9vbGVhbjtcbiAgc2hvd1Byb2Nlc3Npbmc6IGJvb2xlYW47XG59XG4iXX0=
@@ -1400,7 +1400,7 @@ InputChipsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versio
1400
1400
  BrowserAnimationsModule,
1401
1401
  ChipModule,
1402
1402
  FormsModule,
1403
- ReactiveFormsModule
1403
+ ReactiveFormsModule,
1404
1404
  ], ReactiveFormsModule, FormsModule] });
1405
1405
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: InputChipsModule, decorators: [{
1406
1406
  type: NgModule,
@@ -1412,9 +1412,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
1412
1412
  BrowserAnimationsModule,
1413
1413
  ChipModule,
1414
1414
  FormsModule,
1415
- ReactiveFormsModule
1415
+ ReactiveFormsModule,
1416
1416
  ],
1417
- exports: [InputChipsComponent, ReactiveFormsModule, FormsModule]
1417
+ exports: [InputChipsComponent, ReactiveFormsModule, FormsModule],
1418
1418
  }]
1419
1419
  }] });
1420
1420
 
@@ -2505,19 +2505,38 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImpor
2505
2505
  }] });
2506
2506
 
2507
2507
  class PhaserCardComponent {
2508
- constructor() { }
2508
+ constructor() {
2509
+ this.cardClicked = new EventEmitter();
2510
+ this.cardHover = new EventEmitter();
2511
+ }
2512
+ onCardClick() {
2513
+ this.cardClicked.emit(this.model);
2514
+ }
2515
+ onCardHover() {
2516
+ this.cardHover.emit('Card Hover');
2517
+ }
2509
2518
  }
2510
2519
  PhaserCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: PhaserCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2511
- PhaserCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: PhaserCardComponent, selector: "symphony-phaser-card", inputs: { model: "model", cardHeightPx: "cardHeightPx", cardWidthPx: "cardWidthPx" }, ngImport: i0, template: "<div\n *ngIf=\"model\"\n class=\"card-item-wrapper\"\n [style.height.px]=\"cardHeightPx\"\n [style.width.px]=\"cardWidthPx\"\n>\n <div class=\"card-item\">\n <div class=\"card-phaser-wrapper snapIn\" [class]=\"model.backgroundColor\">\n <symphony-phaser\n [phaser]=\"model.phaserState\"\n [outlineColor]=\"model.phaserOutlineColor\"\n ></symphony-phaser>\n </div>\n\n <div class=\"card-content-wrapper snapInContent\">\n <div class=\"card-title-wrap sfx-d-flex\">\n <div class=\"card-icon\">\n <symphony-icon [icon]=\"'si-info'\"></symphony-icon>\n </div>\n <div class=\"card-title\">\n <symphony-h5\n [text]=\"model.eyebrowText\"\n title=\"{{ model.eyebrowText }}\"\n class=\"sfx-ellipse\"\n ></symphony-h5>\n </div>\n </div>\n <div class=\"card-description\">\n <symphony-h3\n [text]=\"model.messageBody\"\n title=\"{{ model.messageBody }}\"\n ></symphony-h3>\n </div>\n </div>\n </div>\n</div>\n", styles: [".color-sample{float:left;border-radius:50%;height:30px;width:30px;margin-top:10px;margin-right:20px}.background-color-black{background-color:#000}.background-color-grey{background-color:#bababa}.background-color-light-grey-1{background-color:#d0d0d0}.background-color-light-grey-2{background-color:#d9d9d9}.background-color-light-grey-3{background-color:#ebebeb}.background-color-medium-black{background-color:#464646}.background-color-space-grey{background-color:#141414}.background-color-white{background-color:#fff}.background-color-green{background-color:#00d56b}.background-color-ice-blue{background-color:#03bcce}.background-color-lavender{background-color:#af5af9}.background-color-orange{background-color:#ffa700}.background-color-pink{background-color:#ff6cff}.background-color-purple{background-color:#801afc}.background-color-red{background-color:#f0001e}.background-color-skyblue{background-color:#007dbb}.background-color-turquoise{background-color:#00ebb5}.background-color-yellow{background-color:#fde928}.background-color-cyan{background-color:#00ffd8}.background-color-strong-orange{background-color:#ffa700}.background-color-soft-lime-green{background-color:#67f95a}.background-color-bright-violet{background-color:#7428fd}.background-color-lime-green{background-color:#00bb5e}.card-item-wrapper{position:relative;overflow:hidden;box-shadow:0 4px 4px #00000040;height:420px}.card-item-wrapper .card-phaser-wrapper{height:200px;display:flex;justify-content:center;align-items:center}.card-item-wrapper .card-item{transition:.2s;cursor:pointer;transform-origin:bottom;animation-duration:2s;animation-iteration-count:1}.card-item-wrapper .card-item .card-content-wrapper{padding:30px;background-color:#fff}.card-item-wrapper .card-title-wrap{margin-bottom:11px}.card-item-wrapper .card-title-wrap h5{font-family:neuzeit_groteskregular,sans-serif;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.card-item-wrapper .card-description h3{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.card-item-wrapper .card-icon{padding-right:8px}.snapIn{animation:snapIn .75s ease-in-out 0s}@keyframes snapIn{0%{height:420px}25%{height:190px}50%{height:195px}to{height:200px}}.snapInContent{animation:snapInContent .75s ease-in-out 0s}@keyframes snapInContent{0%{transform:translateY(200px);height:0;opacity:0}25%{opacity:1}50%{transform:translateY(-20px);opacity:1}to{transform:translateY(0);height:220px;opacity:1}}\n"], components: [{ type: PhaserComponent, selector: "symphony-phaser", inputs: ["phaser", "outlineColor"] }, { type: IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: H3Component, selector: "symphony-h3", inputs: ["text", "isSecondary"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
2520
+ PhaserCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: PhaserCardComponent, selector: "symphony-phaser-card", inputs: { model: "model", cardHeightPx: "cardHeightPx", cardWidthPx: "cardWidthPx", hasAnimation: "hasAnimation", isClickable: "isClickable", hasHover: "hasHover" }, outputs: { cardClicked: "cardClicked", cardHover: "cardHover" }, ngImport: i0, template: "<div\n *ngIf=\"model\"\n class=\"card-item-wrapper\"\n [style.height.px]=\"cardHeightPx\"\n [style.width.px]=\"cardWidthPx\"\n [ngClass]=\"{ 'has-hover': isClickable }\"\n [ngClass]=\"{ 'has-hover': hasHover }\"\n (click)=\"isClickable && onCardClick()\"\n (mouseenter)=\"hasHover && onCardHover()\"\n>\n <div class=\"card-item\">\n <div\n class=\"card-phaser-wrapper \"\n [ngClass]=\"{ 'snap-in': hasAnimation }\"\n [class]=\"model.backgroundColor\"\n >\n <symphony-phaser\n [phaser]=\"model.phaserState\"\n [outlineColor]=\"model.phaserOutlineColor\"\n ></symphony-phaser>\n </div>\n\n <div\n class=\"card-content-wrapper\"\n [ngClass]=\"{ 'snap-in-content': hasAnimation }\"\n >\n <div class=\"card-title-wrap sfx-d-flex\">\n <div class=\"card-icon\">\n <symphony-icon [icon]=\"'si-info'\"></symphony-icon>\n </div>\n <div class=\"card-title\">\n <symphony-h5\n [text]=\"model.eyebrowText\"\n title=\"{{ model.eyebrowText }}\"\n class=\"sfx-ellipse\"\n ></symphony-h5>\n </div>\n </div>\n <div class=\"card-description\">\n <symphony-h3\n [text]=\"model.messageBody\"\n title=\"{{ model.messageBody }}\"\n ></symphony-h3>\n </div>\n </div>\n </div>\n</div>\n", styles: [".color-sample{float:left;border-radius:50%;height:30px;width:30px;margin-top:10px;margin-right:20px}.background-color-black{background-color:#000}.background-color-grey{background-color:#bababa}.background-color-light-grey-1{background-color:#d0d0d0}.background-color-light-grey-2{background-color:#d9d9d9}.background-color-light-grey-3{background-color:#ebebeb}.background-color-medium-black{background-color:#464646}.background-color-space-grey{background-color:#141414}.background-color-white{background-color:#fff}.background-color-green{background-color:#00d56b}.background-color-ice-blue{background-color:#03bcce}.background-color-lavender{background-color:#af5af9}.background-color-orange{background-color:#ffa700}.background-color-pink{background-color:#ff6cff}.background-color-purple{background-color:#801afc}.background-color-red{background-color:#f0001e}.background-color-skyblue{background-color:#007dbb}.background-color-turquoise{background-color:#00ebb5}.background-color-yellow{background-color:#fde928}.background-color-cyan{background-color:#00ffd8}.background-color-strong-orange{background-color:#ffa700}.background-color-soft-lime-green{background-color:#67f95a}.background-color-bright-violet{background-color:#7428fd}.background-color-lime-green{background-color:#00bb5e}.card-item-wrapper{position:relative;overflow:hidden;box-shadow:0 4px 4px #00000040;height:420px}.card-item-wrapper.has-hover{cursor:pointer}.card-item-wrapper .card-phaser-wrapper{height:200px;display:flex;justify-content:center;align-items:center}.card-item-wrapper .card-item{transition:.2s;transform-origin:bottom;animation-duration:2s;animation-iteration-count:1}.card-item-wrapper .card-item .card-content-wrapper{padding:30px;background-color:#fff}.card-item-wrapper .card-title-wrap{margin-bottom:11px}.card-item-wrapper .card-title-wrap h5{font-family:neuzeit_groteskregular,sans-serif;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.card-item-wrapper .card-description h3{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.card-item-wrapper .card-icon{padding-right:8px}.snap-in{animation:snap-in .75s ease-in-out 0s}@keyframes snap-in{0%{height:420px}25%{height:190px}50%{height:195px}to{height:200px}}.snap-in-content{animation:snap-in-content .75s ease-in-out 0s}@keyframes snap-in-content{0%{transform:translateY(200px);height:0;opacity:0}25%{opacity:1}50%{transform:translateY(-20px);opacity:1}to{transform:translateY(0);height:220px;opacity:1}}\n"], components: [{ type: PhaserComponent, selector: "symphony-phaser", inputs: ["phaser", "outlineColor"] }, { type: IconComponent, selector: "symphony-icon", inputs: ["icon", "isSecondary", "size", "iconColor"], outputs: ["clicked"] }, { type: H5Component, selector: "symphony-h5", inputs: ["text", "isSecondary"] }, { type: H3Component, selector: "symphony-h3", inputs: ["text", "isSecondary"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], encapsulation: i0.ViewEncapsulation.None });
2512
2521
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: PhaserCardComponent, decorators: [{
2513
2522
  type: Component,
2514
- args: [{ selector: 'symphony-phaser-card', encapsulation: ViewEncapsulation.None, template: "<div\n *ngIf=\"model\"\n class=\"card-item-wrapper\"\n [style.height.px]=\"cardHeightPx\"\n [style.width.px]=\"cardWidthPx\"\n>\n <div class=\"card-item\">\n <div class=\"card-phaser-wrapper snapIn\" [class]=\"model.backgroundColor\">\n <symphony-phaser\n [phaser]=\"model.phaserState\"\n [outlineColor]=\"model.phaserOutlineColor\"\n ></symphony-phaser>\n </div>\n\n <div class=\"card-content-wrapper snapInContent\">\n <div class=\"card-title-wrap sfx-d-flex\">\n <div class=\"card-icon\">\n <symphony-icon [icon]=\"'si-info'\"></symphony-icon>\n </div>\n <div class=\"card-title\">\n <symphony-h5\n [text]=\"model.eyebrowText\"\n title=\"{{ model.eyebrowText }}\"\n class=\"sfx-ellipse\"\n ></symphony-h5>\n </div>\n </div>\n <div class=\"card-description\">\n <symphony-h3\n [text]=\"model.messageBody\"\n title=\"{{ model.messageBody }}\"\n ></symphony-h3>\n </div>\n </div>\n </div>\n</div>\n", styles: [".color-sample{float:left;border-radius:50%;height:30px;width:30px;margin-top:10px;margin-right:20px}.background-color-black{background-color:#000}.background-color-grey{background-color:#bababa}.background-color-light-grey-1{background-color:#d0d0d0}.background-color-light-grey-2{background-color:#d9d9d9}.background-color-light-grey-3{background-color:#ebebeb}.background-color-medium-black{background-color:#464646}.background-color-space-grey{background-color:#141414}.background-color-white{background-color:#fff}.background-color-green{background-color:#00d56b}.background-color-ice-blue{background-color:#03bcce}.background-color-lavender{background-color:#af5af9}.background-color-orange{background-color:#ffa700}.background-color-pink{background-color:#ff6cff}.background-color-purple{background-color:#801afc}.background-color-red{background-color:#f0001e}.background-color-skyblue{background-color:#007dbb}.background-color-turquoise{background-color:#00ebb5}.background-color-yellow{background-color:#fde928}.background-color-cyan{background-color:#00ffd8}.background-color-strong-orange{background-color:#ffa700}.background-color-soft-lime-green{background-color:#67f95a}.background-color-bright-violet{background-color:#7428fd}.background-color-lime-green{background-color:#00bb5e}.card-item-wrapper{position:relative;overflow:hidden;box-shadow:0 4px 4px #00000040;height:420px}.card-item-wrapper .card-phaser-wrapper{height:200px;display:flex;justify-content:center;align-items:center}.card-item-wrapper .card-item{transition:.2s;cursor:pointer;transform-origin:bottom;animation-duration:2s;animation-iteration-count:1}.card-item-wrapper .card-item .card-content-wrapper{padding:30px;background-color:#fff}.card-item-wrapper .card-title-wrap{margin-bottom:11px}.card-item-wrapper .card-title-wrap h5{font-family:neuzeit_groteskregular,sans-serif;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.card-item-wrapper .card-description h3{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.card-item-wrapper .card-icon{padding-right:8px}.snapIn{animation:snapIn .75s ease-in-out 0s}@keyframes snapIn{0%{height:420px}25%{height:190px}50%{height:195px}to{height:200px}}.snapInContent{animation:snapInContent .75s ease-in-out 0s}@keyframes snapInContent{0%{transform:translateY(200px);height:0;opacity:0}25%{opacity:1}50%{transform:translateY(-20px);opacity:1}to{transform:translateY(0);height:220px;opacity:1}}\n"] }]
2523
+ args: [{ selector: 'symphony-phaser-card', encapsulation: ViewEncapsulation.None, template: "<div\n *ngIf=\"model\"\n class=\"card-item-wrapper\"\n [style.height.px]=\"cardHeightPx\"\n [style.width.px]=\"cardWidthPx\"\n [ngClass]=\"{ 'has-hover': isClickable }\"\n [ngClass]=\"{ 'has-hover': hasHover }\"\n (click)=\"isClickable && onCardClick()\"\n (mouseenter)=\"hasHover && onCardHover()\"\n>\n <div class=\"card-item\">\n <div\n class=\"card-phaser-wrapper \"\n [ngClass]=\"{ 'snap-in': hasAnimation }\"\n [class]=\"model.backgroundColor\"\n >\n <symphony-phaser\n [phaser]=\"model.phaserState\"\n [outlineColor]=\"model.phaserOutlineColor\"\n ></symphony-phaser>\n </div>\n\n <div\n class=\"card-content-wrapper\"\n [ngClass]=\"{ 'snap-in-content': hasAnimation }\"\n >\n <div class=\"card-title-wrap sfx-d-flex\">\n <div class=\"card-icon\">\n <symphony-icon [icon]=\"'si-info'\"></symphony-icon>\n </div>\n <div class=\"card-title\">\n <symphony-h5\n [text]=\"model.eyebrowText\"\n title=\"{{ model.eyebrowText }}\"\n class=\"sfx-ellipse\"\n ></symphony-h5>\n </div>\n </div>\n <div class=\"card-description\">\n <symphony-h3\n [text]=\"model.messageBody\"\n title=\"{{ model.messageBody }}\"\n ></symphony-h3>\n </div>\n </div>\n </div>\n</div>\n", styles: [".color-sample{float:left;border-radius:50%;height:30px;width:30px;margin-top:10px;margin-right:20px}.background-color-black{background-color:#000}.background-color-grey{background-color:#bababa}.background-color-light-grey-1{background-color:#d0d0d0}.background-color-light-grey-2{background-color:#d9d9d9}.background-color-light-grey-3{background-color:#ebebeb}.background-color-medium-black{background-color:#464646}.background-color-space-grey{background-color:#141414}.background-color-white{background-color:#fff}.background-color-green{background-color:#00d56b}.background-color-ice-blue{background-color:#03bcce}.background-color-lavender{background-color:#af5af9}.background-color-orange{background-color:#ffa700}.background-color-pink{background-color:#ff6cff}.background-color-purple{background-color:#801afc}.background-color-red{background-color:#f0001e}.background-color-skyblue{background-color:#007dbb}.background-color-turquoise{background-color:#00ebb5}.background-color-yellow{background-color:#fde928}.background-color-cyan{background-color:#00ffd8}.background-color-strong-orange{background-color:#ffa700}.background-color-soft-lime-green{background-color:#67f95a}.background-color-bright-violet{background-color:#7428fd}.background-color-lime-green{background-color:#00bb5e}.card-item-wrapper{position:relative;overflow:hidden;box-shadow:0 4px 4px #00000040;height:420px}.card-item-wrapper.has-hover{cursor:pointer}.card-item-wrapper .card-phaser-wrapper{height:200px;display:flex;justify-content:center;align-items:center}.card-item-wrapper .card-item{transition:.2s;transform-origin:bottom;animation-duration:2s;animation-iteration-count:1}.card-item-wrapper .card-item .card-content-wrapper{padding:30px;background-color:#fff}.card-item-wrapper .card-title-wrap{margin-bottom:11px}.card-item-wrapper .card-title-wrap h5{font-family:neuzeit_groteskregular,sans-serif;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.card-item-wrapper .card-description h3{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.card-item-wrapper .card-icon{padding-right:8px}.snap-in{animation:snap-in .75s ease-in-out 0s}@keyframes snap-in{0%{height:420px}25%{height:190px}50%{height:195px}to{height:200px}}.snap-in-content{animation:snap-in-content .75s ease-in-out 0s}@keyframes snap-in-content{0%{transform:translateY(200px);height:0;opacity:0}25%{opacity:1}50%{transform:translateY(-20px);opacity:1}to{transform:translateY(0);height:220px;opacity:1}}\n"] }]
2515
2524
  }], ctorParameters: function () { return []; }, propDecorators: { model: [{
2516
2525
  type: Input
2517
2526
  }], cardHeightPx: [{
2518
2527
  type: Input
2519
2528
  }], cardWidthPx: [{
2520
2529
  type: Input
2530
+ }], hasAnimation: [{
2531
+ type: Input
2532
+ }], isClickable: [{
2533
+ type: Input
2534
+ }], hasHover: [{
2535
+ type: Input
2536
+ }], cardClicked: [{
2537
+ type: Output
2538
+ }], cardHover: [{
2539
+ type: Output
2521
2540
  }] } });
2522
2541
 
2523
2542
  class PhaserCardModule {
@@ -5012,10 +5031,10 @@ class AdvertisePostingboardSelectionItemComponent {
5012
5031
  }
5013
5032
  }
5014
5033
  AdvertisePostingboardSelectionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: AdvertisePostingboardSelectionItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
5015
- AdvertisePostingboardSelectionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: AdvertisePostingboardSelectionItemComponent, selector: "symphony-advertise-postingboard-selection-item", inputs: { model: "model" }, outputs: { priceChange: "priceChange", postingBoardSelect: "postingBoardSelect" }, ngImport: i0, template: "<div *ngIf=\"model\" class=\"posting-board-selection-item\">\n <div class=\"inline-block\">\n <symphony-input-checkbox\n [label]=\"model.boardName\"\n [isActive]=\"model.isSelected\"\n (clicked)=\"onPostingBoardSelect($event)\"\n ></symphony-input-checkbox>\n </div>\n <div class=\"inline-block editText\">\n <symphony-input-editable-text\n [model]=\"editableTextModel\"\n (confirm)=\"onBoardPriceChange($event)\"\n ></symphony-input-editable-text>\n </div>\n</div>\n", styles: [".posting-board-selection-item{position:relative;padding-right:100px}.posting-board-selection-item .editText{position:absolute;right:0}.inline-block{display:inline-block}\n"], components: [{ type: InputCheckboxComponent, selector: "symphony-input-checkbox", inputs: ["isActive", "label", "isRequired"], outputs: ["clicked"] }, { type: InputEditableTextComponent, selector: "symphony-input-editable-text", inputs: ["model", "type"], outputs: ["confirm"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
5034
+ AdvertisePostingboardSelectionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: AdvertisePostingboardSelectionItemComponent, selector: "symphony-advertise-postingboard-selection-item", inputs: { model: "model" }, outputs: { priceChange: "priceChange", postingBoardSelect: "postingBoardSelect" }, ngImport: i0, template: "<div *ngIf=\"model && model.isVisible\" class=\"posting-board-selection-item\">\n <div class=\"inline-block\">\n <symphony-input-checkbox\n [label]=\"model.boardName\"\n [isActive]=\"model.isSelected\"\n (clicked)=\"onPostingBoardSelect($event)\"\n ></symphony-input-checkbox>\n </div>\n <div class=\"inline-block editText\">\n <symphony-input-editable-text\n [model]=\"editableTextModel\"\n (confirm)=\"onBoardPriceChange($event)\"\n ></symphony-input-editable-text>\n </div>\n</div>\n", styles: [".posting-board-selection-item{position:relative;padding-right:100px}.posting-board-selection-item .editText{position:absolute;right:0}.inline-block{display:inline-block}\n"], components: [{ type: InputCheckboxComponent, selector: "symphony-input-checkbox", inputs: ["isActive", "label", "isRequired"], outputs: ["clicked"] }, { type: InputEditableTextComponent, selector: "symphony-input-editable-text", inputs: ["model", "type"], outputs: ["confirm"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
5016
5035
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: AdvertisePostingboardSelectionItemComponent, decorators: [{
5017
5036
  type: Component,
5018
- args: [{ selector: 'symphony-advertise-postingboard-selection-item', template: "<div *ngIf=\"model\" class=\"posting-board-selection-item\">\n <div class=\"inline-block\">\n <symphony-input-checkbox\n [label]=\"model.boardName\"\n [isActive]=\"model.isSelected\"\n (clicked)=\"onPostingBoardSelect($event)\"\n ></symphony-input-checkbox>\n </div>\n <div class=\"inline-block editText\">\n <symphony-input-editable-text\n [model]=\"editableTextModel\"\n (confirm)=\"onBoardPriceChange($event)\"\n ></symphony-input-editable-text>\n </div>\n</div>\n", styles: [".posting-board-selection-item{position:relative;padding-right:100px}.posting-board-selection-item .editText{position:absolute;right:0}.inline-block{display:inline-block}\n"] }]
5037
+ args: [{ selector: 'symphony-advertise-postingboard-selection-item', template: "<div *ngIf=\"model && model.isVisible\" class=\"posting-board-selection-item\">\n <div class=\"inline-block\">\n <symphony-input-checkbox\n [label]=\"model.boardName\"\n [isActive]=\"model.isSelected\"\n (clicked)=\"onPostingBoardSelect($event)\"\n ></symphony-input-checkbox>\n </div>\n <div class=\"inline-block editText\">\n <symphony-input-editable-text\n [model]=\"editableTextModel\"\n (confirm)=\"onBoardPriceChange($event)\"\n ></symphony-input-editable-text>\n </div>\n</div>\n", styles: [".posting-board-selection-item{position:relative;padding-right:100px}.posting-board-selection-item .editText{position:absolute;right:0}.inline-block{display:inline-block}\n"] }]
5019
5038
  }], ctorParameters: function () { return []; }, propDecorators: { model: [{
5020
5039
  type: Input
5021
5040
  }], priceChange: [{
@@ -5163,7 +5182,10 @@ class AdvertiseModalComponent {
5163
5182
  this.closeButtonClicked.emit();
5164
5183
  }
5165
5184
  onPostingBoardChange(selectedBoard) {
5166
- this.updateOrderSummary();
5185
+ const selectedJobBoards = this.model.jobBoards.filter((jb) => jb.isSelected).length;
5186
+ if (selectedJobBoards > 0) {
5187
+ this.updateOrderSummary();
5188
+ }
5167
5189
  }
5168
5190
  addLineItem(invoiceAreaIndex, selectedBoard) {
5169
5191
  this.orderSummary.invoiceAreas[invoiceAreaIndex].lineItems.push({