Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@angular-extensions/elements

Package Overview
Dependencies
Maintainers
4
Versions
67
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@angular-extensions/elements - npm Package Compare versions

Comparing version 12.1.2 to 12.4.1

29

bundles/angular-extensions-elements.umd.js

@@ -351,3 +351,4 @@ (function (global, factory) {

var LazyElementsLoaderService = /** @class */ (function () {
function LazyElementsLoaderService(registry, options) {
function LazyElementsLoaderService(errorHandler, registry, options) {
this.errorHandler = errorHandler;
this.registry = registry;

@@ -394,3 +395,9 @@ this.options = options;

return __awaiter(this, void 0, void 0, function () {
var config, notifier_1, beforeLoadHook, afterLoadHook_1, script_1;
// The `load` and `error` event listeners capture `this`. That's why they have to be removed manually.
// Otherwise, the `LazyElementsLoaderService` is not going to be GC'd.
function cleanup() {
script_1.removeEventListener('load', onLoad_1);
script_1.removeEventListener('error', onError_1);
}
var config, notifier_1, beforeLoadHook, afterLoadHook_1, script_1, onLoad_1, onError_1;
var _this = this;

@@ -432,3 +439,3 @@ return __generator(this, function (_o) {

script_1.src = url;
script_1.onload = function () {
onLoad_1 = function () {
if (afterLoadHook_1) {

@@ -442,4 +449,14 @@ _this.handleHook(afterLoadHook_1, tag)

}
cleanup();
};
script_1.onerror = notifier_1.reject;
onError_1 = function (error) {
notifier_1.reject(error);
cleanup();
// Caretaker note: don't put it before the `reject` and `cleanup` since the user may have some
// custom error handler that will re-throw the error through `throw error`. Hence the code won't
// be executed, and the promise won't be rejected.
_this.errorHandler.handleError(error);
};
script_1.addEventListener('load', onLoad_1);
script_1.addEventListener('error', onError_1);
if (beforeLoadHook) {

@@ -503,3 +520,3 @@ this.handleHook(beforeLoadHook, tag)

}());
LazyElementsLoaderService.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: LazyElementsLoaderService, deps: [{ token: LAZY_ELEMENTS_REGISTRY }, { token: LAZY_ELEMENT_ROOT_OPTIONS, optional: true }], target: i0__namespace.ɵɵFactoryTarget.Injectable });
LazyElementsLoaderService.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: LazyElementsLoaderService, deps: [{ token: i0__namespace.ErrorHandler }, { token: LAZY_ELEMENTS_REGISTRY }, { token: LAZY_ELEMENT_ROOT_OPTIONS, optional: true }], target: i0__namespace.ɵɵFactoryTarget.Injectable });
LazyElementsLoaderService.ɵprov = i0__namespace.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: LazyElementsLoaderService, providedIn: 'root' });

@@ -512,3 +529,3 @@ i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: LazyElementsLoaderService, decorators: [{

}], ctorParameters: function () {
return [{ type: undefined, decorators: [{
return [{ type: i0__namespace.ErrorHandler }, { type: undefined, decorators: [{
type: i0.Inject,

@@ -515,0 +532,0 @@ args: [LAZY_ELEMENTS_REGISTRY]

import { __awaiter } from "tslib";
import { Inject, Injectable, Optional } from '@angular/core';
import { Inject, Injectable, Optional, } from '@angular/core';
import { LAZY_ELEMENT_ROOT_OPTIONS, LAZY_ELEMENTS_REGISTRY, } from './lazy-elements.tokens';

@@ -7,3 +7,4 @@ import * as i0 from "@angular/core";

export class LazyElementsLoaderService {
constructor(registry, options) {
constructor(errorHandler, registry, options) {
this.errorHandler = errorHandler;
this.registry = registry;

@@ -77,3 +78,3 @@ this.options = options;

script.src = url;
script.onload = () => {
const onLoad = () => {
if (afterLoadHook) {

@@ -87,4 +88,20 @@ this.handleHook(afterLoadHook, tag)

}
cleanup();
};
script.onerror = notifier.reject;
const onError = (error) => {
notifier.reject(error);
cleanup();
// Caretaker note: don't put it before the `reject` and `cleanup` since the user may have some
// custom error handler that will re-throw the error through `throw error`. Hence the code won't
// be executed, and the promise won't be rejected.
this.errorHandler.handleError(error);
};
// The `load` and `error` event listeners capture `this`. That's why they have to be removed manually.
// Otherwise, the `LazyElementsLoaderService` is not going to be GC'd.
function cleanup() {
script.removeEventListener('load', onLoad);
script.removeEventListener('error', onError);
}
script.addEventListener('load', onLoad);
script.addEventListener('error', onError);
if (beforeLoadHook) {

@@ -135,3 +152,3 @@ this.handleHook(beforeLoadHook, tag)

}
LazyElementsLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, deps: [{ token: LAZY_ELEMENTS_REGISTRY }, { token: LAZY_ELEMENT_ROOT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
LazyElementsLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, deps: [{ token: i0.ErrorHandler }, { token: LAZY_ELEMENTS_REGISTRY }, { token: LAZY_ELEMENT_ROOT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
LazyElementsLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, providedIn: 'root' });

@@ -143,3 +160,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, decorators: [{

}]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
}], ctorParameters: function () { return [{ type: i0.ErrorHandler }, { type: undefined, decorators: [{
type: Inject,

@@ -153,2 +170,2 @@ args: [LAZY_ELEMENTS_REGISTRY]

}] }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements-loader.service.js","sourceRoot":"","sources":["../../../../../projects/elements/src/lib/lazy-elements/lazy-elements-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional, Type } from '@angular/core';\n\nimport { LazyElementRootOptions } from './lazy-elements.module';\nimport {\n  LAZY_ELEMENT_ROOT_OPTIONS,\n  LAZY_ELEMENTS_REGISTRY,\n  LazyElementsRegistry,\n} from './lazy-elements.tokens';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\nexport type Hook = (tag: string) => Promise<void> | void;\n\nexport interface HooksConfig {\n  beforeLoad?: Hook;\n  afterLoad?: Hook;\n}\n\nexport interface ElementConfig {\n  tag: string;\n  url: string;\n  isModule?: boolean;\n  importMap?: boolean;\n  loadingComponent?: Type<any>;\n  errorComponent?: Type<any>;\n  preload?: boolean;\n  hooks?: HooksConfig;\n  isAdded?: boolean;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LazyElementsLoaderService {\n  configs: ElementConfig[] = [];\n\n  constructor(\n    @Inject(LAZY_ELEMENTS_REGISTRY) private registry: LazyElementsRegistry,\n    @Optional()\n    @Inject(LAZY_ELEMENT_ROOT_OPTIONS)\n    public options: LazyElementRootOptions\n  ) {\n    if (!options) {\n      this.options = {};\n    }\n  }\n\n  addConfigs(newConfigs: ElementConfig[]) {\n    newConfigs.forEach((newConfig) => {\n      const existingConfig = this.getElementConfig(newConfig.tag);\n      if (existingConfig) {\n        ngDevMode &&\n          console.warn(\n            `${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`\n          );\n      } else {\n        newConfig.isAdded = true;\n        this.configs.push(newConfig);\n        const shouldPreload =\n          newConfig.preload !== undefined\n            ? newConfig.preload\n            : this.options.preload;\n        if (shouldPreload) {\n          this.loadElement(\n            newConfig.url,\n            newConfig.tag,\n            newConfig.isModule,\n            newConfig.importMap,\n            newConfig.hooks\n          );\n        }\n      }\n    });\n  }\n\n  getElementConfig(tag: string): ElementConfig {\n    return this.configs.find((config) => config.tag === tag);\n  }\n\n  preload(tags?: string[]) {\n    let configs = this.configs;\n    if (tags) {\n      configs = this.configs.filter((config) => tags.includes(config.tag));\n    }\n    configs.forEach((config) =>\n      this.loadElement(\n        config.url,\n        config.tag,\n        config.isModule,\n        config.importMap,\n        config.hooks\n      )\n    );\n  }\n\n  async loadElement(\n    url: string,\n    tag: string,\n    isModule?: boolean,\n    importMap?: boolean,\n    hooksConfig?: HooksConfig\n  ): Promise<void> {\n    const config = this.getElementConfig(tag);\n    isModule ??= config?.isModule ?? this.options.isModule;\n    importMap ??= config?.importMap ?? this.options.importMap;\n\n    if (ngDevMode && !tag) {\n      throw new Error(\n        `${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`\n      );\n    }\n\n    if (!url) {\n      if (ngDevMode && !config?.url && !importMap) {\n        throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);\n      } else if (importMap) {\n        url = tag;\n      } else {\n        url = config.url;\n      }\n    }\n\n    if (!this.hasElement(url)) {\n      const notifier = this.addElement(url);\n\n      const beforeLoadHook =\n        hooksConfig?.beforeLoad ??\n        config?.hooks?.beforeLoad ??\n        this.options?.hooks?.beforeLoad;\n      const afterLoadHook =\n        hooksConfig?.afterLoad ??\n        config?.hooks?.afterLoad ??\n        this.options?.hooks?.afterLoad;\n\n      if (importMap) {\n        url = await this.resolveImportMap(url);\n      }\n\n      const script = document.createElement('script') as HTMLScriptElement;\n      if (isModule) {\n        script.type = 'module';\n      }\n      script.src = url;\n      script.onload = () => {\n        if (afterLoadHook) {\n          this.handleHook(afterLoadHook, tag)\n            .then(notifier.resolve)\n            .catch(notifier.reject);\n        } else {\n          notifier.resolve();\n        }\n      };\n      script.onerror = notifier.reject;\n      if (beforeLoadHook) {\n        this.handleHook(beforeLoadHook, tag)\n          .then(() => document.body.appendChild(script))\n          .catch(notifier.reject);\n      } else {\n        document.body.appendChild(script);\n      }\n    }\n    return this.registry.get(this.stripUrlProtocol(url));\n  }\n\n  private addElement(url: string): Notifier {\n    let notifier: Notifier;\n    this.registry.set(\n      this.stripUrlProtocol(url),\n      new Promise<void>((resolve, reject) => (notifier = { resolve, reject }))\n    );\n    return notifier;\n  }\n\n  private hasElement(url: string): boolean {\n    return this.registry.has(this.stripUrlProtocol(url));\n  }\n\n  private stripUrlProtocol(url: string): string {\n    return url.replace(/https?:\\/\\//, '');\n  }\n\n  private handleHook(hook: Hook, tag: string): Promise<void> {\n    try {\n      return Promise.resolve(hook(tag));\n    } catch (err) {\n      return Promise.reject(err);\n    }\n  }\n\n  private async resolveImportMap(url: string) {\n    const System = (window as any).System;\n    if (System) {\n      await System.prepareImport();\n      url = System.resolve(url);\n    } else if (ngDevMode) {\n      throw new Error(\n        `${LOG_PREFIX} - importMap feature depends on SystemJS library to be globally loaded but none was found, thus '${url}' can't be resolved. You should either load SystemJS or remove the importMap flag.`\n      );\n    }\n    return url;\n  }\n}\n\ninterface Notifier {\n  resolve: () => void;\n  reject: (error: any) => void;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements-loader.service.js","sourceRoot":"","sources":["../../../../../projects/elements/src/lib/lazy-elements/lazy-elements-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ErrorHandler,\n  Inject,\n  Injectable,\n  Optional,\n  Type,\n} from '@angular/core';\n\nimport { LazyElementRootOptions } from './lazy-elements.module';\nimport {\n  LAZY_ELEMENT_ROOT_OPTIONS,\n  LAZY_ELEMENTS_REGISTRY,\n  LazyElementsRegistry,\n} from './lazy-elements.tokens';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\nexport type Hook = (tag: string) => Promise<void> | void;\n\nexport interface HooksConfig {\n  beforeLoad?: Hook;\n  afterLoad?: Hook;\n}\n\nexport interface ElementConfig {\n  tag: string;\n  url: string;\n  isModule?: boolean;\n  importMap?: boolean;\n  loadingComponent?: Type<any>;\n  errorComponent?: Type<any>;\n  preload?: boolean;\n  hooks?: HooksConfig;\n  isAdded?: boolean;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LazyElementsLoaderService {\n  configs: ElementConfig[] = [];\n\n  constructor(\n    private errorHandler: ErrorHandler,\n    @Inject(LAZY_ELEMENTS_REGISTRY) private registry: LazyElementsRegistry,\n    @Optional()\n    @Inject(LAZY_ELEMENT_ROOT_OPTIONS)\n    public options: LazyElementRootOptions\n  ) {\n    if (!options) {\n      this.options = {};\n    }\n  }\n\n  addConfigs(newConfigs: ElementConfig[]) {\n    newConfigs.forEach((newConfig) => {\n      const existingConfig = this.getElementConfig(newConfig.tag);\n      if (existingConfig) {\n        ngDevMode &&\n          console.warn(\n            `${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`\n          );\n      } else {\n        newConfig.isAdded = true;\n        this.configs.push(newConfig);\n        const shouldPreload =\n          newConfig.preload !== undefined\n            ? newConfig.preload\n            : this.options.preload;\n        if (shouldPreload) {\n          this.loadElement(\n            newConfig.url,\n            newConfig.tag,\n            newConfig.isModule,\n            newConfig.importMap,\n            newConfig.hooks\n          );\n        }\n      }\n    });\n  }\n\n  getElementConfig(tag: string): ElementConfig {\n    return this.configs.find((config) => config.tag === tag);\n  }\n\n  preload(tags?: string[]) {\n    let configs = this.configs;\n    if (tags) {\n      configs = this.configs.filter((config) => tags.includes(config.tag));\n    }\n    configs.forEach((config) =>\n      this.loadElement(\n        config.url,\n        config.tag,\n        config.isModule,\n        config.importMap,\n        config.hooks\n      )\n    );\n  }\n\n  async loadElement(\n    url: string,\n    tag: string,\n    isModule?: boolean,\n    importMap?: boolean,\n    hooksConfig?: HooksConfig\n  ): Promise<void> {\n    const config = this.getElementConfig(tag);\n    isModule ??= config?.isModule ?? this.options.isModule;\n    importMap ??= config?.importMap ?? this.options.importMap;\n\n    if (ngDevMode && !tag) {\n      throw new Error(\n        `${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`\n      );\n    }\n\n    if (!url) {\n      if (ngDevMode && !config?.url && !importMap) {\n        throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);\n      } else if (importMap) {\n        url = tag;\n      } else {\n        url = config.url;\n      }\n    }\n\n    if (!this.hasElement(url)) {\n      const notifier = this.addElement(url);\n\n      const beforeLoadHook =\n        hooksConfig?.beforeLoad ??\n        config?.hooks?.beforeLoad ??\n        this.options?.hooks?.beforeLoad;\n      const afterLoadHook =\n        hooksConfig?.afterLoad ??\n        config?.hooks?.afterLoad ??\n        this.options?.hooks?.afterLoad;\n\n      if (importMap) {\n        url = await this.resolveImportMap(url);\n      }\n\n      const script = document.createElement('script') as HTMLScriptElement;\n      if (isModule) {\n        script.type = 'module';\n      }\n      script.src = url;\n      const onLoad = () => {\n        if (afterLoadHook) {\n          this.handleHook(afterLoadHook, tag)\n            .then(notifier.resolve)\n            .catch(notifier.reject);\n        } else {\n          notifier.resolve();\n        }\n\n        cleanup();\n      };\n      const onError = (error: ErrorEvent) => {\n        notifier.reject(error);\n        cleanup();\n        // Caretaker note: don't put it before the `reject` and `cleanup` since the user may have some\n        // custom error handler that will re-throw the error through `throw error`. Hence the code won't\n        // be executed, and the promise won't be rejected.\n        this.errorHandler.handleError(error);\n      };\n      // The `load` and `error` event listeners capture `this`. That's why they have to be removed manually.\n      // Otherwise, the `LazyElementsLoaderService` is not going to be GC'd.\n      function cleanup() {\n        script.removeEventListener('load', onLoad);\n        script.removeEventListener('error', onError);\n      }\n      script.addEventListener('load', onLoad);\n      script.addEventListener('error', onError);\n      if (beforeLoadHook) {\n        this.handleHook(beforeLoadHook, tag)\n          .then(() => document.body.appendChild(script))\n          .catch(notifier.reject);\n      } else {\n        document.body.appendChild(script);\n      }\n    }\n    return this.registry.get(this.stripUrlProtocol(url));\n  }\n\n  private addElement(url: string): Notifier {\n    let notifier: Notifier;\n    this.registry.set(\n      this.stripUrlProtocol(url),\n      new Promise<void>((resolve, reject) => (notifier = { resolve, reject }))\n    );\n    return notifier;\n  }\n\n  private hasElement(url: string): boolean {\n    return this.registry.has(this.stripUrlProtocol(url));\n  }\n\n  private stripUrlProtocol(url: string): string {\n    return url.replace(/https?:\\/\\//, '');\n  }\n\n  private handleHook(hook: Hook, tag: string): Promise<void> {\n    try {\n      return Promise.resolve(hook(tag));\n    } catch (err) {\n      return Promise.reject(err);\n    }\n  }\n\n  private async resolveImportMap(url: string) {\n    const System = (window as any).System;\n    if (System) {\n      await System.prepareImport();\n      url = System.resolve(url);\n    } else if (ngDevMode) {\n      throw new Error(\n        `${LOG_PREFIX} - importMap feature depends on SystemJS library to be globally loaded but none was found, thus '${url}' can't be resolved. You should either load SystemJS or remove the importMap flag.`\n      );\n    }\n    return url;\n  }\n}\n\ninterface Notifier {\n  resolve: () => void;\n  reject: (error: any) => void;\n}\n"]}

@@ -18,3 +18,4 @@ import * as i0 from '@angular/core';

class LazyElementsLoaderService {
constructor(registry, options) {
constructor(errorHandler, registry, options) {
this.errorHandler = errorHandler;
this.registry = registry;

@@ -88,3 +89,3 @@ this.options = options;

script.src = url;
script.onload = () => {
const onLoad = () => {
if (afterLoadHook) {

@@ -98,4 +99,20 @@ this.handleHook(afterLoadHook, tag)

}
cleanup();
};
script.onerror = notifier.reject;
const onError = (error) => {
notifier.reject(error);
cleanup();
// Caretaker note: don't put it before the `reject` and `cleanup` since the user may have some
// custom error handler that will re-throw the error through `throw error`. Hence the code won't
// be executed, and the promise won't be rejected.
this.errorHandler.handleError(error);
};
// The `load` and `error` event listeners capture `this`. That's why they have to be removed manually.
// Otherwise, the `LazyElementsLoaderService` is not going to be GC'd.
function cleanup() {
script.removeEventListener('load', onLoad);
script.removeEventListener('error', onError);
}
script.addEventListener('load', onLoad);
script.addEventListener('error', onError);
if (beforeLoadHook) {

@@ -146,3 +163,3 @@ this.handleHook(beforeLoadHook, tag)

}
LazyElementsLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, deps: [{ token: LAZY_ELEMENTS_REGISTRY }, { token: LAZY_ELEMENT_ROOT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
LazyElementsLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, deps: [{ token: i0.ErrorHandler }, { token: LAZY_ELEMENTS_REGISTRY }, { token: LAZY_ELEMENT_ROOT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
LazyElementsLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, providedIn: 'root' });

@@ -154,3 +171,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: LazyElementsLoaderService, decorators: [{

}]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
}], ctorParameters: function () { return [{ type: i0.ErrorHandler }, { type: undefined, decorators: [{
type: Inject,

@@ -157,0 +174,0 @@ args: [LAZY_ELEMENTS_REGISTRY]

@@ -1,2 +0,2 @@

import { Type } from '@angular/core';
import { ErrorHandler, Type } from '@angular/core';
import { LazyElementRootOptions } from './lazy-elements.module';

@@ -22,6 +22,7 @@ import { LazyElementsRegistry } from './lazy-elements.tokens';

export declare class LazyElementsLoaderService {
private errorHandler;
private registry;
options: LazyElementRootOptions;
configs: ElementConfig[];
constructor(registry: LazyElementsRegistry, options: LazyElementRootOptions);
constructor(errorHandler: ErrorHandler, registry: LazyElementsRegistry, options: LazyElementRootOptions);
addConfigs(newConfigs: ElementConfig[]): void;

@@ -36,4 +37,4 @@ getElementConfig(tag: string): ElementConfig;

private resolveImportMap;
static ɵfac: i0.ɵɵFactoryDeclaration<LazyElementsLoaderService, [null, { optional: true; }]>;
static ɵfac: i0.ɵɵFactoryDeclaration<LazyElementsLoaderService, [null, null, { optional: true; }]>;
static ɵprov: i0.ɵɵInjectableDeclaration<LazyElementsLoaderService>;
}
{
"name": "@angular-extensions/elements",
"version": "12.1.2",
"version": "12.4.1",
"peerDependencies": {

@@ -5,0 +5,0 @@ "@angular/common": ">=12",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc