ngx-rs-ant 1.0.4 → 1.0.8
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.
- package/data-grid/data-grid.component.d.ts +1 -1
- package/data-grid/unit-info-template/unit-info-template.component.d.ts +4 -4
- package/data-grid/user-info-template/user-info-template.component.d.ts +4 -4
- package/esm2020/data-grid/data-grid.component.mjs +15 -7
- package/esm2020/data-grid/file-cell-template/file-cell-template.component.mjs +3 -3
- package/esm2020/data-grid/unit-info-template/unit-info-template.component.mjs +21 -41
- package/esm2020/data-grid/user-info-template/user-info-template.component.mjs +21 -41
- package/esm2020/public-api.mjs +3 -1
- package/esm2020/websocket/websocket.module.mjs +18 -0
- package/esm2020/websocket/websocket.service.mjs +153 -0
- package/fesm2015/ngx-rs-ant.mjs +228 -92
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +227 -92
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/package.json +1 -2
- package/public-api.d.ts +2 -0
- package/websocket/websocket.module.d.ts +7 -0
- package/websocket/websocket.service.d.ts +56 -0
|
@@ -2,64 +2,44 @@ import { Component, Input } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../data-grid.service";
|
|
4
4
|
import * as i2 from "@angular/platform-browser";
|
|
5
|
-
import * as i3 from "
|
|
6
|
-
import * as i4 from "devextreme-angular/
|
|
7
|
-
import * as i5 from "devextreme-angular/ui/
|
|
8
|
-
import * as i6 from "devextreme-angular/ui/tooltip";
|
|
5
|
+
import * as i3 from "devextreme-angular/core";
|
|
6
|
+
import * as i4 from "devextreme-angular/ui/button";
|
|
7
|
+
import * as i5 from "devextreme-angular/ui/tooltip";
|
|
9
8
|
export class UserInfoTemplateComponent {
|
|
10
9
|
constructor(service, domSanitizer) {
|
|
11
10
|
this.service = service;
|
|
12
11
|
this.domSanitizer = domSanitizer;
|
|
13
|
-
this.users = [];
|
|
14
12
|
}
|
|
15
13
|
ngOnInit() {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
this.users.push(response);
|
|
23
|
-
// 重绘表格宽高
|
|
24
|
-
setTimeout(() => {
|
|
25
|
-
this.table.resize();
|
|
26
|
-
});
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
this.service.getUserInfo(value).subscribe(response => {
|
|
32
|
-
this.users.push(response);
|
|
33
|
-
// 重绘表格宽高
|
|
34
|
-
setTimeout(() => {
|
|
35
|
-
this.table.resize();
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
convertContent(userInfo) {
|
|
42
|
-
let content = '<table>';
|
|
43
|
-
for (const item of userInfo) {
|
|
44
|
-
content += `
|
|
14
|
+
this.service.getUserInfo(this.uid).subscribe(response => {
|
|
15
|
+
this.displayName = response.displayName;
|
|
16
|
+
const userInfo = response.userInfo;
|
|
17
|
+
let content = '<table>';
|
|
18
|
+
for (const item of userInfo) {
|
|
19
|
+
content += `
|
|
45
20
|
<tr>
|
|
46
21
|
<td style="text-align: right;">${item.caption}:</td>
|
|
47
22
|
<td style="text-align: left;">${item.value}</td>
|
|
48
23
|
</tr>
|
|
49
24
|
`;
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
25
|
+
}
|
|
26
|
+
content += '</table>';
|
|
27
|
+
this.content = this.domSanitizer.bypassSecurityTrustHtml(content);
|
|
28
|
+
// 重绘表格宽高
|
|
29
|
+
setTimeout(() => {
|
|
30
|
+
this.table.resize();
|
|
31
|
+
});
|
|
32
|
+
});
|
|
53
33
|
}
|
|
54
34
|
}
|
|
55
35
|
UserInfoTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: UserInfoTemplateComponent, deps: [{ token: i1.DataGridService }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
56
|
-
UserInfoTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: UserInfoTemplateComponent, selector: "rs-user-info-template", inputs: { table: "table",
|
|
36
|
+
UserInfoTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: UserInfoTemplateComponent, selector: "rs-user-info-template", inputs: { table: "table", uid: "uid" }, ngImport: i0, template: "<dx-button #textDiv type=\"default\" stylingMode=\"text\">\n {{displayName}}\n <dx-tooltip [target]=\"textDiv.instance.element()\"\n [position]=\"'top'\"\n [showEvent]=\"'click'\">\n <div *dxTemplate=\"let data of 'content'\">\n <div [innerHTML]=\"content\"></div>\n </div>\n </dx-tooltip>\n</dx-button>\n<br/>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }, { kind: "component", type: i4.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }, { kind: "component", type: i5.DxTooltipComponent, selector: "dx-tooltip", inputs: ["animation", "closeOnOutsideClick", "container", "contentTemplate", "copyRootClassesToWrapper", "deferRendering", "disabled", "elementAttr", "height", "hideEvent", "hideOnOutsideClick", "hideOnParentScroll", "hint", "hoverStateEnabled", "maxHeight", "maxWidth", "minHeight", "minWidth", "position", "rtlEnabled", "shading", "shadingColor", "showEvent", "target", "visible", "width", "wrapperAttr"], outputs: ["onContentReady", "onDisposing", "onHidden", "onHiding", "onInitialized", "onOptionChanged", "onShowing", "onShown", "animationChange", "closeOnOutsideClickChange", "containerChange", "contentTemplateChange", "copyRootClassesToWrapperChange", "deferRenderingChange", "disabledChange", "elementAttrChange", "heightChange", "hideEventChange", "hideOnOutsideClickChange", "hideOnParentScrollChange", "hintChange", "hoverStateEnabledChange", "maxHeightChange", "maxWidthChange", "minHeightChange", "minWidthChange", "positionChange", "rtlEnabledChange", "shadingChange", "shadingColorChange", "showEventChange", "targetChange", "visibleChange", "widthChange", "wrapperAttrChange"] }] });
|
|
57
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: UserInfoTemplateComponent, decorators: [{
|
|
58
38
|
type: Component,
|
|
59
|
-
args: [{ selector: 'rs-user-info-template', template: "<
|
|
39
|
+
args: [{ selector: 'rs-user-info-template', template: "<dx-button #textDiv type=\"default\" stylingMode=\"text\">\n {{displayName}}\n <dx-tooltip [target]=\"textDiv.instance.element()\"\n [position]=\"'top'\"\n [showEvent]=\"'click'\">\n <div *dxTemplate=\"let data of 'content'\">\n <div [innerHTML]=\"content\"></div>\n </div>\n </dx-tooltip>\n</dx-button>\n<br/>\n" }]
|
|
60
40
|
}], ctorParameters: function () { return [{ type: i1.DataGridService }, { type: i2.DomSanitizer }]; }, propDecorators: { table: [{
|
|
61
41
|
type: Input
|
|
62
|
-
}],
|
|
42
|
+
}], uid: [{
|
|
63
43
|
type: Input
|
|
64
44
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1pbmZvLXRlbXBsYXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL2RhdGEtZ3JpZC91c2VyLWluZm8tdGVtcGxhdGUvdXNlci1pbmZvLXRlbXBsYXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL2RhdGEtZ3JpZC91c2VyLWluZm8tdGVtcGxhdGUvdXNlci1pbmZvLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFTLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBU3ZELE1BQU0sT0FBTyx5QkFBeUI7SUFRcEMsWUFBb0IsT0FBd0IsRUFBVSxZQUEwQjtRQUE1RCxZQUFPLEdBQVAsT0FBTyxDQUFpQjtRQUFVLGlCQUFZLEdBQVosWUFBWSxDQUFjO0lBQ2hGLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUN0RCxJQUFJLENBQUMsV0FBVyxHQUFHLFFBQVEsQ0FBQyxXQUFXLENBQUM7WUFDeEMsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQztZQUNuQyxJQUFJLE9BQU8sR0FBRyxTQUFTLENBQUM7WUFDeEIsS0FBSyxNQUFNLElBQUksSUFBSSxRQUFRLEVBQUU7Z0JBQzNCLE9BQU8sSUFBSTs7aURBRThCLElBQUksQ0FBQyxPQUFPO2dEQUNiLElBQUksQ0FBQyxLQUFLOztPQUVuRCxDQUFDO2FBQ0Q7WUFDRCxPQUFPLElBQUksVUFBVSxDQUFBO1lBQ3JCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyx1QkFBdUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNsRSxTQUFTO1lBQ1QsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3RCLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOztzSEEvQlUseUJBQXlCOzBHQUF6Qix5QkFBeUIscUdDVHRDLGtXQVdBOzJGREZhLHlCQUF5QjtrQkFMckMsU0FBUzsrQkFDRSx1QkFBdUI7aUlBTWpDLEtBQUs7c0JBREosS0FBSztnQkFHTixHQUFHO3NCQURGLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0RhdGFHcmlkU2VydmljZX0gZnJvbSBcIi4uL2RhdGEtZ3JpZC5zZXJ2aWNlXCI7XG5pbXBvcnQge0RvbVNhbml0aXplcn0gZnJvbSBcIkBhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXJcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncnMtdXNlci1pbmZvLXRlbXBsYXRlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3VzZXItaW5mby10ZW1wbGF0ZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3VzZXItaW5mby10ZW1wbGF0ZS5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJJbmZvVGVtcGxhdGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICB0YWJsZTogYW55O1xuICBASW5wdXQoKVxuICB1aWQ6IGFueTtcbiAgZGlzcGxheU5hbWU6IGFueTtcbiAgY29udGVudDogYW55O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2VydmljZTogRGF0YUdyaWRTZXJ2aWNlLCBwcml2YXRlIGRvbVNhbml0aXplcjogRG9tU2FuaXRpemVyKSB7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnNlcnZpY2UuZ2V0VXNlckluZm8odGhpcy51aWQpLnN1YnNjcmliZShyZXNwb25zZSA9PiB7XG4gICAgICB0aGlzLmRpc3BsYXlOYW1lID0gcmVzcG9uc2UuZGlzcGxheU5hbWU7XG4gICAgICBjb25zdCB1c2VySW5mbyA9IHJlc3BvbnNlLnVzZXJJbmZvO1xuICAgICAgbGV0IGNvbnRlbnQgPSAnPHRhYmxlPic7XG4gICAgICBmb3IgKGNvbnN0IGl0ZW0gb2YgdXNlckluZm8pIHtcbiAgICAgICAgY29udGVudCArPSBgXG4gICAgICAgICAgICA8dHI+XG4gICAgICAgICAgICAgICAgPHRkIHN0eWxlPVwidGV4dC1hbGlnbjogcmlnaHQ7XCI+JHtpdGVtLmNhcHRpb25977yaPC90ZD5cbiAgICAgICAgICAgICAgICA8dGQgc3R5bGU9XCJ0ZXh0LWFsaWduOiBsZWZ0O1wiPiR7aXRlbS52YWx1ZX08L3RkPlxuICAgICAgICAgICAgPC90cj5cbiAgICAgIGA7XG4gICAgICB9XG4gICAgICBjb250ZW50ICs9ICc8L3RhYmxlPidcbiAgICAgIHRoaXMuY29udGVudCA9IHRoaXMuZG9tU2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RIdG1sKGNvbnRlbnQpO1xuICAgICAgLy8g6YeN57uY6KGo5qC85a696auYXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgdGhpcy50YWJsZS5yZXNpemUoKTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG59XG4iLCI8ZHgtYnV0dG9uICN0ZXh0RGl2IHR5cGU9XCJkZWZhdWx0XCIgc3R5bGluZ01vZGU9XCJ0ZXh0XCI+XG4gIHt7ZGlzcGxheU5hbWV9fVxuICA8ZHgtdG9vbHRpcCBbdGFyZ2V0XT1cInRleHREaXYuaW5zdGFuY2UuZWxlbWVudCgpXCJcbiAgICAgICAgICAgICAgW3Bvc2l0aW9uXT1cIid0b3AnXCJcbiAgICAgICAgICAgICAgW3Nob3dFdmVudF09XCInY2xpY2snXCI+XG4gICAgPGRpdiAqZHhUZW1wbGF0ZT1cImxldCBkYXRhIG9mICdjb250ZW50J1wiPlxuICAgICAgPGRpdiBbaW5uZXJIVE1MXT1cImNvbnRlbnRcIj48L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9keC10b29sdGlwPlxuPC9keC1idXR0b24+XG48YnIvPlxuIl19
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -24,4 +24,6 @@ export * from './modal/modal.component';
|
|
|
24
24
|
export * from './modal/modal.module';
|
|
25
25
|
export * from './modal/modal.service';
|
|
26
26
|
export * from './notify/notify';
|
|
27
|
-
|
|
27
|
+
export * from './websocket/websocket.module';
|
|
28
|
+
export * from './websocket/websocket.service';
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYm94LWNvbnRhaW5lci9ib3gtaXRlbS9pdGVtLWNvbmZpZy9pdGVtLWNvbmZpZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ib3gtY29udGFpbmVyL2JveC1pdGVtL2l0ZW0tc3R5bGUvaXRlbS1zdHlsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ib3gtY29udGFpbmVyL2JveC1jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYm94LWNvbnRhaW5lci9ib3gtY29udGFpbmVyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2JveC1jb250YWluZXIvUGx1Z2luTWFuYWdlcic7XG5leHBvcnQgKiBmcm9tICcuL2RhdGEtZ3JpZC9kYXRhLWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL2RhdGEtZ3JpZC5mYWN0b3J5JztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL2luc3RhbmNlLWxpbmstdGVtcGxhdGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL21hc3Rlci1kZXRhaWwtdGVtcGxhdGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL3Jvdy1idXR0b25zLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGEtZ3JpZC9kYXRhLWdyaWQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS1ncmlkL2RhdGEtZ3JpZC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJhd2VyL2RyYXdlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kcmF3ZXIvZHJhd2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RyYXdlci9kcmF3ZXIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcGFyYW1zL2R5bmFtaWMtcGFyYW1zLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcGFyYW1zL2R5bmFtaWMtcGFyYW1zLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2Zvcm0vZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtL2Zvcm0ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS9mb3JtLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9pY29uLXNlbGVjdG9yL2ljb24tc2VsZWN0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaWNvbi1zZWxlY3Rvci9pY29uLXNlbGVjdG9yLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsL21vZGFsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsL21vZGFsLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsL21vZGFsLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3RpZnkvbm90aWZ5JztcbmV4cG9ydCAqIGZyb20gJy4vd2Vic29ja2V0L3dlYnNvY2tldC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi93ZWJzb2NrZXQvd2Vic29ja2V0LnNlcnZpY2UnO1xuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class WebsocketModule {
|
|
5
|
+
}
|
|
6
|
+
WebsocketModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WebsocketModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
WebsocketModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: WebsocketModule, imports: [CommonModule] });
|
|
8
|
+
WebsocketModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WebsocketModule, imports: [CommonModule] });
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WebsocketModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
declarations: [],
|
|
13
|
+
imports: [
|
|
14
|
+
CommonModule
|
|
15
|
+
]
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vic29ja2V0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL3dlYnNvY2tldC93ZWJzb2NrZXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDOztBQVE3QyxNQUFNLE9BQU8sZUFBZTs7NEdBQWYsZUFBZTs2R0FBZixlQUFlLFlBSHhCLFlBQVk7NkdBR0gsZUFBZSxZQUh4QixZQUFZOzJGQUdILGVBQWU7a0JBTjNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3FCQUNiO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFdlYnNvY2tldE1vZHVsZSB7XG59XG4iXX0=
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { interval, Subject } from "rxjs";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class WebsocketService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.connectSuccess = false; // websocket 连接成功
|
|
7
|
+
this.period = 60 * 1000 * 10; // 10分钟检查一次
|
|
8
|
+
this.reconnectFlag = false; // 重连
|
|
9
|
+
this.reconnectPeriod = 5 * 1000; // 重连失败,则5秒钟重连一次
|
|
10
|
+
this.serverMessageSubject = new Subject(); // subject对象,用于发送服务器消息
|
|
11
|
+
// 实例化时开始连接服务器
|
|
12
|
+
this.connect();
|
|
13
|
+
// 进入程序就进行心跳检测,避免出现开始就连接中断,后续不重连
|
|
14
|
+
this.heartCheckStart();
|
|
15
|
+
// 将messageSubject存储到window对象上
|
|
16
|
+
window.serverMessageSubject = this.serverMessageSubject;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* 创建新连接
|
|
20
|
+
*/
|
|
21
|
+
connect() {
|
|
22
|
+
this.url = 'ws://' + window.location.host + '/ws?token=' + localStorage.getItem('token');
|
|
23
|
+
// 创建websocket对象
|
|
24
|
+
this.createWebSocket();
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* 创建连接
|
|
28
|
+
*/
|
|
29
|
+
createWebSocket() {
|
|
30
|
+
// 如果没有建立过连接,才建立连接并且添加时间监听
|
|
31
|
+
this.webSocket = new WebSocket(this.url);
|
|
32
|
+
// 建立连接成功
|
|
33
|
+
this.webSocket.onopen = () => this.onOpen();
|
|
34
|
+
// 接收到消息
|
|
35
|
+
this.webSocket.onmessage = (e) => this.onMessage(e);
|
|
36
|
+
// 连接关闭
|
|
37
|
+
this.webSocket.onclose = (e) => this.onClose(e);
|
|
38
|
+
// 异常
|
|
39
|
+
this.webSocket.onerror = (e) => this.onError(e);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* 连接打开
|
|
43
|
+
*/
|
|
44
|
+
onOpen() {
|
|
45
|
+
console.log('websocket 已连接');
|
|
46
|
+
// 设置连接成功
|
|
47
|
+
this.connectSuccess = true;
|
|
48
|
+
// 如果是重连中
|
|
49
|
+
if (this.reconnectFlag) {
|
|
50
|
+
// 1.停止重连
|
|
51
|
+
this.stopReconnect();
|
|
52
|
+
// 2.重新开启心跳
|
|
53
|
+
this.heartCheckStart();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* 接受到消息
|
|
58
|
+
*/
|
|
59
|
+
onMessage(event) {
|
|
60
|
+
// 将接受到的消息发布出去
|
|
61
|
+
const message = JSON.parse(event.data);
|
|
62
|
+
if (message.type === 'websocket') {
|
|
63
|
+
sessionStorage.setItem('clientId', message.value);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
this.serverMessageSubject.next(message);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* 连接关闭
|
|
71
|
+
*/
|
|
72
|
+
onClose(e) {
|
|
73
|
+
console.log('websocket 连接关闭', e);
|
|
74
|
+
this.connectSuccess = false;
|
|
75
|
+
this.webSocket.close();
|
|
76
|
+
// 关闭时开始重连
|
|
77
|
+
this.reconnect();
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 连接异常
|
|
81
|
+
*/
|
|
82
|
+
onError(e) {
|
|
83
|
+
// 出现异常时一定会进onClose,所以只在onClose做一次重连动作
|
|
84
|
+
console.log('websocket 连接异常', e);
|
|
85
|
+
this.connectSuccess = false;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* 开始重新连接
|
|
89
|
+
*/
|
|
90
|
+
reconnect() {
|
|
91
|
+
// 如果已重连,则直接return,避免重复连接
|
|
92
|
+
if (this.connectSuccess) {
|
|
93
|
+
this.stopReconnect();
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
// 如果正在连接中,则直接return,避免产生多个轮训事件
|
|
97
|
+
if (this.reconnectFlag) {
|
|
98
|
+
console.log('正在重连...');
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
// 开始重连
|
|
102
|
+
this.reconnectFlag = true;
|
|
103
|
+
// 如果没能成功连接,则定时重连
|
|
104
|
+
this.reconnectSubscription = interval(this.reconnectPeriod).subscribe(async (val) => {
|
|
105
|
+
console.log(`重连:${val + 1}次`);
|
|
106
|
+
// 重新连接
|
|
107
|
+
this.connect();
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* 停止重连
|
|
112
|
+
*/
|
|
113
|
+
stopReconnect() {
|
|
114
|
+
// 连接标识置为false
|
|
115
|
+
this.reconnectFlag = false;
|
|
116
|
+
// 取消订阅
|
|
117
|
+
if (typeof this.reconnectSubscription !== 'undefined' && this.reconnectSubscription != null) {
|
|
118
|
+
this.reconnectSubscription.unsubscribe();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* 开始心跳检测
|
|
123
|
+
*/
|
|
124
|
+
heartCheckStart() {
|
|
125
|
+
this.serverTimeoutSubscription = interval(this.period).subscribe(() => {
|
|
126
|
+
console.log('心跳检查');
|
|
127
|
+
// 保持连接状态,重置下
|
|
128
|
+
if (this.webSocket != null && this.webSocket.readyState === 1) {
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
// 停止心跳
|
|
132
|
+
this.heartCheckStop();
|
|
133
|
+
// 开始重连
|
|
134
|
+
this.reconnect();
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* 停止心跳检测
|
|
140
|
+
*/
|
|
141
|
+
heartCheckStop() {
|
|
142
|
+
// 取消订阅停止心跳
|
|
143
|
+
if (typeof this.serverTimeoutSubscription !== 'undefined' && this.serverTimeoutSubscription != null) {
|
|
144
|
+
this.serverTimeoutSubscription.unsubscribe();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
WebsocketService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WebsocketService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
149
|
+
WebsocketService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WebsocketService });
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WebsocketService, decorators: [{
|
|
151
|
+
type: Injectable
|
|
152
|
+
}], ctorParameters: function () { return []; } });
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"websocket.service.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/websocket/websocket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {interval, Subject, Subscription} from \"rxjs\";\n\n@Injectable()\nexport class WebsocketService {\n  private url: any;                                // 默认请求的url\n  private webSocket!: WebSocket;                   // websocket对象\n  private connectSuccess = false;                 // websocket 连接成功\n  private period = 60 * 1000 * 10;                // 10分钟检查一次\n  private serverTimeoutSubscription!: Subscription;        // 定时检测连接对象\n  private reconnectFlag = false;                  // 重连\n  private reconnectPeriod = 5 * 1000;              // 重连失败,则5秒钟重连一次\n  private reconnectSubscription!: Subscription;            // 重连订阅对象\n  public serverMessageSubject = new Subject<any>();// subject对象,用于发送服务器消息\n\n  constructor() {\n    // 实例化时开始连接服务器\n    this.connect();\n    // 进入程序就进行心跳检测,避免出现开始就连接中断,后续不重连\n    this.heartCheckStart();\n    // 将messageSubject存储到window对象上\n    (window as any).serverMessageSubject = this.serverMessageSubject;\n  }\n\n  /**\n   * 创建新连接\n   */\n  private connect() {\n    this.url = 'ws://' + window.location.host + '/ws?token=' + localStorage.getItem('token');\n    // 创建websocket对象\n    this.createWebSocket();\n  }\n\n  /**\n   * 创建连接\n   */\n  private createWebSocket() {\n    // 如果没有建立过连接，才建立连接并且添加时间监听\n    this.webSocket = new WebSocket(this.url);\n    // 建立连接成功\n    this.webSocket.onopen = () => this.onOpen();\n    // 接收到消息\n    this.webSocket.onmessage = (e) => this.onMessage(e);\n    // 连接关闭\n    this.webSocket.onclose = (e) => this.onClose(e);\n    // 异常\n    this.webSocket.onerror = (e) => this.onError(e);\n  }\n\n  /**\n   * 连接打开\n   */\n  private onOpen() {\n    console.log('websocket 已连接');\n    // 设置连接成功\n    this.connectSuccess = true;\n    // 如果是重连中\n    if (this.reconnectFlag) {\n      // 1.停止重连\n      this.stopReconnect();\n      // 2.重新开启心跳\n      this.heartCheckStart();\n    }\n  }\n\n  /**\n   * 接受到消息\n   */\n  private onMessage(event: any) {\n    // 将接受到的消息发布出去\n    const message = JSON.parse(event.data);\n    if (message.type === 'websocket') {\n      sessionStorage.setItem('clientId', message.value);\n    } else {\n      this.serverMessageSubject.next(message);\n    }\n  }\n\n  /**\n   * 连接关闭\n   */\n  private onClose(e: any) {\n    console.log('websocket 连接关闭', e);\n    this.connectSuccess = false;\n    this.webSocket.close();\n    // 关闭时开始重连\n    this.reconnect();\n  }\n\n  /**\n   * 连接异常\n   */\n  private onError(e: any) {\n    // 出现异常时一定会进onClose,所以只在onClose做一次重连动作\n    console.log('websocket 连接异常', e);\n    this.connectSuccess = false;\n  }\n\n  /**\n   * 开始重新连接\n   */\n  private reconnect() {\n    // 如果已重连,则直接return,避免重复连接\n    if (this.connectSuccess) {\n      this.stopReconnect();\n      return;\n    }\n    // 如果正在连接中,则直接return,避免产生多个轮训事件\n    if (this.reconnectFlag) {\n      console.log('正在重连...');\n      return;\n    }\n    // 开始重连\n    this.reconnectFlag = true;\n    // 如果没能成功连接,则定时重连\n    this.reconnectSubscription = interval(this.reconnectPeriod).subscribe(async (val) => {\n      console.log(`重连：${val + 1}次`);\n      // 重新连接\n      this.connect();\n    });\n  }\n\n  /**\n   * 停止重连\n   */\n  private stopReconnect() {\n    // 连接标识置为false\n    this.reconnectFlag = false;\n    // 取消订阅\n    if (typeof this.reconnectSubscription !== 'undefined' && this.reconnectSubscription != null) {\n      this.reconnectSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * 开始心跳检测\n   */\n  private heartCheckStart() {\n    this.serverTimeoutSubscription = interval(this.period).subscribe(() => {\n      console.log('心跳检查')\n      // 保持连接状态,重置下\n      if (this.webSocket != null && this.webSocket.readyState === 1) {\n      } else {\n        // 停止心跳\n        this.heartCheckStop();\n        // 开始重连\n        this.reconnect();\n      }\n    });\n  }\n\n  /**\n   * 停止心跳检测\n   */\n  private heartCheckStop() {\n    // 取消订阅停止心跳\n    if (typeof this.serverTimeoutSubscription !== 'undefined' && this.serverTimeoutSubscription != null) {\n      this.serverTimeoutSubscription.unsubscribe();\n    }\n  }\n}\n"]}
|