@annalib/anna-core 31.0.32 → 31.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -64,4 +64,4 @@ export class EllipsisWithTableTooltip {
64
64
  this.tooltipClass = tooltipClass;
65
65
  }
66
66
  }
67
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-non-editable-gt-models.js","sourceRoot":"","sources":["../../../../../../projects/anna-core/src/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.ts"],"names":[],"mappings":"AAoEA,MAAM,OAAO,sBAAsB;IAG/B,YAAY,IAAuD;QAC/D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;IAC5C,CAAC;CACJ;AAED,MAAM,CAAN,IAAY,cAYX;AAZD,WAAY,cAAc;IACtB,2EAAyD,CAAA;IACzD,yCAAuB,CAAA;IACvB,iDAA+B,CAAA;IAC/B,+CAA6B,CAAA;IAC7B,uEAAqD,CAAA;IACrD,2DAAyC,CAAA;IACzC,6CAA2B,CAAA;IAC3B,mDAAiC,CAAA;IACjC,mDAAiC,CAAA;IACjC,mDAAiC,CAAA;IACjC,mDAAiC,CAAA;AACrC,CAAC,EAZW,cAAc,KAAd,cAAc,QAYzB;AA4ED,MAAM,OAAO,aAAa;IAStB,YACI,qBAA0B,EAC1B,IAAY,EACZ,SAAiB,EACjB,WAAoB,EACpB,WAA2C;QAE3C,IAAI,CAAC,EAAE,GAAG,qBAAqB,CAAC;QAChC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,8BAA8B,GAAG,KAAK,CAAC;IAChD,CAAC;CACJ;AAED,MAAM,OAAO,iBAAiB;IAQ1B,YACI,EAAO,EACP,QAAiB,EACjB,SAAiB,EACjB,aAAsB,EACtB,WAAoB,EACpB,WAAoB;QAZxB,aAAQ,GAAY,IAAI,CAAC;QAcrB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACnC,CAAC;CACJ;AA+CD,MAAM,OAAO,sBAAsB;aACf,iBAAY,GAAG,iBAAiB,CAAC;aACjC,gBAAW,GAAG,eAAe,CAAC;aAC9B,kBAAa,GAAG,iBAAiB,CAAC;aAClC,mBAAc,GAAG,oBAAoB,CAAC;aACtC,UAAK,GAAG,SAAS,CAAC;aAClB,uBAAkB,GAAG,uBAAuB,CAAC;aAC7C,0CAAqC,GAAG,oCAAoC,CAAC;aAC7E,yBAAoB,GAAG,yBAAyB,CAAC;aACjD,0BAAqB,GAAG,yBAAyB,CAAC;aAClD,0BAAqB,GAAG,0BAA0B,CAAC;aACnD,mBAAc,GAAG,kBAAkB,CAAC;aAEpC,sBAAiB,GAAG,0BAA0B,CAAC;;AAGnE,MAAM,OAAO,wBAAwB;IASjC,YACI,OAAe,EACf,YAAmC,EACnC,SAAgB,EAChB,SAAiB,EACjB,WAAmB,EACnB,WAAoB,EACpB,YAAoB;QAEpB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG,WAAW,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;IACrC,CAAC;CACJ","sourcesContent":["import { IWeekCalendar } from \"./anna-global-dropdown-config.model\";\r\n\r\nexport interface IGtTableHeader {\r\n    headerInfo: IHeaderInfo[];\r\n    visible: boolean;\r\n    width: string;\r\n}\r\n\r\nexport interface IHeaderInfo {\r\n    name: string;\r\n    objectKey: string;\r\n    actionKey?: string;\r\n    tooltipKey?: string;\r\n    isDisabledKey?: string;\r\n    typeOfHeaderData: DATATYPE;\r\n    typeOfBodyData: DATATYPE;\r\n    filter?: FILTERTYPE;\r\n    filterSortObjectKeys?: string[];\r\n    isSortRequired?: boolean[];\r\n    isFilterRequired?: boolean[];\r\n    showTooltipIcon: boolean;\r\n    disableTooltipIcon?: boolean;\r\n    tooltip?: ITooltip;\r\n    joinedFilterSortObjectKeys?: string;\r\n    showSplitedOptionsInFilter?: boolean[]; \r\n        // Indicates whether to display split options in a checkbox filter. \r\n        // When set to true, the values in the filter will be split into individual options. \r\n        // For example, if the filter has values like \"A18+, A35+\", it will split them into two separate options (\"A18+\" and \"A35+\") in the checkbox filter.\r\n\r\n    splitDelimiter?: string[]; \r\n        // Defines the key or logic used to split the values in the checkbox filter when `showSplitedOptionsInFilter` is true.\r\n        // This key determines how the values are split. For example, if the filter contains \"A18+, A35+\" and `splitDelimiter` is set to a comma or plus sign ('+'), \r\n        // the filter will generate separate options for \"A18+\" and \"A35+\" based on the split delimiter.\r\n}\r\n\r\ntype DATATYPE =\r\n    | \"CHECKBOX\"\r\n    | \"ICON\"\r\n    | \"STRING\"\r\n    | \"RADIO\"\r\n    | \"\"\r\n    | \"SVG_ICON\"\r\n    | \"TEXT_ACTIONS\"\r\n    | \"CLICKABLE_DATA\"\r\n    | \"STRING__TEXT_ACTION\"\r\n    | \"STRING__ICON_ACTION\"\r\n    | \"STRING___ICON_OR_TEXT_ACTION\"\r\n    | \"HTML\"\r\n    | \"HTML_STRING\"\r\n    | \"ICON_CELL\"\r\n    | \"STRING_OR_INPUT\"\r\n    | \"SINGLE_RADIO\"\r\n    | \"STRING_WITH_TOOLTIP\"\r\n    | \"STRING_WITH_ELLIPSIS_AND_READ_MORE_TOOLTIP\"\r\n    | \"STRING_ELLIPSIS_WITH_TABLE_TOOLTIP\"\r\n    | \"STRING_WITH_TOOLTIP_INNER_HTML\"\r\n    | \"ICON_CELL_AND_STRING_WITH_ELLIPSIS_AND_READ_MORE_TOOLTIP\";\r\n    \r\ntype FILTERTYPE = \"CHECKBOX\" | \"SLIDER\" | \"DATE\" | \"TIME\" | \"WEEK\";\r\n\r\nexport interface ISvgOrIconTypeInGTTable {\r\n    showObjectKey: boolean;\r\n    svgOrIconName?: string;\r\n    svgOrIconTooltipMsg?: string;\r\n    additionalText?: string;\r\n    additionalTextClass?: string;\r\n}\r\n\r\nexport class SvgOrIconTypeInGTTable {\r\n    showObjectKey: boolean;\r\n    svgOrIconName?: string;\r\n    constructor(data: { showObjectKey: boolean; svgOrIconName: string }) {\r\n        this.showObjectKey = data.showObjectKey;\r\n        this.svgOrIconName = data.svgOrIconName;\r\n    }\r\n}\r\n\r\nexport enum SvgOrIconNames {\r\n    PAY_FOR_PERFORMANCE_ACTIVE = \"PAY_FOR_PERFORMANCE_ACTIVE\",\r\n    AUTOMATED = \"AUTOMATED\",\r\n    DELETED_ORDER = \"DELETED_ORDER\",\r\n    WARNING_ICON = \"WARNING_ICON\",\r\n    INFORMATION_OUTLINE_ICON = \"INFORMATION_OUTLINE_ICON\",\r\n    ALERT_OCTAGON_ICON = \"ALERT_OCTAGON_ICON\",\r\n    CANCEL_ICON = \"CANCEL_ICON\",\r\n    ALPHA_B_CIRCLE = \"ALPHA_B_CIRCLE\",\r\n    ALPHA_R_CIRCLE = \"ALPHA_R_CIRCLE\",\r\n    ALPHA_E_CIRCLE = \"ALPHA_E_CIRCLE\",\r\n    ALPHA_A_CIRCLE = \"ALPHA_A_CIRCLE\",\r\n}\r\n\r\nexport interface ITotalRowInfo {\r\n    colspan: number;\r\n    data: string;\r\n    lowerData?: string;\r\n    colName: string;\r\n    class?: string;\r\n    tooltipMessage?: string;\r\n    additionalRedTextAfterData?: string;\r\n    isActionColumn?: boolean;\r\n    actionData?: ClickableItem[];\r\n    isIconColumn?: boolean;\r\n    iconData?: { class: string; disabled?: boolean };\r\n    tooltipIconClass?: string;\r\n}\r\n\r\nexport interface IGtHeaderConfig {\r\n    iconColumn: boolean;\r\n    checkboxColumn: boolean;\r\n    lastColumnKeys: string[];\r\n}\r\n\r\nexport interface IGtGeneralConfig extends ISpotTableConfig {\r\n    component: COMPONENTNAME;\r\n    totalRow: boolean;\r\n    isHeaderChecked?: boolean;\r\n    disableHeaderCheckbox?: boolean;\r\n    multiWeekPickerConfig?: IWeekCalendar;\r\n    verticalScrollOffsetForFilterTooltip?: number;\r\n    tableContainerName?: string;\r\n    tableOuterContainerName?: string;\r\n    showAllColumnFilter: boolean;\r\n    bufferSize: number;\r\n    page: string;\r\n}\r\n\r\ntype COMPONENTNAME =\r\n    | \"SPOTDETAILS\"\r\n    | \"EXCLUDEINVENTORYPOPUP\"\r\n    | \"EXCLUDEINVENTORY\"\r\n    | \"DRRLISTING\"\r\n    | \"DRR\"\r\n    | \"\"\r\n    | \"RATING\"\r\n    | \"ORDER_LISTING_INFLIGHT\"\r\n    | \"ORDER_LISTING_COMPLETED\"\r\n    | \"ORDER_LISTING_BLANK\"\r\n    | \"LUR_VIOLATIONS\"\r\n    | \"ACTIVITYLOG\"\r\n    | \"NOTIFICATIONS\"\r\n    | \"DP_RESTRICTIONS\";\r\ninterface ISpotTableConfig {\r\n    isGrouped: boolean;\r\n}\r\n\r\nexport interface ITooltip {\r\n    iconPosition: \"left\" | \"right\" | \"above\" | \"below\" | \"before\" | \"after\";\r\n    name: string;\r\n    tooltipPosition: string;\r\n    iconClass: string;\r\n    tooltipClass: string;\r\n    tooltipMessage?: string;\r\n}\r\n\r\nexport interface IconData {\r\n    data: any;\r\n    iconClass: string;\r\n}\r\nexport interface TextAction {\r\n    id: number;\r\n    name: string;\r\n    class: string;\r\n    isDisabled: boolean;\r\n}\r\n\r\nexport class ClickableItem {\r\n    id: any;\r\n    name: string;\r\n    isDisabled: boolean;\r\n    class: string;\r\n    showTooltip: boolean;\r\n    tooltipData: { key: string; value: string };\r\n    enableTooltipForAdditionalText: boolean;\r\n\r\n    constructor(\r\n        typeOfActionLinkForGt: any,\r\n        name: string,\r\n        className: string,\r\n        showTooltip: boolean,\r\n        tooltipData: { key: string; value: string },\r\n    ) {\r\n        this.id = typeOfActionLinkForGt;\r\n        this.name = name;\r\n        this.class = className;\r\n        this.showTooltip = showTooltip;\r\n        this.tooltipData = tooltipData;\r\n        this.enableTooltipForAdditionalText = false;\r\n    }\r\n}\r\n\r\nexport class IconCellActionKey {\r\n    id: number | string;\r\n    showIcon: boolean = true;\r\n    iconClass: string;\r\n    showObjectKey: boolean;\r\n    showTooltip: boolean;\r\n    tooltipData?: string;\r\n\r\n    constructor(\r\n        id: any,\r\n        showIcon: boolean,\r\n        iconClass: string,\r\n        showObjectKey: boolean,\r\n        showTooltip: boolean,\r\n        tooltipData?: string,\r\n    ) {\r\n        this.id = id;\r\n        this.showIcon = showIcon;\r\n        this.iconClass = iconClass;\r\n        this.showObjectKey = showObjectKey;\r\n        this.showTooltip = showTooltip;\r\n        this.tooltipData = tooltipData;\r\n    }\r\n}\r\n\r\nexport interface IActionItemTypeWithStringIconOrTextAction {\r\n    id: any;\r\n    data: string;\r\n\r\n    typeOfData: \"STRING\" | \"ICON_TEXT_ACTION\";\r\n    additionalTextBeforeLink: string;\r\n\r\n    iconClass?: string;\r\n    showIcon: boolean;\r\n    disabledIcon?: boolean;\r\n\r\n    linkClass?: string;\r\n    showLink?: boolean;\r\n    disabledLink?: boolean;\r\n\r\n    showTooltip: boolean;\r\n\r\n    tooltipData?: { key: string; value: string }[];\r\n    tooltipClass?: string;\r\n    tooltipPlacement?: string;\r\n\r\n    enableTooltipForAdditionalText?: boolean;\r\n}\r\n\r\nexport type IconToShow =\r\n    | \"LIVE\"\r\n    | \"PAY_FOR_PERFORMANCE_ACTIVE\"\r\n    | \"PAY_FOR_PERFORMANCE\"\r\n    | \"REJECTED\"\r\n    | \"NOTIFY\"\r\n    | \"AWAITING_APPROVAL\"\r\n    | \"DELETED_ORDER\"\r\n    | \"NEED_SELLER_CONFIRMATION\"\r\n    | \"NEED_BUYER_CONFIRMATION\"\r\n    | \"AUTOMATED\"\r\n    | \"WARNING_ICON\"\r\n    | \"INFORMATION_OUTLINE_ICON\"\r\n    | \"ALERT_OCTAGON_ICON\"\r\n    | \"CANCEL_ICON\"\r\n    | \"ALPHA_B_CIRCLE\"\r\n    | \"ALPHA_R_CIRCLE\"\r\n    | \"ALPHA_E_CIRCLE\"\r\n    | \"ALPHA_A_CIRCLE\"\r\n    | \"MESSAGE\";\r\n\r\nexport class TableClassNameConstant {\r\n    static readonly defaultClass = \"table-body-row \";\r\n    static readonly selectedRow = \"selected-row \";\r\n    static readonly selectableRow = \"selectable-row \";\r\n    static readonly lastRowOfGroup = \"last-row-of-group \";\r\n    static readonly mgRow = \"mg-row \";\r\n    static readonly redColorCellBorder = \"redcolor-cell-border \";\r\n    static readonly redColorCellBorderForBookedRtgImpsCol = \" redcolor-cell-border-rtg-imps-col\";\r\n    static readonly greenColorCellBorder = \"greencolor-cell-border \";\r\n    static readonly yellowColorCellBorder = \"yellowcolor-cell-border\";\r\n    static readonly orangeColorCellBorder = \"orangecolor-cell-border \";\r\n    static readonly redColorStatus = \"redcolor-status \";\r\n\r\n    static readonly groupedTableClass = \"grouped-table-container \";\r\n}\r\n\r\nexport class EllipsisWithTableTooltip {\r\n    tooltipHeader: string;\r\n    tableHeaders: HeaderWithObjectKey[];\r\n    tableData: any[];\r\n    cellValue: string;\r\n    tooltipHoverText: string;\r\n    showTooltip: boolean;\r\n    tooltipClass: string;\r\n\r\n    constructor(\r\n        heading: string,\r\n        tableHeaders: HeaderWithObjectKey[],\r\n        tableData: any[],\r\n        cellValue: string,\r\n        tooltipText: string,\r\n        showTooltip: boolean,\r\n        tooltipClass: string,\r\n    ) {\r\n        this.tooltipHeader = heading;\r\n        this.tableHeaders = tableHeaders;\r\n        this.tableData = tableData;\r\n        this.cellValue = cellValue;\r\n        this.tooltipHoverText = tooltipText;\r\n        this.showTooltip = showTooltip;\r\n        this.tooltipClass = tooltipClass;\r\n    }\r\n}\r\n\r\nexport interface HeaderWithObjectKey {\r\n    headerName: string;\r\n    objectKey: string;\r\n    width: string;\r\n}\r\n\r\nexport interface InnerHTMLTooltipAction {\r\n    dataToDisplay?: string; // Text or data to display before the tooltip\r\n    showTooltip?: boolean; // Whether to show the tooltip\r\n    tooltipInnerHtmlTemplate?: string; // Template or content for the tooltip\r\n    tooltipPosition?: string; // Tooltip position (e.g., 'top', 'bottom')\r\n    tooltipIconClass?: string; // CSS class for the tooltip icon\r\n    tooltipInnerClass?: string; // CSS class for customizing tooltip's inner content\r\n    disableTooltip?: boolean; // Whether to disable the tooltip\r\n    tooltipMarkerText?: string; // Text for the tooltip icon or indicator\r\n    dataToDisplayAfterTooltip?: string; // Data to display after the tooltip\r\n    isManualTrigger?: boolean; // Whether the tooltip trigger is manual or automatic\r\n}\r\n\r\nexport interface ITooltipTableHeader {\r\n    name: string;\r\n    key: string;\r\n    width: string;\r\n    colspan?: number;\r\n    rowspan?: number;\r\n}\r\n\r\nexport interface ITooltipTableRowData {\r\n    [key: string]: any; // Allow dynamic keys for row data\r\n}\r\n"]}
67
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-non-editable-gt-models.js","sourceRoot":"","sources":["../../../../../../projects/anna-core/src/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.ts"],"names":[],"mappings":"AAqEA,MAAM,OAAO,sBAAsB;IAG/B,YAAY,IAAuD;QAC/D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;IAC5C,CAAC;CACJ;AAED,MAAM,CAAN,IAAY,cAYX;AAZD,WAAY,cAAc;IACtB,2EAAyD,CAAA;IACzD,yCAAuB,CAAA;IACvB,iDAA+B,CAAA;IAC/B,+CAA6B,CAAA;IAC7B,uEAAqD,CAAA;IACrD,2DAAyC,CAAA;IACzC,6CAA2B,CAAA;IAC3B,mDAAiC,CAAA;IACjC,mDAAiC,CAAA;IACjC,mDAAiC,CAAA;IACjC,mDAAiC,CAAA;AACrC,CAAC,EAZW,cAAc,KAAd,cAAc,QAYzB;AA4ED,MAAM,OAAO,aAAa;IAStB,YACI,qBAA0B,EAC1B,IAAY,EACZ,SAAiB,EACjB,WAAoB,EACpB,WAA2C;QAE3C,IAAI,CAAC,EAAE,GAAG,qBAAqB,CAAC;QAChC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,8BAA8B,GAAG,KAAK,CAAC;IAChD,CAAC;CACJ;AAED,MAAM,OAAO,iBAAiB;IAQ1B,YACI,EAAO,EACP,QAAiB,EACjB,SAAiB,EACjB,aAAsB,EACtB,WAAoB,EACpB,WAAoB;QAZxB,aAAQ,GAAY,IAAI,CAAC;QAcrB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACnC,CAAC;CACJ;AA+CD,MAAM,OAAO,sBAAsB;aACf,iBAAY,GAAG,iBAAiB,CAAC;aACjC,gBAAW,GAAG,eAAe,CAAC;aAC9B,kBAAa,GAAG,iBAAiB,CAAC;aAClC,mBAAc,GAAG,oBAAoB,CAAC;aACtC,UAAK,GAAG,SAAS,CAAC;aAClB,uBAAkB,GAAG,uBAAuB,CAAC;aAC7C,0CAAqC,GAAG,oCAAoC,CAAC;aAC7E,yBAAoB,GAAG,yBAAyB,CAAC;aACjD,0BAAqB,GAAG,yBAAyB,CAAC;aAClD,0BAAqB,GAAG,0BAA0B,CAAC;aACnD,mBAAc,GAAG,kBAAkB,CAAC;aAEpC,sBAAiB,GAAG,0BAA0B,CAAC;;AAGnE,MAAM,OAAO,wBAAwB;IASjC,YACI,OAAe,EACf,YAAmC,EACnC,SAAgB,EAChB,SAAiB,EACjB,WAAmB,EACnB,WAAoB,EACpB,YAAoB;QAEpB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG,WAAW,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;IACrC,CAAC;CACJ","sourcesContent":["import { IWeekCalendar } from \"./anna-global-dropdown-config.model\";\r\n\r\nexport interface IGtTableHeader {\r\n    headerInfo: IHeaderInfo[];\r\n    visible: boolean;\r\n    width: string;\r\n}\r\n\r\nexport interface IHeaderInfo {\r\n    name: string;\r\n    objectKey: string;\r\n    actionKey?: string;\r\n    tooltipKey?: string;\r\n    isDisabledKey?: string;\r\n    typeOfHeaderData: DATATYPE;\r\n    typeOfBodyData: DATATYPE;\r\n    filter?: FILTERTYPE;\r\n    filterSortObjectKeys?: string[];\r\n    isSortRequired?: boolean[];\r\n    isFilterRequired?: boolean[];\r\n    showTooltipIcon: boolean;\r\n    disableTooltipIcon?: boolean;\r\n    tooltip?: ITooltip;\r\n    joinedFilterSortObjectKeys?: string;\r\n    showSplitedOptionsInFilter?: boolean[];\r\n    // Indicates whether to display split options in a checkbox filter.\r\n    // When set to true, the values in the filter will be split into individual options.\r\n    // For example, if the filter has values like \"A18+, A35+\", it will split them into two separate options (\"A18+\" and \"A35+\") in the checkbox filter.\r\n\r\n    splitDelimiter?: string[];\r\n    // Defines the key or logic used to split the values in the checkbox filter when `showSplitedOptionsInFilter` is true.\r\n    // This key determines how the values are split. For example, if the filter contains \"A18+, A35+\" and `splitDelimiter` is set to a comma or plus sign ('+'),\r\n    // the filter will generate separate options for \"A18+\" and \"A35+\" based on the split delimiter.\r\n}\r\n\r\ntype DATATYPE =\r\n    | \"CHECKBOX\"\r\n    | \"ICON\"\r\n    | \"STRING\"\r\n    | \"RADIO\"\r\n    | \"\"\r\n    | \"SVG_ICON\"\r\n    | \"TEXT_ACTIONS\"\r\n    | \"CLICKABLE_DATA\"\r\n    | \"STRING__TEXT_ACTION\"\r\n    | \"STRING__ICON_ACTION\"\r\n    | \"STRING___ICON_OR_TEXT_ACTION\"\r\n    | \"HTML\"\r\n    | \"HTML_STRING\"\r\n    | \"ICON_CELL\"\r\n    | \"STRING_OR_INPUT\"\r\n    | \"SINGLE_RADIO\"\r\n    | \"STRING_WITH_TOOLTIP\"\r\n    | \"STRING_WITH_ELLIPSIS_AND_READ_MORE_TOOLTIP\"\r\n    | \"STRING_ELLIPSIS_WITH_TABLE_TOOLTIP\"\r\n    | \"STRING_WITH_TOOLTIP_INNER_HTML\"\r\n    | \"ICON_CELL_AND_STRING_WITH_ELLIPSIS_AND_READ_MORE_TOOLTIP\"\r\n    | \"SINGLE_SELECT_DROPDOWN\";\r\n\r\ntype FILTERTYPE = \"CHECKBOX\" | \"SLIDER\" | \"DATE\" | \"TIME\" | \"WEEK\";\r\n\r\nexport interface ISvgOrIconTypeInGTTable {\r\n    showObjectKey: boolean;\r\n    svgOrIconName?: string;\r\n    svgOrIconTooltipMsg?: string;\r\n    additionalText?: string;\r\n    additionalTextClass?: string;\r\n}\r\n\r\nexport class SvgOrIconTypeInGTTable {\r\n    showObjectKey: boolean;\r\n    svgOrIconName?: string;\r\n    constructor(data: { showObjectKey: boolean; svgOrIconName: string }) {\r\n        this.showObjectKey = data.showObjectKey;\r\n        this.svgOrIconName = data.svgOrIconName;\r\n    }\r\n}\r\n\r\nexport enum SvgOrIconNames {\r\n    PAY_FOR_PERFORMANCE_ACTIVE = \"PAY_FOR_PERFORMANCE_ACTIVE\",\r\n    AUTOMATED = \"AUTOMATED\",\r\n    DELETED_ORDER = \"DELETED_ORDER\",\r\n    WARNING_ICON = \"WARNING_ICON\",\r\n    INFORMATION_OUTLINE_ICON = \"INFORMATION_OUTLINE_ICON\",\r\n    ALERT_OCTAGON_ICON = \"ALERT_OCTAGON_ICON\",\r\n    CANCEL_ICON = \"CANCEL_ICON\",\r\n    ALPHA_B_CIRCLE = \"ALPHA_B_CIRCLE\",\r\n    ALPHA_R_CIRCLE = \"ALPHA_R_CIRCLE\",\r\n    ALPHA_E_CIRCLE = \"ALPHA_E_CIRCLE\",\r\n    ALPHA_A_CIRCLE = \"ALPHA_A_CIRCLE\",\r\n}\r\n\r\nexport interface ITotalRowInfo {\r\n    colspan: number;\r\n    data: string;\r\n    lowerData?: string;\r\n    colName: string;\r\n    class?: string;\r\n    tooltipMessage?: string;\r\n    additionalRedTextAfterData?: string;\r\n    isActionColumn?: boolean;\r\n    actionData?: ClickableItem[];\r\n    isIconColumn?: boolean;\r\n    iconData?: { class: string; disabled?: boolean };\r\n    tooltipIconClass?: string;\r\n}\r\n\r\nexport interface IGtHeaderConfig {\r\n    iconColumn: boolean;\r\n    checkboxColumn: boolean;\r\n    lastColumnKeys: string[];\r\n}\r\n\r\nexport interface IGtGeneralConfig extends ISpotTableConfig {\r\n    component: COMPONENTNAME;\r\n    totalRow: boolean;\r\n    isHeaderChecked?: boolean;\r\n    disableHeaderCheckbox?: boolean;\r\n    multiWeekPickerConfig?: IWeekCalendar;\r\n    verticalScrollOffsetForFilterTooltip?: number;\r\n    tableContainerName?: string;\r\n    tableOuterContainerName?: string;\r\n    showAllColumnFilter: boolean;\r\n    bufferSize: number;\r\n    page: string;\r\n}\r\n\r\ntype COMPONENTNAME =\r\n    | \"SPOTDETAILS\"\r\n    | \"EXCLUDEINVENTORYPOPUP\"\r\n    | \"EXCLUDEINVENTORY\"\r\n    | \"DRRLISTING\"\r\n    | \"DRR\"\r\n    | \"\"\r\n    | \"RATING\"\r\n    | \"ORDER_LISTING_INFLIGHT\"\r\n    | \"ORDER_LISTING_COMPLETED\"\r\n    | \"ORDER_LISTING_BLANK\"\r\n    | \"LUR_VIOLATIONS\"\r\n    | \"ACTIVITYLOG\"\r\n    | \"NOTIFICATIONS\"\r\n    | \"DP_RESTRICTIONS\";\r\ninterface ISpotTableConfig {\r\n    isGrouped: boolean;\r\n}\r\n\r\nexport interface ITooltip {\r\n    iconPosition: \"left\" | \"right\" | \"above\" | \"below\" | \"before\" | \"after\";\r\n    name: string;\r\n    tooltipPosition: string;\r\n    iconClass: string;\r\n    tooltipClass: string;\r\n    tooltipMessage?: string;\r\n}\r\n\r\nexport interface IconData {\r\n    data: any;\r\n    iconClass: string;\r\n}\r\nexport interface TextAction {\r\n    id: number;\r\n    name: string;\r\n    class: string;\r\n    isDisabled: boolean;\r\n}\r\n\r\nexport class ClickableItem {\r\n    id: any;\r\n    name: string;\r\n    isDisabled: boolean;\r\n    class: string;\r\n    showTooltip: boolean;\r\n    tooltipData: { key: string; value: string };\r\n    enableTooltipForAdditionalText: boolean;\r\n\r\n    constructor(\r\n        typeOfActionLinkForGt: any,\r\n        name: string,\r\n        className: string,\r\n        showTooltip: boolean,\r\n        tooltipData: { key: string; value: string },\r\n    ) {\r\n        this.id = typeOfActionLinkForGt;\r\n        this.name = name;\r\n        this.class = className;\r\n        this.showTooltip = showTooltip;\r\n        this.tooltipData = tooltipData;\r\n        this.enableTooltipForAdditionalText = false;\r\n    }\r\n}\r\n\r\nexport class IconCellActionKey {\r\n    id: number | string;\r\n    showIcon: boolean = true;\r\n    iconClass: string;\r\n    showObjectKey: boolean;\r\n    showTooltip: boolean;\r\n    tooltipData?: string;\r\n\r\n    constructor(\r\n        id: any,\r\n        showIcon: boolean,\r\n        iconClass: string,\r\n        showObjectKey: boolean,\r\n        showTooltip: boolean,\r\n        tooltipData?: string,\r\n    ) {\r\n        this.id = id;\r\n        this.showIcon = showIcon;\r\n        this.iconClass = iconClass;\r\n        this.showObjectKey = showObjectKey;\r\n        this.showTooltip = showTooltip;\r\n        this.tooltipData = tooltipData;\r\n    }\r\n}\r\n\r\nexport interface IActionItemTypeWithStringIconOrTextAction {\r\n    id: any;\r\n    data: string;\r\n\r\n    typeOfData: \"STRING\" | \"ICON_TEXT_ACTION\";\r\n    additionalTextBeforeLink: string;\r\n\r\n    iconClass?: string;\r\n    showIcon: boolean;\r\n    disabledIcon?: boolean;\r\n\r\n    linkClass?: string;\r\n    showLink?: boolean;\r\n    disabledLink?: boolean;\r\n\r\n    showTooltip: boolean;\r\n\r\n    tooltipData?: { key: string; value: string }[];\r\n    tooltipClass?: string;\r\n    tooltipPlacement?: string;\r\n\r\n    enableTooltipForAdditionalText?: boolean;\r\n}\r\n\r\nexport type IconToShow =\r\n    | \"LIVE\"\r\n    | \"PAY_FOR_PERFORMANCE_ACTIVE\"\r\n    | \"PAY_FOR_PERFORMANCE\"\r\n    | \"REJECTED\"\r\n    | \"NOTIFY\"\r\n    | \"AWAITING_APPROVAL\"\r\n    | \"DELETED_ORDER\"\r\n    | \"NEED_SELLER_CONFIRMATION\"\r\n    | \"NEED_BUYER_CONFIRMATION\"\r\n    | \"AUTOMATED\"\r\n    | \"WARNING_ICON\"\r\n    | \"INFORMATION_OUTLINE_ICON\"\r\n    | \"ALERT_OCTAGON_ICON\"\r\n    | \"CANCEL_ICON\"\r\n    | \"ALPHA_B_CIRCLE\"\r\n    | \"ALPHA_R_CIRCLE\"\r\n    | \"ALPHA_E_CIRCLE\"\r\n    | \"ALPHA_A_CIRCLE\"\r\n    | \"MESSAGE\";\r\n\r\nexport class TableClassNameConstant {\r\n    static readonly defaultClass = \"table-body-row \";\r\n    static readonly selectedRow = \"selected-row \";\r\n    static readonly selectableRow = \"selectable-row \";\r\n    static readonly lastRowOfGroup = \"last-row-of-group \";\r\n    static readonly mgRow = \"mg-row \";\r\n    static readonly redColorCellBorder = \"redcolor-cell-border \";\r\n    static readonly redColorCellBorderForBookedRtgImpsCol = \" redcolor-cell-border-rtg-imps-col\";\r\n    static readonly greenColorCellBorder = \"greencolor-cell-border \";\r\n    static readonly yellowColorCellBorder = \"yellowcolor-cell-border\";\r\n    static readonly orangeColorCellBorder = \"orangecolor-cell-border \";\r\n    static readonly redColorStatus = \"redcolor-status \";\r\n\r\n    static readonly groupedTableClass = \"grouped-table-container \";\r\n}\r\n\r\nexport class EllipsisWithTableTooltip {\r\n    tooltipHeader: string;\r\n    tableHeaders: HeaderWithObjectKey[];\r\n    tableData: any[];\r\n    cellValue: string;\r\n    tooltipHoverText: string;\r\n    showTooltip: boolean;\r\n    tooltipClass: string;\r\n\r\n    constructor(\r\n        heading: string,\r\n        tableHeaders: HeaderWithObjectKey[],\r\n        tableData: any[],\r\n        cellValue: string,\r\n        tooltipText: string,\r\n        showTooltip: boolean,\r\n        tooltipClass: string,\r\n    ) {\r\n        this.tooltipHeader = heading;\r\n        this.tableHeaders = tableHeaders;\r\n        this.tableData = tableData;\r\n        this.cellValue = cellValue;\r\n        this.tooltipHoverText = tooltipText;\r\n        this.showTooltip = showTooltip;\r\n        this.tooltipClass = tooltipClass;\r\n    }\r\n}\r\n\r\nexport interface HeaderWithObjectKey {\r\n    headerName: string;\r\n    objectKey: string;\r\n    width: string;\r\n}\r\n\r\nexport interface InnerHTMLTooltipAction {\r\n    dataToDisplay?: string; // Text or data to display before the tooltip\r\n    showTooltip?: boolean; // Whether to show the tooltip\r\n    tooltipInnerHtmlTemplate?: string; // Template or content for the tooltip\r\n    tooltipPosition?: string; // Tooltip position (e.g., 'top', 'bottom')\r\n    tooltipIconClass?: string; // CSS class for the tooltip icon\r\n    tooltipInnerClass?: string; // CSS class for customizing tooltip's inner content\r\n    disableTooltip?: boolean; // Whether to disable the tooltip\r\n    tooltipMarkerText?: string; // Text for the tooltip icon or indicator\r\n    dataToDisplayAfterTooltip?: string; // Data to display after the tooltip\r\n    isManualTrigger?: boolean; // Whether the tooltip trigger is manual or automatic\r\n}\r\n\r\nexport interface ITooltipTableHeader {\r\n    name: string;\r\n    key: string;\r\n    width: string;\r\n    colspan?: number;\r\n    rowspan?: number;\r\n}\r\n\r\nexport interface ITooltipTableRowData {\r\n    [key: string]: any; // Allow dynamic keys for row data\r\n}\r\n"]}
@@ -0,0 +1,155 @@
1
+ /* eslint-disable import/no-extraneous-dependencies */
2
+ import { CdkFixedSizeVirtualScroll, CdkVirtualForOf, CdkVirtualScrollViewport } from "@angular/cdk/scrolling";
3
+ import { NgClass, NgFor, NgIf, NgTemplateOutlet } from "@angular/common";
4
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from "@angular/core";
5
+ import { FormsModule } from "@angular/forms";
6
+ import { MatMenuModule } from "@angular/material/menu";
7
+ import { isEqual } from "lodash-es";
8
+ import { AnnaFilterSearchedTextPipe } from "../../../anna-core-shared-lib/pipes/annaFilterSearchedText.pipe";
9
+ import { AnnaTypeofDataPipe } from "../../../anna-core-shared-lib/pipes/annaTypeOfData.pipe";
10
+ import { AnnaGlobalConfigService } from "../../../anna-core-shared-lib/services/anna-global-config.service";
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "../../../anna-core-shared-lib/services/anna-global-config.service";
13
+ import * as i2 from "../../../anna-core-shared-lib/pipes/annaFilterSearchedText.pipe";
14
+ import * as i3 from "@angular/material/menu";
15
+ import * as i4 from "@angular/forms";
16
+ export class AnnaSingleSelectComponent {
17
+ constructor(annaGlobalConfig, searchFilterPipe) {
18
+ this.annaGlobalConfig = annaGlobalConfig;
19
+ this.searchFilterPipe = searchFilterPipe;
20
+ this.loading = false;
21
+ this.showAdditionalDataInSelectedText = false;
22
+ this.keyToUseForDisplay = "text";
23
+ this.keyToUseForCheckingSelectedItem = "id";
24
+ this.hideDropdownArrow = false;
25
+ this.borderbottomObject = {};
26
+ this.defaultDropdownHeight = null;
27
+ this.itemsToHideInDropdownIds = [];
28
+ this.showClearSelection = false;
29
+ this.valueChanged = new EventEmitter();
30
+ this.dropdownClosedEvent = new EventEmitter();
31
+ this.dropdownOpenedEvent = new EventEmitter();
32
+ this.clearSelectionClickedEvent = new EventEmitter();
33
+ this.yPosition = "above";
34
+ }
35
+ ngOnChanges(changes) {
36
+ if (changes.config?.currentValue) {
37
+ this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };
38
+ }
39
+ if (changes.items?.currentValue) {
40
+ if (this.defaultDropdownHeight)
41
+ this.heightOfCheckboxTooltipFilter = this.defaultDropdownHeight;
42
+ else
43
+ this.heightOfCheckboxTooltipFilter = this.items.length > 7 ? 200 : 25.68 * this.items.length;
44
+ }
45
+ if (changes.itemsToHideInDropdownIds?.currentValue) {
46
+ this.items = this.items.filter((item) => !this.itemsToHideInDropdownIds.includes(item.id));
47
+ }
48
+ }
49
+ ngOnInit() {
50
+ this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };
51
+ this.setPostion();
52
+ }
53
+ trackByFn(index) {
54
+ return index;
55
+ }
56
+ itemSelected(item, event) {
57
+ if (item?.isDisabled) {
58
+ event.stopPropagation();
59
+ return;
60
+ }
61
+ if (!isEqual(this.selectedItem, item)) {
62
+ this.valueChanged.emit(item);
63
+ }
64
+ this.selectedItem = item;
65
+ }
66
+ dropdownOpened() {
67
+ this.searchFor = "";
68
+ this.updateHeight();
69
+ this.width = this.buttonElement.nativeElement.offsetWidth;
70
+ this.dropdownOpenedEvent.emit();
71
+ }
72
+ dropdownClosed() {
73
+ this.dropdownClosedEvent.emit();
74
+ }
75
+ clearSelectionClicked() {
76
+ this.selectedItem = null;
77
+ this.clearSelectionClickedEvent.emit();
78
+ }
79
+ setPostion() {
80
+ if (this.config && this.config.position === "TOP") {
81
+ this.yPosition = "above";
82
+ }
83
+ else if (this.config && this.config.position === "BOTTOM") {
84
+ this.yPosition = "below";
85
+ }
86
+ }
87
+ updateHeight() {
88
+ const items = this.searchFilterPipe.transform(this.items, this.searchFor, this.keyToUseForDisplay);
89
+ if (items.length > 7) {
90
+ this.heightOfCheckboxTooltipFilter = 200;
91
+ }
92
+ else if (items.length > 0) {
93
+ this.heightOfCheckboxTooltipFilter = 25.68 * items.length;
94
+ }
95
+ else {
96
+ this.heightOfCheckboxTooltipFilter = 25.68;
97
+ }
98
+ }
99
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaSingleSelectComponent, deps: [{ token: i1.AnnaGlobalConfigService }, { token: i2.AnnaFilterSearchedTextPipe }], target: i0.ɵɵFactoryTarget.Component }); }
100
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AnnaSingleSelectComponent, isStandalone: true, selector: "anna-core-single-select", inputs: { config: "config", loading: "loading", showAdditionalDataInSelectedText: "showAdditionalDataInSelectedText", disabled: "disabled", items: "items", selectedItem: "selectedItem", keyToUseForDisplay: "keyToUseForDisplay", keyToUseForCheckingSelectedItem: "keyToUseForCheckingSelectedItem", hideDropdownArrow: "hideDropdownArrow", borderbottomObject: "borderbottomObject", defaultDropdownHeight: "defaultDropdownHeight", itemsToHideInDropdownIds: "itemsToHideInDropdownIds", showClearSelection: "showClearSelection" }, outputs: { valueChanged: "valueChanged", dropdownClosedEvent: "dropdownClosedEvent", dropdownOpenedEvent: "dropdownOpenedEvent", clearSelectionClickedEvent: "clearSelectionClickedEvent" }, viewQueries: [{ propertyName: "buttonElement", first: true, predicate: ["dropdown"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<button\r\n id=\"dropdown-trigger\"\r\n #dropdown\r\n #t=\"matMenuTrigger\"\r\n (menuClosed)=\"dropdownClosed()\"\r\n (menuOpened)=\"dropdownOpened()\"\r\n [matMenuTriggerFor]=\"contextMenu\"\r\n [disabled]=\"disabled || loading\"\r\n>\r\n <span\r\n class=\"placeholder\"\r\n *ngIf=\"!selectedItem && config\"\r\n >{{ config.placeholder }}</span\r\n >\r\n <span\r\n class=\"selected-item\"\r\n [class]=\"selectedItem.class\"\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"selectedItem\"\r\n >\r\n <ng-container *ngIf=\"(selectedItem | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n {{ selectedItem[keyToUseForDisplay] }}\r\n <ng-container *ngIf=\"showAdditionalDataInSelectedText && selectedItem && selectedItem?.additionalData\">\r\n <span [class]=\"selectedItem?.additionalClass\">{{ selectedItem?.additionalData }} </span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #stringTypeTemplate>\r\n {{ selectedItem }}\r\n </ng-template>\r\n </span>\r\n <div\r\n *ngIf=\"loading\"\r\n [ngClass]=\"{ 'spinner-for-button-directive': loading }\"\r\n ></div>\r\n\r\n <ng-container *ngIf=\"!loading && !hideDropdownArrow\">\r\n <i\r\n *ngIf=\"!t.menuOpen\"\r\n class=\"mdi mdi-menu-down icon\"\r\n ></i>\r\n <i\r\n *ngIf=\"t.menuOpen\"\r\n class=\"mdi mdi-menu-up icon\"\r\n ></i>\r\n </ng-container>\r\n</button>\r\n<ng-content select=\".role-tooltip-icon\"></ng-content>\r\n<mat-menu\r\n backdropClass=\"single-select-dropdown\"\r\n [yPosition]=\"yPosition\"\r\n #contextMenu=\"matMenu\"\r\n>\r\n <ng-template matMenuContent>\r\n <div\r\n class=\"{{ config.classes }}\"\r\n [style.width.px]=\"width\"\r\n >\r\n <div\r\n class=\"gap\"\r\n *ngIf=\"config.showSearchBar\"\r\n ></div>\r\n <div\r\n *ngIf=\"showClearSelection\"\r\n class=\"clear-selection\"\r\n >\r\n <a\r\n (click)=\"clearSelectionClicked()\"\r\n [ngClass]=\"{ disabled: !selectedItem }\"\r\n >Clear selection</a\r\n >\r\n </div>\r\n <section\r\n *ngIf=\"config.showSearchBar\"\r\n class=\"search-bar\"\r\n >\r\n <i class=\"mi mdi-search search-icon\"></i>\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"searchFor\"\r\n placeholder=\"Search\"\r\n (ngModelChange)=\"updateHeight()\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n </section>\r\n <cdk-virtual-scroll-viewport\r\n class=\"dropdown-data-container\"\r\n itemSize=\"18\"\r\n [style.height.px]=\"heightOfCheckboxTooltipFilter\"\r\n >\r\n <ul\r\n class=\"single-select-ul\"\r\n [style.width.px]=\"width\"\r\n >\r\n <ng-container *ngIf=\"items && (items[0] | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *cdkVirtualFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n let last = last;\r\n trackBy: trackByFn\r\n \"\r\n [ngClass]=\"{\r\n active:\r\n selectedItem &&\r\n selectedItem[keyToUseForCheckingSelectedItem] ===\r\n item[keyToUseForCheckingSelectedItem],\r\n 'show-bottom-border': !last && borderbottomObject[item.id],\r\n disabled: item.isDisabled\r\n }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span [class]=\"item.class\"> {{ item[keyToUseForDisplay] }} </span>\r\n <ng-container *ngIf=\"item && item.additionalData\">\r\n <span\r\n class=\"ml-0\"\r\n [class]=\"item.additionalClass\"\r\n >\r\n {{ item?.additionalData }}\r\n </span>\r\n </ng-container>\r\n </li>\r\n\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-container>\r\n\r\n <ng-template #stringTypeTemplate>\r\n <ng-container\r\n *ngFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n [ngClass]=\"{ active: selectedItem && selectedItem === item }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span> {{ item }} </span>\r\n </li>\r\n </ng-container>\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-template>\r\n </ul>\r\n </cdk-virtual-scroll-viewport>\r\n </div>\r\n </ng-template>\r\n</mat-menu>\r\n\r\n<ng-template\r\n #noDataCase\r\n let-items=\"items\"\r\n>\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"(items | AnnafilterSearchedText: searchFor : keyToUseForDisplay)?.length === 0\"\r\n >\r\n <span> No data found </span>\r\n </li>\r\n</ng-template>\r\n", styles: ["#dropdown-trigger{height:1.5rem;background:#fff;border-radius:2px;border:1px solid #b7b7b7;width:100%;text-align:left;display:flex;align-items:center}#dropdown-trigger:disabled{background-color:#bdbdbd;opacity:.5}#dropdown-trigger:disabled .placeholder,#dropdown-trigger:disabled .icon{color:#000}.placeholder{color:#bdbdbd;width:100%;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;opacity:1!important}.icon{font-size:1.125rem;float:right;margin-left:auto}.search-bar{margin:0 7px 8px;border:1px solid #b7b7b7;height:24px;border-radius:2px}.search-bar input{outline:none;border:none;position:relative;bottom:4px;width:calc(100% - 29px);font-size:var(--dropdown-text-fs)}.search-bar .search-icon{font-size:var(--multi-select-dropdown-checkbox-fs);color:#9b9b9b;margin:5px}.search-bar .close-icon{cursor:pointer}ul{overflow-y:auto;padding-left:0;padding-bottom:0;margin-bottom:0;max-height:calc(50vh - 80px)!important}li{list-style-type:none;cursor:pointer;padding-inline:10px;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:2.14;letter-spacing:normal;color:#4a4a4a;width:100%}ul::-webkit-scrollbar{width:4px;height:4px}ul::-webkit-scrollbar-track{border:1px solid rgba(0,0,0,.1)}ul::-webkit-scrollbar-thumb{border-radius:4px;background-color:#0006!important;border:1px solid rgba(0,0,0,.2)}li:hover{background:#ebebeb}li.active{color:#fff;background:#268bff}span.selected-item{background:transparent;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;width:calc(100% - 22px);display:inline-block;vertical-align:middle}.ellipsify,li,span.selected-item{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}::ng-deep .cdk-overlay-container{z-index:1051}span.red-color-text{color:#f44336!important}span.additional-data-color-text{color:#b7b6b6!important}span.italic{font-style:italic}.spinner-for-button-directive{left:0;margin-left:auto}.spinner-for-button-directive span.additional-data-color-text{color:#000}::ng-deep .mat-menu-panel{min-height:auto!important}.small-text li{font-size:12px!important}.ml-0{margin-left:0}#dropdown-trigger:disabled{cursor:default!important}#dropdown-trigger:disabled span{color:#4a4a4a!important;cursor:default!important}::ng-deep .mat-mdc-menu-panel.mat-elevation-z8{box-shadow:var(--dropdown-box-shadow)}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content{background-color:#fff;padding:0!important}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content.mdc-list{background-color:#fff}::ng-deep .mat-mdc-menu-panel.mat-mdc-menu-panel{max-width:none!important}::ng-deep .mat-mdc-menu-panel .clear-selection{margin:0 7px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a{color:#268bff!important;text-decoration:underline!important;font-size:12px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a.disabled{color:#4a4a4a!important;pointer-events:none;cursor:not-allowed;opacity:.5}li{background-color:#fff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.5rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container li.disabled{opacity:.5;cursor:default}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.1875rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:#d3d3d3}::ng-deep ul.single-select-ul{max-height:none!important}li.show-bottom-border{border-bottom:1px solid #e6e6e6}::ng-deep .no-wrap-text ul li{line-height:1.41!important;padding-top:4px;padding-bottom:4px}::ng-deep .no-wrap-text ul li span{white-space:normal!important}.gap{height:9px}\n"], dependencies: [{ kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i3.MatMenuContent, selector: "ng-template[matMenuContent]" }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "directive", type: CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: AnnaFilterSearchedTextPipe, name: "AnnafilterSearchedText" }, { kind: "pipe", type: AnnaTypeofDataPipe, name: "AnnatypeofData" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
101
+ }
102
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaSingleSelectComponent, decorators: [{
103
+ type: Component,
104
+ args: [{ selector: "anna-core-single-select", changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
105
+ MatMenuModule,
106
+ NgIf,
107
+ NgClass,
108
+ FormsModule,
109
+ CdkVirtualScrollViewport,
110
+ CdkFixedSizeVirtualScroll,
111
+ CdkVirtualForOf,
112
+ NgTemplateOutlet,
113
+ NgFor,
114
+ AnnaFilterSearchedTextPipe,
115
+ AnnaTypeofDataPipe,
116
+ ], template: "<button\r\n id=\"dropdown-trigger\"\r\n #dropdown\r\n #t=\"matMenuTrigger\"\r\n (menuClosed)=\"dropdownClosed()\"\r\n (menuOpened)=\"dropdownOpened()\"\r\n [matMenuTriggerFor]=\"contextMenu\"\r\n [disabled]=\"disabled || loading\"\r\n>\r\n <span\r\n class=\"placeholder\"\r\n *ngIf=\"!selectedItem && config\"\r\n >{{ config.placeholder }}</span\r\n >\r\n <span\r\n class=\"selected-item\"\r\n [class]=\"selectedItem.class\"\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"selectedItem\"\r\n >\r\n <ng-container *ngIf=\"(selectedItem | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n {{ selectedItem[keyToUseForDisplay] }}\r\n <ng-container *ngIf=\"showAdditionalDataInSelectedText && selectedItem && selectedItem?.additionalData\">\r\n <span [class]=\"selectedItem?.additionalClass\">{{ selectedItem?.additionalData }} </span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #stringTypeTemplate>\r\n {{ selectedItem }}\r\n </ng-template>\r\n </span>\r\n <div\r\n *ngIf=\"loading\"\r\n [ngClass]=\"{ 'spinner-for-button-directive': loading }\"\r\n ></div>\r\n\r\n <ng-container *ngIf=\"!loading && !hideDropdownArrow\">\r\n <i\r\n *ngIf=\"!t.menuOpen\"\r\n class=\"mdi mdi-menu-down icon\"\r\n ></i>\r\n <i\r\n *ngIf=\"t.menuOpen\"\r\n class=\"mdi mdi-menu-up icon\"\r\n ></i>\r\n </ng-container>\r\n</button>\r\n<ng-content select=\".role-tooltip-icon\"></ng-content>\r\n<mat-menu\r\n backdropClass=\"single-select-dropdown\"\r\n [yPosition]=\"yPosition\"\r\n #contextMenu=\"matMenu\"\r\n>\r\n <ng-template matMenuContent>\r\n <div\r\n class=\"{{ config.classes }}\"\r\n [style.width.px]=\"width\"\r\n >\r\n <div\r\n class=\"gap\"\r\n *ngIf=\"config.showSearchBar\"\r\n ></div>\r\n <div\r\n *ngIf=\"showClearSelection\"\r\n class=\"clear-selection\"\r\n >\r\n <a\r\n (click)=\"clearSelectionClicked()\"\r\n [ngClass]=\"{ disabled: !selectedItem }\"\r\n >Clear selection</a\r\n >\r\n </div>\r\n <section\r\n *ngIf=\"config.showSearchBar\"\r\n class=\"search-bar\"\r\n >\r\n <i class=\"mi mdi-search search-icon\"></i>\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"searchFor\"\r\n placeholder=\"Search\"\r\n (ngModelChange)=\"updateHeight()\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n </section>\r\n <cdk-virtual-scroll-viewport\r\n class=\"dropdown-data-container\"\r\n itemSize=\"18\"\r\n [style.height.px]=\"heightOfCheckboxTooltipFilter\"\r\n >\r\n <ul\r\n class=\"single-select-ul\"\r\n [style.width.px]=\"width\"\r\n >\r\n <ng-container *ngIf=\"items && (items[0] | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *cdkVirtualFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n let last = last;\r\n trackBy: trackByFn\r\n \"\r\n [ngClass]=\"{\r\n active:\r\n selectedItem &&\r\n selectedItem[keyToUseForCheckingSelectedItem] ===\r\n item[keyToUseForCheckingSelectedItem],\r\n 'show-bottom-border': !last && borderbottomObject[item.id],\r\n disabled: item.isDisabled\r\n }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span [class]=\"item.class\"> {{ item[keyToUseForDisplay] }} </span>\r\n <ng-container *ngIf=\"item && item.additionalData\">\r\n <span\r\n class=\"ml-0\"\r\n [class]=\"item.additionalClass\"\r\n >\r\n {{ item?.additionalData }}\r\n </span>\r\n </ng-container>\r\n </li>\r\n\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-container>\r\n\r\n <ng-template #stringTypeTemplate>\r\n <ng-container\r\n *ngFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n [ngClass]=\"{ active: selectedItem && selectedItem === item }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span> {{ item }} </span>\r\n </li>\r\n </ng-container>\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-template>\r\n </ul>\r\n </cdk-virtual-scroll-viewport>\r\n </div>\r\n </ng-template>\r\n</mat-menu>\r\n\r\n<ng-template\r\n #noDataCase\r\n let-items=\"items\"\r\n>\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"(items | AnnafilterSearchedText: searchFor : keyToUseForDisplay)?.length === 0\"\r\n >\r\n <span> No data found </span>\r\n </li>\r\n</ng-template>\r\n", styles: ["#dropdown-trigger{height:1.5rem;background:#fff;border-radius:2px;border:1px solid #b7b7b7;width:100%;text-align:left;display:flex;align-items:center}#dropdown-trigger:disabled{background-color:#bdbdbd;opacity:.5}#dropdown-trigger:disabled .placeholder,#dropdown-trigger:disabled .icon{color:#000}.placeholder{color:#bdbdbd;width:100%;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;opacity:1!important}.icon{font-size:1.125rem;float:right;margin-left:auto}.search-bar{margin:0 7px 8px;border:1px solid #b7b7b7;height:24px;border-radius:2px}.search-bar input{outline:none;border:none;position:relative;bottom:4px;width:calc(100% - 29px);font-size:var(--dropdown-text-fs)}.search-bar .search-icon{font-size:var(--multi-select-dropdown-checkbox-fs);color:#9b9b9b;margin:5px}.search-bar .close-icon{cursor:pointer}ul{overflow-y:auto;padding-left:0;padding-bottom:0;margin-bottom:0;max-height:calc(50vh - 80px)!important}li{list-style-type:none;cursor:pointer;padding-inline:10px;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:2.14;letter-spacing:normal;color:#4a4a4a;width:100%}ul::-webkit-scrollbar{width:4px;height:4px}ul::-webkit-scrollbar-track{border:1px solid rgba(0,0,0,.1)}ul::-webkit-scrollbar-thumb{border-radius:4px;background-color:#0006!important;border:1px solid rgba(0,0,0,.2)}li:hover{background:#ebebeb}li.active{color:#fff;background:#268bff}span.selected-item{background:transparent;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;width:calc(100% - 22px);display:inline-block;vertical-align:middle}.ellipsify,li,span.selected-item{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}::ng-deep .cdk-overlay-container{z-index:1051}span.red-color-text{color:#f44336!important}span.additional-data-color-text{color:#b7b6b6!important}span.italic{font-style:italic}.spinner-for-button-directive{left:0;margin-left:auto}.spinner-for-button-directive span.additional-data-color-text{color:#000}::ng-deep .mat-menu-panel{min-height:auto!important}.small-text li{font-size:12px!important}.ml-0{margin-left:0}#dropdown-trigger:disabled{cursor:default!important}#dropdown-trigger:disabled span{color:#4a4a4a!important;cursor:default!important}::ng-deep .mat-mdc-menu-panel.mat-elevation-z8{box-shadow:var(--dropdown-box-shadow)}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content{background-color:#fff;padding:0!important}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content.mdc-list{background-color:#fff}::ng-deep .mat-mdc-menu-panel.mat-mdc-menu-panel{max-width:none!important}::ng-deep .mat-mdc-menu-panel .clear-selection{margin:0 7px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a{color:#268bff!important;text-decoration:underline!important;font-size:12px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a.disabled{color:#4a4a4a!important;pointer-events:none;cursor:not-allowed;opacity:.5}li{background-color:#fff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.5rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container li.disabled{opacity:.5;cursor:default}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.1875rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:#d3d3d3}::ng-deep ul.single-select-ul{max-height:none!important}li.show-bottom-border{border-bottom:1px solid #e6e6e6}::ng-deep .no-wrap-text ul li{line-height:1.41!important;padding-top:4px;padding-bottom:4px}::ng-deep .no-wrap-text ul li span{white-space:normal!important}.gap{height:9px}\n"] }]
117
+ }], ctorParameters: function () { return [{ type: i1.AnnaGlobalConfigService }, { type: i2.AnnaFilterSearchedTextPipe }]; }, propDecorators: { config: [{
118
+ type: Input
119
+ }], loading: [{
120
+ type: Input
121
+ }], showAdditionalDataInSelectedText: [{
122
+ type: Input
123
+ }], disabled: [{
124
+ type: Input
125
+ }], items: [{
126
+ type: Input
127
+ }], selectedItem: [{
128
+ type: Input
129
+ }], keyToUseForDisplay: [{
130
+ type: Input
131
+ }], keyToUseForCheckingSelectedItem: [{
132
+ type: Input
133
+ }], hideDropdownArrow: [{
134
+ type: Input
135
+ }], borderbottomObject: [{
136
+ type: Input
137
+ }], defaultDropdownHeight: [{
138
+ type: Input
139
+ }], itemsToHideInDropdownIds: [{
140
+ type: Input
141
+ }], showClearSelection: [{
142
+ type: Input
143
+ }], valueChanged: [{
144
+ type: Output
145
+ }], dropdownClosedEvent: [{
146
+ type: Output
147
+ }], dropdownOpenedEvent: [{
148
+ type: Output
149
+ }], clearSelectionClickedEvent: [{
150
+ type: Output
151
+ }], buttonElement: [{
152
+ type: ViewChild,
153
+ args: ["dropdown"]
154
+ }] } });
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-single-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-single-select/anna-single-select.component.ts","../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-single-select/anna-single-select.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable import/no-extraneous-dependencies */\r\nimport { CdkFixedSizeVirtualScroll, CdkVirtualForOf, CdkVirtualScrollViewport } from \"@angular/cdk/scrolling\";\r\nimport { NgClass, NgFor, NgIf, NgTemplateOutlet } from \"@angular/common\";\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild,\r\n} from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { isEqual } from \"lodash-es\";\r\n\r\nimport { ICustomSingleSelect } from \"../../../anna-core-shared-lib/models/anna-global-dropdown-config.model\";\r\nimport { AnnaFilterSearchedTextPipe } from \"../../../anna-core-shared-lib/pipes/annaFilterSearchedText.pipe\";\r\nimport { AnnaTypeofDataPipe } from \"../../../anna-core-shared-lib/pipes/annaTypeOfData.pipe\";\r\nimport { AnnaGlobalConfigService } from \"../../../anna-core-shared-lib/services/anna-global-config.service\";\r\nimport { SingleSelectIdText } from \"./models/anna-single-select.model\";\r\n\r\n@Component({\r\n    selector: \"anna-core-single-select\",\r\n    templateUrl: \"./anna-single-select.component.html\",\r\n    styleUrls: [\"./anna-single-select.component.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [\r\n        MatMenuModule,\r\n        NgIf,\r\n        NgClass,\r\n        FormsModule,\r\n        CdkVirtualScrollViewport,\r\n        CdkFixedSizeVirtualScroll,\r\n        CdkVirtualForOf,\r\n        NgTemplateOutlet,\r\n        NgFor,\r\n        AnnaFilterSearchedTextPipe,\r\n        AnnaTypeofDataPipe,\r\n    ],\r\n})\r\nexport class AnnaSingleSelectComponent implements OnInit, OnChanges {\r\n    @Input() config: ICustomSingleSelect;\r\n    @Input() loading: boolean = false;\r\n    @Input() showAdditionalDataInSelectedText: boolean = false;\r\n    @Input() disabled: boolean;\r\n    @Input() items: SingleSelectIdText[] | string[] | any;\r\n    @Input() selectedItem: SingleSelectIdText | string | any;\r\n    @Input() keyToUseForDisplay: string = \"text\";\r\n    @Input() keyToUseForCheckingSelectedItem: string = \"id\";\r\n    @Input() hideDropdownArrow: boolean = false;\r\n    @Input() borderbottomObject: any = {};\r\n    @Input() defaultDropdownHeight: number = null;\r\n    @Input() itemsToHideInDropdownIds: number[] = [];\r\n    @Input() showClearSelection: boolean = false;\r\n\r\n    @Output() valueChanged: EventEmitter<SingleSelectIdText> = new EventEmitter<SingleSelectIdText>();\r\n    @Output() dropdownClosedEvent: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() dropdownOpenedEvent: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() clearSelectionClickedEvent: EventEmitter<any> = new EventEmitter<any>();\r\n    searchFor: string;\r\n    yPosition: any = \"above\";\r\n    width: number;\r\n    heightOfCheckboxTooltipFilter: number;\r\n\r\n    @ViewChild(\"dropdown\") buttonElement: ElementRef;\r\n\r\n    constructor(\r\n        private annaGlobalConfig: AnnaGlobalConfigService,\r\n        private searchFilterPipe: AnnaFilterSearchedTextPipe,\r\n    ) {}\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.config?.currentValue) {\r\n            this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };\r\n        }\r\n\r\n        if (changes.items?.currentValue) {\r\n            if (this.defaultDropdownHeight) this.heightOfCheckboxTooltipFilter = this.defaultDropdownHeight;\r\n            else this.heightOfCheckboxTooltipFilter = this.items.length > 7 ? 200 : 25.68 * this.items.length;\r\n        }\r\n\r\n        if (changes.itemsToHideInDropdownIds?.currentValue) {\r\n            this.items = this.items.filter(\r\n                (item: SingleSelectIdText) => !this.itemsToHideInDropdownIds.includes(item.id),\r\n            );\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };\r\n        this.setPostion();\r\n    }\r\n\r\n    trackByFn(index: number) {\r\n        return index;\r\n    }\r\n\r\n    itemSelected(item: SingleSelectIdText, event: MouseEvent) {\r\n        if (item?.isDisabled) {\r\n            event.stopPropagation();\r\n            return;\r\n        }\r\n        if (!isEqual(this.selectedItem, item)) {\r\n            this.valueChanged.emit(item);\r\n        }\r\n        this.selectedItem = item;\r\n    }\r\n\r\n    dropdownOpened() {\r\n        this.searchFor = \"\";\r\n        this.updateHeight();\r\n        this.width = this.buttonElement.nativeElement.offsetWidth;\r\n        this.dropdownOpenedEvent.emit();\r\n    }\r\n\r\n    dropdownClosed() {\r\n        this.dropdownClosedEvent.emit();\r\n    }\r\n\r\n    clearSelectionClicked() {\r\n        this.selectedItem = null;\r\n        this.clearSelectionClickedEvent.emit();\r\n    }\r\n\r\n    setPostion() {\r\n        if (this.config && this.config.position === \"TOP\") {\r\n            this.yPosition = \"above\";\r\n        } else if (this.config && this.config.position === \"BOTTOM\") {\r\n            this.yPosition = \"below\";\r\n        }\r\n    }\r\n    updateHeight() {\r\n        const items = this.searchFilterPipe.transform(this.items, this.searchFor, this.keyToUseForDisplay);\r\n        if (items.length > 7) {\r\n            this.heightOfCheckboxTooltipFilter = 200;\r\n        } else if (items.length > 0) {\r\n            this.heightOfCheckboxTooltipFilter = 25.68 * items.length;\r\n        } else {\r\n            this.heightOfCheckboxTooltipFilter = 25.68;\r\n        }\r\n    }\r\n}\r\n","<button\r\n    id=\"dropdown-trigger\"\r\n    #dropdown\r\n    #t=\"matMenuTrigger\"\r\n    (menuClosed)=\"dropdownClosed()\"\r\n    (menuOpened)=\"dropdownOpened()\"\r\n    [matMenuTriggerFor]=\"contextMenu\"\r\n    [disabled]=\"disabled || loading\"\r\n>\r\n    <span\r\n        class=\"placeholder\"\r\n        *ngIf=\"!selectedItem && config\"\r\n        >{{ config.placeholder }}</span\r\n    >\r\n    <span\r\n        class=\"selected-item\"\r\n        [class]=\"selectedItem.class\"\r\n        annaCoreShowEllipsisTextOnHover\r\n        *ngIf=\"selectedItem\"\r\n    >\r\n        <ng-container *ngIf=\"(selectedItem | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n            {{ selectedItem[keyToUseForDisplay] }}\r\n            <ng-container *ngIf=\"showAdditionalDataInSelectedText && selectedItem && selectedItem?.additionalData\">\r\n                <span [class]=\"selectedItem?.additionalClass\">{{ selectedItem?.additionalData }} </span>\r\n            </ng-container>\r\n        </ng-container>\r\n        <ng-template #stringTypeTemplate>\r\n            {{ selectedItem }}\r\n        </ng-template>\r\n    </span>\r\n    <div\r\n        *ngIf=\"loading\"\r\n        [ngClass]=\"{ 'spinner-for-button-directive': loading }\"\r\n    ></div>\r\n\r\n    <ng-container *ngIf=\"!loading && !hideDropdownArrow\">\r\n        <i\r\n            *ngIf=\"!t.menuOpen\"\r\n            class=\"mdi mdi-menu-down icon\"\r\n        ></i>\r\n        <i\r\n            *ngIf=\"t.menuOpen\"\r\n            class=\"mdi mdi-menu-up icon\"\r\n        ></i>\r\n    </ng-container>\r\n</button>\r\n<ng-content select=\".role-tooltip-icon\"></ng-content>\r\n<mat-menu\r\n    backdropClass=\"single-select-dropdown\"\r\n    [yPosition]=\"yPosition\"\r\n    #contextMenu=\"matMenu\"\r\n>\r\n    <ng-template matMenuContent>\r\n        <div\r\n            class=\"{{ config.classes }}\"\r\n            [style.width.px]=\"width\"\r\n        >\r\n            <div\r\n                class=\"gap\"\r\n                *ngIf=\"config.showSearchBar\"\r\n            ></div>\r\n            <div\r\n                *ngIf=\"showClearSelection\"\r\n                class=\"clear-selection\"\r\n            >\r\n                <a\r\n                    (click)=\"clearSelectionClicked()\"\r\n                    [ngClass]=\"{ disabled: !selectedItem }\"\r\n                    >Clear selection</a\r\n                >\r\n            </div>\r\n            <section\r\n                *ngIf=\"config.showSearchBar\"\r\n                class=\"search-bar\"\r\n            >\r\n                <i class=\"mi mdi-search search-icon\"></i>\r\n                <input\r\n                    type=\"text\"\r\n                    [(ngModel)]=\"searchFor\"\r\n                    placeholder=\"Search\"\r\n                    (ngModelChange)=\"updateHeight()\"\r\n                    (click)=\"$event.stopPropagation()\"\r\n                />\r\n            </section>\r\n            <cdk-virtual-scroll-viewport\r\n                class=\"dropdown-data-container\"\r\n                itemSize=\"18\"\r\n                [style.height.px]=\"heightOfCheckboxTooltipFilter\"\r\n            >\r\n                <ul\r\n                    class=\"single-select-ul\"\r\n                    [style.width.px]=\"width\"\r\n                >\r\n                    <ng-container *ngIf=\"items && (items[0] | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n                        <li\r\n                            annaCoreShowEllipsisTextOnHover\r\n                            *cdkVirtualFor=\"\r\n                                let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n                                let last = last;\r\n                                trackBy: trackByFn\r\n                            \"\r\n                            [ngClass]=\"{\r\n                                active:\r\n                                    selectedItem &&\r\n                                    selectedItem[keyToUseForCheckingSelectedItem] ===\r\n                                        item[keyToUseForCheckingSelectedItem],\r\n                                'show-bottom-border': !last && borderbottomObject[item.id],\r\n                                disabled: item.isDisabled\r\n                            }\"\r\n                            (click)=\"itemSelected(item, $event)\"\r\n                        >\r\n                            <span [class]=\"item.class\"> {{ item[keyToUseForDisplay] }} </span>\r\n                            <ng-container *ngIf=\"item && item.additionalData\">\r\n                                <span\r\n                                    class=\"ml-0\"\r\n                                    [class]=\"item.additionalClass\"\r\n                                >\r\n                                    {{ item?.additionalData }}\r\n                                </span>\r\n                            </ng-container>\r\n                        </li>\r\n\r\n                        <ng-container\r\n                            [ngTemplateOutlet]=\"noDataCase\"\r\n                            [ngTemplateOutletContext]=\"{ items: items }\"\r\n                        ></ng-container>\r\n                    </ng-container>\r\n\r\n                    <ng-template #stringTypeTemplate>\r\n                        <ng-container\r\n                            *ngFor=\"\r\n                                let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n                                trackBy: trackByFn\r\n                            \"\r\n                        >\r\n                            <li\r\n                                annaCoreShowEllipsisTextOnHover\r\n                                [ngClass]=\"{ active: selectedItem && selectedItem === item }\"\r\n                                (click)=\"itemSelected(item, $event)\"\r\n                            >\r\n                                <span> {{ item }} </span>\r\n                            </li>\r\n                        </ng-container>\r\n                        <ng-container\r\n                            [ngTemplateOutlet]=\"noDataCase\"\r\n                            [ngTemplateOutletContext]=\"{ items: items }\"\r\n                        ></ng-container>\r\n                    </ng-template>\r\n                </ul>\r\n            </cdk-virtual-scroll-viewport>\r\n        </div>\r\n    </ng-template>\r\n</mat-menu>\r\n\r\n<ng-template\r\n    #noDataCase\r\n    let-items=\"items\"\r\n>\r\n    <li\r\n        annaCoreShowEllipsisTextOnHover\r\n        *ngIf=\"(items | AnnafilterSearchedText: searchFor : keyToUseForDisplay)?.length === 0\"\r\n    >\r\n        <span> No data found </span>\r\n    </li>\r\n</ng-template>\r\n"]}
@@ -0,0 +1,12 @@
1
+ export class SingleSelectIdText {
2
+ constructor(id, text, className, additionalClass, additionalData, isSelected, isDisabled) {
3
+ this.id = id;
4
+ this.text = text;
5
+ this.class = className;
6
+ this.additionalClass = additionalClass;
7
+ this.additionalData = additionalData;
8
+ this.isSelected = isSelected;
9
+ this.isDisabled = isDisabled;
10
+ }
11
+ }
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5uYS1zaW5nbGUtc2VsZWN0Lm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5uYS1jb3JlL3NyYy9saWIvYW5uYS1kcm9wZG93bi1saWIvY29tcG9uZW50cy9hbm5hLXNpbmdsZS1zZWxlY3QvbW9kZWxzL2FubmEtc2luZ2xlLXNlbGVjdC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sa0JBQWtCO0lBUTNCLFlBQ0ksRUFBTyxFQUNQLElBQVksRUFDWixTQUFrQixFQUNsQixlQUF3QixFQUN4QixjQUF1QixFQUN2QixVQUFvQixFQUNwQixVQUFvQjtRQUVwQixJQUFJLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQztRQUNiLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsU0FBUyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxlQUFlLEdBQUcsZUFBZSxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO1FBQzdCLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO0lBQ2pDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBTaW5nbGVTZWxlY3RJZFRleHQge1xyXG4gICAgaWQ6IGFueTtcclxuICAgIHRleHQ6IHN0cmluZztcclxuICAgIGNsYXNzPzogc3RyaW5nO1xyXG4gICAgYWRkaXRpb25hbENsYXNzPzogc3RyaW5nO1xyXG4gICAgYWRkaXRpb25hbERhdGE/OiBzdHJpbmc7XHJcbiAgICBpc1NlbGVjdGVkPzogYm9vbGVhbjtcclxuICAgIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgaWQ6IGFueSxcclxuICAgICAgICB0ZXh0OiBzdHJpbmcsXHJcbiAgICAgICAgY2xhc3NOYW1lPzogc3RyaW5nLFxyXG4gICAgICAgIGFkZGl0aW9uYWxDbGFzcz86IHN0cmluZyxcclxuICAgICAgICBhZGRpdGlvbmFsRGF0YT86IHN0cmluZyxcclxuICAgICAgICBpc1NlbGVjdGVkPzogYm9vbGVhbixcclxuICAgICAgICBpc0Rpc2FibGVkPzogYm9vbGVhbixcclxuICAgICkge1xyXG4gICAgICAgIHRoaXMuaWQgPSBpZDtcclxuICAgICAgICB0aGlzLnRleHQgPSB0ZXh0O1xyXG4gICAgICAgIHRoaXMuY2xhc3MgPSBjbGFzc05hbWU7XHJcbiAgICAgICAgdGhpcy5hZGRpdGlvbmFsQ2xhc3MgPSBhZGRpdGlvbmFsQ2xhc3M7XHJcbiAgICAgICAgdGhpcy5hZGRpdGlvbmFsRGF0YSA9IGFkZGl0aW9uYWxEYXRhO1xyXG4gICAgICAgIHRoaXMuaXNTZWxlY3RlZCA9IGlzU2VsZWN0ZWQ7XHJcbiAgICAgICAgdGhpcy5pc0Rpc2FibGVkID0gaXNEaXNhYmxlZDtcclxuICAgIH1cclxufVxyXG4iXX0=