@pega/angular-sdk-components 0.23.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/_shared/styles.scss +28 -0
- package/esm2022/lib/_bridge/angular-pconnect.mjs +416 -0
- package/esm2022/lib/_bridge/component-mapper/component-mapper.component.mjs +114 -0
- package/esm2022/lib/_bridge/helpers/sdk-pega-component-map.mjs +228 -0
- package/esm2022/lib/_bridge/helpers/sdk_component_map.mjs +142 -0
- package/esm2022/lib/_components/designSystemExtension/alert/alert.component.mjs +50 -0
- package/esm2022/lib/_components/designSystemExtension/alert-banner/alert-banner.component.mjs +29 -0
- package/esm2022/lib/_components/designSystemExtension/banner/banner.component.mjs +31 -0
- package/esm2022/lib/_components/designSystemExtension/case-create-stage/case-create-stage.component.mjs +51 -0
- package/esm2022/lib/_components/designSystemExtension/material-case-summary/material-case-summary.component.mjs +80 -0
- package/esm2022/lib/_components/designSystemExtension/material-details/material-details.component.mjs +37 -0
- package/esm2022/lib/_components/designSystemExtension/material-details-fields/material-details-fields.component.mjs +31 -0
- package/esm2022/lib/_components/designSystemExtension/material-summary-item/material-summary-item.component.mjs +36 -0
- package/esm2022/lib/_components/designSystemExtension/material-summary-list/material-summary-list.component.mjs +25 -0
- package/esm2022/lib/_components/designSystemExtension/material-utility/material-utility.component.mjs +28 -0
- package/esm2022/lib/_components/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.mjs +42 -0
- package/esm2022/lib/_components/designSystemExtension/operator/operator.component.mjs +136 -0
- package/esm2022/lib/_components/designSystemExtension/pulse/pulse.component.mjs +33 -0
- package/esm2022/lib/_components/designSystemExtension/rich-text-editor/rich-text-editor.component.mjs +93 -0
- package/esm2022/lib/_components/designSystemExtension/wss-quick-create/wss-quick-create.component.mjs +18 -0
- package/esm2022/lib/_components/field/auto-complete/auto-complete.component.mjs +286 -0
- package/esm2022/lib/_components/field/cancel-alert/cancel-alert.component.mjs +98 -0
- package/esm2022/lib/_components/field/check-box/check-box.component.mjs +157 -0
- package/esm2022/lib/_components/field/currency/currency.component.mjs +160 -0
- package/esm2022/lib/_components/field/date/date.component.mjs +219 -0
- package/esm2022/lib/_components/field/date-time/date-time.component.mjs +200 -0
- package/esm2022/lib/_components/field/decimal/decimal.component.mjs +157 -0
- package/esm2022/lib/_components/field/dropdown/dropdown.component.mjs +197 -0
- package/esm2022/lib/_components/field/email/email.component.mjs +150 -0
- package/esm2022/lib/_components/field/integer/integer.component.mjs +155 -0
- package/esm2022/lib/_components/field/list-view-action-buttons/list-view-action-buttons.component.mjs +44 -0
- package/esm2022/lib/_components/field/percentage/percentage.component.mjs +155 -0
- package/esm2022/lib/_components/field/phone/phone.component.mjs +167 -0
- package/esm2022/lib/_components/field/radio-buttons/radio-buttons.component.mjs +189 -0
- package/esm2022/lib/_components/field/rich-text/rich-text.component.mjs +103 -0
- package/esm2022/lib/_components/field/scalar-list/scalar-list.component.mjs +95 -0
- package/esm2022/lib/_components/field/semantic-link/semantic-link.component.mjs +57 -0
- package/esm2022/lib/_components/field/text/text.component.mjs +138 -0
- package/esm2022/lib/_components/field/text-area/text-area.component.mjs +155 -0
- package/esm2022/lib/_components/field/text-content/text-content.component.mjs +69 -0
- package/esm2022/lib/_components/field/text-input/text-input.component.mjs +152 -0
- package/esm2022/lib/_components/field/time/time.component.mjs +151 -0
- package/esm2022/lib/_components/field/url/url.component.mjs +150 -0
- package/esm2022/lib/_components/field/user-reference/user-reference.component.mjs +175 -0
- package/esm2022/lib/_components/infra/Containers/flow-container/flow-container.component.mjs +491 -0
- package/esm2022/lib/_components/infra/Containers/flow-container/helpers.mjs +68 -0
- package/esm2022/lib/_components/infra/Containers/hybrid-view-container/hybrid-view-container.component.mjs +24 -0
- package/esm2022/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.mjs +314 -0
- package/esm2022/lib/_components/infra/Containers/preview-view-container/preview-view-container.component.mjs +32 -0
- package/esm2022/lib/_components/infra/Containers/view-container/view-container.component.mjs +219 -0
- package/esm2022/lib/_components/infra/action-buttons/action-buttons.component.mjs +31 -0
- package/esm2022/lib/_components/infra/assignment/assignment.component.mjs +387 -0
- package/esm2022/lib/_components/infra/assignment-card/assignment-card.component.mjs +47 -0
- package/esm2022/lib/_components/infra/dashboard-filter/dashboard-filter.component.mjs +88 -0
- package/esm2022/lib/_components/infra/defer-load/defer-load.component.mjs +144 -0
- package/esm2022/lib/_components/infra/error-boundary/error-boundary.component.mjs +18 -0
- package/esm2022/lib/_components/infra/multi-step/multi-step.component.mjs +80 -0
- package/esm2022/lib/_components/infra/navbar/navbar.component.mjs +132 -0
- package/esm2022/lib/_components/infra/reference/reference.component.mjs +133 -0
- package/esm2022/lib/_components/infra/region/region.component.mjs +33 -0
- package/esm2022/lib/_components/infra/root-container/root-container.component.mjs +228 -0
- package/esm2022/lib/_components/infra/stages/stages.component.mjs +62 -0
- package/esm2022/lib/_components/infra/view/view.component.mjs +173 -0
- package/esm2022/lib/_components/template/app-shell/app-shell.component.mjs +140 -0
- package/esm2022/lib/_components/template/banner-page/banner-page.component.mjs +43 -0
- package/esm2022/lib/_components/template/case-summary/case-summary.component.mjs +72 -0
- package/esm2022/lib/_components/template/case-view/case-view.component.mjs +196 -0
- package/esm2022/lib/_components/template/confirmation/confirmation.component.mjs +68 -0
- package/esm2022/lib/_components/template/data-reference/data-reference.component.mjs +239 -0
- package/esm2022/lib/_components/template/default-form/default-form.component.mjs +61 -0
- package/esm2022/lib/_components/template/details/details.component.mjs +102 -0
- package/esm2022/lib/_components/template/details-narrow-wide/details-narrow-wide.component.mjs +72 -0
- package/esm2022/lib/_components/template/details-one-column/details-one-column.component.mjs +71 -0
- package/esm2022/lib/_components/template/details-sub-tabs/details-sub-tabs.component.mjs +66 -0
- package/esm2022/lib/_components/template/details-three-column/details-three-column.component.mjs +80 -0
- package/esm2022/lib/_components/template/details-two-column/details-two-column.component.mjs +77 -0
- package/esm2022/lib/_components/template/details-wide-narrow/details-wide-narrow.component.mjs +77 -0
- package/esm2022/lib/_components/template/dynamic-tabs/dynamic-tabs.component.mjs +65 -0
- package/esm2022/lib/_components/template/field-group-list/field-group-list.component.mjs +23 -0
- package/esm2022/lib/_components/template/field-group-template/field-group-template.component.mjs +134 -0
- package/esm2022/lib/_components/template/field-value-list/field-value-list.component.mjs +19 -0
- package/esm2022/lib/_components/template/inline-dashboard/inline-dashboard.component.mjs +22 -0
- package/esm2022/lib/_components/template/inline-dashboard-page/inline-dashboard-page.component.mjs +40 -0
- package/esm2022/lib/_components/template/list-page/list-page.component.mjs +14 -0
- package/esm2022/lib/_components/template/list-view/DefaultViewMeta.mjs +208 -0
- package/esm2022/lib/_components/template/list-view/list-view.component.mjs +1198 -0
- package/esm2022/lib/_components/template/list-view/listViewHelpers.mjs +61 -0
- package/esm2022/lib/_components/template/list-view/utils.mjs +660 -0
- package/esm2022/lib/_components/template/multi-reference-readonly/multi-reference-readonly.component.mjs +44 -0
- package/esm2022/lib/_components/template/narrow-wide-form/narrow-wide-form.component.mjs +30 -0
- package/esm2022/lib/_components/template/one-column/one-column.component.mjs +30 -0
- package/esm2022/lib/_components/template/one-column-page/one-column-page.component.mjs +16 -0
- package/esm2022/lib/_components/template/one-column-tab/one-column-tab.component.mjs +30 -0
- package/esm2022/lib/_components/template/page/page.component.mjs +52 -0
- package/esm2022/lib/_components/template/promoted-filters/promoted-filters.component.mjs +149 -0
- package/esm2022/lib/_components/template/repeating-structures/repeating-structures.component.mjs +139 -0
- package/esm2022/lib/_components/template/simple-table/simple-table.component.mjs +106 -0
- package/esm2022/lib/_components/template/simple-table-manual/helpers.mjs +270 -0
- package/esm2022/lib/_components/template/simple-table-manual/simple-table-manual.component.mjs +760 -0
- package/esm2022/lib/_components/template/simple-table-select/simple-table-select.component.mjs +131 -0
- package/esm2022/lib/_components/template/single-reference-readonly/single-reference-readonly.component.mjs +16 -0
- package/esm2022/lib/_components/template/sub-tabs/sub-tabs.component.mjs +67 -0
- package/esm2022/lib/_components/template/three-column/three-column.component.mjs +30 -0
- package/esm2022/lib/_components/template/three-column-page/three-column-page.component.mjs +16 -0
- package/esm2022/lib/_components/template/two-column/two-column.component.mjs +30 -0
- package/esm2022/lib/_components/template/two-column-page/two-column-page.component.mjs +40 -0
- package/esm2022/lib/_components/template/two-column-tab/two-column-tab.component.mjs +30 -0
- package/esm2022/lib/_components/template/utils.mjs +22 -0
- package/esm2022/lib/_components/template/wide-narrow-form/wide-narrow-form.component.mjs +30 -0
- package/esm2022/lib/_components/template/wide-narrow-page/wide-narrow-page.component.mjs +53 -0
- package/esm2022/lib/_components/template/wss-nav-bar/wss-nav-bar.component.mjs +135 -0
- package/esm2022/lib/_components/widget/app-announcement/app-announcement.component.mjs +24 -0
- package/esm2022/lib/_components/widget/attachment/attachment.component.mjs +588 -0
- package/esm2022/lib/_components/widget/case-history/case-history.component.mjs +81 -0
- package/esm2022/lib/_components/widget/feed-container/feed-container.component.mjs +525 -0
- package/esm2022/lib/_components/widget/file-utility/file-utility.component.mjs +631 -0
- package/esm2022/lib/_components/widget/list-utility/list-utility.component.mjs +57 -0
- package/esm2022/lib/_components/widget/quick-create/quick-create.component.mjs +75 -0
- package/esm2022/lib/_components/widget/todo/todo.component.mjs +213 -0
- package/esm2022/lib/_components/widget/utility/utility.component.mjs +34 -0
- package/esm2022/lib/_directives/thousand-seperator.directive.mjs +28 -0
- package/esm2022/lib/_helpers/case-utils.mjs +71 -0
- package/esm2022/lib/_helpers/common.mjs +20 -0
- package/esm2022/lib/_helpers/currency-utils.mjs +57 -0
- package/esm2022/lib/_helpers/date-format-utils.mjs +68 -0
- package/esm2022/lib/_helpers/event-util.mjs +19 -0
- package/esm2022/lib/_helpers/field-group-utils.mjs +47 -0
- package/esm2022/lib/_helpers/filter-utils.mjs +106 -0
- package/esm2022/lib/_helpers/formatters/currency-map.mjs +903 -0
- package/esm2022/lib/_helpers/formatters/format-utils.mjs +68 -0
- package/esm2022/lib/_helpers/tab-utils.mjs +59 -0
- package/esm2022/lib/_helpers/template-utils.mjs +56 -0
- package/esm2022/lib/_helpers/utils.mjs +386 -0
- package/esm2022/lib/_helpers/versionHelpers.mjs +12 -0
- package/esm2022/lib/_messages/error-messages.service.mjs +31 -0
- package/esm2022/lib/_messages/get-login-status.service.mjs +26 -0
- package/esm2022/lib/_messages/oauth-response.service.mjs +30 -0
- package/esm2022/lib/_messages/progress-spinner.service.mjs +30 -0
- package/esm2022/lib/_messages/reset-pconnect.service.mjs +31 -0
- package/esm2022/lib/_messages/update-worklist.service.mjs +30 -0
- package/esm2022/lib/_services/case.service.mjs +32 -0
- package/esm2022/lib/_services/datapage.service.mjs +52 -0
- package/esm2022/lib/_services/endpoints.mjs +61 -0
- package/esm2022/lib/_services/server-config.service.mjs +52 -0
- package/esm2022/lib/_types/PConnProps.interface.mjs +2 -0
- package/esm2022/pega-angular-sdk-components.mjs +5 -0
- package/esm2022/public-api.mjs +138 -0
- package/esm2022/sdk-local-component-map.mjs +9 -0
- package/fesm2022/pega-angular-sdk-components.mjs +17380 -0
- package/fesm2022/pega-angular-sdk-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/_bridge/angular-pconnect.d.ts +140 -0
- package/lib/_bridge/component-mapper/component-mapper.component.d.ts +20 -0
- package/lib/_bridge/helpers/sdk-pega-component-map.d.ts +213 -0
- package/lib/_bridge/helpers/sdk_component_map.d.ts +3 -0
- package/lib/_components/designSystemExtension/alert/alert.component.d.ts +12 -0
- package/lib/_components/designSystemExtension/alert-banner/alert-banner.component.d.ts +13 -0
- package/lib/_components/designSystemExtension/banner/banner.component.d.ts +15 -0
- package/lib/_components/designSystemExtension/case-create-stage/case-create-stage.component.d.ts +20 -0
- package/lib/_components/designSystemExtension/material-case-summary/material-case-summary.component.d.ts +18 -0
- package/lib/_components/designSystemExtension/material-details/material-details.component.d.ts +15 -0
- package/lib/_components/designSystemExtension/material-details-fields/material-details-fields.component.d.ts +12 -0
- package/lib/_components/designSystemExtension/material-summary-item/material-summary-item.component.d.ts +15 -0
- package/lib/_components/designSystemExtension/material-summary-list/material-summary-list.component.d.ts +9 -0
- package/lib/_components/designSystemExtension/material-utility/material-utility.component.d.ts +16 -0
- package/lib/_components/designSystemExtension/material-vertical-tabs/material-vertical-tabs.component.d.ts +11 -0
- package/lib/_components/designSystemExtension/operator/operator.component.d.ts +25 -0
- package/lib/_components/designSystemExtension/pulse/pulse.component.d.ts +16 -0
- package/lib/_components/designSystemExtension/rich-text-editor/rich-text-editor.component.d.ts +23 -0
- package/lib/_components/designSystemExtension/wss-quick-create/wss-quick-create.component.d.ts +7 -0
- package/lib/_components/field/auto-complete/auto-complete.component.d.ts +74 -0
- package/lib/_components/field/cancel-alert/cancel-alert.component.d.ts +24 -0
- package/lib/_components/field/check-box/check-box.component.d.ts +48 -0
- package/lib/_components/field/currency/currency.component.d.ts +50 -0
- package/lib/_components/field/date/date.component.d.ts +65 -0
- package/lib/_components/field/date-time/date-time.component.d.ts +55 -0
- package/lib/_components/field/decimal/decimal.component.d.ts +46 -0
- package/lib/_components/field/dropdown/dropdown.component.d.ts +60 -0
- package/lib/_components/field/email/email.component.d.ts +44 -0
- package/lib/_components/field/integer/integer.component.d.ts +44 -0
- package/lib/_components/field/list-view-action-buttons/list-view-action-buttons.component.d.ts +15 -0
- package/lib/_components/field/percentage/percentage.component.d.ts +44 -0
- package/lib/_components/field/phone/phone.component.d.ts +48 -0
- package/lib/_components/field/radio-buttons/radio-buttons.component.d.ts +60 -0
- package/lib/_components/field/rich-text/rich-text.component.d.ts +42 -0
- package/lib/_components/field/scalar-list/scalar-list.component.d.ts +37 -0
- package/lib/_components/field/semantic-link/semantic-link.component.d.ts +30 -0
- package/lib/_components/field/text/text.component.d.ts +40 -0
- package/lib/_components/field/text-area/text-area.component.d.ts +45 -0
- package/lib/_components/field/text-content/text-content.component.d.ts +30 -0
- package/lib/_components/field/text-input/text-input.component.d.ts +45 -0
- package/lib/_components/field/time/time.component.d.ts +43 -0
- package/lib/_components/field/url/url.component.d.ts +43 -0
- package/lib/_components/field/user-reference/user-reference.component.d.ts +39 -0
- package/lib/_components/infra/Containers/flow-container/flow-container.component.d.ts +85 -0
- package/lib/_components/infra/Containers/flow-container/helpers.d.ts +2 -0
- package/lib/_components/infra/Containers/hybrid-view-container/hybrid-view-container.component.d.ts +15 -0
- package/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.d.ts +71 -0
- package/lib/_components/infra/Containers/preview-view-container/preview-view-container.component.d.ts +15 -0
- package/lib/_components/infra/Containers/view-container/view-container.component.d.ts +51 -0
- package/lib/_components/infra/action-buttons/action-buttons.component.d.ts +12 -0
- package/lib/_components/infra/assignment/assignment.component.d.ts +72 -0
- package/lib/_components/infra/assignment-card/assignment-card.component.d.ts +18 -0
- package/lib/_components/infra/dashboard-filter/dashboard-filter.component.d.ts +20 -0
- package/lib/_components/infra/defer-load/defer-load.component.d.ts +46 -0
- package/lib/_components/infra/error-boundary/error-boundary.component.d.ts +8 -0
- package/lib/_components/infra/multi-step/multi-step.component.d.ts +31 -0
- package/lib/_components/infra/navbar/navbar.component.d.ts +51 -0
- package/lib/_components/infra/reference/reference.component.d.ts +16 -0
- package/lib/_components/infra/region/region.component.d.ts +14 -0
- package/lib/_components/infra/root-container/root-container.component.d.ts +35 -0
- package/lib/_components/infra/stages/stages.component.d.ts +29 -0
- package/lib/_components/infra/view/view.component.d.ts +40 -0
- package/lib/_components/template/app-shell/app-shell.component.d.ts +55 -0
- package/lib/_components/template/banner-page/banner-page.component.d.ts +27 -0
- package/lib/_components/template/case-summary/case-summary.component.d.ts +34 -0
- package/lib/_components/template/case-view/case-view.component.d.ts +56 -0
- package/lib/_components/template/confirmation/confirmation.component.d.ts +38 -0
- package/lib/_components/template/data-reference/data-reference.component.d.ts +41 -0
- package/lib/_components/template/default-form/default-form.component.d.ts +21 -0
- package/lib/_components/template/details/details.component.d.ts +20 -0
- package/lib/_components/template/details-narrow-wide/details-narrow-wide.component.d.ts +21 -0
- package/lib/_components/template/details-one-column/details-one-column.component.d.ts +22 -0
- package/lib/_components/template/details-sub-tabs/details-sub-tabs.component.d.ts +24 -0
- package/lib/_components/template/details-three-column/details-three-column.component.d.ts +25 -0
- package/lib/_components/template/details-two-column/details-two-column.component.d.ts +25 -0
- package/lib/_components/template/details-wide-narrow/details-wide-narrow.component.d.ts +24 -0
- package/lib/_components/template/dynamic-tabs/dynamic-tabs.component.d.ts +20 -0
- package/lib/_components/template/field-group-list/field-group-list.component.d.ts +9 -0
- package/lib/_components/template/field-group-template/field-group-template.component.d.ts +52 -0
- package/lib/_components/template/field-value-list/field-value-list.component.d.ts +8 -0
- package/lib/_components/template/inline-dashboard/inline-dashboard.component.d.ts +16 -0
- package/lib/_components/template/inline-dashboard-page/inline-dashboard-page.component.d.ts +25 -0
- package/lib/_components/template/list-page/list-page.component.d.ts +7 -0
- package/lib/_components/template/list-view/DefaultViewMeta.d.ts +1 -0
- package/lib/_components/template/list-view/list-view.component.d.ts +157 -0
- package/lib/_components/template/list-view/listViewHelpers.d.ts +1 -0
- package/lib/_components/template/list-view/utils.d.ts +118 -0
- package/lib/_components/template/multi-reference-readonly/multi-reference-readonly.component.d.ts +25 -0
- package/lib/_components/template/narrow-wide-form/narrow-wide-form.component.d.ts +14 -0
- package/lib/_components/template/one-column/one-column.component.d.ts +14 -0
- package/lib/_components/template/one-column-page/one-column-page.component.d.ts +9 -0
- package/lib/_components/template/one-column-tab/one-column-tab.component.d.ts +14 -0
- package/lib/_components/template/page/page.component.d.ts +25 -0
- package/lib/_components/template/promoted-filters/promoted-filters.component.d.ts +35 -0
- package/lib/_components/template/repeating-structures/repeating-structures.component.d.ts +37 -0
- package/lib/_components/template/simple-table/simple-table.component.d.ts +43 -0
- package/lib/_components/template/simple-table-manual/helpers.d.ts +81 -0
- package/lib/_components/template/simple-table-manual/simple-table-manual.component.d.ts +159 -0
- package/lib/_components/template/simple-table-select/simple-table-select.component.d.ts +32 -0
- package/lib/_components/template/single-reference-readonly/single-reference-readonly.component.d.ts +9 -0
- package/lib/_components/template/sub-tabs/sub-tabs.component.d.ts +26 -0
- package/lib/_components/template/three-column/three-column.component.d.ts +14 -0
- package/lib/_components/template/three-column-page/three-column-page.component.d.ts +9 -0
- package/lib/_components/template/two-column/two-column.component.d.ts +14 -0
- package/lib/_components/template/two-column-page/two-column-page.component.d.ts +17 -0
- package/lib/_components/template/two-column-tab/two-column-tab.component.d.ts +14 -0
- package/lib/_components/template/utils.d.ts +2 -0
- package/lib/_components/template/wide-narrow-form/wide-narrow-form.component.d.ts +14 -0
- package/lib/_components/template/wide-narrow-page/wide-narrow-page.component.d.ts +20 -0
- package/lib/_components/template/wss-nav-bar/wss-nav-bar.component.d.ts +50 -0
- package/lib/_components/widget/app-announcement/app-announcement.component.d.ts +19 -0
- package/lib/_components/widget/attachment/attachment.component.d.ts +99 -0
- package/lib/_components/widget/case-history/case-history.component.d.ts +24 -0
- package/lib/_components/widget/feed-container/feed-container.component.d.ts +49 -0
- package/lib/_components/widget/file-utility/file-utility.component.d.ts +150 -0
- package/lib/_components/widget/list-utility/list-utility.component.d.ts +23 -0
- package/lib/_components/widget/quick-create/quick-create.component.d.ts +29 -0
- package/lib/_components/widget/todo/todo.component.d.ts +64 -0
- package/lib/_components/widget/utility/utility.component.d.ts +25 -0
- package/lib/_directives/thousand-seperator.directive.d.ts +9 -0
- package/lib/_helpers/case-utils.d.ts +19 -0
- package/lib/_helpers/common.d.ts +3 -0
- package/lib/_helpers/currency-utils.d.ts +10 -0
- package/lib/_helpers/date-format-utils.d.ts +12 -0
- package/lib/_helpers/event-util.d.ts +2 -0
- package/lib/_helpers/field-group-utils.d.ts +16 -0
- package/lib/_helpers/filter-utils.d.ts +46 -0
- package/lib/_helpers/formatters/currency-map.d.ts +1132 -0
- package/lib/_helpers/formatters/format-utils.d.ts +8 -0
- package/lib/_helpers/tab-utils.d.ts +4 -0
- package/lib/_helpers/template-utils.d.ts +16 -0
- package/lib/_helpers/utils.d.ts +32 -0
- package/lib/_helpers/versionHelpers.d.ts +8 -0
- package/lib/_messages/error-messages.service.d.ts +15 -0
- package/lib/_messages/get-login-status.service.d.ts +10 -0
- package/lib/_messages/oauth-response.service.d.ts +14 -0
- package/lib/_messages/progress-spinner.service.d.ts +14 -0
- package/lib/_messages/reset-pconnect.service.d.ts +15 -0
- package/lib/_messages/update-worklist.service.d.ts +14 -0
- package/lib/_services/case.service.d.ts +12 -0
- package/lib/_services/datapage.service.d.ts +14 -0
- package/lib/_services/endpoints.d.ts +39 -0
- package/lib/_services/server-config.service.d.ts +31 -0
- package/lib/_types/PConnProps.interface.d.ts +17 -0
- package/package.json +28 -0
- package/public-api.d.ts +133 -0
- package/sdk-local-component-map.d.ts +2 -0
- package/sdk-local-component-map.ts +12 -0
|
@@ -0,0 +1,525 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
2
|
+
import { Component, Input } from '@angular/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
5
|
+
import { MatGridListModule } from '@angular/material/grid-list';
|
|
6
|
+
import { MatInputModule } from '@angular/material/input';
|
|
7
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
8
|
+
import isEqual from 'fast-deep-equal';
|
|
9
|
+
import { Utils } from '../../../_helpers/utils';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../../_bridge/angular-pconnect";
|
|
12
|
+
import * as i2 from "../../../_helpers/utils";
|
|
13
|
+
import * as i3 from "@angular/common";
|
|
14
|
+
import * as i4 from "@angular/material/form-field";
|
|
15
|
+
import * as i5 from "@angular/material/input";
|
|
16
|
+
import * as i6 from "@angular/material/grid-list";
|
|
17
|
+
import * as i7 from "@angular/material/button";
|
|
18
|
+
export class FeedContainerComponent {
|
|
19
|
+
constructor(angularPConnect, cdRef, utils) {
|
|
20
|
+
this.angularPConnect = angularPConnect;
|
|
21
|
+
this.cdRef = cdRef;
|
|
22
|
+
this.utils = utils;
|
|
23
|
+
// Used with AngularPConnect
|
|
24
|
+
this.angularPConnectData = {};
|
|
25
|
+
this.showReplyComment$ = {};
|
|
26
|
+
this.userData = new Map();
|
|
27
|
+
this.pulseComment = {};
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
this.userName$ = PCore.getEnvironmentInfo().getOperatorName();
|
|
31
|
+
this.imageKey$ = PCore.getEnvironmentInfo().getOperatorImageInsKey();
|
|
32
|
+
this.updateCurrentUserName(this.userName$);
|
|
33
|
+
// First thing in initialization is registering and subscribing to the AngularPConnect service
|
|
34
|
+
this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
|
|
35
|
+
// Then, continue on with other initialization
|
|
36
|
+
// debugger;
|
|
37
|
+
// const {
|
|
38
|
+
// fetchMessages,
|
|
39
|
+
// likeMessage,
|
|
40
|
+
// postMessage
|
|
41
|
+
// } = FeedApi(this.pConn$);
|
|
42
|
+
// this.fetchMessages = fetchMessages;
|
|
43
|
+
// this.likeMessage = likeMessage;
|
|
44
|
+
// this.postMessage = postMessage;
|
|
45
|
+
// // this.userName$ = this.pConn$.getValue("pxRequestor.pxUserName");
|
|
46
|
+
// // this.imageKey$ = this.pConn$.getValue("OperatorID.pyImageInsKey");
|
|
47
|
+
// //this.userName$ = this.pConn$.getDataObject()["D_pxEnvironmentInfo"].pxOperator.pyUserName;
|
|
48
|
+
// //this.imageKey$ = this.pConn$.getDataObject()["D_pxEnvironmentInfo"].pxOperator.pyImageInsKey;
|
|
49
|
+
// this.userName$ = this.pConn$.getEnvironmentInfo().getOperatorName();
|
|
50
|
+
// this.imageKey$ = this.pConn$.getEnvironmentInfo().getOperatorImageInsKey();
|
|
51
|
+
// this.actionsAPI = this.pConn$.getActionsApi();
|
|
52
|
+
// let owner = this.pConn$.getConfigProps().value;
|
|
53
|
+
// // with new FeedAPI: owner is the proper value to pass in
|
|
54
|
+
// // and no longer takes 2nd argument
|
|
55
|
+
// this./*feedAPI.*/fetchMessages(owner /*, this.pConn$.getContextName()*/);
|
|
56
|
+
// const configProps: any = this.pConn$.getConfigProps();
|
|
57
|
+
// const { messageIDs } = configProps;
|
|
58
|
+
// const { fetchMessages, postMessage, getMentionSuggestions, getTagSuggestions } = FeedApi(this.pConn$);
|
|
59
|
+
const appName = PCore.getEnvironmentInfo().getApplicationName();
|
|
60
|
+
let value = '';
|
|
61
|
+
let feedID = '';
|
|
62
|
+
let feedClass = '';
|
|
63
|
+
if (this.pConn$.getCaseSummary().ID) {
|
|
64
|
+
value = this.pConn$.getCaseSummary().ID;
|
|
65
|
+
feedID = 'pyCaseFeed';
|
|
66
|
+
feedClass = this.pConn$.getCaseSummary().content.classID;
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
value = `DATA-PORTAL $${appName}`;
|
|
70
|
+
feedID = 'pyDashboardFeed';
|
|
71
|
+
feedClass = '@baseclass';
|
|
72
|
+
}
|
|
73
|
+
const onUploadProgress = () => { };
|
|
74
|
+
const errorHandler = () => { };
|
|
75
|
+
const attachments = () => { };
|
|
76
|
+
const postComment = ({ value: message, clear }) => {
|
|
77
|
+
const attachmentIDs = [];
|
|
78
|
+
const attachmentUtils = PCore.getAttachmentUtils();
|
|
79
|
+
if (attachments && !!attachments.length) {
|
|
80
|
+
/* attachments;
|
|
81
|
+
.filter((file) => !file.error)
|
|
82
|
+
.map((file) => {
|
|
83
|
+
return attachmentUtils
|
|
84
|
+
.uploadAttachment(file, onUploadProgress, errorHandler)
|
|
85
|
+
.then((fileResponse) => {
|
|
86
|
+
const fileConfig = {
|
|
87
|
+
type: "File",
|
|
88
|
+
category: "File",
|
|
89
|
+
fileName: file.name,
|
|
90
|
+
ID: fileResponse.data.ID
|
|
91
|
+
};
|
|
92
|
+
attachmentIDs.push(fileConfig);
|
|
93
|
+
if (attachments.length === attachmentIDs.length) {
|
|
94
|
+
postMessage(
|
|
95
|
+
value,
|
|
96
|
+
transformMarkdownToMsg(message),
|
|
97
|
+
attachmentIDs
|
|
98
|
+
);
|
|
99
|
+
clear();
|
|
100
|
+
setAttachments([]);
|
|
101
|
+
}
|
|
102
|
+
})
|
|
103
|
+
|
|
104
|
+
.catch(console.error);
|
|
105
|
+
}); */
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
// postMessage(value, transformMarkdownToMsg(message));
|
|
109
|
+
clear();
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
/*
|
|
113
|
+
|
|
114
|
+
const { getPConnect, messageIDs } = props;
|
|
115
|
+
const [mentionResults, setMentionResults] = useState([]);
|
|
116
|
+
const [tagResults, setTagResults] = useState([]);
|
|
117
|
+
const [attachments, setAttachments] = useState([]);
|
|
118
|
+
const [feedFilters, setFeedFilters] = useState();
|
|
119
|
+
const {
|
|
120
|
+
fetchMessages,
|
|
121
|
+
postMessage,
|
|
122
|
+
getMentionSuggestions,
|
|
123
|
+
getTagSuggestions
|
|
124
|
+
} = FeedApi(getPConnect());
|
|
125
|
+
const appName = PCore.getEnvironmentInfo().getApplicationName();
|
|
126
|
+
let value = "";
|
|
127
|
+
let feedID = "";
|
|
128
|
+
let feedClass = "";
|
|
129
|
+
if (getPConnect().getCaseSummary().ID) {
|
|
130
|
+
value = getPConnect().getCaseSummary().ID;
|
|
131
|
+
feedID = "pyCaseFeed";
|
|
132
|
+
feedClass = getPConnect().getCaseSummary().content.classID;
|
|
133
|
+
} else {
|
|
134
|
+
value = `DATA-PORTAL $${appName}`;
|
|
135
|
+
feedID = "pyDashboardFeed";
|
|
136
|
+
feedClass = "@baseclass";
|
|
137
|
+
}
|
|
138
|
+
// For cancelling fetchrequest for filetrs
|
|
139
|
+
const fetchMessagesCancelTokenSource = useRef([]);
|
|
140
|
+
|
|
141
|
+
useEffect(() => {
|
|
142
|
+
fetchMessages(
|
|
143
|
+
value,
|
|
144
|
+
feedID,
|
|
145
|
+
feedClass,
|
|
146
|
+
null,
|
|
147
|
+
fetchMessagesCancelTokenSource.current
|
|
148
|
+
).then((res) => {
|
|
149
|
+
setFeedFilters(res);
|
|
150
|
+
});
|
|
151
|
+
PCore.getAssetLoader().getLoader("component-loader")(["Activity"]);
|
|
152
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
153
|
+
}, []);
|
|
154
|
+
|
|
155
|
+
const onUploadProgress = useCallback((file) => {
|
|
156
|
+
return ({ loaded, total }) => {
|
|
157
|
+
file.progress = Math.floor((loaded / total) * 100);
|
|
158
|
+
setAttachments((current) => {
|
|
159
|
+
return current.map((currFile) => {
|
|
160
|
+
return currFile.name === file.name ? file : currFile;
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
};
|
|
164
|
+
}, []);
|
|
165
|
+
|
|
166
|
+
const errorHandler = useCallback((isFetchCanceled, file) => {
|
|
167
|
+
return (error) => {
|
|
168
|
+
if (!isFetchCanceled(error)) {
|
|
169
|
+
let localizedValue = "Upload failed";
|
|
170
|
+
if (
|
|
171
|
+
error.response &&
|
|
172
|
+
error.response.data &&
|
|
173
|
+
error.response.data.errorDetails
|
|
174
|
+
) {
|
|
175
|
+
localizedValue = error.response.data.errorDetails[0].localizedValue;
|
|
176
|
+
}
|
|
177
|
+
delete file.progress;
|
|
178
|
+
setAttachments((current) => {
|
|
179
|
+
return current.map((currFile) => {
|
|
180
|
+
if (currFile.name === file.name) {
|
|
181
|
+
currFile.meta = localizedValue;
|
|
182
|
+
currFile.error = true;
|
|
183
|
+
}
|
|
184
|
+
return currFile;
|
|
185
|
+
});
|
|
186
|
+
});
|
|
187
|
+
error.isHandled = true;
|
|
188
|
+
}
|
|
189
|
+
throw error;
|
|
190
|
+
};
|
|
191
|
+
}, []);
|
|
192
|
+
|
|
193
|
+
const postComment = ({ value: message, clear }) => {
|
|
194
|
+
const attachmentIDs = [];
|
|
195
|
+
const attachmentUtils = PCore.getAttachmentUtils();
|
|
196
|
+
if (attachments && !!attachments.length) {
|
|
197
|
+
attachments
|
|
198
|
+
.filter((file) => !file.error)
|
|
199
|
+
.map((file) => {
|
|
200
|
+
return attachmentUtils
|
|
201
|
+
.uploadAttachment(file, onUploadProgress, errorHandler)
|
|
202
|
+
.then((fileResponse) => {
|
|
203
|
+
const fileConfig = {
|
|
204
|
+
type: "File",
|
|
205
|
+
category: "File",
|
|
206
|
+
fileName: file.name,
|
|
207
|
+
ID: fileResponse.data.ID
|
|
208
|
+
};
|
|
209
|
+
attachmentIDs.push(fileConfig);
|
|
210
|
+
if (attachments.length === attachmentIDs.length) {
|
|
211
|
+
postMessage(
|
|
212
|
+
value,
|
|
213
|
+
transformMarkdownToMsg(message),
|
|
214
|
+
attachmentIDs
|
|
215
|
+
);
|
|
216
|
+
clear();
|
|
217
|
+
setAttachments([]);
|
|
218
|
+
}
|
|
219
|
+
})
|
|
220
|
+
|
|
221
|
+
.catch(console.error);
|
|
222
|
+
});
|
|
223
|
+
} else {
|
|
224
|
+
postMessage(value, transformMarkdownToMsg(message));
|
|
225
|
+
clear();
|
|
226
|
+
}
|
|
227
|
+
};
|
|
228
|
+
|
|
229
|
+
*/
|
|
230
|
+
/* On search is called when @ character is entered and will display the mention */
|
|
231
|
+
/*
|
|
232
|
+
const onSearch = debounce((event) => {
|
|
233
|
+
if (event.type === "mention") {
|
|
234
|
+
getMentionSuggestions({
|
|
235
|
+
pulseContext: value,
|
|
236
|
+
searchFor: event.search
|
|
237
|
+
}).then((res) => {
|
|
238
|
+
setMentionResults(res);
|
|
239
|
+
});
|
|
240
|
+
} else {
|
|
241
|
+
getTagSuggestions({
|
|
242
|
+
searchFor: event.search
|
|
243
|
+
}).then((res) => {
|
|
244
|
+
setTagResults(res);
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
}, 150);
|
|
248
|
+
|
|
249
|
+
const userName = getPConnect().getEnvironmentInfo().getOperatorName();
|
|
250
|
+
const imageKey = getPConnect().getEnvironmentInfo().getOperatorImageInsKey();
|
|
251
|
+
|
|
252
|
+
const onFilesAdded = useCallback((newlyAddedFiles) => {
|
|
253
|
+
setAttachments((current) => [
|
|
254
|
+
...newlyAddedFiles.map((file) => {
|
|
255
|
+
if (!validateMaxSize(file, 5)) {
|
|
256
|
+
file.error = true;
|
|
257
|
+
file.meta = "File is too big. Max allowed size is 5MB.";
|
|
258
|
+
}
|
|
259
|
+
file.icon = getIconFromFileType(file.type);
|
|
260
|
+
file.onDelete = () => {
|
|
261
|
+
setAttachments((c) => c.filter((f) => f.name !== file.name));
|
|
262
|
+
};
|
|
263
|
+
return file;
|
|
264
|
+
}),
|
|
265
|
+
...current
|
|
266
|
+
]);
|
|
267
|
+
}, []);
|
|
268
|
+
|
|
269
|
+
const onFilterChange = useCallback(
|
|
270
|
+
(filterID) => {
|
|
271
|
+
const updatedFilters = [...feedFilters];
|
|
272
|
+
const filterToUpdate = updatedFilters.find(
|
|
273
|
+
(feedItem) => feedItem.id === filterID
|
|
274
|
+
);
|
|
275
|
+
filterToUpdate.on = !filterToUpdate.on;
|
|
276
|
+
if (filterID === "All")
|
|
277
|
+
updatedFilters.forEach((feedFilter) => {
|
|
278
|
+
feedFilter.on = filterToUpdate.on;
|
|
279
|
+
});
|
|
280
|
+
else if (
|
|
281
|
+
updatedFilters.find(
|
|
282
|
+
(feedItem) => feedItem.on === false && feedItem.id !== "All"
|
|
283
|
+
)
|
|
284
|
+
)
|
|
285
|
+
updatedFilters.find((feedItem) => feedItem.id === "All").on = false;
|
|
286
|
+
else updatedFilters.find((feedItem) => feedItem.id === "All").on = true;
|
|
287
|
+
setFeedFilters(updatedFilters);
|
|
288
|
+
fetchMessages(
|
|
289
|
+
value,
|
|
290
|
+
feedID,
|
|
291
|
+
feedClass,
|
|
292
|
+
feedFilters,
|
|
293
|
+
fetchMessagesCancelTokenSource.current
|
|
294
|
+
);
|
|
295
|
+
},
|
|
296
|
+
[
|
|
297
|
+
value,
|
|
298
|
+
feedID,
|
|
299
|
+
feedClass,
|
|
300
|
+
feedFilters,
|
|
301
|
+
fetchMessagesCancelTokenSource,
|
|
302
|
+
fetchMessages
|
|
303
|
+
]
|
|
304
|
+
);
|
|
305
|
+
|
|
306
|
+
*/
|
|
307
|
+
// set up svg images
|
|
308
|
+
this.svgComment$ = this.utils.getImageSrc('chat', this.utils.getSDKStaticContentUrl());
|
|
309
|
+
this.svgLike$ = this.utils.getImageSrc('thumbs-up', this.utils.getSDKStaticContentUrl());
|
|
310
|
+
this.svgLikedByMe$ = this.utils.getImageSrc('thumbs-up-solid', this.utils.getSDKStaticContentUrl());
|
|
311
|
+
this.svgSend$ = this.utils.getImageSrc('send', this.utils.getSDKStaticContentUrl());
|
|
312
|
+
}
|
|
313
|
+
ngOnDestroy() {
|
|
314
|
+
if (this.angularPConnectData.unsubscribeFn) {
|
|
315
|
+
this.angularPConnectData.unsubscribeFn();
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
// Callback passed when subscribing to store change
|
|
319
|
+
onStateChange() {
|
|
320
|
+
const bLogging = false;
|
|
321
|
+
if (bLogging) {
|
|
322
|
+
// console.log( `in ${this.constructor.name} onStateChange` );
|
|
323
|
+
// debugger;
|
|
324
|
+
}
|
|
325
|
+
// Should always check the bridge to see if the component should update itself (re-render)
|
|
326
|
+
const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);
|
|
327
|
+
// console.log( `${this.constructor.name} shouldComponentUpdate: ${bUpdateSelf}`);
|
|
328
|
+
// ONLY call updateSelf when the component should update
|
|
329
|
+
// AND removing the "gate" that was put there since shouldComponentUpdate
|
|
330
|
+
// should be the real "gate"
|
|
331
|
+
if (bUpdateSelf) {
|
|
332
|
+
this.updateSelf();
|
|
333
|
+
}
|
|
334
|
+
else {
|
|
335
|
+
// @ts-ignore - parameter “contextName” for getDataObject method should be optional
|
|
336
|
+
const newPulseData = this.pConn$.getDataObject().pulse;
|
|
337
|
+
if (!isEqual(newPulseData, this.pulseData)) {
|
|
338
|
+
this.updateSelf();
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
// @ts-ignore - parameter “contextName” for getDataObject method should be optional
|
|
342
|
+
this.pulseData = this.pConn$.getDataObject().pulse;
|
|
343
|
+
}
|
|
344
|
+
updateSelf() {
|
|
345
|
+
this.getMessageData();
|
|
346
|
+
}
|
|
347
|
+
getMessageData() {
|
|
348
|
+
const messageIDs = this.pConn$.getConfigProps().messageIDs;
|
|
349
|
+
const userName = this.pConn$.getConfigProps().currentUser;
|
|
350
|
+
// @ts-ignore - second parameter pageReference for getValue method should be optional
|
|
351
|
+
const imageKey = this.pConn$.getValue('OperatorID.pyImageInsKey');
|
|
352
|
+
// @ts-ignore - parameter “contextName” for getDataObject method should be optional
|
|
353
|
+
const oData = this.pConn$.getDataObject();
|
|
354
|
+
if (messageIDs && messageIDs.length > 0) {
|
|
355
|
+
this.pulseMessages$ = JSON.parse(JSON.stringify(oData.pulse.messages));
|
|
356
|
+
// convert to just an array of objects
|
|
357
|
+
this.pulseMessages$ = this.convertToArray(this.pulseMessages$);
|
|
358
|
+
// create a copy, so we can modify
|
|
359
|
+
this.pulseMessages$ = this.appendPulseMessage(this.pulseMessages$);
|
|
360
|
+
// most recent on top
|
|
361
|
+
this.pulseMessages$ = this.pulseMessages$.sort((a, b) => (a.updateTimeUTC < b.updateTimeUTC ? 1 : -1));
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
convertToArray(messages) {
|
|
365
|
+
const arMessages = [];
|
|
366
|
+
for (let i = 0; i < messages.length; i++) {
|
|
367
|
+
arMessages.push(messages[i]);
|
|
368
|
+
}
|
|
369
|
+
return arMessages;
|
|
370
|
+
}
|
|
371
|
+
appendPulseMessage(messages) {
|
|
372
|
+
for (let i = 0; i < messages.length; i++) {
|
|
373
|
+
const message = messages[i];
|
|
374
|
+
const postedTime = message.postedTime;
|
|
375
|
+
const updatedTime = message.updatedTime;
|
|
376
|
+
this.showReplyComment$[message.ID] = false;
|
|
377
|
+
message.displayPostedTime = this.utils.generateDateTime(postedTime, 'DateTime-Since');
|
|
378
|
+
// for sorting lasted update
|
|
379
|
+
if (updatedTime != null) {
|
|
380
|
+
message.updateTimeUTC = new Date(updatedTime).getTime();
|
|
381
|
+
}
|
|
382
|
+
else {
|
|
383
|
+
message.updateTimeUTC = new Date(postedTime).getTime();
|
|
384
|
+
}
|
|
385
|
+
message.displayPostedBy = message.postedByUser.name;
|
|
386
|
+
message.displayPostedByInitials = this.utils.getInitials(message.postedByUser.name);
|
|
387
|
+
// if didn't break, then look at the replies
|
|
388
|
+
for (let j = 0; j < message.replies.length; j++) {
|
|
389
|
+
const reply = message.replies[j];
|
|
390
|
+
const replyPostedTime = reply.postedTime;
|
|
391
|
+
reply.displayPostedTime = this.utils.generateDateTime(replyPostedTime, 'DateTime-Since');
|
|
392
|
+
// let oReplyUser = this.userData.get(reply.postedByUser);
|
|
393
|
+
const oReplyUser = reply.postedByUser;
|
|
394
|
+
if (oReplyUser) {
|
|
395
|
+
reply.displayPostedBy = oReplyUser.name;
|
|
396
|
+
reply.displayPostedByInitials = this.utils.getInitials(oReplyUser.name);
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
} // for
|
|
400
|
+
return messages;
|
|
401
|
+
}
|
|
402
|
+
updateMessagesWithOperators() {
|
|
403
|
+
for (let i = 0; i < this.pulseMessages$.length; i++) {
|
|
404
|
+
const message = this.pulseMessages$[i];
|
|
405
|
+
const postedTime = message.postedTime;
|
|
406
|
+
this.showReplyComment$[message.ID] = false;
|
|
407
|
+
message.displayPostedTime = this.utils.generateDateTime(postedTime, 'DateTime-Since');
|
|
408
|
+
const oUser = this.userData.get(message.postedBy);
|
|
409
|
+
if (oUser) {
|
|
410
|
+
message.displayPostedBy = oUser.pyUserName;
|
|
411
|
+
message.displayPostedByInitials = this.utils.getInitials(oUser.pyUserName);
|
|
412
|
+
}
|
|
413
|
+
else {
|
|
414
|
+
const oUserParams = {
|
|
415
|
+
OperatorId: message.postedBy
|
|
416
|
+
};
|
|
417
|
+
// Do something with oUserParams
|
|
418
|
+
}
|
|
419
|
+
// if didn't break, then look at the replies
|
|
420
|
+
for (let j = 0; j < message.replies.length; j++) {
|
|
421
|
+
const reply = message.replies[j];
|
|
422
|
+
const replyPostedTime = reply.postedTime;
|
|
423
|
+
reply.displayPostedTime = this.utils.generateDateTime(replyPostedTime, 'DateTime-Since');
|
|
424
|
+
// let oReplyUser = this.userData.get(reply.postedByUser);
|
|
425
|
+
const oReplyUser = reply.postedByUser;
|
|
426
|
+
if (oReplyUser) {
|
|
427
|
+
reply.displayPostedBy = oReplyUser.name;
|
|
428
|
+
reply.displayPostedByInitials = this.utils.getInitials(oReplyUser.name);
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
} // for
|
|
432
|
+
}
|
|
433
|
+
updateCurrentUserName(sUser) {
|
|
434
|
+
this.currentUserInitials$ = this.utils.getInitials(sUser);
|
|
435
|
+
this.currentUserName$ = sUser;
|
|
436
|
+
}
|
|
437
|
+
postClick() {
|
|
438
|
+
// don't send a blank message
|
|
439
|
+
if (this.pulseConversation && this.pulseConversation != '') {
|
|
440
|
+
// let pulseMessage = {
|
|
441
|
+
// contextName : this.pConn$.getContextName(),
|
|
442
|
+
// message: this.pulseConversation,
|
|
443
|
+
// pulseContext: this.pConn$.getValue(".pzInsKey")
|
|
444
|
+
// };
|
|
445
|
+
// debugger;
|
|
446
|
+
// used to be: this./*feedAPI.*/postMessage(pulseMessage);
|
|
447
|
+
// With latest FeedAPI, the 1st arg should be getConfigProps().value
|
|
448
|
+
// If feedAPI is defined then only post message
|
|
449
|
+
if (this.feedAPI) {
|
|
450
|
+
this. /* feedAPI. */postMessage(this.pConn$.getConfigProps().value, this.pulseConversation);
|
|
451
|
+
}
|
|
452
|
+
else {
|
|
453
|
+
console.log("We don't support Pulse yet");
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
// clear out local copy
|
|
457
|
+
document.getElementById('pulseMessage').value = '';
|
|
458
|
+
this.pulseConversation = '';
|
|
459
|
+
}
|
|
460
|
+
messageChange(event) {
|
|
461
|
+
this.pulseConversation = event.target.value;
|
|
462
|
+
}
|
|
463
|
+
likeClick(messageID, rMessageID, bLikedByMe, level) {
|
|
464
|
+
let pulseMessage = {};
|
|
465
|
+
if (level === 'top') {
|
|
466
|
+
pulseMessage = {
|
|
467
|
+
pulseContext: rMessageID,
|
|
468
|
+
isReply: null,
|
|
469
|
+
contextName: this.pConn$.getContextName(),
|
|
470
|
+
likedBy: bLikedByMe,
|
|
471
|
+
messageID
|
|
472
|
+
};
|
|
473
|
+
}
|
|
474
|
+
else {
|
|
475
|
+
pulseMessage = {
|
|
476
|
+
pulseContext: rMessageID,
|
|
477
|
+
isReply: true,
|
|
478
|
+
contextName: this.pConn$.getContextName(),
|
|
479
|
+
likedBy: bLikedByMe,
|
|
480
|
+
messageID
|
|
481
|
+
};
|
|
482
|
+
}
|
|
483
|
+
// debugger;
|
|
484
|
+
this. /* feedAPI. */likeMessage(pulseMessage);
|
|
485
|
+
}
|
|
486
|
+
commentClick(messageID) {
|
|
487
|
+
// iterator through messages, find match, turn on comment entry
|
|
488
|
+
const foundMessage = this.pulseMessages$.find(message => message.ID === messageID);
|
|
489
|
+
if (foundMessage) {
|
|
490
|
+
this.showReplyComment$[foundMessage.ID] = true;
|
|
491
|
+
}
|
|
492
|
+
this.cdRef.detectChanges();
|
|
493
|
+
}
|
|
494
|
+
postCommentClick(messageID) {
|
|
495
|
+
// debugger;
|
|
496
|
+
if (this.pulseComment[messageID] && this.pulseComment[messageID] != '') {
|
|
497
|
+
// let pulseMessage = {
|
|
498
|
+
// contextName : this.pConn$.getContextName(),
|
|
499
|
+
// message: this.pulseComment[messageID],
|
|
500
|
+
// pulseContext: messageID,
|
|
501
|
+
// reply: true
|
|
502
|
+
// };
|
|
503
|
+
// debugger;
|
|
504
|
+
// Used to be: this./*feedAPI.*/postMessage(pulseMessage);
|
|
505
|
+
// Latest update to API has changed and the postMessage actually gets
|
|
506
|
+
// the pulse context...
|
|
507
|
+
// used to use: contextName
|
|
508
|
+
// new FeedAPI wants args to be messageID, this.pulseComment[messageID], true (since this is a reply)
|
|
509
|
+
this. /* feedAPI. */postMessage(messageID, this.pulseComment[messageID], true);
|
|
510
|
+
this.pulseComment[messageID] = '';
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
newCommentChange(event, messageID) {
|
|
514
|
+
this.pulseComment[messageID] = event.target.value;
|
|
515
|
+
}
|
|
516
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FeedContainerComponent, deps: [{ token: i1.AngularPConnectService }, { token: i0.ChangeDetectorRef }, { token: i2.Utils }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
517
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FeedContainerComponent, isStandalone: true, selector: "app-feed-container", inputs: { pConn$: "pConn$" }, providers: [Utils], ngImport: i0, template: "<div>\n <div style=\"text-align: left\">\n <h3>Pulse</h3>\n\n <div class=\"psdk-pulse-divider\"></div>\n\n <br />\n <div class=\"psdk-pulse\">\n <div class=\"psdk-avatar-big\">{{ this.currentUserInitials$ }}</div>\n <mat-form-field class=\"psdk-full-width\">\n <textarea matInput rows=\"5\" id=\"pulseMessage\" placeholder=\"Start a conversation\" type=\"text\" (change)=\"messageChange($event)\"></textarea>\n </mat-form-field>\n </div>\n </div>\n</div>\n\n<mat-grid-list cols=\"2\" rowHeight=\"6.25rem\">\n <mat-grid-tile> </mat-grid-tile>\n <mat-grid-tile>\n <button mat-raised-button color=\"primary\" (click)=\"postClick()\">Post</button>\n </mat-grid-tile>\n</mat-grid-list>\n\n<div *ngFor=\"let pulseMessage of pulseMessages$; let odd = odd\" style=\"text-align: left\" [style.background-color]=\"odd ? 'white' : '#eeeeee'\">\n <div class=\"psdk-pulse-divider\"></div>\n <br />\n <div class=\"psdk-pulse\">\n <div class=\"psdk-avatar-big\">{{ pulseMessage.displayPostedByInitials }}</div>\n <div class=\"psdk-pulse-message-group\">\n <div class=\"psdk-pulse-message-by\">{{ pulseMessage.displayPostedBy }}</div>\n <div class=\"psdk-pulse-message-time\">{{ pulseMessage.displayPostedTime }}</div>\n </div>\n </div>\n <div class=\"psdk-pulse-message-text\">{{ pulseMessage.message }}</div>\n <div class=\"psdk-pulse-message-actions\">\n <div class=\"psdk-pulse-message-action-group\">\n <button mat-button (click)=\"commentClick(pulseMessage.ID)\">\n <img class=\"psdk-comment-svg-icon\" src=\"{{ svgComment$ }}\" />\n <label class=\"psdk-pulse-message-like-label\"\n >Comment <span *ngIf=\"pulseMessage?.replies.length > 0\"> | {{ pulseMessage.replies.length }}</span></label\n >\n </button>\n </div>\n <div class=\"psdk-pulse-message-action-like\">\n <div *ngIf=\"pulseMessage?.likeCount; else notLiked\">\n <button *ngIf=\"pulseMessage?.likedByMe == 'true'\" mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, true, 'top')\">\n <!-- <mat-icon class=\"psdk-icon-liked-by-me\" svgIcon=\"thumb-up\" mastListIcon ></mat-icon> -->\n <img class=\"psdk-liked-by-me-svg-icon\" src=\"{{ svgLikedByMe$ }}\" />\n <label class=\"psdk-pulse-message-like-label\">Like | {{ pulseMessage.likeCount }}</label>\n </button>\n <button *ngIf=\"pulseMessage?.likedByMe != 'true'\" mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, false, 'top')\">\n <!-- <mat-icon class=\"psdk-icon\" svgIcon=\"thumb-up-outline\" mastListIcon ></mat-icon> -->\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n <label class=\"psdk-pulse-message-like-label\">Like | {{ pulseMessage.likeCount }}</label>\n </button>\n </div>\n <ng-template #notLiked>\n <button mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, false, 'top')\">\n <!-- <mat-icon class=\"psdk-icon\" svgIcon=\"thumb-up-outline\" mastListIcon ></mat-icon> -->\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n <label class=\"psdk-pulse-message-like-label\">Like</label>\n </button>\n </ng-template>\n </div>\n </div>\n\n <div *ngIf=\"pulseMessage?.replies\" class=\"psdk-pulse-reply\">\n <div *ngFor=\"let replyMessage of pulseMessage.replies\" class=\"psdk-pulse-reply-align\">\n <div class=\"psdk-pulse-divider\"></div>\n <br />\n <div class=\"psdk-pulse-reply-group\">\n <div class=\"psdk-avatar\">{{ replyMessage.displayPostedByInitials }}</div>\n <div class=\"psdk-pulse-reply-by\">{{ replyMessage.displayPostedBy }}</div>\n <div class=\"psdk-pulse-reply-message\">{{ replyMessage.message }}</div>\n </div>\n <div class=\"psdk-pulse-reply-actions\">\n <button mat-button (click)=\"commentClick(pulseMessage.ID)\" class=\"psdk-pulse-reply-comment\">\n <img class=\"psdk-comment-svg-icon\" src=\"{{ svgComment$ }}\" />\n </button>\n <div *ngIf=\"replyMessage?.likeCount; else replyNotLiked\">\n <button\n *ngIf=\"replyMessage?.likedByMe === 'true'\"\n mat-button\n (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, true, 'reply')\"\n class=\"psdk-pulse-reply-like\"\n >\n <img class=\"psdk-liked-by-me-svg-icon\" src=\"{{ svgLikedByMe$ }}\" />\n </button>\n <button\n *ngIf=\"replyMessage?.likedByMe != 'true'\"\n mat-button\n (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, false, 'reply')\"\n class=\"psdk-pulse-reply-like\"\n >\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n </button>\n <label class=\"psdk-pulse-reply-like-label\">Like | {{ replyMessage.likeCount }}</label>\n </div>\n <ng-template #replyNotLiked>\n <button\n *ngIf=\"replyMessage?.likedByMe != 'true'\"\n mat-button\n (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, false, 'reply')\"\n class=\"psdk-pulse-reply-like\"\n >\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n </button>\n </ng-template>\n\n <div class=\"psdk-pulse-reply-time\">{{ replyMessage.displayPostedTime }}</div>\n </div>\n <br />\n </div>\n\n <div *ngIf=\"showReplyComment$[pulseMessage.ID] == true\">\n <div class=\"psdk-pulse-divider\"></div>\n <br />\n <div class=\"psdk-pulse-comment-group\">\n <div class=\"psdk-avatar\">{{ this.currentUserInitials$ }}</div>\n <mat-form-field class=\"psdk-full-width\">\n <textarea\n matInput\n rows=\"5\"\n id=\"pulseMessage\"\n placeholder=\"Add a comment\"\n type=\"text\"\n (change)=\"newCommentChange($event, pulseMessage.ID)\"\n ></textarea>\n </mat-form-field>\n <button mat-button (click)=\"postCommentClick(pulseMessage.ID)\" class=\"psdk-pulse-comment-post\">\n <img class=\"psdk-send-svg-icon\" src=\"{{ svgSend$ }}\" />\n </button>\n </div>\n </div>\n </div>\n <br />\n</div>\n", styles: [".psdk-pulse-divider{border-bottom:.0625rem solid lightgrey}.psdk-full-width{width:100%;padding-left:.625rem}.psdk-icon{padding:0rem .125rem;min-width:unset;display:inline-block}.psdk-icon-liked-by-me{padding:0rem .125rem;min-width:unset;display:inline-block;color:#673ab7}.psdk-send-svg-icon{width:1.4rem}.psdk-comment-svg-icon,.psdk-like-svg-icon{width:1.4rem;padding:0rem .3215rem}.psdk-liked-by-me-svg-icon{width:1.4rem;padding:0rem .3215rem;filter:invert(23%) sepia(23%) saturate(6785%) hue-rotate(250deg) brightness(93%) contrast(88%)}.psdk-avatar{margin:0rem;padding:0rem;min-width:2.5rem;min-height:2.5rem;max-width:2.5rem;max-height:2.5rem;border-radius:50%;justify-content:center;align-items:center;text-align:center;display:flex;background:#673ab7;color:#fff;font-weight:700;font-size:1.25rem}.psdk-avatar-big{margin:0rem;padding:0rem;min-width:3.125rem;min-height:3.125rem;max-width:3.125rem;max-height:3.125rem;border-radius:50%;justify-content:center;align-items:center;text-align:center;display:flex;background:#673ab7;color:#fff;font-weight:700;font-size:1.5625rem}.psdk-pulse{display:inline-flex;width:100%;padding-bottom:.625rem}.psdk-pulse-message-group{display:flex;flex-direction:column;padding-left:.625rem}.psdk-pulse-message-by{margin-bottom:0rem;font-weight:700;font-size:.9375rem}.psdk-pulse-message-time{color:#aaa}.psdk-pulse-message-text{white-space:pre-line}.psdk-pulse-message-actions{display:flex;flex-direction:row;padding-top:1.25rem}.psdk-pulse-message-action-group,.psdk-pulse-message-action-like{flex-basis:15em}.psdk-pulse-message-like-label{vertical-align:middle}.psdk-pulse-reply{padding-left:1.25rem}.psdk-pulse-reply-align{text-align:left}.psdk-pulse-reply-group{display:flex;flex-direction:row;align-items:center}.psdk-pulse-reply-by{padding:0rem .625rem;font-weight:700;font-size:.9375rem}.psdk-pulse-reply-message{background-color:#ddd;border-radius:.625rem;padding:0rem 1.25rem;white-space:pre-line}.psdk-pulse-reply-actions{display:flex;flex-direction:row;align-items:center;padding-left:3.125rem}.psdk-pulse-reply-comment,.psdk-pulse-reply-like{padding:0rem;min-width:1.875rem}.psdk-pulse-reply-like-label{vertical-align:middle;padding-right:.3125rem}.psdk-pulse-reply-time{color:#aaa;padding-left:.625rem}.psdk-pulse-comment-group{display:flex;flex-direction:row;align-items:center}.psdk-pulse-comment-post{padding:0rem;min-width:1.875rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatGridListModule }, { kind: "component", type: i6.MatGridList, selector: "mat-grid-list", inputs: ["cols", "gutterSize", "rowHeight"], exportAs: ["matGridList"] }, { kind: "component", type: i6.MatGridTile, selector: "mat-grid-tile", inputs: ["rowspan", "colspan"], exportAs: ["matGridTile"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i7.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] }); }
|
|
518
|
+
}
|
|
519
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FeedContainerComponent, decorators: [{
|
|
520
|
+
type: Component,
|
|
521
|
+
args: [{ selector: 'app-feed-container', providers: [Utils], standalone: true, imports: [CommonModule, MatFormFieldModule, MatInputModule, MatGridListModule, MatButtonModule], template: "<div>\n <div style=\"text-align: left\">\n <h3>Pulse</h3>\n\n <div class=\"psdk-pulse-divider\"></div>\n\n <br />\n <div class=\"psdk-pulse\">\n <div class=\"psdk-avatar-big\">{{ this.currentUserInitials$ }}</div>\n <mat-form-field class=\"psdk-full-width\">\n <textarea matInput rows=\"5\" id=\"pulseMessage\" placeholder=\"Start a conversation\" type=\"text\" (change)=\"messageChange($event)\"></textarea>\n </mat-form-field>\n </div>\n </div>\n</div>\n\n<mat-grid-list cols=\"2\" rowHeight=\"6.25rem\">\n <mat-grid-tile> </mat-grid-tile>\n <mat-grid-tile>\n <button mat-raised-button color=\"primary\" (click)=\"postClick()\">Post</button>\n </mat-grid-tile>\n</mat-grid-list>\n\n<div *ngFor=\"let pulseMessage of pulseMessages$; let odd = odd\" style=\"text-align: left\" [style.background-color]=\"odd ? 'white' : '#eeeeee'\">\n <div class=\"psdk-pulse-divider\"></div>\n <br />\n <div class=\"psdk-pulse\">\n <div class=\"psdk-avatar-big\">{{ pulseMessage.displayPostedByInitials }}</div>\n <div class=\"psdk-pulse-message-group\">\n <div class=\"psdk-pulse-message-by\">{{ pulseMessage.displayPostedBy }}</div>\n <div class=\"psdk-pulse-message-time\">{{ pulseMessage.displayPostedTime }}</div>\n </div>\n </div>\n <div class=\"psdk-pulse-message-text\">{{ pulseMessage.message }}</div>\n <div class=\"psdk-pulse-message-actions\">\n <div class=\"psdk-pulse-message-action-group\">\n <button mat-button (click)=\"commentClick(pulseMessage.ID)\">\n <img class=\"psdk-comment-svg-icon\" src=\"{{ svgComment$ }}\" />\n <label class=\"psdk-pulse-message-like-label\"\n >Comment <span *ngIf=\"pulseMessage?.replies.length > 0\"> | {{ pulseMessage.replies.length }}</span></label\n >\n </button>\n </div>\n <div class=\"psdk-pulse-message-action-like\">\n <div *ngIf=\"pulseMessage?.likeCount; else notLiked\">\n <button *ngIf=\"pulseMessage?.likedByMe == 'true'\" mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, true, 'top')\">\n <!-- <mat-icon class=\"psdk-icon-liked-by-me\" svgIcon=\"thumb-up\" mastListIcon ></mat-icon> -->\n <img class=\"psdk-liked-by-me-svg-icon\" src=\"{{ svgLikedByMe$ }}\" />\n <label class=\"psdk-pulse-message-like-label\">Like | {{ pulseMessage.likeCount }}</label>\n </button>\n <button *ngIf=\"pulseMessage?.likedByMe != 'true'\" mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, false, 'top')\">\n <!-- <mat-icon class=\"psdk-icon\" svgIcon=\"thumb-up-outline\" mastListIcon ></mat-icon> -->\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n <label class=\"psdk-pulse-message-like-label\">Like | {{ pulseMessage.likeCount }}</label>\n </button>\n </div>\n <ng-template #notLiked>\n <button mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, false, 'top')\">\n <!-- <mat-icon class=\"psdk-icon\" svgIcon=\"thumb-up-outline\" mastListIcon ></mat-icon> -->\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n <label class=\"psdk-pulse-message-like-label\">Like</label>\n </button>\n </ng-template>\n </div>\n </div>\n\n <div *ngIf=\"pulseMessage?.replies\" class=\"psdk-pulse-reply\">\n <div *ngFor=\"let replyMessage of pulseMessage.replies\" class=\"psdk-pulse-reply-align\">\n <div class=\"psdk-pulse-divider\"></div>\n <br />\n <div class=\"psdk-pulse-reply-group\">\n <div class=\"psdk-avatar\">{{ replyMessage.displayPostedByInitials }}</div>\n <div class=\"psdk-pulse-reply-by\">{{ replyMessage.displayPostedBy }}</div>\n <div class=\"psdk-pulse-reply-message\">{{ replyMessage.message }}</div>\n </div>\n <div class=\"psdk-pulse-reply-actions\">\n <button mat-button (click)=\"commentClick(pulseMessage.ID)\" class=\"psdk-pulse-reply-comment\">\n <img class=\"psdk-comment-svg-icon\" src=\"{{ svgComment$ }}\" />\n </button>\n <div *ngIf=\"replyMessage?.likeCount; else replyNotLiked\">\n <button\n *ngIf=\"replyMessage?.likedByMe === 'true'\"\n mat-button\n (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, true, 'reply')\"\n class=\"psdk-pulse-reply-like\"\n >\n <img class=\"psdk-liked-by-me-svg-icon\" src=\"{{ svgLikedByMe$ }}\" />\n </button>\n <button\n *ngIf=\"replyMessage?.likedByMe != 'true'\"\n mat-button\n (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, false, 'reply')\"\n class=\"psdk-pulse-reply-like\"\n >\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n </button>\n <label class=\"psdk-pulse-reply-like-label\">Like | {{ replyMessage.likeCount }}</label>\n </div>\n <ng-template #replyNotLiked>\n <button\n *ngIf=\"replyMessage?.likedByMe != 'true'\"\n mat-button\n (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, false, 'reply')\"\n class=\"psdk-pulse-reply-like\"\n >\n <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n </button>\n </ng-template>\n\n <div class=\"psdk-pulse-reply-time\">{{ replyMessage.displayPostedTime }}</div>\n </div>\n <br />\n </div>\n\n <div *ngIf=\"showReplyComment$[pulseMessage.ID] == true\">\n <div class=\"psdk-pulse-divider\"></div>\n <br />\n <div class=\"psdk-pulse-comment-group\">\n <div class=\"psdk-avatar\">{{ this.currentUserInitials$ }}</div>\n <mat-form-field class=\"psdk-full-width\">\n <textarea\n matInput\n rows=\"5\"\n id=\"pulseMessage\"\n placeholder=\"Add a comment\"\n type=\"text\"\n (change)=\"newCommentChange($event, pulseMessage.ID)\"\n ></textarea>\n </mat-form-field>\n <button mat-button (click)=\"postCommentClick(pulseMessage.ID)\" class=\"psdk-pulse-comment-post\">\n <img class=\"psdk-send-svg-icon\" src=\"{{ svgSend$ }}\" />\n </button>\n </div>\n </div>\n </div>\n <br />\n</div>\n", styles: [".psdk-pulse-divider{border-bottom:.0625rem solid lightgrey}.psdk-full-width{width:100%;padding-left:.625rem}.psdk-icon{padding:0rem .125rem;min-width:unset;display:inline-block}.psdk-icon-liked-by-me{padding:0rem .125rem;min-width:unset;display:inline-block;color:#673ab7}.psdk-send-svg-icon{width:1.4rem}.psdk-comment-svg-icon,.psdk-like-svg-icon{width:1.4rem;padding:0rem .3215rem}.psdk-liked-by-me-svg-icon{width:1.4rem;padding:0rem .3215rem;filter:invert(23%) sepia(23%) saturate(6785%) hue-rotate(250deg) brightness(93%) contrast(88%)}.psdk-avatar{margin:0rem;padding:0rem;min-width:2.5rem;min-height:2.5rem;max-width:2.5rem;max-height:2.5rem;border-radius:50%;justify-content:center;align-items:center;text-align:center;display:flex;background:#673ab7;color:#fff;font-weight:700;font-size:1.25rem}.psdk-avatar-big{margin:0rem;padding:0rem;min-width:3.125rem;min-height:3.125rem;max-width:3.125rem;max-height:3.125rem;border-radius:50%;justify-content:center;align-items:center;text-align:center;display:flex;background:#673ab7;color:#fff;font-weight:700;font-size:1.5625rem}.psdk-pulse{display:inline-flex;width:100%;padding-bottom:.625rem}.psdk-pulse-message-group{display:flex;flex-direction:column;padding-left:.625rem}.psdk-pulse-message-by{margin-bottom:0rem;font-weight:700;font-size:.9375rem}.psdk-pulse-message-time{color:#aaa}.psdk-pulse-message-text{white-space:pre-line}.psdk-pulse-message-actions{display:flex;flex-direction:row;padding-top:1.25rem}.psdk-pulse-message-action-group,.psdk-pulse-message-action-like{flex-basis:15em}.psdk-pulse-message-like-label{vertical-align:middle}.psdk-pulse-reply{padding-left:1.25rem}.psdk-pulse-reply-align{text-align:left}.psdk-pulse-reply-group{display:flex;flex-direction:row;align-items:center}.psdk-pulse-reply-by{padding:0rem .625rem;font-weight:700;font-size:.9375rem}.psdk-pulse-reply-message{background-color:#ddd;border-radius:.625rem;padding:0rem 1.25rem;white-space:pre-line}.psdk-pulse-reply-actions{display:flex;flex-direction:row;align-items:center;padding-left:3.125rem}.psdk-pulse-reply-comment,.psdk-pulse-reply-like{padding:0rem;min-width:1.875rem}.psdk-pulse-reply-like-label{vertical-align:middle;padding-right:.3125rem}.psdk-pulse-reply-time{color:#aaa;padding-left:.625rem}.psdk-pulse-comment-group{display:flex;flex-direction:row;align-items:center}.psdk-pulse-comment-post{padding:0rem;min-width:1.875rem}\n"] }]
|
|
522
|
+
}], ctorParameters: function () { return [{ type: i1.AngularPConnectService }, { type: i0.ChangeDetectorRef }, { type: i2.Utils }]; }, propDecorators: { pConn$: [{
|
|
523
|
+
type: Input
|
|
524
|
+
}] } });
|
|
525
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed-container.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/widget/feed-container/feed-container.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/widget/feed-container/feed-container.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nimport { Component, OnInit, Input, ChangeDetectorRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatGridListModule } from '@angular/material/grid-list';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport isEqual from 'fast-deep-equal';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { Utils } from '../../../_helpers/utils';\n\ndeclare const window: any;\n\n@Component({\n  selector: 'app-feed-container',\n  templateUrl: './feed-container.component.html',\n  styleUrls: ['./feed-container.component.scss'],\n  providers: [Utils],\n  standalone: true,\n  imports: [CommonModule, MatFormFieldModule, MatInputModule, MatGridListModule, MatButtonModule]\n})\nexport class FeedContainerComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  userName$: string;\n  imageKey$: string;\n\n  currentUserInitials$: string;\n  currentUserName$: string;\n\n  pulseMessages$: any[];\n  showReplyComment$: Object = {};\n\n  svgComment$: string;\n  svgLike$: string;\n  svgLikedByMe$: string;\n  svgSend$: string;\n\n  pulseConversation: string;\n  userData: Map<any, any> = new Map();\n\n  pulseComment: Object = {};\n\n  // functions\n  actionsAPI: any;\n  // until FeedAPI moved back to PCore, we access the methods directly (see ngInit)\n  feedAPI: any;\n\n  pulseData: any;\n\n  // Temporary way to use FeedApi...\n  fetchMessages: any;\n  likeMessage: any;\n  postMessage: any;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private cdRef: ChangeDetectorRef,\n    private utils: Utils\n  ) {}\n\n  ngOnInit(): void {\n    this.userName$ = PCore.getEnvironmentInfo().getOperatorName();\n    this.imageKey$ = PCore.getEnvironmentInfo().getOperatorImageInsKey();\n    this.updateCurrentUserName(this.userName$);\n\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    // Then, continue on with other initialization\n    // debugger;\n\n    // const {\n    //   fetchMessages,\n    //   likeMessage,\n    //   postMessage\n    // } = FeedApi(this.pConn$);\n    // this.fetchMessages = fetchMessages;\n    // this.likeMessage = likeMessage;\n    // this.postMessage = postMessage;\n\n    // // this.userName$ = this.pConn$.getValue(\"pxRequestor.pxUserName\");\n    // // this.imageKey$ = this.pConn$.getValue(\"OperatorID.pyImageInsKey\");\n\n    // //this.userName$ = this.pConn$.getDataObject()[\"D_pxEnvironmentInfo\"].pxOperator.pyUserName;\n    // //this.imageKey$ = this.pConn$.getDataObject()[\"D_pxEnvironmentInfo\"].pxOperator.pyImageInsKey;\n    // this.userName$ = this.pConn$.getEnvironmentInfo().getOperatorName();\n    // this.imageKey$ = this.pConn$.getEnvironmentInfo().getOperatorImageInsKey();\n\n    // this.actionsAPI = this.pConn$.getActionsApi();\n\n    // let owner = this.pConn$.getConfigProps().value;\n\n    // // with new FeedAPI: owner is the proper value to pass in\n    // //  and no longer takes 2nd argument\n    // this./*feedAPI.*/fetchMessages(owner /*, this.pConn$.getContextName()*/);\n\n    // const configProps: any = this.pConn$.getConfigProps();\n\n    // const { messageIDs } = configProps;\n\n    // const { fetchMessages, postMessage, getMentionSuggestions, getTagSuggestions } = FeedApi(this.pConn$);\n\n    const appName = PCore.getEnvironmentInfo().getApplicationName();\n    let value = '';\n    let feedID = '';\n    let feedClass = '';\n\n    if (this.pConn$.getCaseSummary().ID) {\n      value = this.pConn$.getCaseSummary().ID;\n      feedID = 'pyCaseFeed';\n      feedClass = this.pConn$.getCaseSummary().content.classID;\n    } else {\n      value = `DATA-PORTAL $${appName}`;\n      feedID = 'pyDashboardFeed';\n      feedClass = '@baseclass';\n    }\n\n    const onUploadProgress = () => {};\n    const errorHandler = () => {};\n    const attachments = () => {};\n\n    const postComment = ({ value: message, clear }) => {\n      const attachmentIDs = [];\n      const attachmentUtils = PCore.getAttachmentUtils();\n      if (attachments && !!attachments.length) {\n        /* attachments;\n          .filter((file) => !file.error)\n          .map((file) => {\n            return attachmentUtils\n              .uploadAttachment(file, onUploadProgress, errorHandler)\n              .then((fileResponse) => {\n                const fileConfig = {\n                  type: \"File\",\n                  category: \"File\",\n                  fileName: file.name,\n                  ID: fileResponse.data.ID\n                };\n                attachmentIDs.push(fileConfig);\n                if (attachments.length === attachmentIDs.length) {\n                  postMessage(\n                    value,\n                    transformMarkdownToMsg(message),\n                    attachmentIDs\n                  );\n                  clear();\n                  setAttachments([]);\n                }\n              })\n\n              .catch(console.error);\n          }); */\n      } else {\n        // postMessage(value, transformMarkdownToMsg(message));\n        clear();\n      }\n    };\n\n    /*\n\n    const { getPConnect, messageIDs } = props;\n    const [mentionResults, setMentionResults] = useState([]);\n    const [tagResults, setTagResults] = useState([]);\n    const [attachments, setAttachments] = useState([]);\n    const [feedFilters, setFeedFilters] = useState();\n    const {\n      fetchMessages,\n      postMessage,\n      getMentionSuggestions,\n      getTagSuggestions\n    } = FeedApi(getPConnect());\n    const appName = PCore.getEnvironmentInfo().getApplicationName();\n    let value = \"\";\n    let feedID = \"\";\n    let feedClass = \"\";\n    if (getPConnect().getCaseSummary().ID) {\n      value = getPConnect().getCaseSummary().ID;\n      feedID = \"pyCaseFeed\";\n      feedClass = getPConnect().getCaseSummary().content.classID;\n    } else {\n      value = `DATA-PORTAL $${appName}`;\n      feedID = \"pyDashboardFeed\";\n      feedClass = \"@baseclass\";\n    }\n    // For cancelling fetchrequest for filetrs\n    const fetchMessagesCancelTokenSource = useRef([]);\n\n    useEffect(() => {\n      fetchMessages(\n        value,\n        feedID,\n        feedClass,\n        null,\n        fetchMessagesCancelTokenSource.current\n      ).then((res) => {\n        setFeedFilters(res);\n      });\n      PCore.getAssetLoader().getLoader(\"component-loader\")([\"Activity\"]);\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n    }, []);\n\n    const onUploadProgress = useCallback((file) => {\n      return ({ loaded, total }) => {\n        file.progress = Math.floor((loaded / total) * 100);\n        setAttachments((current) => {\n          return current.map((currFile) => {\n            return currFile.name === file.name ? file : currFile;\n          });\n        });\n      };\n    }, []);\n\n    const errorHandler = useCallback((isFetchCanceled, file) => {\n      return (error) => {\n        if (!isFetchCanceled(error)) {\n          let localizedValue = \"Upload failed\";\n          if (\n            error.response &&\n            error.response.data &&\n            error.response.data.errorDetails\n          ) {\n            localizedValue = error.response.data.errorDetails[0].localizedValue;\n          }\n          delete file.progress;\n          setAttachments((current) => {\n            return current.map((currFile) => {\n              if (currFile.name === file.name) {\n                currFile.meta = localizedValue;\n                currFile.error = true;\n              }\n              return currFile;\n            });\n          });\n          error.isHandled = true;\n        }\n        throw error;\n      };\n    }, []);\n\n    const postComment = ({ value: message, clear }) => {\n      const attachmentIDs = [];\n      const attachmentUtils = PCore.getAttachmentUtils();\n      if (attachments && !!attachments.length) {\n        attachments\n          .filter((file) => !file.error)\n          .map((file) => {\n            return attachmentUtils\n              .uploadAttachment(file, onUploadProgress, errorHandler)\n              .then((fileResponse) => {\n                const fileConfig = {\n                  type: \"File\",\n                  category: \"File\",\n                  fileName: file.name,\n                  ID: fileResponse.data.ID\n                };\n                attachmentIDs.push(fileConfig);\n                if (attachments.length === attachmentIDs.length) {\n                  postMessage(\n                    value,\n                    transformMarkdownToMsg(message),\n                    attachmentIDs\n                  );\n                  clear();\n                  setAttachments([]);\n                }\n              })\n\n              .catch(console.error);\n          });\n      } else {\n        postMessage(value, transformMarkdownToMsg(message));\n        clear();\n      }\n    };\n\n    */\n\n    /* On search is called when @ character is entered and will display the mention */\n\n    /*\n    const onSearch = debounce((event) => {\n      if (event.type === \"mention\") {\n        getMentionSuggestions({\n          pulseContext: value,\n          searchFor: event.search\n        }).then((res) => {\n          setMentionResults(res);\n        });\n      } else {\n        getTagSuggestions({\n          searchFor: event.search\n        }).then((res) => {\n          setTagResults(res);\n        });\n      }\n    }, 150);\n\n    const userName = getPConnect().getEnvironmentInfo().getOperatorName();\n    const imageKey = getPConnect().getEnvironmentInfo().getOperatorImageInsKey();\n\n    const onFilesAdded = useCallback((newlyAddedFiles) => {\n      setAttachments((current) => [\n        ...newlyAddedFiles.map((file) => {\n          if (!validateMaxSize(file, 5)) {\n            file.error = true;\n            file.meta = \"File is too big. Max allowed size is 5MB.\";\n          }\n          file.icon = getIconFromFileType(file.type);\n          file.onDelete = () => {\n            setAttachments((c) => c.filter((f) => f.name !== file.name));\n          };\n          return file;\n        }),\n        ...current\n      ]);\n    }, []);\n\n    const onFilterChange = useCallback(\n      (filterID) => {\n        const updatedFilters = [...feedFilters];\n        const filterToUpdate = updatedFilters.find(\n          (feedItem) => feedItem.id === filterID\n        );\n        filterToUpdate.on = !filterToUpdate.on;\n        if (filterID === \"All\")\n          updatedFilters.forEach((feedFilter) => {\n            feedFilter.on = filterToUpdate.on;\n          });\n        else if (\n          updatedFilters.find(\n            (feedItem) => feedItem.on === false && feedItem.id !== \"All\"\n          )\n        )\n          updatedFilters.find((feedItem) => feedItem.id === \"All\").on = false;\n        else updatedFilters.find((feedItem) => feedItem.id === \"All\").on = true;\n        setFeedFilters(updatedFilters);\n        fetchMessages(\n          value,\n          feedID,\n          feedClass,\n          feedFilters,\n          fetchMessagesCancelTokenSource.current\n        );\n      },\n      [\n        value,\n        feedID,\n        feedClass,\n        feedFilters,\n        fetchMessagesCancelTokenSource,\n        fetchMessages\n      ]\n    );\n\n    */\n\n    // set up svg images\n    this.svgComment$ = this.utils.getImageSrc('chat', this.utils.getSDKStaticContentUrl());\n    this.svgLike$ = this.utils.getImageSrc('thumbs-up', this.utils.getSDKStaticContentUrl());\n    this.svgLikedByMe$ = this.utils.getImageSrc('thumbs-up-solid', this.utils.getSDKStaticContentUrl());\n    this.svgSend$ = this.utils.getImageSrc('send', this.utils.getSDKStaticContentUrl());\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  // Callback passed when subscribing to store change\n  onStateChange() {\n    const bLogging = false;\n    if (bLogging) {\n      // console.log( `in ${this.constructor.name} onStateChange` );\n      // debugger;\n    }\n    // Should always check the bridge to see if the component should update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n    // console.log( `${this.constructor.name} shouldComponentUpdate: ${bUpdateSelf}`);\n\n    // ONLY call updateSelf when the component should update\n    //    AND removing the \"gate\" that was put there since shouldComponentUpdate\n    //      should be the real \"gate\"\n    if (bUpdateSelf) {\n      this.updateSelf();\n    } else {\n      // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n      const newPulseData = this.pConn$.getDataObject().pulse;\n\n      if (!isEqual(newPulseData, this.pulseData)) {\n        this.updateSelf();\n      }\n    }\n\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    this.pulseData = this.pConn$.getDataObject().pulse;\n  }\n\n  updateSelf() {\n    this.getMessageData();\n  }\n\n  getMessageData() {\n    const messageIDs = (this.pConn$.getConfigProps() as any).messageIDs;\n    const userName = (this.pConn$.getConfigProps() as any).currentUser;\n    // @ts-ignore - second parameter pageReference for getValue method should be optional\n    const imageKey = this.pConn$.getValue('OperatorID.pyImageInsKey');\n\n    // @ts-ignore - parameter “contextName” for getDataObject method should be optional\n    const oData: any = this.pConn$.getDataObject();\n\n    if (messageIDs && messageIDs.length > 0) {\n      this.pulseMessages$ = JSON.parse(JSON.stringify(oData.pulse.messages));\n\n      // convert to just an array of objects\n      this.pulseMessages$ = this.convertToArray(this.pulseMessages$);\n\n      // create a copy, so we can modify\n      this.pulseMessages$ = this.appendPulseMessage(this.pulseMessages$);\n\n      // most recent on top\n      this.pulseMessages$ = this.pulseMessages$.sort((a, b) => (a.updateTimeUTC < b.updateTimeUTC ? 1 : -1));\n    }\n  }\n\n  convertToArray(messages: any[]): any[] {\n    const arMessages: any[] = [];\n\n    for (let i = 0; i < messages.length; i++) {\n      arMessages.push(messages[i]);\n    }\n\n    return arMessages;\n  }\n\n  appendPulseMessage(messages: any[]): any[] {\n    for (let i = 0; i < messages.length; i++) {\n      const message = messages[i];\n      const postedTime = message.postedTime;\n      const updatedTime = message.updatedTime;\n\n      this.showReplyComment$[message.ID] = false;\n\n      message.displayPostedTime = this.utils.generateDateTime(postedTime, 'DateTime-Since');\n\n      // for sorting lasted update\n      if (updatedTime != null) {\n        message.updateTimeUTC = new Date(updatedTime).getTime();\n      } else {\n        message.updateTimeUTC = new Date(postedTime).getTime();\n      }\n\n      message.displayPostedBy = message.postedByUser.name;\n      message.displayPostedByInitials = this.utils.getInitials(message.postedByUser.name);\n\n      // if didn't break, then look at the replies\n      for (let j = 0; j < message.replies.length; j++) {\n        const reply = message.replies[j];\n\n        const replyPostedTime = reply.postedTime;\n        reply.displayPostedTime = this.utils.generateDateTime(replyPostedTime, 'DateTime-Since');\n\n        // let oReplyUser = this.userData.get(reply.postedByUser);\n        const oReplyUser = reply.postedByUser;\n\n        if (oReplyUser) {\n          reply.displayPostedBy = oReplyUser.name;\n          reply.displayPostedByInitials = this.utils.getInitials(oReplyUser.name);\n        }\n      }\n    } // for\n\n    return messages;\n  }\n\n  updateMessagesWithOperators() {\n    for (let i = 0; i < this.pulseMessages$.length; i++) {\n      const message = this.pulseMessages$[i];\n\n      const postedTime = message.postedTime;\n\n      this.showReplyComment$[message.ID] = false;\n\n      message.displayPostedTime = this.utils.generateDateTime(postedTime, 'DateTime-Since');\n\n      const oUser = this.userData.get(message.postedBy);\n\n      if (oUser) {\n        message.displayPostedBy = oUser.pyUserName;\n        message.displayPostedByInitials = this.utils.getInitials(oUser.pyUserName);\n      } else {\n        const oUserParams = {\n          OperatorId: message.postedBy\n        };\n        // Do something with oUserParams\n      }\n\n      // if didn't break, then look at the replies\n      for (let j = 0; j < message.replies.length; j++) {\n        const reply = message.replies[j];\n\n        const replyPostedTime = reply.postedTime;\n        reply.displayPostedTime = this.utils.generateDateTime(replyPostedTime, 'DateTime-Since');\n\n        // let oReplyUser = this.userData.get(reply.postedByUser);\n        const oReplyUser = reply.postedByUser;\n\n        if (oReplyUser) {\n          reply.displayPostedBy = oReplyUser.name;\n          reply.displayPostedByInitials = this.utils.getInitials(oReplyUser.name);\n        }\n      }\n    } // for\n  }\n\n  updateCurrentUserName(sUser: string) {\n    this.currentUserInitials$ = this.utils.getInitials(sUser);\n    this.currentUserName$ = sUser;\n  }\n\n  postClick() {\n    // don't send a blank message\n    if (this.pulseConversation && this.pulseConversation != '') {\n      // let pulseMessage = {\n      //   contextName : this.pConn$.getContextName(),\n      //   message: this.pulseConversation,\n      //   pulseContext: this.pConn$.getValue(\".pzInsKey\")\n      // };\n\n      // debugger;\n      // used to be: this./*feedAPI.*/postMessage(pulseMessage);\n      // With latest FeedAPI, the 1st arg should be getConfigProps().value\n\n      // If feedAPI is defined then only post message\n      if (this.feedAPI) {\n        this./* feedAPI. */ postMessage((this.pConn$.getConfigProps() as any).value, this.pulseConversation);\n      } else {\n        console.log(\"We don't support Pulse yet\");\n      }\n    }\n\n    // clear out local copy\n    (document.getElementById('pulseMessage') as HTMLElement | any).value = '';\n    this.pulseConversation = '';\n  }\n\n  messageChange(event: any) {\n    this.pulseConversation = event.target.value;\n  }\n\n  likeClick(messageID: string, rMessageID: string, bLikedByMe: boolean, level: string) {\n    let pulseMessage = {};\n\n    if (level === 'top') {\n      pulseMessage = {\n        pulseContext: rMessageID,\n        isReply: null,\n        contextName: this.pConn$.getContextName(),\n        likedBy: bLikedByMe,\n        messageID\n      };\n    } else {\n      pulseMessage = {\n        pulseContext: rMessageID,\n        isReply: true,\n        contextName: this.pConn$.getContextName(),\n        likedBy: bLikedByMe,\n        messageID\n      };\n    }\n\n    // debugger;\n    this./* feedAPI. */ likeMessage(pulseMessage);\n  }\n\n  commentClick(messageID) {\n    // iterator through messages, find match, turn on comment entry\n    const foundMessage = this.pulseMessages$.find(message => message.ID === messageID);\n\n    if (foundMessage) {\n      this.showReplyComment$[foundMessage.ID] = true;\n    }\n\n    this.cdRef.detectChanges();\n  }\n\n  postCommentClick(messageID) {\n    // debugger;\n\n    if (this.pulseComment[messageID] && this.pulseComment[messageID] != '') {\n      // let pulseMessage = {\n      //   contextName : this.pConn$.getContextName(),\n      //   message: this.pulseComment[messageID],\n      //   pulseContext: messageID,\n      //   reply: true\n      // };\n\n      // debugger;\n      // Used to be: this./*feedAPI.*/postMessage(pulseMessage);\n      //  Latest update to API has changed and the postMessage actually gets\n      //  the pulse context...\n      // used to use: contextName\n      // new FeedAPI wants args to be messageID, this.pulseComment[messageID], true (since this is a reply)\n      this./* feedAPI. */ postMessage(messageID, this.pulseComment[messageID], true);\n\n      this.pulseComment[messageID] = '';\n    }\n  }\n\n  newCommentChange(event, messageID) {\n    this.pulseComment[messageID] = event.target.value;\n  }\n}\n","<div>\n  <div style=\"text-align: left\">\n    <h3>Pulse</h3>\n\n    <div class=\"psdk-pulse-divider\"></div>\n\n    <br />\n    <div class=\"psdk-pulse\">\n      <div class=\"psdk-avatar-big\">{{ this.currentUserInitials$ }}</div>\n      <mat-form-field class=\"psdk-full-width\">\n        <textarea matInput rows=\"5\" id=\"pulseMessage\" placeholder=\"Start a conversation\" type=\"text\" (change)=\"messageChange($event)\"></textarea>\n      </mat-form-field>\n    </div>\n  </div>\n</div>\n\n<mat-grid-list cols=\"2\" rowHeight=\"6.25rem\">\n  <mat-grid-tile> </mat-grid-tile>\n  <mat-grid-tile>\n    <button mat-raised-button color=\"primary\" (click)=\"postClick()\">Post</button>\n  </mat-grid-tile>\n</mat-grid-list>\n\n<div *ngFor=\"let pulseMessage of pulseMessages$; let odd = odd\" style=\"text-align: left\" [style.background-color]=\"odd ? 'white' : '#eeeeee'\">\n  <div class=\"psdk-pulse-divider\"></div>\n  <br />\n  <div class=\"psdk-pulse\">\n    <div class=\"psdk-avatar-big\">{{ pulseMessage.displayPostedByInitials }}</div>\n    <div class=\"psdk-pulse-message-group\">\n      <div class=\"psdk-pulse-message-by\">{{ pulseMessage.displayPostedBy }}</div>\n      <div class=\"psdk-pulse-message-time\">{{ pulseMessage.displayPostedTime }}</div>\n    </div>\n  </div>\n  <div class=\"psdk-pulse-message-text\">{{ pulseMessage.message }}</div>\n  <div class=\"psdk-pulse-message-actions\">\n    <div class=\"psdk-pulse-message-action-group\">\n      <button mat-button (click)=\"commentClick(pulseMessage.ID)\">\n        <img class=\"psdk-comment-svg-icon\" src=\"{{ svgComment$ }}\" />\n        <label class=\"psdk-pulse-message-like-label\"\n          >Comment <span *ngIf=\"pulseMessage?.replies.length > 0\"> | {{ pulseMessage.replies.length }}</span></label\n        >\n      </button>\n    </div>\n    <div class=\"psdk-pulse-message-action-like\">\n      <div *ngIf=\"pulseMessage?.likeCount; else notLiked\">\n        <button *ngIf=\"pulseMessage?.likedByMe == 'true'\" mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, true, 'top')\">\n          <!-- <mat-icon class=\"psdk-icon-liked-by-me\" svgIcon=\"thumb-up\" mastListIcon ></mat-icon> -->\n          <img class=\"psdk-liked-by-me-svg-icon\" src=\"{{ svgLikedByMe$ }}\" />\n          <label class=\"psdk-pulse-message-like-label\">Like | {{ pulseMessage.likeCount }}</label>\n        </button>\n        <button *ngIf=\"pulseMessage?.likedByMe != 'true'\" mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, false, 'top')\">\n          <!-- <mat-icon class=\"psdk-icon\" svgIcon=\"thumb-up-outline\" mastListIcon ></mat-icon> -->\n          <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n          <label class=\"psdk-pulse-message-like-label\">Like | {{ pulseMessage.likeCount }}</label>\n        </button>\n      </div>\n      <ng-template #notLiked>\n        <button mat-button (click)=\"likeClick(pulseMessage.ID, pulseMessage.ID, false, 'top')\">\n          <!-- <mat-icon class=\"psdk-icon\" svgIcon=\"thumb-up-outline\" mastListIcon ></mat-icon> -->\n          <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n          <label class=\"psdk-pulse-message-like-label\">Like</label>\n        </button>\n      </ng-template>\n    </div>\n  </div>\n\n  <div *ngIf=\"pulseMessage?.replies\" class=\"psdk-pulse-reply\">\n    <div *ngFor=\"let replyMessage of pulseMessage.replies\" class=\"psdk-pulse-reply-align\">\n      <div class=\"psdk-pulse-divider\"></div>\n      <br />\n      <div class=\"psdk-pulse-reply-group\">\n        <div class=\"psdk-avatar\">{{ replyMessage.displayPostedByInitials }}</div>\n        <div class=\"psdk-pulse-reply-by\">{{ replyMessage.displayPostedBy }}</div>\n        <div class=\"psdk-pulse-reply-message\">{{ replyMessage.message }}</div>\n      </div>\n      <div class=\"psdk-pulse-reply-actions\">\n        <button mat-button (click)=\"commentClick(pulseMessage.ID)\" class=\"psdk-pulse-reply-comment\">\n          <img class=\"psdk-comment-svg-icon\" src=\"{{ svgComment$ }}\" />\n        </button>\n        <div *ngIf=\"replyMessage?.likeCount; else replyNotLiked\">\n          <button\n            *ngIf=\"replyMessage?.likedByMe === 'true'\"\n            mat-button\n            (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, true, 'reply')\"\n            class=\"psdk-pulse-reply-like\"\n          >\n            <img class=\"psdk-liked-by-me-svg-icon\" src=\"{{ svgLikedByMe$ }}\" />\n          </button>\n          <button\n            *ngIf=\"replyMessage?.likedByMe != 'true'\"\n            mat-button\n            (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, false, 'reply')\"\n            class=\"psdk-pulse-reply-like\"\n          >\n            <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n          </button>\n          <label class=\"psdk-pulse-reply-like-label\">Like | {{ replyMessage.likeCount }}</label>\n        </div>\n        <ng-template #replyNotLiked>\n          <button\n            *ngIf=\"replyMessage?.likedByMe != 'true'\"\n            mat-button\n            (click)=\"likeClick(pulseMessage.ID, replyMessage.ID, false, 'reply')\"\n            class=\"psdk-pulse-reply-like\"\n          >\n            <img class=\"psdk-like-svg-icon\" src=\"{{ svgLike$ }}\" />\n          </button>\n        </ng-template>\n\n        <div class=\"psdk-pulse-reply-time\">{{ replyMessage.displayPostedTime }}</div>\n      </div>\n      <br />\n    </div>\n\n    <div *ngIf=\"showReplyComment$[pulseMessage.ID] == true\">\n      <div class=\"psdk-pulse-divider\"></div>\n      <br />\n      <div class=\"psdk-pulse-comment-group\">\n        <div class=\"psdk-avatar\">{{ this.currentUserInitials$ }}</div>\n        <mat-form-field class=\"psdk-full-width\">\n          <textarea\n            matInput\n            rows=\"5\"\n            id=\"pulseMessage\"\n            placeholder=\"Add a comment\"\n            type=\"text\"\n            (change)=\"newCommentChange($event, pulseMessage.ID)\"\n          ></textarea>\n        </mat-form-field>\n        <button mat-button (click)=\"postCommentClick(pulseMessage.ID)\" class=\"psdk-pulse-comment-post\">\n          <img class=\"psdk-send-svg-icon\" src=\"{{ svgSend$ }}\" />\n        </button>\n      </div>\n    </div>\n  </div>\n  <br />\n</div>\n"]}
|