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.
|
|
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 =
|
|
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.
|
|
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
|
-
|
|
212
|
-
|
|
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
|
-
|
|
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.
|
|
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 =
|
|
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.
|
|
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
|
-
|
|
9355
|
-
|
|
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
|
-
|
|
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
|
}
|