igniteui-angular 18.1.6 → 18.1.7

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.
@@ -23,4 +23,4 @@ export var PivotSummaryPosition;
23
23
  PivotSummaryPosition["Top"] = "top";
24
24
  PivotSummaryPosition["Bottom"] = "bottom";
25
25
  })(PivotSummaryPosition || (PivotSummaryPosition = {}));
26
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-grid.interface.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/pivot-grid/pivot-grid.interface.ts"],"names":[],"mappings":"AAOA;;EAEE;AACF,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAC9B,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO;IACtF,qBAAqB,EAAE,GAAG,EAAE,wBAAwB,EAAE,GAAG;CAC5D,CAAC;AAqMF,qBAAqB;AACrB,mDAAmD;AACnD,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC1B,yDAAG,CAAA;IACH,+DAAM,CAAA;IACN,+DAAM,CAAA;AACV,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAGD,MAAM,CAAN,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC1B,2CAAqB,CAAA;IACrB,+CAAyB,CAAA;AAC7B,CAAC,EAHW,kBAAkB,KAAlB,kBAAkB,QAG7B;AAED,MAAM,CAAN,IAAY,oBAGX;AAHD,WAAY,oBAAoB;IAC5B,mCAAW,CAAA;IACX,yCAAiB,CAAA;AACrB,CAAC,EAHW,oBAAoB,KAApB,oBAAoB,QAG/B","sourcesContent":["import { IDataCloneStrategy } from '../../data-operations/data-clone-strategy';\nimport { GridColumnDataType } from '../../data-operations/data-util';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { SortingDirection } from '../../data-operations/sorting-strategy';\nimport { ColumnType } from '../common/grid.interface';\n\n\n/**\n* Default pivot keys used for data processing in the pivot pipes.\n*/\nexport const DEFAULT_PIVOT_KEYS = {\n    aggregations: 'aggregations', records: 'records', children: 'children', level: 'level',\n    rowDimensionSeparator: '_', columnDimensionSeparator: '-'\n};\n\n/**\n * Event emitted when dimension collection for rows, columns of filters is changed.\n */\nexport interface IDimensionsChange {\n    /** The new list of dimensions. */\n    dimensions: IPivotDimension[],\n    /** The dimension list type - Row, Column or Filter. */\n    dimensionCollectionType: PivotDimensionType\n}\n\n/**\n* Event emitted when values list is changed.\n*/\nexport interface IValuesChange {\n    /** The new list of values. */\n    values: IPivotValue[]\n}\n\n/**\n * Event emitted when pivot configuration is changed.\n */\nexport interface IPivotConfigurationChangedEventArgs {\n    /** The new configuration. */\n    pivotConfiguration: IPivotConfiguration\n}\n\n/**\n* Interface describing Pivot data processing for dimensions.\n* Should contain a process method and return records hierarchy based on the provided dimensions.\n*/\nexport interface IPivotDimensionStrategy {\n    /* blazorCSSuppress */\n    process(collection: any,\n        dimensions: IPivotDimension[],\n        values: IPivotValue[],\n        cloneStrategy: IDataCloneStrategy,\n        pivotKeys?: IPivotKeys): any[];\n}\n\n/**\n* Interface describing a PivotAggregation function.\n* Accepts an array of extracted data members and a array of the original data records.\n*/\nexport type PivotAggregation = (members: any[], data: any[]) => any;\n\n/* marshalByValue */\n/**\n* Interface describing a IPivotAggregator class.\n* Used for specifying custom aggregator lists.\n*/\nexport interface IPivotAggregator {\n    /** Aggregation unique key. */\n    key: string;\n    /** Aggregation label to show in the UI. */\n    label: string;\n    /**\n     * Aggregation name that will be used from a list of predefined aggregations.\n     * If not set will use the specified aggregator function.\n     */\n    aggregatorName?: PivotAggregationType;\n\n    /* blazorAlternateType: AggregatorEventHandler */\n    /* blazorOnlyScript */\n    /**\n     * Aggregator function can be a custom implementation of `PivotAggregation`, or\n     * use predefined ones from `IgxPivotAggregate` and its variants.\n     */\n    aggregator?: (members: any[], data?: any[]) => any;\n}\n\n/* marshalByValue */\n/**\n* Configuration of the pivot grid.\n*/\nexport interface IPivotConfiguration {\n    /** A strategy to transform the rows. */\n    rowStrategy?: IPivotDimensionStrategy | null;\n    /** A strategy to transform the columns. */\n    columnStrategy?: IPivotDimensionStrategy | null;\n    /** A list of the rows. */\n    rows: IPivotDimension[] | null;\n    /** A list of the columns. */\n    columns: IPivotDimension[] | null;\n    /** A list of the values. */\n    values: IPivotValue[] | null;\n    /** Dimensions to be displayed in the filter area. */\n    filters?: IPivotDimension[] | null;\n    /** Pivot data keys used for data generation. Can be used for custom remote scenarios where the data is pre-populated. */\n    pivotKeys?: IPivotKeys;\n}\n\n/* blazorElement */\n/* marshalByValue */\n/**\n* Configuration of a pivot dimension.\n*/\nexport interface IPivotDimension {\n    /** Allows defining a hierarchy when multiple sub groups need to be extracted from single member. */\n    childLevel?: IPivotDimension;\n    /** Field name to use in order to extract value. */\n    memberName: string;\n\n    /* csTreatAsEvent: MemberFunctionHandler */\n    /* blazorOnlyScript */\n    /** Function that extracts the value */\n    memberFunction?: (data: any) => any;\n    /** Display name to show instead of the field name of this value. **/\n    displayName?: string;\n    /** Enables/Disables a particular dimension from pivot structure. */\n    enabled: boolean;\n    /**\n     * A predefined or defined via the `igxPivotSelector` filter expression tree for the current dimension to be applied in the filter pipe.\n     * */\n    filter?: IFilteringExpressionsTree | null;\n    /** Enable/disable sorting for a particular dimension. True by default. */\n    sortable?: boolean;\n    /**\n     * The sorting direction of the current dimension. Determines the order in which the values will appear in the related dimension.\n     */\n    sortDirection?: SortingDirection;\n    /**\n     * The dataType of the related data field.\n     */\n    dataType?: GridColumnDataType;\n    /** The width of the dimension cells to be rendered.Can be pixel, % or \"auto\". */\n    width?: string;\n    /** Level of the dimension. */\n    level?: number;\n    /** @hidden @internal */\n    autoWidth?: number;\n    horizontalSummary? : boolean;\n}\n\n/* marshalByValue */\n/**\n* Configuration of a pivot value aggregation.\n*/\nexport interface IPivotValue {\n    /** Field name to use in order to extract value. */\n    member: string;\n    /** Display name to show instead of member for the column header of this value. **/\n    displayName?: string;\n    /**\n     * Active aggregator definition with key, label and aggregator.\n     */\n    aggregate: IPivotAggregator;\n    /**\n     * List of aggregates to show in aggregate drop-down.\n     */\n    aggregateList?: IPivotAggregator[];\n    /** Enables/Disables a particular value from pivot aggregation. */\n    enabled: boolean;\n    /**  Allow conditionally styling of the IgxPivotGrid cells. */\n    styles?: any;\n    /** Enables a data type specific template of the cells */\n    dataType?: GridColumnDataType;\n\n    /* csTreatAsEvent: PivotValueFormatterEventHandler */\n    /* blazorOnlyScript */\n    /** Applies display format to cell values. */\n    formatter?: (value: any, rowData?: IPivotGridRecord, columnData?: IPivotGridColumn) => any;\n}\n\n/** Interface describing the Pivot column data.\n*  Contains information on the related column dimensions and their values.\n*/\nexport interface IPivotGridColumn {\n        field: string,\n        /* blazorSuppress */\n        /** Gets/Sets the group value associated with the related column dimension by its memberName. **/\n        dimensionValues: Map<string, string>;\n        /** List of dimensions associated with the column.**/\n        dimensions: IPivotDimension[];\n        value: IPivotValue\n}\n\n/* marshalByValue */\n/** Interface describing the Pivot data keys used for data generation.\n*  Can be used for custom remote scenarios where the data is pre-populated.\n*/\nexport interface IPivotKeys {\n    /** Field that stores children for hierarchy building. */\n    children: string;\n    /** Field that stores reference to the original data records. */\n    records: string;\n    /** Field that stores aggregation values. */\n    aggregations: string;\n    /** Field that stores dimension level based on its hierarchy. */\n    level: string;\n    /** Separator used when generating the unique column field values. */\n    columnDimensionSeparator: string;\n    /** Separator used when generating the unique row field values. */\n    rowDimensionSeparator: string;\n}\n\n/* mustCoerceToInt */\n/** The dimension types - Row, Column or Filter. */\nexport enum PivotDimensionType {\n    Row,\n    Column,\n    Filter\n}\n\n\nexport enum PivotRowLayoutType {\n    Vertical = \"vertical\",\n    Horizontal = \"horizontal\"\n}\n\nexport enum PivotSummaryPosition {\n    Top = \"top\",\n    Bottom = \"bottom\"\n}\n\nexport interface IPivotUISettings {\n    showConfiguration?: boolean;\n    showRowHeaders?: boolean;\n    rowLayout?: PivotRowLayoutType;\n    horizontalSummariesPosition?: PivotSummaryPosition;\n}\n\nexport type PivotAggregationType = 'SUM' | 'AVG' | 'MIN' | 'MAX' | 'COUNT' | 'LATEST' | 'EARLIEST' ;\n\n/** Interface describing the pivot dimension data.\n* Contains additional information needed to render dimension headers.\n*/\nexport interface IPivotDimensionData {\n    /** Associated column definition. */\n    column: ColumnType;\n    /** Associated dimension definition. */\n    dimension: IPivotDimension;\n    /** List of previous dimension groups. */\n    prevDimensions: IPivotDimension[];\n    /** Whether this a child dimension. */\n    isChild?: boolean;\n}\n\nexport interface PivotRowHeaderGroupType {\n    rowIndex: number;\n    parent: any;\n    header: any;\n    headerID: string;\n    grid: any;\n}\n\nexport interface DimensionValueType {\n    value: string;\n    children: Map<string, string | DimensionValueType>;\n}\n\nexport interface IPivotGridRecord {\n    /* blazorSuppress */\n    /** Gets/Sets the group value associated with the related row dimension by its memberName. **/\n    dimensionValues: Map<string, string>;\n    /* blazorSuppress */\n    /** Gets/Sets the aggregation value associated with the value path. Value path depends on configured column dimension hierarchy and values.**/\n    aggregationValues: Map<string, any>;\n    /* blazorSuppress */\n    /** List of children records in case any row dimension member contain a hierarchy. Each dimension member contains its own hierarchy, which you can get by its memberName. **/\n    children?: Map<string, IPivotGridRecord[]>;\n    /** List of original data records associated with the current pivoted data. **/\n    records?: any[];\n     /** Record level**/\n    level?: number;\n    /** List of dimensions associated with the record.**/\n    dimensions: IPivotDimension[];\n    /** If set, it specifies the name of the dimension, that has total record enabled. */\n    totalRecordDimensionName?: string;\n    /** The index of the record in the total view */\n    dataIndex?: number;\n}\n\nexport interface IPivotGridGroupRecord extends IPivotGridRecord {\n    height?: number;\n    rowSpan?: number;\n}\n\nexport interface IPivotGridHorizontalGroup {\n    value?: string;\n    rootDimension?: IPivotDimension;\n    dimensions?: IPivotDimension[];\n    records?: IPivotGridRecord[];\n    rowStart?: number;\n    rowSpan?: number;\n    colStart?: number;\n    colSpan?: number;\n}\n\nexport interface IgxPivotGridValueTemplateContext {\n    $implicit: IPivotValue;\n}\n"]}
26
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-grid.interface.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/pivot-grid/pivot-grid.interface.ts"],"names":[],"mappings":"AAOA;;EAEE;AACF,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAC9B,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO;IACtF,qBAAqB,EAAE,GAAG,EAAE,wBAAwB,EAAE,GAAG;CAC5D,CAAC;AAyMF,qBAAqB;AACrB,mDAAmD;AACnD,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC1B,yDAAG,CAAA;IACH,+DAAM,CAAA;IACN,+DAAM,CAAA;AACV,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAGD,MAAM,CAAN,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC1B,2CAAqB,CAAA;IACrB,+CAAyB,CAAA;AAC7B,CAAC,EAHW,kBAAkB,KAAlB,kBAAkB,QAG7B;AAED,MAAM,CAAN,IAAY,oBAGX;AAHD,WAAY,oBAAoB;IAC5B,mCAAW,CAAA;IACX,yCAAiB,CAAA;AACrB,CAAC,EAHW,oBAAoB,KAApB,oBAAoB,QAG/B","sourcesContent":["import { IDataCloneStrategy } from '../../data-operations/data-clone-strategy';\nimport { GridColumnDataType } from '../../data-operations/data-util';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { SortingDirection } from '../../data-operations/sorting-strategy';\nimport { ColumnType } from '../common/grid.interface';\n\n\n/**\n* Default pivot keys used for data processing in the pivot pipes.\n*/\nexport const DEFAULT_PIVOT_KEYS = {\n    aggregations: 'aggregations', records: 'records', children: 'children', level: 'level',\n    rowDimensionSeparator: '_', columnDimensionSeparator: '-'\n};\n\n/**\n * Event emitted when dimension collection for rows, columns of filters is changed.\n */\nexport interface IDimensionsChange {\n    /** The new list of dimensions. */\n    dimensions: IPivotDimension[],\n    /** The dimension list type - Row, Column or Filter. */\n    dimensionCollectionType: PivotDimensionType\n}\n\n/**\n* Event emitted when values list is changed.\n*/\nexport interface IValuesChange {\n    /** The new list of values. */\n    values: IPivotValue[]\n}\n\n/**\n * Event emitted when pivot configuration is changed.\n */\nexport interface IPivotConfigurationChangedEventArgs {\n    /** The new configuration. */\n    pivotConfiguration: IPivotConfiguration\n}\n\n/**\n* Interface describing Pivot data processing for dimensions.\n* Should contain a process method and return records hierarchy based on the provided dimensions.\n*/\nexport interface IPivotDimensionStrategy {\n    /* blazorCSSuppress */\n    process(collection: any,\n        dimensions: IPivotDimension[],\n        values: IPivotValue[],\n        cloneStrategy: IDataCloneStrategy,\n        pivotKeys?: IPivotKeys): any[];\n}\n\n/**\n* Interface describing a PivotAggregation function.\n* Accepts an array of extracted data members and a array of the original data records.\n*/\nexport type PivotAggregation = (members: any[], data: any[]) => any;\n\n/* marshalByValue */\n/* jsonAPIComplexObject */\n/**\n* Interface describing a IPivotAggregator class.\n* Used for specifying custom aggregator lists.\n*/\nexport interface IPivotAggregator {\n    /** Aggregation unique key. */\n    key: string;\n    /** Aggregation label to show in the UI. */\n    label: string;\n    /**\n     * Aggregation name that will be used from a list of predefined aggregations.\n     * If not set will use the specified aggregator function.\n     */\n    aggregatorName?: PivotAggregationType;\n\n    /* blazorAlternateType: AggregatorEventHandler */\n    /* blazorOnlyScript */\n    /**\n     * Aggregator function can be a custom implementation of `PivotAggregation`, or\n     * use predefined ones from `IgxPivotAggregate` and its variants.\n     */\n    aggregator?: (members: any[], data?: any[]) => any;\n}\n\n/* marshalByValue */\n/* jsonAPIComplexObject */\n/**\n* Configuration of the pivot grid.\n*/\nexport interface IPivotConfiguration {\n    /** A strategy to transform the rows. */\n    rowStrategy?: IPivotDimensionStrategy | null;\n    /** A strategy to transform the columns. */\n    columnStrategy?: IPivotDimensionStrategy | null;\n    /** A list of the rows. */\n    rows: IPivotDimension[] | null;\n    /** A list of the columns. */\n    columns: IPivotDimension[] | null;\n    /** A list of the values. */\n    values: IPivotValue[] | null;\n    /** Dimensions to be displayed in the filter area. */\n    filters?: IPivotDimension[] | null;\n    /** Pivot data keys used for data generation. Can be used for custom remote scenarios where the data is pre-populated. */\n    pivotKeys?: IPivotKeys;\n}\n\n/* blazorElement */\n/* marshalByValue */\n/* jsonAPIComplexObject */\n/**\n* Configuration of a pivot dimension.\n*/\nexport interface IPivotDimension {\n    /** Allows defining a hierarchy when multiple sub groups need to be extracted from single member. */\n    childLevel?: IPivotDimension;\n    /** Field name to use in order to extract value. */\n    memberName: string;\n\n    /* csTreatAsEvent: MemberFunctionHandler */\n    /* blazorOnlyScript */\n    /** Function that extracts the value */\n    memberFunction?: (data: any) => any;\n    /** Display name to show instead of the field name of this value. **/\n    displayName?: string;\n    /** Enables/Disables a particular dimension from pivot structure. */\n    enabled: boolean;\n    /**\n     * A predefined or defined via the `igxPivotSelector` filter expression tree for the current dimension to be applied in the filter pipe.\n     * */\n    filter?: IFilteringExpressionsTree | null;\n    /** Enable/disable sorting for a particular dimension. True by default. */\n    sortable?: boolean;\n    /**\n     * The sorting direction of the current dimension. Determines the order in which the values will appear in the related dimension.\n     */\n    sortDirection?: SortingDirection;\n    /**\n     * The dataType of the related data field.\n     */\n    dataType?: GridColumnDataType;\n    /** The width of the dimension cells to be rendered.Can be pixel, % or \"auto\". */\n    width?: string;\n    /** Level of the dimension. */\n    level?: number;\n    /** @hidden @internal */\n    autoWidth?: number;\n    horizontalSummary? : boolean;\n}\n\n/* marshalByValue */\n/* jsonAPIComplexObject */\n/**\n* Configuration of a pivot value aggregation.\n*/\nexport interface IPivotValue {\n    /** Field name to use in order to extract value. */\n    member: string;\n    /** Display name to show instead of member for the column header of this value. **/\n    displayName?: string;\n    /**\n     * Active aggregator definition with key, label and aggregator.\n     */\n    aggregate: IPivotAggregator;\n    /**\n     * List of aggregates to show in aggregate drop-down.\n     */\n    aggregateList?: IPivotAggregator[];\n    /** Enables/Disables a particular value from pivot aggregation. */\n    enabled: boolean;\n    /**  Allow conditionally styling of the IgxPivotGrid cells. */\n    styles?: any;\n    /** Enables a data type specific template of the cells */\n    dataType?: GridColumnDataType;\n\n    /* csTreatAsEvent: PivotValueFormatterEventHandler */\n    /* blazorOnlyScript */\n    /** Applies display format to cell values. */\n    formatter?: (value: any, rowData?: IPivotGridRecord, columnData?: IPivotGridColumn) => any;\n}\n\n/** Interface describing the Pivot column data.\n*  Contains information on the related column dimensions and their values.\n*/\nexport interface IPivotGridColumn {\n        field: string,\n        /* blazorSuppress */\n        /** Gets/Sets the group value associated with the related column dimension by its memberName. **/\n        dimensionValues: Map<string, string>;\n        /** List of dimensions associated with the column.**/\n        dimensions: IPivotDimension[];\n        value: IPivotValue\n}\n\n/* marshalByValue */\n/** Interface describing the Pivot data keys used for data generation.\n*  Can be used for custom remote scenarios where the data is pre-populated.\n*/\nexport interface IPivotKeys {\n    /** Field that stores children for hierarchy building. */\n    children: string;\n    /** Field that stores reference to the original data records. */\n    records: string;\n    /** Field that stores aggregation values. */\n    aggregations: string;\n    /** Field that stores dimension level based on its hierarchy. */\n    level: string;\n    /** Separator used when generating the unique column field values. */\n    columnDimensionSeparator: string;\n    /** Separator used when generating the unique row field values. */\n    rowDimensionSeparator: string;\n}\n\n/* mustCoerceToInt */\n/** The dimension types - Row, Column or Filter. */\nexport enum PivotDimensionType {\n    Row,\n    Column,\n    Filter\n}\n\n\nexport enum PivotRowLayoutType {\n    Vertical = \"vertical\",\n    Horizontal = \"horizontal\"\n}\n\nexport enum PivotSummaryPosition {\n    Top = \"top\",\n    Bottom = \"bottom\"\n}\n\nexport interface IPivotUISettings {\n    showConfiguration?: boolean;\n    showRowHeaders?: boolean;\n    rowLayout?: PivotRowLayoutType;\n    horizontalSummariesPosition?: PivotSummaryPosition;\n}\n\nexport type PivotAggregationType = 'SUM' | 'AVG' | 'MIN' | 'MAX' | 'COUNT' | 'LATEST' | 'EARLIEST' ;\n\n/** Interface describing the pivot dimension data.\n* Contains additional information needed to render dimension headers.\n*/\nexport interface IPivotDimensionData {\n    /** Associated column definition. */\n    column: ColumnType;\n    /** Associated dimension definition. */\n    dimension: IPivotDimension;\n    /** List of previous dimension groups. */\n    prevDimensions: IPivotDimension[];\n    /** Whether this a child dimension. */\n    isChild?: boolean;\n}\n\nexport interface PivotRowHeaderGroupType {\n    rowIndex: number;\n    parent: any;\n    header: any;\n    headerID: string;\n    grid: any;\n}\n\nexport interface DimensionValueType {\n    value: string;\n    children: Map<string, string | DimensionValueType>;\n}\n\nexport interface IPivotGridRecord {\n    /* blazorSuppress */\n    /** Gets/Sets the group value associated with the related row dimension by its memberName. **/\n    dimensionValues: Map<string, string>;\n    /* blazorSuppress */\n    /** Gets/Sets the aggregation value associated with the value path. Value path depends on configured column dimension hierarchy and values.**/\n    aggregationValues: Map<string, any>;\n    /* blazorSuppress */\n    /** List of children records in case any row dimension member contain a hierarchy. Each dimension member contains its own hierarchy, which you can get by its memberName. **/\n    children?: Map<string, IPivotGridRecord[]>;\n    /** List of original data records associated with the current pivoted data. **/\n    records?: any[];\n     /** Record level**/\n    level?: number;\n    /** List of dimensions associated with the record.**/\n    dimensions: IPivotDimension[];\n    /** If set, it specifies the name of the dimension, that has total record enabled. */\n    totalRecordDimensionName?: string;\n    /** The index of the record in the total view */\n    dataIndex?: number;\n}\n\nexport interface IPivotGridGroupRecord extends IPivotGridRecord {\n    height?: number;\n    rowSpan?: number;\n}\n\nexport interface IPivotGridHorizontalGroup {\n    value?: string;\n    rootDimension?: IPivotDimension;\n    dimensions?: IPivotDimension[];\n    records?: IPivotGridRecord[];\n    rowStart?: number;\n    rowSpan?: number;\n    colStart?: number;\n    colSpan?: number;\n}\n\nexport interface IgxPivotGridValueTemplateContext {\n    $implicit: IPivotValue;\n}\n"]}
@@ -140,7 +140,6 @@ export class IgxIconService {
140
140
  const icon = this._iconRefs.get(family)?.get(name);
141
141
  const iconFamily = icon?.family ?? family;
142
142
  const _name = icon?.name ?? name;
143
- const type = icon?.type ?? this.familyType(iconFamily);
144
143
  const className = this.familyClassName(iconFamily);
145
144
  const prefix = this._families.get(iconFamily)?.prefix;
146
145
  // Handle name prefixes
@@ -148,6 +147,8 @@ export class IgxIconService {
148
147
  if (iconName && prefix) {
149
148
  iconName = _name.includes(prefix) ? _name : `${prefix}${_name}`;
150
149
  }
150
+ const cached = this.isSvgIconCached(iconName, iconFamily);
151
+ const type = cached ? "svg" : icon?.type ?? this.familyType(iconFamily);
151
152
  return {
152
153
  className,
153
154
  type,
@@ -155,6 +156,12 @@ export class IgxIconService {
155
156
  family: iconFamily,
156
157
  };
157
158
  }
159
+ getOrCreateSvgFamily(family) {
160
+ if (!this._families.has(family)) {
161
+ this._families.set(family, { className: family, type: "svg" });
162
+ }
163
+ return this._families.get(family);
164
+ }
158
165
  /**
159
166
  * Adds an SVG image to the cache. SVG source is an url.
160
167
  * ```typescript
@@ -172,7 +179,7 @@ export class IgxIconService {
172
179
  throw new Error(`The URL provided was not trusted as a resource URL: "${url}".`);
173
180
  }
174
181
  if (!this.isSvgIconCached(name, family)) {
175
- this._families.set(family, { className: family, type: "svg" });
182
+ this.getOrCreateSvgFamily(family);
176
183
  this.fetchSvg(url).subscribe((res) => {
177
184
  this.cacheSvgIcon(name, res, family, stripMeta);
178
185
  });
@@ -189,12 +196,12 @@ export class IgxIconService {
189
196
  * <path d="M74 74h54v54H74" /></svg>', 'svg-flags');
190
197
  * ```
191
198
  */
192
- addSvgIconFromText(name, iconText, family = "", stripMeta = false) {
199
+ addSvgIconFromText(name, iconText, family = this._defaultFamily.name, stripMeta = false) {
193
200
  if (name && iconText) {
194
201
  if (this.isSvgIconCached(name, family)) {
195
202
  return;
196
203
  }
197
- this._families.set(family, { className: family, type: "svg" });
204
+ this.getOrCreateSvgFamily(family);
198
205
  this.cacheSvgIcon(name, iconText, family, stripMeta);
199
206
  }
200
207
  else {
@@ -207,10 +214,9 @@ export class IgxIconService {
207
214
  * const isSvgCached = this.iconService.isSvgIconCached('aruba', 'svg-flags');
208
215
  * ```
209
216
  */
210
- isSvgIconCached(name, family = "") {
211
- const familyClassName = this.familyClassName(family);
212
- if (this._cachedIcons.has(familyClassName)) {
213
- const familyRegistry = this._cachedIcons.get(familyClassName);
217
+ isSvgIconCached(name, family) {
218
+ if (this._cachedIcons.has(family)) {
219
+ const familyRegistry = this._cachedIcons.get(family);
214
220
  return familyRegistry.has(name);
215
221
  }
216
222
  return false;
@@ -221,9 +227,8 @@ export class IgxIconService {
221
227
  * const svgIcon = this.iconService.getSvgIcon('aruba', 'svg-flags');
222
228
  * ```
223
229
  */
224
- getSvgIcon(name, family = "") {
225
- const familyClassName = this.familyClassName(family);
226
- return this._cachedIcons.get(familyClassName)?.get(name);
230
+ getSvgIcon(name, family) {
231
+ return this._cachedIcons.get(family)?.get(name);
227
232
  }
228
233
  /**
229
234
  * @hidden
@@ -236,13 +241,11 @@ export class IgxIconService {
236
241
  * @hidden
237
242
  */
238
243
  cacheSvgIcon(name, value, family = this._defaultFamily.name, stripMeta) {
239
- family = family ? family : this._defaultFamily.name;
240
244
  if (this._platformUtil?.isBrowser && name && value) {
241
245
  const doc = this._domParser.parseFromString(value, "image/svg+xml");
242
246
  const svg = doc.querySelector("svg");
243
247
  if (!this._cachedIcons.has(family)) {
244
248
  this._cachedIcons.set(family, new Map());
245
- this._iconLoaded.next({ name, value, family });
246
249
  }
247
250
  if (svg) {
248
251
  svg.setAttribute("fit", "");
@@ -259,6 +262,7 @@ export class IgxIconService {
259
262
  }
260
263
  const safeSvg = this._sanitizer.bypassSecurityTrustHtml(svg.outerHTML);
261
264
  this._cachedIcons.get(family).set(name, safeSvg);
265
+ this._iconLoaded.next({ name, value, family });
262
266
  }
263
267
  }
264
268
  }
@@ -282,4 +286,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
282
286
  type: Inject,
283
287
  args: [DOCUMENT]
284
288
  }] }] });
285
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.service.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/icon/icon.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, SecurityContext, Inject, Optional } from \"@angular/core\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { DOCUMENT } from \"@angular/common\";\nimport { HttpClient } from \"@angular/common/http\";\nimport { Observable, Subject } from \"rxjs\";\nimport { PlatformUtil } from \"../core/utils\";\nimport { iconReferences } from './icon.references'\nimport { IconFamily, IconMeta, FamilyMeta } from \"./types\";\nimport type { IconType, IconReference } from './types';\nimport { IgxTheme } from \"../services/theme/theme.service\";\n\n/**\n * Event emitted when a SVG icon is loaded through\n * a HTTP request.\n */\nexport interface IgxIconLoadedEvent {\n    /** Name of the icon */\n    name: string;\n    /** The actual SVG text, if any */\n    value?: string;\n    /** The font-family for the icon. Defaults to material. */\n    family: string;\n}\n\n/**\n * **Ignite UI for Angular Icon Service** -\n *\n * The Ignite UI Icon Service makes it easy for developers to include custom SVG images and use them with IgxIconComponent.\n * In addition it could be used to associate a custom class to be applied on IgxIconComponent according to given font-family.\n *\n * Example:\n * ```typescript\n * this.iconService.setFamily('material', { className: 'material-icons', type: 'font' });\n * this.iconService.addSvgIcon('aruba', '/assets/svg/country_flags/aruba.svg', 'svg-flags');\n * ```\n */\n@Injectable({\n    providedIn: \"root\",\n})\nexport class IgxIconService {\n    /**\n     * Observable that emits when an icon is successfully loaded\n     * through a HTTP request.\n     *\n     * @example\n     * ```typescript\n     * this.service.iconLoaded.subscribe((ev: IgxIconLoadedEvent) => ...);\n     * ```\n     */\n    public iconLoaded: Observable<IgxIconLoadedEvent>;\n\n    private _defaultFamily: IconFamily = {\n        name: \"material\",\n        meta: { className: \"material-icons\", type: \"liga\" },\n    };\n    private _iconRefs = new Map<string, Map<string, IconMeta>>();\n    private _families = new Map<string, FamilyMeta>();\n    private _cachedIcons = new Map<string, Map<string, SafeHtml>>();\n    private _iconLoaded = new Subject<IgxIconLoadedEvent>();\n    private _domParser: DOMParser;\n    private theme!: IgxTheme;\n\n    constructor(\n        @Optional() private _sanitizer: DomSanitizer,\n        @Optional() private _httpClient: HttpClient,\n        @Optional() private _platformUtil: PlatformUtil,\n        @Optional() @Inject(DOCUMENT) protected document: Document,\n    ) {\n        this.iconLoaded = this._iconLoaded.asObservable();\n        this.setFamily(this._defaultFamily.name, this._defaultFamily.meta);\n\n        if (this._platformUtil?.isBrowser) {\n            this._domParser = new DOMParser();\n        }\n    }\n\n    /**\n     *  Returns the default font-family.\n     * ```typescript\n     *   const defaultFamily = this.iconService.defaultFamily;\n     * ```\n     */\n    public get defaultFamily(): IconFamily {\n        return this._defaultFamily;\n    }\n\n    /**\n     *  Sets the default font-family.\n     * ```typescript\n     *   this.iconService.defaultFamily = 'svg-flags';\n     * ```\n     */\n    public set defaultFamily(family: IconFamily) {\n        this._defaultFamily = family;\n        this.setFamily(this._defaultFamily.name, this._defaultFamily.meta);\n    }\n\n    /**\n     *  Registers a custom class to be applied to IgxIconComponent for a given font-family.\n     * ```typescript\n     *   this.iconService.registerFamilyAlias('material', 'material-icons');\n     * ```\n     * @deprecated in version 18.1.0. Use `setFamily` instead.\n     */\n    public registerFamilyAlias(\n        alias: string,\n        className: string = alias,\n        type: IconType = \"font\",\n    ): this {\n        this.setFamily(alias, { className, type });\n        return this;\n    }\n\n    /**\n     *  Returns the custom class, if any, associated to a given font-family.\n     * ```typescript\n     *   const familyClass = this.iconService.familyClassName('material');\n     * ```\n     */\n    public familyClassName(alias: string): string {\n        return this._families.get(alias)?.className || alias;\n    }\n\n    /** @hidden @internal */\n    private familyType(alias: string): IconType {\n        return this._families.get(alias)?.type;\n    }\n\n    /** @hidden @internal */\n    public setRefsByTheme(theme: IgxTheme) {\n        if (this.theme !== theme) {\n            this.theme = theme;\n\n            for (const { alias, target } of iconReferences) {\n                const icon = target.get(theme) ?? target.get('default')!;\n                this.addIconRef(alias.name, alias.family, icon);\n            }\n        }\n    }\n\n    /**\n     *  Creates a family to className relationship that is applied to the IgxIconComponent\n     *   whenever that family name is used.\n     * ```typescript\n     *   this.iconService.setFamily('material', { className: 'material-icons', type: 'liga' });\n     * ```\n     */\n    public setFamily(name: string, meta: FamilyMeta) {\n        this._families.set(name, meta);\n    }\n\n    /**\n     *  Adds an icon reference meta for an icon in a meta family.\n     *  Executes only if no icon reference is found.\n     * ```typescript\n     *   this.iconService.addIconRef('aruba', 'default', { name: 'aruba', family: 'svg-flags' });\n     * ```\n     */\n    public addIconRef(name: string, family: string, icon: IconMeta) {\n        const iconRef = this._iconRefs.get(family)?.get(name);\n\n        if (!iconRef) {\n            this.setIconRef(name, family, icon);\n        }\n    }\n\n    /**\n     *  Similar to addIconRef, but always sets the icon reference meta for an icon in a meta family.\n     * ```typescript\n     *   this.iconService.setIconRef('aruba', 'default', { name: 'aruba', family: 'svg-flags' });\n     * ```\n     */\n    public setIconRef(name: string, family: string, icon: IconMeta) {\n        let familyRef = this._iconRefs.get(family);\n\n        if (!familyRef) {\n            familyRef = new Map<string, IconMeta>();\n            this._iconRefs.set(family, familyRef);\n        }\n\n        const familyType = this.familyType(icon?.family);\n        familyRef.set(name, { ...icon, type: icon.type ?? familyType });\n\n        this._iconLoaded.next({ name, family });\n    }\n\n    /**\n     *  Returns the icon reference meta for an icon in a given family.\n     * ```typescript\n     *   const iconRef = this.iconService.getIconRef('aruba', 'default');\n     * ```\n     */\n    public getIconRef(name: string, family: string): IconReference {\n        const icon = this._iconRefs.get(family)?.get(name);\n\n        const iconFamily = icon?.family ?? family;\n        const _name = icon?.name ?? name;\n        const type = icon?.type ?? this.familyType(iconFamily);\n        const className = this.familyClassName(iconFamily);\n        const prefix = this._families.get(iconFamily)?.prefix;\n\n        // Handle name prefixes\n        let iconName = _name;\n\n        if (iconName && prefix) {\n            iconName = _name.includes(prefix) ? _name : `${prefix}${_name}`;\n        }\n\n        return {\n            className,\n            type,\n            name: iconName,\n            family: iconFamily,\n        };\n    }\n\n    /**\n     *  Adds an SVG image to the cache. SVG source is an url.\n     * ```typescript\n     *   this.iconService.addSvgIcon('aruba', '/assets/svg/country_flags/aruba.svg', 'svg-flags');\n     * ```\n     */\n    public addSvgIcon(\n        name: string,\n        url: string,\n        family = this._defaultFamily.name,\n        stripMeta = false,\n    ) {\n        if (name && url) {\n            const safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(url);\n            if (!safeUrl) {\n                throw new Error(\n                    `The provided URL could not be processed as trusted resource URL by Angular's DomSanitizer: \"${url}\".`,\n                );\n            }\n\n            const sanitizedUrl = this._sanitizer.sanitize(\n                SecurityContext.RESOURCE_URL,\n                safeUrl,\n            );\n            if (!sanitizedUrl) {\n                throw new Error(\n                    `The URL provided was not trusted as a resource URL: \"${url}\".`,\n                );\n            }\n\n            if (!this.isSvgIconCached(name, family)) {\n                this._families.set(family, { className: family, type: \"svg\" });\n\n                this.fetchSvg(url).subscribe((res) => {\n                    this.cacheSvgIcon(name, res, family, stripMeta);\n                });\n            }\n        } else {\n            throw new Error(\n                \"You should provide at least `name` and `url` to register an svg icon.\",\n            );\n        }\n    }\n\n    /**\n     *  Adds an SVG image to the cache. SVG source is its text.\n     * ```typescript\n     *   this.iconService.addSvgIconFromText('simple', '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 200 200\">\n     *   <path d=\"M74 74h54v54H74\" /></svg>', 'svg-flags');\n     * ```\n     */\n    public addSvgIconFromText(\n        name: string,\n        iconText: string,\n        family = \"\",\n        stripMeta = false,\n    ) {\n        if (name && iconText) {\n            if (this.isSvgIconCached(name, family)) {\n                return;\n            }\n\n            this._families.set(family, { className: family, type: \"svg\" });\n            this.cacheSvgIcon(name, iconText, family, stripMeta);\n        } else {\n            throw new Error(\n                \"You should provide at least `name` and `iconText` to register an svg icon.\",\n            );\n        }\n    }\n\n    /**\n     *  Returns whether a given SVG image is present in the cache.\n     * ```typescript\n     *   const isSvgCached = this.iconService.isSvgIconCached('aruba', 'svg-flags');\n     * ```\n     */\n    public isSvgIconCached(name: string, family = \"\"): boolean {\n        const familyClassName = this.familyClassName(family);\n        if (this._cachedIcons.has(familyClassName)) {\n            const familyRegistry = this._cachedIcons.get(\n                familyClassName,\n            ) as Map<string, SafeHtml>;\n            return familyRegistry.has(name);\n        }\n\n        return false;\n    }\n\n    /**\n     *  Returns the cached SVG image as string.\n     * ```typescript\n     *   const svgIcon = this.iconService.getSvgIcon('aruba', 'svg-flags');\n     * ```\n     */\n    public getSvgIcon(name: string, family = \"\") {\n        const familyClassName = this.familyClassName(family);\n        return this._cachedIcons.get(familyClassName)?.get(name);\n    }\n\n    /**\n     * @hidden\n     */\n    private fetchSvg(url: string): Observable<string> {\n        const req = this._httpClient.get(url, { responseType: \"text\" });\n        return req;\n    }\n\n    /**\n     * @hidden\n     */\n    private cacheSvgIcon(\n        name: string,\n        value: string,\n        family = this._defaultFamily.name,\n        stripMeta: boolean,\n    ) {\n        family = family ? family : this._defaultFamily.name;\n\n        if (this._platformUtil?.isBrowser && name && value) {\n            const doc = this._domParser.parseFromString(value, \"image/svg+xml\");\n            const svg = doc.querySelector(\"svg\") as SVGElement;\n\n            if (!this._cachedIcons.has(family)) {\n                this._cachedIcons.set(family, new Map<string, SafeHtml>());\n                this._iconLoaded.next({ name, value, family });\n            }\n\n            if (svg) {\n                svg.setAttribute(\"fit\", \"\");\n                svg.setAttribute(\"preserveAspectRatio\", \"xMidYMid meet\");\n\n                if (stripMeta) {\n                    const title = svg.querySelector(\"title\");\n                    const desc = svg.querySelector(\"desc\");\n\n                    if (title) {\n                        svg.removeChild(title);\n                    }\n\n                    if (desc) {\n                        svg.removeChild(desc);\n                    }\n                }\n\n                const safeSvg = this._sanitizer.bypassSecurityTrustHtml(\n                    svg.outerHTML,\n                );\n                this._cachedIcons.get(family).set(name, safeSvg);\n            }\n        }\n    }\n}\n"]}
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.service.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/icon/icon.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, SecurityContext, Inject, Optional } from \"@angular/core\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { DOCUMENT } from \"@angular/common\";\nimport { HttpClient } from \"@angular/common/http\";\nimport { Observable, Subject } from \"rxjs\";\nimport { PlatformUtil } from \"../core/utils\";\nimport { iconReferences } from './icon.references'\nimport { IconFamily, IconMeta, FamilyMeta } from \"./types\";\nimport type { IconType, IconReference } from './types';\nimport { IgxTheme } from \"../services/theme/theme.service\";\n\n/**\n * Event emitted when a SVG icon is loaded through\n * a HTTP request.\n */\nexport interface IgxIconLoadedEvent {\n    /** Name of the icon */\n    name: string;\n    /** The actual SVG text, if any */\n    value?: string;\n    /** The font-family for the icon. Defaults to material. */\n    family: string;\n}\n\n/**\n * **Ignite UI for Angular Icon Service** -\n *\n * The Ignite UI Icon Service makes it easy for developers to include custom SVG images and use them with IgxIconComponent.\n * In addition it could be used to associate a custom class to be applied on IgxIconComponent according to given font-family.\n *\n * Example:\n * ```typescript\n * this.iconService.setFamily('material', { className: 'material-icons', type: 'font' });\n * this.iconService.addSvgIcon('aruba', '/assets/svg/country_flags/aruba.svg', 'svg-flags');\n * ```\n */\n@Injectable({\n    providedIn: \"root\",\n})\nexport class IgxIconService {\n    /**\n     * Observable that emits when an icon is successfully loaded\n     * through a HTTP request.\n     *\n     * @example\n     * ```typescript\n     * this.service.iconLoaded.subscribe((ev: IgxIconLoadedEvent) => ...);\n     * ```\n     */\n    public iconLoaded: Observable<IgxIconLoadedEvent>;\n\n    private _defaultFamily: IconFamily = {\n        name: \"material\",\n        meta: { className: \"material-icons\", type: \"liga\" },\n    };\n    private _iconRefs = new Map<string, Map<string, IconMeta>>();\n    private _families = new Map<string, FamilyMeta>();\n    private _cachedIcons = new Map<string, Map<string, SafeHtml>>();\n    private _iconLoaded = new Subject<IgxIconLoadedEvent>();\n    private _domParser: DOMParser;\n    private theme!: IgxTheme;\n\n    constructor(\n        @Optional() private _sanitizer: DomSanitizer,\n        @Optional() private _httpClient: HttpClient,\n        @Optional() private _platformUtil: PlatformUtil,\n        @Optional() @Inject(DOCUMENT) protected document: Document,\n    ) {\n        this.iconLoaded = this._iconLoaded.asObservable();\n        this.setFamily(this._defaultFamily.name, this._defaultFamily.meta);\n\n        if (this._platformUtil?.isBrowser) {\n            this._domParser = new DOMParser();\n        }\n    }\n\n    /**\n     *  Returns the default font-family.\n     * ```typescript\n     *   const defaultFamily = this.iconService.defaultFamily;\n     * ```\n     */\n    public get defaultFamily(): IconFamily {\n        return this._defaultFamily;\n    }\n\n    /**\n     *  Sets the default font-family.\n     * ```typescript\n     *   this.iconService.defaultFamily = 'svg-flags';\n     * ```\n     */\n    public set defaultFamily(family: IconFamily) {\n        this._defaultFamily = family;\n        this.setFamily(this._defaultFamily.name, this._defaultFamily.meta);\n    }\n\n    /**\n     *  Registers a custom class to be applied to IgxIconComponent for a given font-family.\n     * ```typescript\n     *   this.iconService.registerFamilyAlias('material', 'material-icons');\n     * ```\n     * @deprecated in version 18.1.0. Use `setFamily` instead.\n     */\n    public registerFamilyAlias(\n        alias: string,\n        className: string = alias,\n        type: IconType = \"font\",\n    ): this {\n        this.setFamily(alias, { className, type });\n        return this;\n    }\n\n    /**\n     *  Returns the custom class, if any, associated to a given font-family.\n     * ```typescript\n     *   const familyClass = this.iconService.familyClassName('material');\n     * ```\n     */\n    public familyClassName(alias: string): string {\n        return this._families.get(alias)?.className || alias;\n    }\n\n    /** @hidden @internal */\n    private familyType(alias: string): IconType {\n        return this._families.get(alias)?.type;\n    }\n\n    /** @hidden @internal */\n    public setRefsByTheme(theme: IgxTheme) {\n        if (this.theme !== theme) {\n            this.theme = theme;\n\n            for (const { alias, target } of iconReferences) {\n                const icon = target.get(theme) ?? target.get('default')!;\n                this.addIconRef(alias.name, alias.family, icon);\n            }\n        }\n    }\n\n    /**\n     *  Creates a family to className relationship that is applied to the IgxIconComponent\n     *   whenever that family name is used.\n     * ```typescript\n     *   this.iconService.setFamily('material', { className: 'material-icons', type: 'liga' });\n     * ```\n     */\n    public setFamily(name: string, meta: FamilyMeta) {\n        this._families.set(name, meta);\n    }\n\n    /**\n     *  Adds an icon reference meta for an icon in a meta family.\n     *  Executes only if no icon reference is found.\n     * ```typescript\n     *   this.iconService.addIconRef('aruba', 'default', { name: 'aruba', family: 'svg-flags' });\n     * ```\n     */\n    public addIconRef(name: string, family: string, icon: IconMeta) {\n        const iconRef = this._iconRefs.get(family)?.get(name);\n\n        if (!iconRef) {\n            this.setIconRef(name, family, icon);\n        }\n    }\n\n    /**\n     *  Similar to addIconRef, but always sets the icon reference meta for an icon in a meta family.\n     * ```typescript\n     *   this.iconService.setIconRef('aruba', 'default', { name: 'aruba', family: 'svg-flags' });\n     * ```\n     */\n    public setIconRef(name: string, family: string, icon: IconMeta) {\n        let familyRef = this._iconRefs.get(family);\n\n        if (!familyRef) {\n            familyRef = new Map<string, IconMeta>();\n            this._iconRefs.set(family, familyRef);\n        }\n\n        const familyType = this.familyType(icon?.family);\n        familyRef.set(name, { ...icon, type: icon.type ?? familyType });\n\n        this._iconLoaded.next({ name, family });\n    }\n\n    /**\n     *  Returns the icon reference meta for an icon in a given family.\n     * ```typescript\n     *   const iconRef = this.iconService.getIconRef('aruba', 'default');\n     * ```\n     */\n    public getIconRef(name: string, family: string): IconReference {\n        const icon = this._iconRefs.get(family)?.get(name);\n\n        const iconFamily = icon?.family ?? family;\n        const _name = icon?.name ?? name;\n        const className = this.familyClassName(iconFamily);\n        const prefix = this._families.get(iconFamily)?.prefix;\n\n        // Handle name prefixes\n        let iconName = _name;\n\n        if (iconName && prefix) {\n            iconName = _name.includes(prefix) ? _name : `${prefix}${_name}`;\n        }\n\n        const cached = this.isSvgIconCached(iconName, iconFamily);\n        const type = cached ? \"svg\" : icon?.type ?? this.familyType(iconFamily);\n\n        return {\n            className,\n            type,\n            name: iconName,\n            family: iconFamily,\n        };\n    }\n\n    private getOrCreateSvgFamily(family: string) {\n        if (!this._families.has(family)) {\n            this._families.set(family, { className: family, type: \"svg\" });\n        }\n\n        return this._families.get(family);\n    }\n    /**\n     *  Adds an SVG image to the cache. SVG source is an url.\n     * ```typescript\n     *   this.iconService.addSvgIcon('aruba', '/assets/svg/country_flags/aruba.svg', 'svg-flags');\n     * ```\n     */\n    public addSvgIcon(\n        name: string,\n        url: string,\n        family = this._defaultFamily.name,\n        stripMeta = false,\n    ) {\n        if (name && url) {\n            const safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(url);\n\n            if (!safeUrl) {\n                throw new Error(\n                    `The provided URL could not be processed as trusted resource URL by Angular's DomSanitizer: \"${url}\".`,\n                );\n            }\n\n            const sanitizedUrl = this._sanitizer.sanitize(\n                SecurityContext.RESOURCE_URL,\n                safeUrl,\n            );\n\n            if (!sanitizedUrl) {\n                throw new Error(\n                    `The URL provided was not trusted as a resource URL: \"${url}\".`,\n                );\n            }\n\n            if (!this.isSvgIconCached(name, family)) {\n                this.getOrCreateSvgFamily(family);\n\n                this.fetchSvg(url).subscribe((res) => {\n                    this.cacheSvgIcon(name, res, family, stripMeta);\n                });\n            }\n        } else {\n            throw new Error(\n                \"You should provide at least `name` and `url` to register an svg icon.\",\n            );\n        }\n    }\n\n    /**\n     *  Adds an SVG image to the cache. SVG source is its text.\n     * ```typescript\n     *   this.iconService.addSvgIconFromText('simple', '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 200 200\">\n     *   <path d=\"M74 74h54v54H74\" /></svg>', 'svg-flags');\n     * ```\n     */\n    public addSvgIconFromText(\n        name: string,\n        iconText: string,\n        family = this._defaultFamily.name,\n        stripMeta = false,\n    ) {\n        if (name && iconText) {\n            if (this.isSvgIconCached(name, family)) {\n                return;\n            }\n\n            this.getOrCreateSvgFamily(family);\n            this.cacheSvgIcon(name, iconText, family, stripMeta);\n        } else {\n            throw new Error(\n                \"You should provide at least `name` and `iconText` to register an svg icon.\",\n            );\n        }\n    }\n\n    /**\n     *  Returns whether a given SVG image is present in the cache.\n     * ```typescript\n     *   const isSvgCached = this.iconService.isSvgIconCached('aruba', 'svg-flags');\n     * ```\n     */\n    public isSvgIconCached(name: string, family: string): boolean {\n        if (this._cachedIcons.has(family)) {\n            const familyRegistry = this._cachedIcons.get(\n                family,\n            ) as Map<string, SafeHtml>;\n\n            return familyRegistry.has(name);\n        }\n\n        return false;\n    }\n\n    /**\n     *  Returns the cached SVG image as string.\n     * ```typescript\n     *   const svgIcon = this.iconService.getSvgIcon('aruba', 'svg-flags');\n     * ```\n     */\n    public getSvgIcon(name: string, family: string) {\n        return this._cachedIcons.get(family)?.get(name);\n    }\n\n    /**\n     * @hidden\n     */\n    private fetchSvg(url: string): Observable<string> {\n        const req = this._httpClient.get(url, { responseType: \"text\" });\n        return req;\n    }\n\n    /**\n     * @hidden\n     */\n    private cacheSvgIcon(\n        name: string,\n        value: string,\n        family = this._defaultFamily.name,\n        stripMeta: boolean,\n    ) {\n        if (this._platformUtil?.isBrowser && name && value) {\n            const doc = this._domParser.parseFromString(value, \"image/svg+xml\");\n            const svg = doc.querySelector(\"svg\") as SVGElement;\n\n            if (!this._cachedIcons.has(family)) {\n                this._cachedIcons.set(family, new Map<string, SafeHtml>());\n            }\n\n            if (svg) {\n                svg.setAttribute(\"fit\", \"\");\n                svg.setAttribute(\"preserveAspectRatio\", \"xMidYMid meet\");\n\n                if (stripMeta) {\n                    const title = svg.querySelector(\"title\");\n                    const desc = svg.querySelector(\"desc\");\n\n                    if (title) {\n                        svg.removeChild(title);\n                    }\n\n                    if (desc) {\n                        svg.removeChild(desc);\n                    }\n                }\n\n                const safeSvg = this._sanitizer.bypassSecurityTrustHtml(\n                    svg.outerHTML,\n                );\n\n                this._cachedIcons.get(family).set(name, safeSvg);\n                this._iconLoaded.next({ name, value, family });\n            }\n        }\n    }\n}\n"]}
@@ -9283,7 +9283,6 @@ class IgxIconService {
9283
9283
  const icon = this._iconRefs.get(family)?.get(name);
9284
9284
  const iconFamily = icon?.family ?? family;
9285
9285
  const _name = icon?.name ?? name;
9286
- const type = icon?.type ?? this.familyType(iconFamily);
9287
9286
  const className = this.familyClassName(iconFamily);
9288
9287
  const prefix = this._families.get(iconFamily)?.prefix;
9289
9288
  // Handle name prefixes
@@ -9291,6 +9290,8 @@ class IgxIconService {
9291
9290
  if (iconName && prefix) {
9292
9291
  iconName = _name.includes(prefix) ? _name : `${prefix}${_name}`;
9293
9292
  }
9293
+ const cached = this.isSvgIconCached(iconName, iconFamily);
9294
+ const type = cached ? "svg" : icon?.type ?? this.familyType(iconFamily);
9294
9295
  return {
9295
9296
  className,
9296
9297
  type,
@@ -9298,6 +9299,12 @@ class IgxIconService {
9298
9299
  family: iconFamily,
9299
9300
  };
9300
9301
  }
9302
+ getOrCreateSvgFamily(family) {
9303
+ if (!this._families.has(family)) {
9304
+ this._families.set(family, { className: family, type: "svg" });
9305
+ }
9306
+ return this._families.get(family);
9307
+ }
9301
9308
  /**
9302
9309
  * Adds an SVG image to the cache. SVG source is an url.
9303
9310
  * ```typescript
@@ -9315,7 +9322,7 @@ class IgxIconService {
9315
9322
  throw new Error(`The URL provided was not trusted as a resource URL: "${url}".`);
9316
9323
  }
9317
9324
  if (!this.isSvgIconCached(name, family)) {
9318
- this._families.set(family, { className: family, type: "svg" });
9325
+ this.getOrCreateSvgFamily(family);
9319
9326
  this.fetchSvg(url).subscribe((res) => {
9320
9327
  this.cacheSvgIcon(name, res, family, stripMeta);
9321
9328
  });
@@ -9332,12 +9339,12 @@ class IgxIconService {
9332
9339
  * <path d="M74 74h54v54H74" /></svg>', 'svg-flags');
9333
9340
  * ```
9334
9341
  */
9335
- addSvgIconFromText(name, iconText, family = "", stripMeta = false) {
9342
+ addSvgIconFromText(name, iconText, family = this._defaultFamily.name, stripMeta = false) {
9336
9343
  if (name && iconText) {
9337
9344
  if (this.isSvgIconCached(name, family)) {
9338
9345
  return;
9339
9346
  }
9340
- this._families.set(family, { className: family, type: "svg" });
9347
+ this.getOrCreateSvgFamily(family);
9341
9348
  this.cacheSvgIcon(name, iconText, family, stripMeta);
9342
9349
  }
9343
9350
  else {
@@ -9350,10 +9357,9 @@ class IgxIconService {
9350
9357
  * const isSvgCached = this.iconService.isSvgIconCached('aruba', 'svg-flags');
9351
9358
  * ```
9352
9359
  */
9353
- isSvgIconCached(name, family = "") {
9354
- const familyClassName = this.familyClassName(family);
9355
- if (this._cachedIcons.has(familyClassName)) {
9356
- const familyRegistry = this._cachedIcons.get(familyClassName);
9360
+ isSvgIconCached(name, family) {
9361
+ if (this._cachedIcons.has(family)) {
9362
+ const familyRegistry = this._cachedIcons.get(family);
9357
9363
  return familyRegistry.has(name);
9358
9364
  }
9359
9365
  return false;
@@ -9364,9 +9370,8 @@ class IgxIconService {
9364
9370
  * const svgIcon = this.iconService.getSvgIcon('aruba', 'svg-flags');
9365
9371
  * ```
9366
9372
  */
9367
- getSvgIcon(name, family = "") {
9368
- const familyClassName = this.familyClassName(family);
9369
- return this._cachedIcons.get(familyClassName)?.get(name);
9373
+ getSvgIcon(name, family) {
9374
+ return this._cachedIcons.get(family)?.get(name);
9370
9375
  }
9371
9376
  /**
9372
9377
  * @hidden
@@ -9379,13 +9384,11 @@ class IgxIconService {
9379
9384
  * @hidden
9380
9385
  */
9381
9386
  cacheSvgIcon(name, value, family = this._defaultFamily.name, stripMeta) {
9382
- family = family ? family : this._defaultFamily.name;
9383
9387
  if (this._platformUtil?.isBrowser && name && value) {
9384
9388
  const doc = this._domParser.parseFromString(value, "image/svg+xml");
9385
9389
  const svg = doc.querySelector("svg");
9386
9390
  if (!this._cachedIcons.has(family)) {
9387
9391
  this._cachedIcons.set(family, new Map());
9388
- this._iconLoaded.next({ name, value, family });
9389
9392
  }
9390
9393
  if (svg) {
9391
9394
  svg.setAttribute("fit", "");
@@ -9402,6 +9405,7 @@ class IgxIconService {
9402
9405
  }
9403
9406
  const safeSvg = this._sanitizer.bypassSecurityTrustHtml(svg.outerHTML);
9404
9407
  this._cachedIcons.get(family).set(name, safeSvg);
9408
+ this._iconLoaded.next({ name, value, family });
9405
9409
  }
9406
9410
  }
9407
9411
  }