• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

atinc / ngx-tethys / #55

30 Jul 2025 07:08AM UTC coverage: 9.866% (-80.4%) from 90.297%
#55

push

why520crazy
feat(empty): add setMessage for update display text #TINFR-2616

92 of 6794 branches covered (1.35%)

Branch coverage included in aggregate %.

2014 of 14552 relevant lines covered (13.84%)

6.15 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

13.04
/src/shared/directives/thy-ctrl-enter.directive.ts
1
import { Directive, Output, ElementRef, EventEmitter, OnInit, NgZone, Renderer2, OnDestroy, inject } from '@angular/core';
2
import { keycodes } from 'ngx-tethys/util';
3

4
/**
5
 * @name thyCtrlEnter
6
 */
7
@Directive({
1✔
8
    selector: '[thyCtrlEnter]'
9
})
×
10
export class ThyCtrlEnterDirective implements OnInit, OnDestroy {
×
11
    private ngZone = inject(NgZone);
×
12
    private elementRef = inject(ElementRef);
×
13
    private renderer = inject(Renderer2);
×
14

×
15
    @Output() thyCtrlEnter = new EventEmitter();
×
16

×
17
    private removeKeydownListenerFn: VoidFunction;
×
18

×
19
    onKeydown = (event: KeyboardEvent) => {
20
        const keyCode = event.which || event.keyCode;
21
        if ((event.ctrlKey || event.metaKey) && keyCode === keycodes.ENTER) {
22
            event.preventDefault();
23
            this.ngZone.run(() => {
24
                this.thyCtrlEnter.emit(event);
×
25
            });
×
26
        }
27
    };
28

29
    ngOnInit() {
×
30
        this.ngZone.runOutsideAngular(() => {
31
            this.removeKeydownListenerFn = this.renderer.listen(this.elementRef.nativeElement, 'keydown', this.onKeydown);
1✔
32
        });
33
    }
34

35
    ngOnDestroy(): void {
1✔
36
        this.removeKeydownListenerFn();
37
    }
38
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc