From 094aadbd4fb7fa9c5707a70e37cf544dc5fe75aa Mon Sep 17 00:00:00 2001 From: "marek.bukovsky" Date: Wed, 3 Jul 2019 18:16:12 +0200 Subject: [PATCH 1/3] FEAT: added support for angular8, and ivy compatible package --- index.ts | 30 +----------------------------- package.json | 22 ++++++++++++---------- public_api.ts | 6 ++++++ src/hotkey.model.ts | 12 ++++++------ src/hotkey.module.ts | 23 +++++++++++++++++++++++ tsconfig.json | 13 +++++++++---- 6 files changed, 57 insertions(+), 49 deletions(-) create mode 100644 public_api.ts create mode 100644 src/hotkey.module.ts diff --git a/index.ts b/index.ts index 0994dfc..9a85f30 100644 --- a/index.ts +++ b/index.ts @@ -1,29 +1 @@ -import {NgModule, ModuleWithProviders} from '@angular/core'; -import {CommonModule} from '@angular/common'; -import {HotkeysDirective} from './src/hotkeys.directive'; -import {CheatSheetComponent} from './src/cheatsheet.component'; -import {IHotkeyOptions, HotkeyOptions} from './src/hotkey.options'; -import {HotkeysService} from './src/hotkeys.service'; - -export * from './src/cheatsheet.component'; -export * from './src/hotkey.model'; -export * from './src/hotkey.options'; -export * from './src/hotkeys.directive'; -export * from './src/hotkeys.service'; - -@NgModule({ - imports : [CommonModule], - exports : [HotkeysDirective, CheatSheetComponent], - declarations : [HotkeysDirective, CheatSheetComponent] -}) -export class HotkeyModule { - static forRoot(options: IHotkeyOptions = {}): ModuleWithProviders { - return { - ngModule : HotkeyModule, - providers : [ - HotkeysService, - {provide : HotkeyOptions, useValue : options} - ] - }; - } -} \ No newline at end of file +export * from './public_api'; \ No newline at end of file diff --git a/package.json b/package.json index f8f268f..e80ae0d 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "prepare": "tsc && ngc", "tsc": "tsc", "tsc:watch": "tsc --watch", - "ngc": "./node_modules/.bin/ngc -p tsconfig.json" + "ngc": "ngc -p tsconfig.json" }, "repository": { "type": "git", @@ -28,25 +28,27 @@ "bugs": { "url": "git@github.com:brtnshrdr/angular2-hotkeys.git/issues" }, - "main": "./index.js", + "module": "./angular2-hotkeys.js", + "typings":"./angular2-hotkeys.d.ts", "dependencies": { "mousetrap": "^1.6.0", "@types/mousetrap": "^1.6.0" }, "devDependencies": { - "@angular/common": "4.2.5", - "@angular/compiler": "4.2.5", - "@angular/compiler-cli": "4.2.5", - "@angular/core": "4.2.5", + "@angular/common": "8.0.0", + "@angular/compiler": "8.0.0", + "@angular/compiler-cli": "8.0.0", + "@angular/core": "8.0.0", + "tsickle": "0.35.0", "@types/core-js": "0.9.41", "codelyzer": "~3.0.1", - "rxjs": "^5.5.0", + "rxjs": "^6.5.0", "tslint": "^3.15.1", - "typescript": "~2.3.3", - "zone.js": "^0.8.4" + "typescript": "~3.4.5", + "zone.js": "^0.9.1" }, "peerDependencies": { - "@angular/core": "^5.2.0 || ^6.0.0 || ^7.0.0", + "@angular/core": "^5.2.0 || ^6.0.0 || ^7.0.0 || ^8.0.0", "rxjs": "^5.5.0 || ^6.0.0" }, "engines": { diff --git a/public_api.ts b/public_api.ts new file mode 100644 index 0000000..e3d387d --- /dev/null +++ b/public_api.ts @@ -0,0 +1,6 @@ +export * from './src/cheatsheet.component'; +export * from './src/hotkey.model'; +export * from './src/hotkey.options'; +export * from './src/hotkeys.directive'; +export * from './src/hotkeys.service'; +export * from './src/hotkey.module'; diff --git a/src/hotkey.model.ts b/src/hotkey.model.ts index 9f6e12b..9de1972 100644 --- a/src/hotkey.model.ts +++ b/src/hotkey.model.ts @@ -37,12 +37,12 @@ export class Hotkey { /** * Creates a new Hotkey for Mousetrap binding * - * @param {string} combo mousetrap key binding - * @param {string} description description for the help menu - * @param {Function} callback method to call when key is pressed - * @param {string} action the type of event to listen for (for mousetrap) - * @param {array} allowIn an array of tag names to allow this combo in ('INPUT', 'SELECT', and/or 'TEXTAREA') - * @param {boolean} persistent if true, the binding is preserved upon route changes + * @param combo mousetrap key binding + * @param description description for the help menu + * @param callback method to call when key is pressed + * @param action the type of event to listen for (for mousetrap) + * @param allowIn an array of tag names to allow this combo in ('INPUT', 'SELECT', and/or 'TEXTAREA') + * @param persistent if true, the binding is preserved upon route changes */ constructor(public combo: string | string[], public callback: (event: KeyboardEvent, combo: string) => ExtendedKeyboardEvent | boolean, public allowIn?: string[], public description?: string | Function, public action?: string, diff --git a/src/hotkey.module.ts b/src/hotkey.module.ts new file mode 100644 index 0000000..ec682bb --- /dev/null +++ b/src/hotkey.module.ts @@ -0,0 +1,23 @@ +import {NgModule, ModuleWithProviders} from '@angular/core'; +import {CommonModule} from '@angular/common'; +import {HotkeysDirective} from './hotkeys.directive'; +import {CheatSheetComponent} from './cheatsheet.component'; +import {IHotkeyOptions, HotkeyOptions} from './hotkey.options'; +import {HotkeysService} from './hotkeys.service'; + +@NgModule({ + imports : [CommonModule], + exports : [HotkeysDirective, CheatSheetComponent], + declarations : [HotkeysDirective, CheatSheetComponent] +}) +export class HotkeyModule { + static forRoot(options: IHotkeyOptions = {}): ModuleWithProviders { + return { + ngModule : HotkeyModule, + providers : [ + HotkeysService, + {provide : HotkeyOptions, useValue : options} + ] + }; + } +} \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json index 041ecde..0e40973 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,8 +1,8 @@ { "compilerOptions": { "noImplicitAny": true, - "module": "commonjs", - "target": "ES5", + "module": "esnext", + "target": "es5", "emitDecoratorMetadata": true, "experimentalDecorators": true, "sourceMap": true, @@ -13,13 +13,18 @@ ] }, "angularCompilerOptions": { - "genDir": "compiled" + "enableResourceInlining": true, + "annotateForClosureCompiler": true, + "strictMetadataEmit": false, + "skipTemplateCodegen": true, + "flatModuleOutFile": "angular2-hotkeys.js", + "flatModuleId": "angular2-hotkeys" }, "typeRoots": [ "node_modules/@types" ], "files": [ - "index.ts" + "public_api.ts" ], "exclude": [ "node_modules" From 246b6c23697a18a1a65b25dd239d7aaacf5775fb Mon Sep 17 00:00:00 2001 From: "marek.bukovsky" Date: Thu, 4 Jul 2019 06:42:28 +0200 Subject: [PATCH 2/3] Fixed compilation, now correctly compiles project --- tsconfig.json | 1 + 1 file changed, 1 insertion(+) diff --git a/tsconfig.json b/tsconfig.json index 0e40973..1ae2a5d 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -3,6 +3,7 @@ "noImplicitAny": true, "module": "esnext", "target": "es5", + "moduleResolution": "node", "emitDecoratorMetadata": true, "experimentalDecorators": true, "sourceMap": true, From daebfb0367c01d0ef25e55644a8a3fff43d80c67 Mon Sep 17 00:00:00 2001 From: "marek.bukovsky" Date: Thu, 4 Jul 2019 08:56:20 +0200 Subject: [PATCH 3/3] Updated readme, now displays correct info about angular supported version --- README.MD | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.MD b/README.MD index 6450f5b..69de688 100644 --- a/README.MD +++ b/README.MD @@ -1,5 +1,5 @@ # angular2-hotkeys -Angular 5.2.0+, 6 and 7 Compatible. Older versions might work but isn't officially tested. +Angular 5.2.0+, 6, 7 and 8 Compatible. Older versions might work but isn't officially tested. Also library is Angular IVY ready. ## Installation To install this library, run: