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

@iplab/ngx-file-upload

Package Overview
Dependencies
Maintainers
1
Versions
69
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@iplab/ngx-file-upload - npm Package Compare versions

Comparing version 2.0.5 to 2.0.6

4

esm2015/lib/components/file-upload-attr.component.js

@@ -128,3 +128,3 @@ import { __decorate, __metadata, __param } from "tslib";

__metadata("design:type", Function),
__metadata("design:paramtypes", [DragEvent]),
__metadata("design:paramtypes", [Event]),
__metadata("design:returntype", void 0)

@@ -177,2 +177,2 @@ ], FileUploadAttributeComponent.prototype, "onDrop", null);

export { FileUploadAttributeComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["lib/components/file-upload-attr.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,KAAK,EACL,MAAM,EACN,UAAU,EACV,YAAY,EACZ,SAAS,EACT,SAAS,EACT,WAAW,EACX,MAAM,EACN,SAAS,EACT,YAAY,EACZ,WAAW,EACX,SAAS,EACT,aAAa,EAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AA0C5D,IAAa,4BAA4B,GAAzC,MAAa,4BAA4B;IAerC,YACW,iBAAoC,EACnC,cAA0B,EAC1B,QAAmB,EACD,QAAQ;QAH3B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACnC,mBAAc,GAAd,cAAc,CAAY;QAC1B,aAAQ,GAAR,QAAQ,CAAW;QACD,aAAQ,GAAR,QAAQ,CAAA;QAhB/B,YAAO,GAAsB,IAAI,CAAC;QAMlC,gBAAW,GAAqB,IAAI,CAAC;QAEpC,UAAK,GAAoB,EAAE,CAAC;QAE5B,kBAAa,GAAwB,EAAE,CAAC;QA8GxC,YAAO,GAAe,GAAG,EAAE;YAC/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACvE,CAAC,CAAA;IAzGE,CAAC;IAEG,QAAQ;QACX,IAAI,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC7B,IAAI,CAAC,OAAO,GAAG,IAAI,iBAAiB,EAAE,CAAC;SAC1C;IACL,CAAC;IAEM,eAAe;QAClB,IAAI,IAAI,CAAC,iBAAiB,CAAC,uBAAuB,EAAE,EAAE;YAClD,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;IAClC,CAAC;IAGD,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC;IAC/D,CAAC;IAGD,IAAW,SAAS;QAChB,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;IAC1D,CAAC;IAEO,SAAS;QACb,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YACjG,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAChG,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC5C,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,SAAS,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAC7G,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,CAAC,WAAW,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YACnD,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,SAAS,EAAE,CAAC,KAAU,EAAE,EAAE;gBAC9E,IAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,SAAS,KAAK,WAAW,IAAI,SAAS,KAAK,WAAW,EAAE;oBAChF,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;iBAC3B;YACL,CAAC,CAAC,CACL,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAChC,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,SAAS,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CACvG,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAClF,CAAC;IACN,CAAC;IAEO,sBAAsB;QAC1B,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;SACzE;aAAM;YACH,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;SAC5E;IACL,CAAC;IAEO,iBAAiB,CAAC,KAAgB;QACtC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,KAAgB;QAC/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACxE,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,KAAgB;QAChC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IAC3E,CAAC;IAGM,MAAM,CAAC,KAAgB;QAC1B,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YACvB,OAAO;SACV;QACD,MAAM,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC;QACvC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;CAMJ,CAAA;;YA/GiC,iBAAiB;YACnB,UAAU;YAChB,SAAS;4CAC1B,MAAM,SAAC,QAAQ;;AAhBpB;IADC,KAAK,EAAE;8BACQ,iBAAiB;6DAAQ;AAGzC;IADC,SAAS,CAAC,SAAS,CAAC;8BACL,UAAU;6DAAiB;AAG3C;IADC,YAAY,CAAC,aAAa,CAAC;8BACR,WAAW;iEAAa;AAkC5C;IADC,WAAW,CAAC,iBAAiB,CAAC;;;4DAG9B;AAGD;IADC,WAAW,CAAC,kBAAkB,CAAC;;;6DAG/B;AAgED;IADC,YAAY,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACZ,SAAS;;0DAO7B;AAzHQ,4BAA4B;IAtCxC,SAAS,CAAC;QACP,QAAQ,EAAE,kBAAkB;QAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA8BT;QAED,SAAS,EAAE;YACP,iBAAiB;SACpB;;KACJ,CAAC;IAoBO,WAAA,MAAM,CAAC,QAAQ,CAAC,CAAA;qCAHS,iBAAiB;QACnB,UAAU;QAChB,SAAS;GAlBtB,4BAA4B,CA+HxC;SA/HY,4BAA4B","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styleUrls: [`./file-upload-attr.component.scss`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    }\r\n\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["lib/components/file-upload-attr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styleUrls: [`./file-upload-attr.component.scss`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: Event): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: Event): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: Event): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: Event): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = (event as any).dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    }\r\n\r\n}\r\n"]}

@@ -137,3 +137,3 @@ import { __decorate, __metadata, __param } from "tslib";

__metadata("design:type", Function),
__metadata("design:paramtypes", [DragEvent]),
__metadata("design:paramtypes", [Event]),
__metadata("design:returntype", void 0)

@@ -158,2 +158,2 @@ ], FileUploadAttributeComponent.prototype, "onDrop", null);

export { FileUploadAttributeComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["lib/components/file-upload-attr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styleUrls: [`./file-upload-attr.component.scss`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    }\r\n\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["lib/components/file-upload-attr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styleUrls: [`./file-upload-attr.component.scss`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: Event): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: Event): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: Event): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: Event): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = (event as any).dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    }\r\n\r\n}\r\n"]}

@@ -31,4 +31,4 @@ import { OnInit, ElementRef, Renderer2, OnDestroy, TemplateRef, AfterViewInit } from '@angular/core';

private onDragLeave;
onDrop(event: DragEvent): void;
onDrop(event: Event): void;
private onTouch;
}

@@ -6,3 +6,3 @@ {

"bugs": "https://github.com/pIvan/file-upload/issues",
"version": "2.0.5",
"version": "2.0.6",
"author": "Ivan Pintar",

@@ -9,0 +9,0 @@ "license": "MIT",

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

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