@eqproject/eqp-dynamic-module 2.10.32 → 2.10.34
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/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +3 -3
- package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.mjs +3 -3
- package/esm2020/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.mjs +24 -8
- package/esm2020/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.mjs +2 -2
- package/esm2020/lib/components/private/graphs/graph/graph.component.mjs +7 -7
- package/esm2020/lib/components/private/tmw-image-marker/tmw-image-marker.component.mjs +7 -5
- package/esm2020/lib/directives/dynamic-loader/dynamic-loader.directive.mjs +5 -5
- package/esm2020/lib/directives/speech-to-text/speech-to-text.directive.mjs +4 -4
- package/esm2020/lib/models/fields/attachmentField.model.mjs +1 -1
- package/esm2020/lib/services/utilityHelper.services.mjs +9 -9
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +59 -41
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +59 -41
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.d.ts +2 -0
- package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +1 -1
- package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +1 -1
- package/lib/models/fields/attachmentField.model.d.ts +1 -1
- package/package.json +1 -1
|
@@ -4,10 +4,6 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
5
|
import * as i2 from "@canvasjs/angular-stockcharts";
|
|
6
6
|
export class GraphComponent {
|
|
7
|
-
onResize() {
|
|
8
|
-
this.loaded = false;
|
|
9
|
-
this.loadGraph(Math.floor(window.innerWidth / 2));
|
|
10
|
-
}
|
|
11
7
|
constructor(datePipe) {
|
|
12
8
|
this.datePipe = datePipe;
|
|
13
9
|
this.data = new Array();
|
|
@@ -17,6 +13,10 @@ export class GraphComponent {
|
|
|
17
13
|
this.loaded = false;
|
|
18
14
|
this.counter = 0;
|
|
19
15
|
}
|
|
16
|
+
onResize() {
|
|
17
|
+
this.loaded = false;
|
|
18
|
+
this.loadGraph(Math.floor(window.innerWidth / 2));
|
|
19
|
+
}
|
|
20
20
|
ngOnInit() {
|
|
21
21
|
var self = this;
|
|
22
22
|
// Aggiustamento e scrittura dati
|
|
@@ -163,10 +163,10 @@ export class GraphComponent {
|
|
|
163
163
|
}
|
|
164
164
|
}
|
|
165
165
|
GraphComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, deps: [{ token: i1.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
166
|
-
GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, host: { listeners: { "window:resize": "onResize($event)" } }, ngImport: i0, template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
|
|
166
|
+
GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, host: { listeners: { "window:resize": "onResize($event)" } }, ngImport: i0, template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\r\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
|
|
167
167
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, decorators: [{
|
|
168
168
|
type: Component,
|
|
169
|
-
args: [{ selector: 'graph', template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>" }]
|
|
169
|
+
args: [{ selector: 'graph', template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\r\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>" }]
|
|
170
170
|
}], ctorParameters: function () { return [{ type: i1.DatePipe }]; }, propDecorators: { onResize: [{
|
|
171
171
|
type: HostListener,
|
|
172
172
|
args: ['window:resize', ['$event']]
|
|
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
177
177
|
type: Input,
|
|
178
178
|
args: ["title"]
|
|
179
179
|
}] } });
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, OnInit } from '@angular/core';\r\nimport { Coords } from '../../../../models/graph.model';\r\nimport { DatePipe } from '@angular/common';\r\nimport * as ss from 'simple-statistics';\r\n\r\n\r\n@Component({\r\n  selector: 'graph',\r\n  templateUrl: './graph.component.html',\r\n  styleUrls: ['./graph.component.scss']\r\n})\r\n\r\nexport class GraphComponent implements OnInit {\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize() {\r\n    this.loaded = false;\r\n    this.loadGraph(Math.floor(window.innerWidth/2));\r\n  }\r\n\r\n  @Input(\"data\") data: Array<Coords> = new Array<Coords>();\r\n  @Input(\"title\") title: string = \"\";\r\n\r\n  trendColor: string = '#EB0102';\r\n  mainColor: string = '#006cad';\r\n\r\n  m: number; // m of the linear regression\r\n  q: number; // q of the linear regression\r\n  trend: string; // trend string\r\n  linearRegression: Array<Coords>; // variable used to store the linear regression points to plot\r\n\r\n\r\n\r\n  stockChartOptions: any;\r\n\r\n  loaded: boolean = false;\r\n  counter: number = 0;\r\n\r\n  constructor(\r\n    private datePipe: DatePipe\r\n    ) {}  \r\n\r\n  ngOnInit() {\r\n\r\n    var self = this;\r\n\r\n    // Aggiustamento e scrittura dati\r\n    if (this.data.length > 0){\r\n      this.loadGraph(Math.floor(window.innerWidth/2));\r\n    }\r\n  }\r\n\r\n  loadGraph(width: number){\r\n\r\n    var lastvalue = this.data[0];\r\n    var firstvalue = this.data[this.data.length-1];\r\n\r\n    var stockChartMinimum = new Date(firstvalue.x);\r\n    var stockChartMaximum = new Date(lastvalue.x);\r\n    var stockChartTitleText = this.title;\r\n    var stockChartdataPoints = this.data;\r\n\r\n    this.linearRegression = new Array<Coords>();\r\n    this.trend = \"\";\r\n\r\n    stockChartdataPoints.reverse();\r\n    if (stockChartdataPoints.length > 2) {\r\n      let x = [];\r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        x.push([i, stockChartdataPoints[i].y]);\r\n      }\r\n      let parameters = ss.linearRegression(x);\r\n      this.m = parameters.m;\r\n      this.q = parameters.b;\r\n      if (this.m > 0) {\r\n          this.trend += \" ↗\";\r\n        } else if (this.m < 0) {\r\n          this.trend += \" ↘\";\r\n      }\r\n      // console.log(x);\r\n      // console.log(stockChartdataPoints);\r\n      \r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        if (i == 0 || i == stockChartdataPoints.length - 1) {\r\n          this.linearRegression.push({x: stockChartdataPoints[i].x,\r\n            y: this.m*i + this.q,\r\n            label: stockChartdataPoints[i].label,\r\n            name: stockChartdataPoints[i].name\r\n          })\r\n        }\r\n      }\r\n      //this.linearRegression.reverse();\r\n      // console.log(this.linearRegression);\r\n      // console.log(this.m);\r\n      // console.log(this.q);\r\n    }\r\n\r\n    this.stockChartOptions = {\r\n      theme: 'light2',\r\n      animationEnabled: true,\r\n      width: width,\r\n      height: 500,\r\n      creditText: \"\",\r\n      creditHref: \"\",\r\n      title: {\r\n        text: stockChartTitleText\r\n      },\r\n      charts: [{\r\n        axisX: {\r\n          labelFormatter: this.labelFormatterFunction,\r\n        },\r\n        data: [\r\n          {\r\n            toolTipContent: null,\r\n            type: 'line',\r\n            color: this.trendColor,\r\n            showInLegend: true,\r\n            legendMarkerType: \"none\",\r\n            markerType: \"none\",\r\n            legendText: \"Trend\" + this.trend,\r\n            dataPoints: this.linearRegression\r\n          },\r\n          {\r\n            type: \"spline\",\r\n            dataPoints: stockChartdataPoints,\r\n            color: this.mainColor,\r\n          }\r\n        ],\r\n        culture: \"it\"\r\n      }],\r\n      rangeSelector: {\r\n        enabled: false\r\n      },\r\n      navigator: {\r\n        slider: {\r\n          minimum: stockChartMinimum,\r\n          maximum: stockChartMaximum\r\n        }\r\n      },\r\n      options: {\r\n        responsive: true,\r\n        maintainAspectRatio: false\r\n      }\r\n    };\r\n\r\n    this.loaded = true;\r\n  }\r\n\r\n  labelFormatterFunction(e) {\r\n    let label = \"\";\r\n    let dirtyLabel;\r\n    let date = e.value;\r\n\r\n      let newYear: number = date.getFullYear();\r\n      let newMonth: number = date.getMonth() + 1;\r\n      let newMonthString: string;\r\n      if (newMonth < 10) {\r\n      newMonthString = \"0\" + newMonth.toString();\r\n      } else {\r\n      newMonthString = newMonth.toString();\r\n      }\r\n      let newDay: number = date.getDate();\r\n      let newDayString: string;\r\n      if (newDay < 10) {\r\n      newDayString = \"0\" + newDay.toString();\r\n      } else {\r\n      newDayString = newDay.toString();\r\n      }\r\n      let newHour: number = date.getHours();\r\n      let newHourString: string;\r\n      if (newHour < 10) {\r\n      newHourString = \"0\" + newHour.toString();\r\n      } else {\r\n      newHourString = newHour.toString();\r\n      }\r\n      let newMinute: number = date.getMinutes();\r\n      let newMinuteString: string;\r\n      if (newMinute < 10) {\r\n      newMinuteString = \"0\" + newMinute.toString();\r\n      } else {\r\n      newMinuteString = newMinute.toString();\r\n      }\r\n\r\n      dirtyLabel = newDayString + \"/\" + newMonthString + \"/\" + newYear.toString() + \" \" + newHourString  + \":\" + newMinuteString;\r\n\r\n      for (let i = 0; i < 5; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n      label += \" \";\r\n      for (let i = 11; i < 16; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n\r\n      //label = label.replace(\"00:00\",\"\");\r\n    \r\n    return label;\r\n  }  \r\n  \r\n\r\n}\r\n","<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>"]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, OnInit } from '@angular/core';\r\nimport { Coords } from '../../../../models/graph.model';\r\nimport { DatePipe } from '@angular/common';\r\nimport * as ss from 'simple-statistics';\r\n\r\n\r\n@Component({\r\n  selector: 'graph',\r\n  templateUrl: './graph.component.html',\r\n  styleUrls: ['./graph.component.scss']\r\n})\r\n\r\nexport class GraphComponent implements OnInit {\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize() {\r\n    this.loaded = false;\r\n    this.loadGraph(Math.floor(window.innerWidth/2));\r\n  }\r\n\r\n  @Input(\"data\") data: Array<Coords> = new Array<Coords>();\r\n  @Input(\"title\") title: string = \"\";\r\n\r\n  trendColor: string = '#EB0102';\r\n  mainColor: string = '#006cad';\r\n\r\n  m: number; // m of the linear regression\r\n  q: number; // q of the linear regression\r\n  trend: string; // trend string\r\n  linearRegression: Array<Coords>; // variable used to store the linear regression points to plot\r\n\r\n\r\n\r\n  stockChartOptions: any;\r\n\r\n  loaded: boolean = false;\r\n  counter: number = 0;\r\n\r\n  constructor(\r\n    private datePipe: DatePipe\r\n    ) {}  \r\n\r\n  ngOnInit() {\r\n\r\n    var self = this;\r\n\r\n    // Aggiustamento e scrittura dati\r\n    if (this.data.length > 0){\r\n      this.loadGraph(Math.floor(window.innerWidth/2));\r\n    }\r\n  }\r\n\r\n  loadGraph(width: number){\r\n\r\n    var lastvalue = this.data[0];\r\n    var firstvalue = this.data[this.data.length-1];\r\n\r\n    var stockChartMinimum = new Date(firstvalue.x);\r\n    var stockChartMaximum = new Date(lastvalue.x);\r\n    var stockChartTitleText = this.title;\r\n    var stockChartdataPoints = this.data;\r\n\r\n    this.linearRegression = new Array<Coords>();\r\n    this.trend = \"\";\r\n\r\n    stockChartdataPoints.reverse();\r\n    if (stockChartdataPoints.length > 2) {\r\n      let x = [];\r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        x.push([i, stockChartdataPoints[i].y]);\r\n      }\r\n      let parameters = ss.linearRegression(x);\r\n      this.m = parameters.m;\r\n      this.q = parameters.b;\r\n      if (this.m > 0) {\r\n          this.trend += \" ↗\";\r\n        } else if (this.m < 0) {\r\n          this.trend += \" ↘\";\r\n      }\r\n      // console.log(x);\r\n      // console.log(stockChartdataPoints);\r\n      \r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        if (i == 0 || i == stockChartdataPoints.length - 1) {\r\n          this.linearRegression.push({x: stockChartdataPoints[i].x,\r\n            y: this.m*i + this.q,\r\n            label: stockChartdataPoints[i].label,\r\n            name: stockChartdataPoints[i].name\r\n          })\r\n        }\r\n      }\r\n      //this.linearRegression.reverse();\r\n      // console.log(this.linearRegression);\r\n      // console.log(this.m);\r\n      // console.log(this.q);\r\n    }\r\n\r\n    this.stockChartOptions = {\r\n      theme: 'light2',\r\n      animationEnabled: true,\r\n      width: width,\r\n      height: 500,\r\n      creditText: \"\",\r\n      creditHref: \"\",\r\n      title: {\r\n        text: stockChartTitleText\r\n      },\r\n      charts: [{\r\n        axisX: {\r\n          labelFormatter: this.labelFormatterFunction,\r\n        },\r\n        data: [\r\n          {\r\n            toolTipContent: null,\r\n            type: 'line',\r\n            color: this.trendColor,\r\n            showInLegend: true,\r\n            legendMarkerType: \"none\",\r\n            markerType: \"none\",\r\n            legendText: \"Trend\" + this.trend,\r\n            dataPoints: this.linearRegression\r\n          },\r\n          {\r\n            type: \"spline\",\r\n            dataPoints: stockChartdataPoints,\r\n            color: this.mainColor,\r\n          }\r\n        ],\r\n        culture: \"it\"\r\n      }],\r\n      rangeSelector: {\r\n        enabled: false\r\n      },\r\n      navigator: {\r\n        slider: {\r\n          minimum: stockChartMinimum,\r\n          maximum: stockChartMaximum\r\n        }\r\n      },\r\n      options: {\r\n        responsive: true,\r\n        maintainAspectRatio: false\r\n      }\r\n    };\r\n\r\n    this.loaded = true;\r\n  }\r\n\r\n  labelFormatterFunction(e) {\r\n    let label = \"\";\r\n    let dirtyLabel;\r\n    let date = e.value;\r\n\r\n      let newYear: number = date.getFullYear();\r\n      let newMonth: number = date.getMonth() + 1;\r\n      let newMonthString: string;\r\n      if (newMonth < 10) {\r\n      newMonthString = \"0\" + newMonth.toString();\r\n      } else {\r\n      newMonthString = newMonth.toString();\r\n      }\r\n      let newDay: number = date.getDate();\r\n      let newDayString: string;\r\n      if (newDay < 10) {\r\n      newDayString = \"0\" + newDay.toString();\r\n      } else {\r\n      newDayString = newDay.toString();\r\n      }\r\n      let newHour: number = date.getHours();\r\n      let newHourString: string;\r\n      if (newHour < 10) {\r\n      newHourString = \"0\" + newHour.toString();\r\n      } else {\r\n      newHourString = newHour.toString();\r\n      }\r\n      let newMinute: number = date.getMinutes();\r\n      let newMinuteString: string;\r\n      if (newMinute < 10) {\r\n      newMinuteString = \"0\" + newMinute.toString();\r\n      } else {\r\n      newMinuteString = newMinute.toString();\r\n      }\r\n\r\n      dirtyLabel = newDayString + \"/\" + newMonthString + \"/\" + newYear.toString() + \" \" + newHourString  + \":\" + newMinuteString;\r\n\r\n      for (let i = 0; i < 5; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n      label += \" \";\r\n      for (let i = 11; i < 16; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n\r\n      //label = label.replace(\"00:00\",\"\");\r\n    \r\n    return label;\r\n  }  \r\n  \r\n\r\n}\r\n","<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\r\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>"]}
|
|
@@ -56,10 +56,12 @@ export class TmwImageMarkerComponent {
|
|
|
56
56
|
});
|
|
57
57
|
}
|
|
58
58
|
newMarker() {
|
|
59
|
-
var startX =
|
|
60
|
-
var startY =
|
|
61
|
-
var left = this.randomIntFromInterval(startX
|
|
62
|
-
var top = this.randomIntFromInterval(startY
|
|
59
|
+
var startX = 40;
|
|
60
|
+
var startY = 40;
|
|
61
|
+
//var left = this.randomIntFromInterval(startX-100,startX+100);
|
|
62
|
+
//var top = this.randomIntFromInterval(startY-100,startY+100);
|
|
63
|
+
var left = startX;
|
|
64
|
+
var top = startY;
|
|
63
65
|
var description;
|
|
64
66
|
var caption = '0';
|
|
65
67
|
// Creazione della caption
|
|
@@ -346,4 +348,4 @@ export class OutMarker {
|
|
|
346
348
|
}
|
|
347
349
|
export class MarkedImage {
|
|
348
350
|
}
|
|
349
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tmw-image-marker.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/tmw-image-marker/tmw-image-marker.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/tmw-image-marker/tmw-image-marker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { fabric } from 'fabric';\r\nimport { Observable, of, switchMap } from 'rxjs';\r\nimport { GlobalService } from '../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'tmw-image-marker',\r\n  templateUrl: './tmw-image-marker.component.html',\r\n  styleUrls: ['./tmw-image-marker.component.scss']\r\n})\r\nexport class TmwImageMarkerComponent {\r\n\r\n  @Input() src: string;\r\n  @Input() width: number;\r\n  @Input() height: number;\r\n  @Input() inConfig: boolean = false;\r\n  @Input() savedMarkers: string = null;\r\n\r\n  @Input() public outputMimeType = 'image/jpeg';\r\n  @Input() public outputQuality = 0.8;\r\n\r\n  @Input() public forceSizeCanvas = true;\r\n\r\n  @Output() closeDialog: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() save: EventEmitter<MarkedImage> = new EventEmitter<MarkedImage>();\r\n\r\n  componentGuid: string;\r\n  isLoading: boolean = true;\r\n  hasError: boolean = false;\r\n\r\n  private canvas: fabric.Canvas;\r\n  private stack: fabric.Object[] = [];\r\n\r\n  markers: Array<Marker> = new Array<Marker>();\r\n  outmarkers: Array<OutMarker> = new Array<OutMarker>();\r\n  markedImage: MarkedImage = new MarkedImage();\r\n\r\n  canUndo: boolean = false;\r\n  canRedo: boolean = false;\r\n\r\n  errorMessage: string = \"\";\r\n\r\n  private imageUsed?: fabric.Image;\r\n\r\n  constructor() {}\r\n\r\n  public ngOnInit(): void {\r\n\r\n    // Creazione di una GUID unica per il componente\r\n    this.componentGuid = 'xxxx-xxxx-xxxx-xxxx'.replace(/[xy]/g, function (c) {\r\n      var r = Math.random() * 16 | 0,\r\n        v = c == 'x' ? r : (r & 0x3 | 0x8);\r\n      return v.toString(16);\r\n    });\r\n\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    this.isLoading = false;\r\n\r\n    const canvasScaledElement = document.getElementById(this.componentGuid);\r\n    this.canvas = new fabric.Canvas(canvasScaledElement, {\r\n      hoverCursor: 'pointer',\r\n      isDrawingMode: false,\r\n    });\r\n    this.canvas.backgroundColor = 'white';\r\n\r\n    if (this.src) {\r\n      this.importPhotoFromSrc(this.src);\r\n    } else {\r\n      if (!this.width || !this.height) {\r\n        throw new Error('No width or hight given !');\r\n      }\r\n\r\n      this.canvas.setWidth(this.width);\r\n      this.canvas.setHeight(this.height);\r\n    }\r\n\r\n    this.canvas.on('path:created', () => {\r\n      this.stack = [];\r\n      this.setUndoRedo();\r\n    });\r\n\r\n  }  \r\n\r\n  newMarker(){\r\n    var startX = Math.floor(this.width / 2);\r\n    var startY = Math.floor(this.height / 2);\r\n\r\n    var left = this.randomIntFromInterval(startX-100,startX+100);\r\n    var top = this.randomIntFromInterval(startY-100,startY+100);\r\n    var description: '';\r\n    var caption = '0';\r\n\r\n    // Creazione della caption\r\n    for (var i = 1; i <= 100000; i++){\r\n      if (this.markers.find(x => x.caption == i.toString()) == null){\r\n        caption = i.toString();\r\n        break;\r\n      }\r\n    }\r\n    \r\n\r\n    this.createMarker(top,left,caption,description);\r\n  }\r\n\r\n  createMarker(top: number, left: number, caption: string, description: string){\r\n\r\n    /*\r\n    * Creo un nuovo Marker\r\n    */\r\n\r\n    // Creo il cerchio\r\n    var circle = new fabric.Circle({\r\n      radius: 30,\r\n      opacity: 0.7,\r\n      fill: 'darkblue',\r\n      stroke: 'white',\r\n      strokeWidth: 2,\r\n      originX: 'center', \r\n      originY: 'center' \r\n    });\r\n\r\n    // Creo il testo dentro al cerchio \r\n    var text = new fabric.Text(caption,\r\n    {  fontSize: 25, \r\n        originX: 'center', \r\n        originY: 'center',\r\n        fill : 'white' \r\n      });\r\n\r\n    // Creo il gruppo nel quale metto cerchio e testo in modo che si muovano insieme\r\n    var group = new fabric.Group([ circle, text ], {  left: left, top: top });    \r\n\r\n    // Creo un oggetto marker che contiene gli elementi atomici. Serve per le cancellazioni e il rollback/modifica degli elementi\r\n    var marker: Marker = new Marker();\r\n    marker.circle = circle;\r\n    marker.text = text;\r\n    marker.group = group;\r\n    marker.caption = caption;\r\n    marker.description = description;\r\n\r\n    // Aggiungo il gruppo nella lista dei gruppi\r\n    this.markers.push(marker);\r\n    this.markers.sort((a,b)=> { return Number(a.caption) - Number(b.caption) });\r\n\r\n    // Aggiungo il gruppo all'immagine a schermo\r\n    this.canvas.add(group);\r\n  }\r\n\r\n  deleteMarkerByIndex(index: number){\r\n    this.canvas.remove(this.markers[index].group);\r\n    this.markers.splice(index,1);\r\n  }\r\n\r\n  removeAllMarkers(){\r\n    this.markers.forEach((marker) => {\r\n      this.canvas.remove(marker.group);\r\n    });\r\n    this.markers = new Array<Marker>();\r\n  }\r\n\r\n  private setUndoRedo() {\r\n    this.canUndo = this.canvas.getObjects().length > 0;\r\n    this.canRedo = this.stack.length > 0;\r\n  }\r\n\r\n  /*\r\n\r\n    // Actions\r\n    public undo() {\r\n      if (this.canUndo) {\r\n        const lastId = this.canvas.getObjects().length - 1;\r\n        const lastObj = this.canvas.getObjects()[lastId];\r\n        this.stack.push(lastObj);\r\n        this.canvas.remove(lastObj);\r\n        this.setUndoRedo();\r\n      }\r\n    }\r\n  \r\n    public redo() {\r\n      if (this.canRedo) {\r\n        const firstInStack = this.stack.splice(-1, 1)[0];\r\n        if (firstInStack) {\r\n          this.canvas.insertAt(firstInStack, this.canvas.getObjects().length - 1, false);\r\n        }\r\n        this.setUndoRedo();\r\n      }\r\n    }\r\n  \r\n    public clearCanvas() {\r\n      if (this.canvas) {\r\n        this.canvas.remove(...this.canvas.getObjects());\r\n        this.setUndoRedo();\r\n      }\r\n    }\r\n\r\n*/\r\n\r\n  private importPhotoFromSrc(src: string) {\r\n    this.isLoading = true;\r\n    let isFirstTry = true;\r\n    const imgEl = new Image();\r\n    imgEl.setAttribute('crossOrigin', 'anonymous');\r\n    imgEl.src = src;\r\n    imgEl.onerror = () => {\r\n      // Retry with cors proxy\r\n      if (isFirstTry) {\r\n        imgEl.src = 'https://cors-anywhere.herokuapp.com/' + this.src;\r\n        isFirstTry = false;\r\n      } else {\r\n        this.isLoading = false;\r\n        this.hasError = true;\r\n        this.errorMessage = \"CORS Error\";\r\n      }\r\n    };\r\n    imgEl.onload = () => {\r\n      this.isLoading = false;\r\n      this.imageUsed = new fabric.Image(imgEl);\r\n\r\n      this.imageUsed.cloneAsImage(image => {\r\n        let width = imgEl.width;\r\n        let height = imgEl.height;\r\n\r\n        if (this.width) {\r\n          width = this.width;\r\n        }\r\n        if (this.height) {\r\n          height = this.height;\r\n        }\r\n\r\n        // ricalcolo le dimensioni dell'immagine per farla entrare nello schermo\r\n        // diminuisco di un 5% alla volta le dimensioni fino a rientrare nell'85% della grandezza della finestra\r\n        let windowWidth = window.innerWidth;\r\n        let windowHeight = window.innerHeight;\r\n        while(width > windowWidth * 0.85){\r\n          width = width * 0.95;\r\n          height = height * 0.95;\r\n        }\r\n        while(height > windowHeight * 0.85){\r\n          width = width * 0.95;\r\n          height = height * 0.95;\r\n        }\r\n\r\n\r\n        image.scaleToWidth(width, false);\r\n        image.scaleToHeight(height, false);\r\n\r\n        this.canvas.setBackgroundImage(image, ((img: HTMLImageElement) => {\r\n          if (img) {\r\n            if (this.forceSizeCanvas) {\r\n              this.canvas.setWidth(width);\r\n              this.canvas.setHeight(height);\r\n            } else {\r\n              this.canvas.setWidth(image.getScaledWidth());\r\n              this.canvas.setHeight(image.getScaledHeight());\r\n            }\r\n          }\r\n        }), {\r\n          crossOrigin: 'anonymous',\r\n          originX: 'left',\r\n          originY: 'top'\r\n        });\r\n      });\r\n\r\n      if (this.savedMarkers != null){ this.loadMarkers(); }\r\n    };\r\n  }\r\n\r\n  loadMarkers(){\r\n    var markersObj: Array<OutMarker> = JSON.parse(this.savedMarkers);\r\n    markersObj.forEach((marker) => {\r\n      this.createMarker(marker.top,marker.left,marker.caption,marker.description);\r\n    });\r\n  }\r\n\r\n  public saveImage(){\r\n\r\n    this.outmarkers = new Array<OutMarker>();\r\n\r\n    this.markers.forEach((marker) => {\r\n      var outmarker = new OutMarker();\r\n      outmarker.caption = marker.caption;\r\n      outmarker.description = marker.description;\r\n      outmarker.top = marker.group.top;\r\n      outmarker.left = marker.group.left;\r\n      this.outmarkers.push(outmarker);\r\n    })\r\n\r\n    if (this.width && this.height) {\r\n      const canvasScaledElement: HTMLCanvasElement = document.createElement('canvas');\r\n      const canvasScaled = new fabric.Canvas(canvasScaledElement);\r\n      canvasScaled.backgroundColor = 'white';\r\n\r\n      new Observable<fabric.Canvas>(observer => {\r\n        if (this.imageUsed) {\r\n\r\n            canvasScaled.setBackgroundImage(this.imageUsed, (img: HTMLImageElement) => {\r\n              if (!img) {\r\n                observer.error(new Error('Impossible to draw the image on the temporary canvas'));\r\n              }\r\n\r\n              canvasScaled.setWidth(img.width);\r\n              canvasScaled.setHeight(img.height);\r\n\r\n              observer.next(canvasScaled);\r\n              observer.complete();\r\n            }, {\r\n              crossOrigin: 'anonymous',\r\n              originX: 'left',\r\n              originY: 'top'\r\n            });\r\n          \r\n        } else {\r\n          canvasScaled.setWidth(this.width);\r\n          canvasScaled.setHeight(this.height);\r\n        }\r\n      }).pipe(\r\n        switchMap(() => {\r\n          let process = of(canvasScaled);\r\n\r\n          if (this.canvas.getObjects().length > 0) {\r\n            const ratioX = canvasScaled.getWidth() / this.canvas.getWidth();\r\n            const ratioY = canvasScaled.getHeight() / this.canvas.getHeight();\r\n\r\n            this.canvas.getObjects().forEach((originalObject: fabric.Object, i: number) => {\r\n              process = process.pipe(switchMap(() => {\r\n                return new Observable<fabric.Canvas>(observerObject => {\r\n                  originalObject.clone((clonedObject: fabric.Object) => {\r\n                    clonedObject.set('left', originalObject.left * ratioX);\r\n                    clonedObject.set('top', originalObject.top * ratioY);\r\n                    clonedObject.scaleToWidth(originalObject.width * ratioX);\r\n                    clonedObject.scaleToHeight(originalObject.height * ratioY);\r\n\r\n                    canvasScaled.insertAt(clonedObject, i, false);\r\n                    canvasScaled.renderAll();\r\n\r\n                    observerObject.next(canvasScaled);\r\n                    observerObject.complete();\r\n                  });\r\n                });\r\n              }));\r\n            });\r\n          }\r\n          return process;\r\n        }),\r\n      ).subscribe(() => {\r\n        canvasScaled.renderAll();\r\n        canvasScaled.getElement().toBlob(\r\n          (data: Blob) => {\r\n            this.markedImage.image = data;\r\n            this.markedImage.outmarkers = this.outmarkers;\r\n            this.save.emit(this.markedImage);\r\n          },\r\n          this.outputMimeType,\r\n          this.outputQuality\r\n        );\r\n      });\r\n    } else {\r\n      this.canvas.getElement().toBlob(\r\n        (data: Blob) => {\r\n          this.markedImage.image = data;\r\n          this.markedImage.outmarkers = this.outmarkers;\r\n          this.save.emit(this.markedImage);\r\n        },\r\n        this.outputMimeType,\r\n        this.outputQuality\r\n      );\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  //this.save.emit();\r\n  }\r\n\r\n  public close(){\r\n    this.closeDialog.emit();\r\n  }\r\n\r\n  randomIntFromInterval(min, max) { // min and max included \r\n    return Math.floor(Math.random() * (max - min + 1) + min)\r\n  }\r\n\r\n  log(el){\r\n    GlobalService.debugLog(\"imageMarker element \",el);\r\n  }\r\n\r\n}\r\n\r\nexport class Marker {\r\n  circle: fabric.Circle;\r\n  text: fabric.Text;\r\n  group: fabric.Group;\r\n  top: number;\r\n  left: number;\r\n  caption: string;\r\n  description: string = \"\";\r\n}\r\n\r\nexport class OutMarker {\r\n  top: number;\r\n  left: number;\r\n  caption: string;\r\n  description: string = \"\";\r\n}\r\n\r\nexport class MarkedImage {\r\n  outmarkers: Array<OutMarker>;\r\n  image: Blob;\r\n}","<div class=\"canvas-container\">\r\n    <div class=\"canvas\">\r\n        <canvas [id]=\"componentGuid\"></canvas>\r\n    </div>\r\n    <div class=\"toolbox\">\r\n\r\n        <div class=\"row\">\r\n            <div class=\"col-12\">\r\n                <button class=\"btn btn-primary markerButton\" (click)=\"newMarker()\">Crea nuovo marker</button>\r\n            </div>\r\n            <div class=\"col-12 mt-2\">\r\n\r\n                <div class=\"legend_overflow_container\">\r\n                    <div class=\"legend_container\" *ngFor=\"let marker of markers; index as i\">\r\n                        <div class=\"caption\" [innerHTML]=\"marker.caption\"></div>\r\n                        <div class=\"textarea\"><textarea  [(ngModel)]=\"marker.description\" (click)=\"log(marker.description)\"></textarea></div>\r\n                        <div class=\"delete\" (click)=\"deleteMarkerByIndex(i)\"><mat-icon>delete</mat-icon></div>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"col-12 mt-2\" *ngIf=\"!inConfig\">\r\n                <button class=\"btn btn-success markerButton\" (click)=\"saveImage()\">Salva Immagine</button>\r\n            </div>\r\n            <div class=\"col-12 mt-2\">\r\n                <button class=\"btn btn-warning markerButton\" (click)=\"removeAllMarkers()\">Rimuovi tutti i markers</button>\r\n            </div>            \r\n            <div class=\"col-12 mt-2\">\r\n                <button class=\"btn btn-danger markerButton\" (click)=\"close()\">Annulla Disegno</button>\r\n            </div>\r\n        </div>\r\n        \r\n\r\n\r\n\r\n    </div>\r\n</div>"]}
|
|
351
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tmw-image-marker.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/tmw-image-marker/tmw-image-marker.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/tmw-image-marker/tmw-image-marker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { fabric } from 'fabric';\r\nimport { Observable, of, switchMap } from 'rxjs';\r\nimport { GlobalService } from '../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'tmw-image-marker',\r\n  templateUrl: './tmw-image-marker.component.html',\r\n  styleUrls: ['./tmw-image-marker.component.scss']\r\n})\r\nexport class TmwImageMarkerComponent {\r\n\r\n  @Input() src: string;\r\n  @Input() width: number;\r\n  @Input() height: number;\r\n  @Input() inConfig: boolean = false;\r\n  @Input() savedMarkers: string = null;\r\n\r\n  @Input() public outputMimeType = 'image/jpeg';\r\n  @Input() public outputQuality = 0.8;\r\n\r\n  @Input() public forceSizeCanvas = true;\r\n\r\n  @Output() closeDialog: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() save: EventEmitter<MarkedImage> = new EventEmitter<MarkedImage>();\r\n\r\n  componentGuid: string;\r\n  isLoading: boolean = true;\r\n  hasError: boolean = false;\r\n\r\n  private canvas: fabric.Canvas;\r\n  private stack: fabric.Object[] = [];\r\n\r\n  markers: Array<Marker> = new Array<Marker>();\r\n  outmarkers: Array<OutMarker> = new Array<OutMarker>();\r\n  markedImage: MarkedImage = new MarkedImage();\r\n\r\n  canUndo: boolean = false;\r\n  canRedo: boolean = false;\r\n\r\n  errorMessage: string = \"\";\r\n\r\n  private imageUsed?: fabric.Image;\r\n\r\n  constructor() {}\r\n\r\n  public ngOnInit(): void {\r\n\r\n    // Creazione di una GUID unica per il componente\r\n    this.componentGuid = 'xxxx-xxxx-xxxx-xxxx'.replace(/[xy]/g, function (c) {\r\n      var r = Math.random() * 16 | 0,\r\n        v = c == 'x' ? r : (r & 0x3 | 0x8);\r\n      return v.toString(16);\r\n    });\r\n\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    this.isLoading = false;\r\n\r\n    const canvasScaledElement = document.getElementById(this.componentGuid);\r\n    this.canvas = new fabric.Canvas(canvasScaledElement, {\r\n      hoverCursor: 'pointer',\r\n      isDrawingMode: false,\r\n    });\r\n    this.canvas.backgroundColor = 'white';\r\n\r\n    if (this.src) {\r\n      this.importPhotoFromSrc(this.src);\r\n    } else {\r\n      if (!this.width || !this.height) {\r\n        throw new Error('No width or hight given !');\r\n      }\r\n\r\n      this.canvas.setWidth(this.width);\r\n      this.canvas.setHeight(this.height);\r\n    }\r\n\r\n    this.canvas.on('path:created', () => {\r\n      this.stack = [];\r\n      this.setUndoRedo();\r\n    });\r\n\r\n  }  \r\n\r\n  newMarker(){\r\n    var startX = 40;\r\n    var startY = 40;\r\n\r\n    //var left = this.randomIntFromInterval(startX-100,startX+100);\r\n    //var top = this.randomIntFromInterval(startY-100,startY+100);\r\n    var left = startX;\r\n    var top = startY;\r\n    var description: '';\r\n    var caption = '0';\r\n\r\n    // Creazione della caption\r\n    for (var i = 1; i <= 100000; i++){\r\n      if (this.markers.find(x => x.caption == i.toString()) == null){\r\n        caption = i.toString();\r\n        break;\r\n      }\r\n    }\r\n    \r\n\r\n    this.createMarker(top,left,caption,description);\r\n  }\r\n\r\n  createMarker(top: number, left: number, caption: string, description: string){\r\n\r\n    /*\r\n    * Creo un nuovo Marker\r\n    */\r\n\r\n    // Creo il cerchio\r\n    var circle = new fabric.Circle({\r\n      radius: 30,\r\n      opacity: 0.7,\r\n      fill: 'darkblue',\r\n      stroke: 'white',\r\n      strokeWidth: 2,\r\n      originX: 'center', \r\n      originY: 'center' \r\n    });\r\n\r\n    // Creo il testo dentro al cerchio \r\n    var text = new fabric.Text(caption,\r\n    {  fontSize: 25, \r\n        originX: 'center', \r\n        originY: 'center',\r\n        fill : 'white' \r\n      });\r\n\r\n    // Creo il gruppo nel quale metto cerchio e testo in modo che si muovano insieme\r\n    var group = new fabric.Group([ circle, text ], {  left: left, top: top });    \r\n\r\n    // Creo un oggetto marker che contiene gli elementi atomici. Serve per le cancellazioni e il rollback/modifica degli elementi\r\n    var marker: Marker = new Marker();\r\n    marker.circle = circle;\r\n    marker.text = text;\r\n    marker.group = group;\r\n    marker.caption = caption;\r\n    marker.description = description;\r\n\r\n    // Aggiungo il gruppo nella lista dei gruppi\r\n    this.markers.push(marker);\r\n    this.markers.sort((a,b)=> { return Number(a.caption) - Number(b.caption) });\r\n\r\n    // Aggiungo il gruppo all'immagine a schermo\r\n    this.canvas.add(group);\r\n  }\r\n\r\n  deleteMarkerByIndex(index: number){\r\n    this.canvas.remove(this.markers[index].group);\r\n    this.markers.splice(index,1);\r\n  }\r\n\r\n  removeAllMarkers(){\r\n    this.markers.forEach((marker) => {\r\n      this.canvas.remove(marker.group);\r\n    });\r\n    this.markers = new Array<Marker>();\r\n  }\r\n\r\n  private setUndoRedo() {\r\n    this.canUndo = this.canvas.getObjects().length > 0;\r\n    this.canRedo = this.stack.length > 0;\r\n  }\r\n\r\n  /*\r\n\r\n    // Actions\r\n    public undo() {\r\n      if (this.canUndo) {\r\n        const lastId = this.canvas.getObjects().length - 1;\r\n        const lastObj = this.canvas.getObjects()[lastId];\r\n        this.stack.push(lastObj);\r\n        this.canvas.remove(lastObj);\r\n        this.setUndoRedo();\r\n      }\r\n    }\r\n  \r\n    public redo() {\r\n      if (this.canRedo) {\r\n        const firstInStack = this.stack.splice(-1, 1)[0];\r\n        if (firstInStack) {\r\n          this.canvas.insertAt(firstInStack, this.canvas.getObjects().length - 1, false);\r\n        }\r\n        this.setUndoRedo();\r\n      }\r\n    }\r\n  \r\n    public clearCanvas() {\r\n      if (this.canvas) {\r\n        this.canvas.remove(...this.canvas.getObjects());\r\n        this.setUndoRedo();\r\n      }\r\n    }\r\n\r\n*/\r\n\r\n  private importPhotoFromSrc(src: string) {\r\n    this.isLoading = true;\r\n    let isFirstTry = true;\r\n    const imgEl = new Image();\r\n    imgEl.setAttribute('crossOrigin', 'anonymous');\r\n    imgEl.src = src;\r\n    imgEl.onerror = () => {\r\n      // Retry with cors proxy\r\n      if (isFirstTry) {\r\n        imgEl.src = 'https://cors-anywhere.herokuapp.com/' + this.src;\r\n        isFirstTry = false;\r\n      } else {\r\n        this.isLoading = false;\r\n        this.hasError = true;\r\n        this.errorMessage = \"CORS Error\";\r\n      }\r\n    };\r\n    imgEl.onload = () => {\r\n      this.isLoading = false;\r\n      this.imageUsed = new fabric.Image(imgEl);\r\n\r\n      this.imageUsed.cloneAsImage(image => {\r\n        let width = imgEl.width;\r\n        let height = imgEl.height;\r\n\r\n        if (this.width) {\r\n          width = this.width;\r\n        }\r\n        if (this.height) {\r\n          height = this.height;\r\n        }\r\n\r\n        // ricalcolo le dimensioni dell'immagine per farla entrare nello schermo\r\n        // diminuisco di un 5% alla volta le dimensioni fino a rientrare nell'85% della grandezza della finestra\r\n        let windowWidth = window.innerWidth;\r\n        let windowHeight = window.innerHeight;\r\n        while(width > windowWidth * 0.85){\r\n          width = width * 0.95;\r\n          height = height * 0.95;\r\n        }\r\n        while(height > windowHeight * 0.85){\r\n          width = width * 0.95;\r\n          height = height * 0.95;\r\n        }\r\n\r\n\r\n        image.scaleToWidth(width, false);\r\n        image.scaleToHeight(height, false);\r\n\r\n        this.canvas.setBackgroundImage(image, ((img: HTMLImageElement) => {\r\n          if (img) {\r\n            if (this.forceSizeCanvas) {\r\n              this.canvas.setWidth(width);\r\n              this.canvas.setHeight(height);\r\n            } else {\r\n              this.canvas.setWidth(image.getScaledWidth());\r\n              this.canvas.setHeight(image.getScaledHeight());\r\n            }\r\n          }\r\n        }), {\r\n          crossOrigin: 'anonymous',\r\n          originX: 'left',\r\n          originY: 'top'\r\n        });\r\n      });\r\n\r\n      if (this.savedMarkers != null){ this.loadMarkers(); }\r\n    };\r\n  }\r\n\r\n  loadMarkers(){\r\n    var markersObj: Array<OutMarker> = JSON.parse(this.savedMarkers);\r\n    markersObj.forEach((marker) => {\r\n      this.createMarker(marker.top,marker.left,marker.caption,marker.description);\r\n    });\r\n  }\r\n\r\n  public saveImage(){\r\n\r\n    this.outmarkers = new Array<OutMarker>();\r\n\r\n    this.markers.forEach((marker) => {\r\n      var outmarker = new OutMarker();\r\n      outmarker.caption = marker.caption;\r\n      outmarker.description = marker.description;\r\n      outmarker.top = marker.group.top;\r\n      outmarker.left = marker.group.left;\r\n      this.outmarkers.push(outmarker);\r\n    })\r\n\r\n    if (this.width && this.height) {\r\n      const canvasScaledElement: HTMLCanvasElement = document.createElement('canvas');\r\n      const canvasScaled = new fabric.Canvas(canvasScaledElement);\r\n      canvasScaled.backgroundColor = 'white';\r\n\r\n      new Observable<fabric.Canvas>(observer => {\r\n        if (this.imageUsed) {\r\n\r\n            canvasScaled.setBackgroundImage(this.imageUsed, (img: HTMLImageElement) => {\r\n              if (!img) {\r\n                observer.error(new Error('Impossible to draw the image on the temporary canvas'));\r\n              }\r\n\r\n              canvasScaled.setWidth(img.width);\r\n              canvasScaled.setHeight(img.height);\r\n\r\n              observer.next(canvasScaled);\r\n              observer.complete();\r\n            }, {\r\n              crossOrigin: 'anonymous',\r\n              originX: 'left',\r\n              originY: 'top'\r\n            });\r\n          \r\n        } else {\r\n          canvasScaled.setWidth(this.width);\r\n          canvasScaled.setHeight(this.height);\r\n        }\r\n      }).pipe(\r\n        switchMap(() => {\r\n          let process = of(canvasScaled);\r\n\r\n          if (this.canvas.getObjects().length > 0) {\r\n            const ratioX = canvasScaled.getWidth() / this.canvas.getWidth();\r\n            const ratioY = canvasScaled.getHeight() / this.canvas.getHeight();\r\n\r\n            this.canvas.getObjects().forEach((originalObject: fabric.Object, i: number) => {\r\n              process = process.pipe(switchMap(() => {\r\n                return new Observable<fabric.Canvas>(observerObject => {\r\n                  originalObject.clone((clonedObject: fabric.Object) => {\r\n                    clonedObject.set('left', originalObject.left * ratioX);\r\n                    clonedObject.set('top', originalObject.top * ratioY);\r\n                    clonedObject.scaleToWidth(originalObject.width * ratioX);\r\n                    clonedObject.scaleToHeight(originalObject.height * ratioY);\r\n\r\n                    canvasScaled.insertAt(clonedObject, i, false);\r\n                    canvasScaled.renderAll();\r\n\r\n                    observerObject.next(canvasScaled);\r\n                    observerObject.complete();\r\n                  });\r\n                });\r\n              }));\r\n            });\r\n          }\r\n          return process;\r\n        }),\r\n      ).subscribe(() => {\r\n        canvasScaled.renderAll();\r\n        canvasScaled.getElement().toBlob(\r\n          (data: Blob) => {\r\n            this.markedImage.image = data;\r\n            this.markedImage.outmarkers = this.outmarkers;\r\n            this.save.emit(this.markedImage);\r\n          },\r\n          this.outputMimeType,\r\n          this.outputQuality\r\n        );\r\n      });\r\n    } else {\r\n      this.canvas.getElement().toBlob(\r\n        (data: Blob) => {\r\n          this.markedImage.image = data;\r\n          this.markedImage.outmarkers = this.outmarkers;\r\n          this.save.emit(this.markedImage);\r\n        },\r\n        this.outputMimeType,\r\n        this.outputQuality\r\n      );\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  //this.save.emit();\r\n  }\r\n\r\n  public close(){\r\n    this.closeDialog.emit();\r\n  }\r\n\r\n  randomIntFromInterval(min, max) { // min and max included \r\n    return Math.floor(Math.random() * (max - min + 1) + min)\r\n  }\r\n\r\n  log(el){\r\n    GlobalService.debugLog(\"imageMarker element \",el);\r\n  }\r\n\r\n}\r\n\r\nexport class Marker {\r\n  circle: fabric.Circle;\r\n  text: fabric.Text;\r\n  group: fabric.Group;\r\n  top: number;\r\n  left: number;\r\n  caption: string;\r\n  description: string = \"\";\r\n}\r\n\r\nexport class OutMarker {\r\n  top: number;\r\n  left: number;\r\n  caption: string;\r\n  description: string = \"\";\r\n}\r\n\r\nexport class MarkedImage {\r\n  outmarkers: Array<OutMarker>;\r\n  image: Blob;\r\n}","<div class=\"canvas-container\">\r\n    <div class=\"canvas\">\r\n        <canvas [id]=\"componentGuid\"></canvas>\r\n    </div>\r\n    <div class=\"toolbox\">\r\n\r\n        <div class=\"row\">\r\n            <div class=\"col-12\">\r\n                <button class=\"btn btn-primary markerButton\" (click)=\"newMarker()\">Crea nuovo marker</button>\r\n            </div>\r\n            <div class=\"col-12 mt-2\">\r\n\r\n                <div class=\"legend_overflow_container\">\r\n                    <div class=\"legend_container\" *ngFor=\"let marker of markers; index as i\">\r\n                        <div class=\"caption\" [innerHTML]=\"marker.caption\"></div>\r\n                        <div class=\"textarea\"><textarea  [(ngModel)]=\"marker.description\" (click)=\"log(marker.description)\"></textarea></div>\r\n                        <div class=\"delete\" (click)=\"deleteMarkerByIndex(i)\"><mat-icon>delete</mat-icon></div>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"col-12 mt-2\" *ngIf=\"!inConfig\">\r\n                <button class=\"btn btn-success markerButton\" (click)=\"saveImage()\">Salva Immagine</button>\r\n            </div>\r\n            <div class=\"col-12 mt-2\">\r\n                <button class=\"btn btn-warning markerButton\" (click)=\"removeAllMarkers()\">Rimuovi tutti i markers</button>\r\n            </div>            \r\n            <div class=\"col-12 mt-2\">\r\n                <button class=\"btn btn-danger markerButton\" (click)=\"close()\">Annulla Disegno</button>\r\n            </div>\r\n        </div>\r\n        \r\n\r\n\r\n\r\n    </div>\r\n</div>"]}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { Directive, Input, EventEmitter, Output } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class DynamicLoaderDirective {
|
|
4
|
-
// In input verrà passato il selettore del componente da ricreare
|
|
5
|
-
set data(data) {
|
|
6
|
-
this.load(data.component, data.inputParams);
|
|
7
|
-
}
|
|
8
4
|
constructor(resolver, viewContainerRef) {
|
|
9
5
|
this.resolver = resolver;
|
|
10
6
|
this.viewContainerRef = viewContainerRef;
|
|
11
7
|
this.out = new EventEmitter();
|
|
12
8
|
}
|
|
9
|
+
// In input verrà passato il selettore del componente da ricreare
|
|
10
|
+
set data(data) {
|
|
11
|
+
this.load(data.component, data.inputParams);
|
|
12
|
+
}
|
|
13
13
|
load(component, inputParams = null) {
|
|
14
14
|
if (!component) {
|
|
15
15
|
throw new Error('Failed to load dynamic component');
|
|
@@ -56,4 +56,4 @@ export class eventOut {
|
|
|
56
56
|
this.Behaviours = new Array();
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1sb2FkZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXFwLWR5bmFtaWMtbW9kdWxlL3NyYy9saWIvZGlyZWN0aXZlcy9keW5hbWljLWxvYWRlci9keW5hbWljLWxvYWRlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQTRELFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTWpJLE1BQU0sT0FBTyxzQkFBc0I7SUFTakMsWUFBb0IsUUFBa0MsRUFBVSxnQkFBa0M7UUFBOUUsYUFBUSxHQUFSLFFBQVEsQ0FBMEI7UUFBVSxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBRnhGLFFBQUcsR0FBMkIsSUFBSSxZQUFZLEVBQVksQ0FBQztJQUVpQyxDQUFDO0lBUHZHLGlFQUFpRTtJQUNqRSxJQUFhLElBQUksQ0FBQyxJQUFnQztRQUNoRCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFNRCxJQUFJLENBQUMsU0FBYyxFQUFFLGNBQW1CLElBQUk7UUFFMUMsSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsa0NBQWtDLENBQUMsQ0FBQztTQUNyRDtRQUVGLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUM5QixJQUFJLGlCQUFpQixHQUFHLFNBQVMsQ0FBQztRQUNsQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsdUJBQXVCLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUNsRixNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFNLGdCQUFnQixDQUFDLENBQUM7UUFFakYsMEdBQTBHO1FBQzFHLHVLQUF1SztRQUN2SyxJQUFJLFdBQVcsSUFBSSxJQUFJLEVBQUU7WUFDdkIsSUFBSSxlQUFlLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUMvQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFO2dCQUMxQixZQUFZLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1QyxDQUFDLENBQUMsQ0FBQztTQUNKO1FBRUQsWUFBWSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUV0RSxDQUFDO0lBRUQ7OztJQUdBO0lBQ0EsWUFBWSxDQUFDLEdBQVE7UUFDbkIsSUFBSSxTQUFTLEdBQUcsR0FBRyxDQUFDO1FBQ3BCLE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7O29IQTFDVSxzQkFBc0I7d0dBQXRCLHNCQUFzQjs0RkFBdEIsc0JBQXNCO2tCQUpsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7aUJBQy9COzhJQUtjLElBQUk7c0JBQWhCLEtBQUs7Z0JBSUksR0FBRztzQkFBWixNQUFNOztBQXNDVCxNQUFNLE9BQU8sMEJBQTBCO0NBR3RDO0FBRUQsTUFBTSxPQUFPLFFBQVE7SUFBckI7UUFFRSxlQUFVLEdBQWtCLElBQUksS0FBSyxFQUFVLENBQUM7SUFFbEQsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCwgVmlld0NvbnRhaW5lclJlZiwgQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLCBDb21wb25lbnRSZWYsIEV2ZW50RW1pdHRlciwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1thcHBEeW5hbWljTG9hZGVyXSdcclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBEeW5hbWljTG9hZGVyRGlyZWN0aXZlIHtcclxuXHJcbiAgLy8gSW4gaW5wdXQgdmVycsOgIHBhc3NhdG8gaWwgc2VsZXR0b3JlIGRlbCBjb21wb25lbnRlIGRhIHJpY3JlYXJlXHJcbiAgQElucHV0KCkgc2V0IGRhdGEoZGF0YTogRHluYW1pY0xvYWRlckRpcmVjdGl2ZURhdGEpIHtcclxuICAgIHRoaXMubG9hZChkYXRhLmNvbXBvbmVudCwgZGF0YS5pbnB1dFBhcmFtcyk7XHJcbiAgfVxyXG5cclxuICBAT3V0cHV0KCkgb3V0OiBFdmVudEVtaXR0ZXI8ZXZlbnRPdXQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxldmVudE91dD4oKTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLCBwcml2YXRlIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHsgfVxyXG5cclxuICBsb2FkKGNvbXBvbmVudDogYW55LCBpbnB1dFBhcmFtczogYW55ID0gbnVsbCk6IGFueSB7XHJcblxyXG4gICAgaWYgKCFjb21wb25lbnQpIHtcclxuICAgICAgdGhyb3cgbmV3IEVycm9yKCdGYWlsZWQgdG8gbG9hZCBkeW5hbWljIGNvbXBvbmVudCcpO1xyXG4gICAgfVxyXG5cclxuICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XHJcbiAgIGxldCBjb21wb25lbnRJbnN0YW5jZSA9IGNvbXBvbmVudDtcclxuICAgY29uc3QgY29tcG9uZW50RmFjdG9yeSA9IHRoaXMucmVzb2x2ZXIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoY29tcG9uZW50SW5zdGFuY2UpO1xyXG4gICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLnZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50PGFueT4oY29tcG9uZW50RmFjdG9yeSk7XHJcblxyXG4gICAgLy9TZSBzb25vIHN0YXRpIHBhc3NhdGkgZGVpIHBhcmFtZXRlcnMgZGkgaW5wdXQgYWxsb3JhIGxpIG1lbW9yaXp6YSBuZWwgY29tcG9uZW50ZSBjYXJpY2F0byBkaW5hbWljYW1lbnRlLlxyXG4gICAgLy9FJyBvdnZpbyBjaGUgaWwgbm9tZSBkZWkgcGFyYW1ldGVycyBkaSBpbnB1dCBwYXNzYXRpIGFsIER5bmFtaWNMb2FkZXIgZGV2ZSBjb2luY2lkZXJlIGNvbiBpbCBub21lIGRlbCBwYXJhbWV0cm8gZGkgaW5wdXQgcGFzc2F0byBhbCBjb21wb25lbnRlIGNhcmljYXRvIGRpbmFtaWNhbWVudGVcclxuICAgIGlmIChpbnB1dFBhcmFtcyAhPSBudWxsKSB7XHJcbiAgICAgIGxldCBpbnB1dFByb3BlcnRpZXMgPSBPYmplY3Qua2V5cyhpbnB1dFBhcmFtcyk7XHJcbiAgICAgIGlucHV0UHJvcGVydGllcy5mb3JFYWNoKHAgPT4ge1xyXG4gICAgICAgIGNvbXBvbmVudFJlZi5pbnN0YW5jZVtwXSA9IGlucHV0UGFyYW1zW3BdO1xyXG4gICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2Uub3V0LnN1YnNjcmliZSh2YWwgPT4geyB0aGlzLm91dC5lbWl0KHZhbCk7IH0pO1xyXG5cclxuICB9XHJcblxyXG4gIC8qKlxyXG4qIFJlc3RyaXR1aXNjZSB1biBjb21wb25lbnRlIHBhc3NhbmRvZ2xpIGNvbWUgcGFyYW1ldHJvIGxhIGNoaWF2ZVxyXG4qIEBwYXJhbSBrZXlcclxuKi9cclxuICBnZXRDb21wb25lbnQoa2V5OiBhbnkpIHtcclxuICAgIGxldCBjb21wb25lbnQgPSBrZXk7XHJcbiAgICByZXR1cm4gY29tcG9uZW50O1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIER5bmFtaWNMb2FkZXJEaXJlY3RpdmVEYXRhIHtcclxuICBjb21wb25lbnQ6IGFueTtcclxuICBpbnB1dFBhcmFtczogYW55O1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgZXZlbnRPdXQge1xyXG4gIEV2ZW50TmFtZTogc3RyaW5nO1xyXG4gIEJlaGF2aW91cnM6IEFycmF5PHN0cmluZz4gPSBuZXcgQXJyYXk8c3RyaW5nPigpO1xyXG4gIFBhcmFtczogYW55O1xyXG59Il19
|
|
@@ -19,9 +19,6 @@ import * as i0 from "@angular/core";
|
|
|
19
19
|
|
|
20
20
|
*/
|
|
21
21
|
export class SpeechToTextDirective {
|
|
22
|
-
SpeechToggle() {
|
|
23
|
-
this.SpeechToTextToggler();
|
|
24
|
-
}
|
|
25
22
|
constructor(elementRef) {
|
|
26
23
|
this.elementRef = elementRef;
|
|
27
24
|
this.debug = false;
|
|
@@ -73,6 +70,9 @@ export class SpeechToTextDirective {
|
|
|
73
70
|
this.domElement.style.display = "none";
|
|
74
71
|
}
|
|
75
72
|
}
|
|
73
|
+
SpeechToggle() {
|
|
74
|
+
this.SpeechToTextToggler();
|
|
75
|
+
}
|
|
76
76
|
ngOnDestroy() {
|
|
77
77
|
this.printDebug("speech onDestroy");
|
|
78
78
|
if (this.recognition) {
|
|
@@ -183,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
183
183
|
type: HostListener,
|
|
184
184
|
args: ["click"]
|
|
185
185
|
}] } });
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"speech-to-text.directive.js","sourceRoot":"","sources":["../../../../../../projects/eqp-dynamic-module/src/lib/directives/speech-to-text/speech-to-text.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostListener,\r\n    Input,\r\n    OnDestroy,\r\n    Output,\r\n  } from \"@angular/core\";\r\n  import { interval, Subscription } from \"rxjs\";\r\n  import { GlobalService } from \"../../services/global.service\";\r\n  \r\n  declare var webkitSpeechRecognition: any;\r\n  \r\n  /* ESEMPIO D'USO\r\n  \r\n    <textarea\r\n      [(ngModel)]=\"text\"\r\n    ></textarea>\r\n  \r\n    <mat-icon\r\n      *ngIf=\"true\" <!-- Senza NGIF non funziona -->\r\n      style=\"cursor: pointer; border-radius: 80px; padding: 5px;\"\r\n      [SpeechToText]\r\n      [(bindedText)]=\"text\"\r\n    >\r\n      keyboard_voice\r\n    </mat-icon>\r\n  \r\n  */\r\n  \r\n  @Directive({\r\n    selector: \"[SpeechToText]\",\r\n  })\r\n  export class SpeechToTextDirective implements OnDestroy{\r\n  \r\n    debug = false;\r\n  \r\n    @Input(\"bindedText\") bindedText: string = \"\";\r\n    @Output() bindedTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n    beginSentence: string = \"\";\r\n    // bindedText = \"\";\r\n    private domElement: HTMLElement;\r\n  \r\n    pausedClass: string = \"keyboard_paused\";\r\n    speakingClass: string = \"keyboard_speaking\";\r\n  \r\n    recognition;\r\n    tempWords: any;\r\n    transcript_arr = [];\r\n    confidence_arr = [];\r\n  \r\n    // isStarted = false; //<< this Flag to check if the user stop the service\r\n    isStoppedSpeechRecog = false;\r\n    isStoppedAutomatically = true; //<< this Flag to check if the service stopped automaticically.\r\n  \r\n    timeInterval = interval(50);\r\n    subscription: Subscription;\r\n  \r\n    @HostListener(\"click\") SpeechToggle() {\r\n      this.SpeechToTextToggler();\r\n    }\r\n  \r\n    constructor(\r\n      private elementRef: ElementRef\r\n      ) {\r\n  \r\n      this.domElement = this.elementRef.nativeElement as HTMLElement;\r\n    \r\n      this.printDebug(window.navigator.userAgent);\r\n  \r\n      try {\r\n        // questa operazione fallisce se non c'è webkit\r\n        this.recognition = new webkitSpeechRecognition();\r\n  \r\n        this.printDebug(this.recognition);\r\n  \r\n        this.recognition.continuous = true;\r\n        this.recognition.interimResults = true;\r\n        this.recognition.lang = \"it-IT\";\r\n  \r\n        this.recognition.addEventListener(\"result\", (e: any) => {\r\n          const transcript = Array.from(e.results)\r\n            .map((result: any) => result[0])\r\n            .map((result) => result.transcript)\r\n            .join(\"\");\r\n  \r\n          this.printDebug(\"construcor transcript: \" + transcript);\r\n  \r\n  \r\n          this.transcript_arr.push(transcript);\r\n          this.tempWords = transcript;\r\n  \r\n          const confidence = Array.from(e.results)\r\n            .map((result: any) => result[0])\r\n            .map((result) => result.confidence)\r\n            .join(\"\");\r\n          this.confidence_arr.push(confidence);\r\n        });\r\n  \r\n        this.recognition.addEventListener(\"end\", (condition: any) => {\r\n          //this.wordConcat();\r\n          if (this.isStoppedAutomatically) {\r\n            this.recognition.stop();\r\n            this.recognition.start();\r\n            this.isStoppedAutomatically = true;\r\n          }\r\n        });\r\n      } catch (error) {\r\n  \r\n        this.printDebug(error);\r\n  \r\n        this.domElement.style.display = \"none\";\r\n      }\r\n  \r\n    }\r\n  \r\n    ngOnDestroy(): void {\r\n      this.printDebug(\"speech onDestroy\");\r\n      \r\n      if(this.recognition){\r\n        this.recognition.abort();\r\n      }\r\n    }\r\n  \r\n    SpeechToTextToggler() {\r\n      if (!GlobalService.isSpeechToTextStarted) {\r\n  \r\n        this.printDebug(\"start\");\r\n  \r\n        this.beginSentence = this.bindedText;\r\n        if (\r\n          this.bindedText == null ||\r\n          this.bindedText == undefined ||\r\n          this.bindedText == \"\"\r\n        ) {\r\n          this.beginSentence = \"\";\r\n          this.bindedText = \"\";\r\n        }\r\n        this.transcript_arr = [];\r\n        this.confidence_arr = [];\r\n  \r\n        let newtext = \"\";\r\n        this.start();\r\n        //this.isStillRecoginze = this.start() === true ? true : false;\r\n        this.subscription = this.timeInterval.subscribe((val) => {\r\n          if (this.bindedText == null || this.bindedText == undefined) {\r\n            this.bindedText =\r\n              this.beginSentence +\r\n              this.transcript_arr[this.transcript_arr.length - 1];\r\n            this.bindedTextChange.emit(this.bindedText);\r\n          } else {\r\n            newtext = this.transcript_arr[this.transcript_arr.length - 1];\r\n            if (newtext != undefined) {\r\n              this.bindedTextChange.emit(this.beginSentence + newtext);\r\n              this.transcript_arr[this.transcript_arr.length - 1];\r\n            } else {\r\n              this.bindedTextChange.emit(this.bindedText);\r\n            }\r\n          }\r\n        });\r\n      } else {\r\n        if(GlobalService.speechDirective === this){\r\n          this.printDebug(\"stop\");\r\n          this.printDebug(\"binded: \" + this.bindedText);\r\n    \r\n          this.transcript_arr = [];\r\n          this.stop();\r\n          this.subscription.unsubscribe();\r\n        } else {\r\n          this.printDebug(\"stop other\");\r\n          GlobalService.speechDirective.SpeechToTextToggler();\r\n          let interval = setInterval(() => {\r\n            if(GlobalService.speechDirective == null){\r\n              this.SpeechToTextToggler();\r\n              clearInterval(interval)\r\n            }\r\n          }, 100);\r\n        }\r\n      }\r\n    }\r\n  \r\n    private start() {\r\n      if (!GlobalService.isSpeechToTextStarted) {\r\n        this.elementRef.nativeElement.classList.remove(this.pausedClass);\r\n        this.elementRef.nativeElement.classList.add(this.speakingClass);\r\n        this.recognition.start();\r\n        GlobalService.isSpeechToTextStarted = true;\r\n        GlobalService.speechDirective = this;\r\n      }\r\n      return true;\r\n    }\r\n    private stop() {    \r\n      if (GlobalService.isSpeechToTextStarted) {\r\n        this.elementRef.nativeElement.classList.remove(this.speakingClass);\r\n        this.elementRef.nativeElement.classList.add(this.pausedClass);\r\n        this.isStoppedAutomatically = false;\r\n        this.wordConcat();\r\n        this.recognition.stop();\r\n        GlobalService.isSpeechToTextStarted = false;\r\n        GlobalService.speechDirective = null;\r\n        this.transcript_arr = [];\r\n      }\r\n      return false;\r\n    }\r\n  \r\n    private wordConcat() {\r\n      this.bindedText = this.bindedText + \". \";\r\n      // this.bindedText = this.bindedText + \" \" + this.tempWords + \".\";\r\n      // this.tempWords = \"\";\r\n    }\r\n  \r\n    private printDebug(message){\r\n      if(this.debug){\r\n        console.log(message);\r\n      }\r\n    }\r\n  }\r\n  "]}
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"speech-to-text.directive.js","sourceRoot":"","sources":["../../../../../../projects/eqp-dynamic-module/src/lib/directives/speech-to-text/speech-to-text.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostListener,\r\n    Input,\r\n    OnDestroy,\r\n    Output,\r\n  } from \"@angular/core\";\r\n  import { interval, Subscription } from \"rxjs\";\r\n  import { GlobalService } from \"../../services/global.service\";\r\n  \r\n  declare var webkitSpeechRecognition: any;\r\n  \r\n  /* ESEMPIO D'USO\r\n  \r\n    <textarea\r\n      [(ngModel)]=\"text\"\r\n    ></textarea>\r\n  \r\n    <mat-icon\r\n      *ngIf=\"true\" <!-- Senza NGIF non funziona -->\r\n      style=\"cursor: pointer; border-radius: 80px; padding: 5px;\"\r\n      [SpeechToText]\r\n      [(bindedText)]=\"text\"\r\n    >\r\n      keyboard_voice\r\n    </mat-icon>\r\n  \r\n  */\r\n  \r\n  @Directive({\r\n    selector: \"[SpeechToText]\",\r\n  })\r\n  export class SpeechToTextDirective implements OnDestroy{\r\n  \r\n    debug = false;\r\n  \r\n    @Input(\"bindedText\") bindedText: string = \"\";\r\n    @Output() bindedTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n    beginSentence: string = \"\";\r\n    // bindedText = \"\";\r\n    private domElement: HTMLElement;\r\n  \r\n    pausedClass: string = \"keyboard_paused\";\r\n    speakingClass: string = \"keyboard_speaking\";\r\n  \r\n    recognition;\r\n    tempWords: any;\r\n    transcript_arr = [];\r\n    confidence_arr = [];\r\n  \r\n    // isStarted = false; //<< this Flag to check if the user stop the service\r\n    isStoppedSpeechRecog = false;\r\n    isStoppedAutomatically = true; //<< this Flag to check if the service stopped automaticically.\r\n  \r\n    timeInterval = interval(50);\r\n    subscription: Subscription;\r\n  \r\n    @HostListener(\"click\") SpeechToggle() {\r\n      this.SpeechToTextToggler();\r\n    }\r\n  \r\n    constructor(\r\n      private elementRef: ElementRef\r\n      ) {\r\n  \r\n      this.domElement = this.elementRef.nativeElement as HTMLElement;\r\n    \r\n      this.printDebug(window.navigator.userAgent);\r\n  \r\n      try {\r\n        // questa operazione fallisce se non c'è webkit\r\n        this.recognition = new webkitSpeechRecognition();\r\n  \r\n        this.printDebug(this.recognition);\r\n  \r\n        this.recognition.continuous = true;\r\n        this.recognition.interimResults = true;\r\n        this.recognition.lang = \"it-IT\";\r\n  \r\n        this.recognition.addEventListener(\"result\", (e: any) => {\r\n          const transcript = Array.from(e.results)\r\n            .map((result: any) => result[0])\r\n            .map((result) => result.transcript)\r\n            .join(\"\");\r\n  \r\n          this.printDebug(\"construcor transcript: \" + transcript);\r\n  \r\n  \r\n          this.transcript_arr.push(transcript);\r\n          this.tempWords = transcript;\r\n  \r\n          const confidence = Array.from(e.results)\r\n            .map((result: any) => result[0])\r\n            .map((result) => result.confidence)\r\n            .join(\"\");\r\n          this.confidence_arr.push(confidence);\r\n        });\r\n  \r\n        this.recognition.addEventListener(\"end\", (condition: any) => {\r\n          //this.wordConcat();\r\n          if (this.isStoppedAutomatically) {\r\n            this.recognition.stop();\r\n            this.recognition.start();\r\n            this.isStoppedAutomatically = true;\r\n          }\r\n        });\r\n      } catch (error) {\r\n  \r\n        this.printDebug(error);\r\n  \r\n        this.domElement.style.display = \"none\";\r\n      }\r\n  \r\n    }\r\n  \r\n    ngOnDestroy(): void {\r\n      this.printDebug(\"speech onDestroy\");\r\n      \r\n      if(this.recognition){\r\n        this.recognition.abort();\r\n      }\r\n    }\r\n  \r\n    SpeechToTextToggler() {\r\n      if (!GlobalService.isSpeechToTextStarted) {\r\n  \r\n        this.printDebug(\"start\");\r\n  \r\n        this.beginSentence = this.bindedText;\r\n        if (\r\n          this.bindedText == null ||\r\n          this.bindedText == undefined ||\r\n          this.bindedText == \"\"\r\n        ) {\r\n          this.beginSentence = \"\";\r\n          this.bindedText = \"\";\r\n        }\r\n        this.transcript_arr = [];\r\n        this.confidence_arr = [];\r\n  \r\n        let newtext = \"\";\r\n        this.start();\r\n        //this.isStillRecoginze = this.start() === true ? true : false;\r\n        this.subscription = this.timeInterval.subscribe((val) => {\r\n          if (this.bindedText == null || this.bindedText == undefined) {\r\n            this.bindedText =\r\n              this.beginSentence +\r\n              this.transcript_arr[this.transcript_arr.length - 1];\r\n            this.bindedTextChange.emit(this.bindedText);\r\n          } else {\r\n            newtext = this.transcript_arr[this.transcript_arr.length - 1];\r\n            if (newtext != undefined) {\r\n              this.bindedTextChange.emit(this.beginSentence + newtext);\r\n              this.transcript_arr[this.transcript_arr.length - 1];\r\n            } else {\r\n              this.bindedTextChange.emit(this.bindedText);\r\n            }\r\n          }\r\n        });\r\n      } else {\r\n        if(GlobalService.speechDirective === this){\r\n          this.printDebug(\"stop\");\r\n          this.printDebug(\"binded: \" + this.bindedText);\r\n    \r\n          this.transcript_arr = [];\r\n          this.stop();\r\n          this.subscription.unsubscribe();\r\n        } else {\r\n          this.printDebug(\"stop other\");\r\n          GlobalService.speechDirective.SpeechToTextToggler();\r\n          let interval = setInterval(() => {\r\n            if(GlobalService.speechDirective == null){\r\n              this.SpeechToTextToggler();\r\n              clearInterval(interval)\r\n            }\r\n          }, 100);\r\n        }\r\n      }\r\n    }\r\n  \r\n    private start() {\r\n      if (!GlobalService.isSpeechToTextStarted) {\r\n        this.elementRef.nativeElement.classList.remove(this.pausedClass);\r\n        this.elementRef.nativeElement.classList.add(this.speakingClass);\r\n        this.recognition.start();\r\n        GlobalService.isSpeechToTextStarted = true;\r\n        GlobalService.speechDirective = this;\r\n      }\r\n      return true;\r\n    }\r\n    private stop() {    \r\n      if (GlobalService.isSpeechToTextStarted) {\r\n        this.elementRef.nativeElement.classList.remove(this.speakingClass);\r\n        this.elementRef.nativeElement.classList.add(this.pausedClass);\r\n        this.isStoppedAutomatically = false;\r\n        this.wordConcat();\r\n        this.recognition.stop();\r\n        GlobalService.isSpeechToTextStarted = false;\r\n        GlobalService.speechDirective = null;\r\n        this.transcript_arr = [];\r\n      }\r\n      return false;\r\n    }\r\n  \r\n    private wordConcat() {\r\n      this.bindedText = this.bindedText + \". \";\r\n      // this.bindedText = this.bindedText + \" \" + this.tempWords + \".\";\r\n      // this.tempWords = \"\";\r\n    }\r\n  \r\n    private printDebug(message){\r\n      if(this.debug){\r\n        console.log(message);\r\n      }\r\n    }\r\n  }\r\n  "]}
|
|
@@ -19,4 +19,4 @@ export const AvailableImageExtensions = [
|
|
|
19
19
|
{ value: '.svg', key: 'image/svg+xml' },
|
|
20
20
|
{ value: '.ico', key: 'image/x-icon' },
|
|
21
21
|
];
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0YWNobWVudEZpZWxkLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXFwLWR5bmFtaWMtbW9kdWxlL3NyYy9saWIvbW9kZWxzL2ZpZWxkcy9hdHRhY2htZW50RmllbGQubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRS9DLE1BQU0sT0FBTyxlQUFnQixTQUFRLFNBQVM7Q0FTN0M7QUFFRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBMEM7SUFDMUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxpQkFBaUIsRUFBRTtJQUN6QyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLG9CQUFvQixFQUFFO0lBQzVDLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsMEJBQTBCLEVBQUU7SUFDbEQsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSwrQkFBK0IsRUFBRTtJQUN2RCxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLHlFQUF5RSxFQUFFO0lBQ2xHLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsbUVBQW1FLEVBQUU7SUFDNUYsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSwyRUFBMkUsRUFBRTtJQUNwRyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRTtJQUNsQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFlBQVksRUFBRTtDQUN2QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQTBDO0lBQzNFLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxHQUFHLEVBQUUsWUFBWSxFQUFFO0lBQzFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFO0lBQ25DLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFO0lBQ25DLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsZUFBZSxFQUFFO0lBQ3ZDLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsY0FBYyxFQUFFO0NBQ3pDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlRmllbGQgfSBmcm9tIFwiLi4vYmFzZUZpZWxkLm1vZGVsXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgQXR0YWNobWVudEZpZWxkIGV4dGVuZHMgQmFzZUZpZWxkIHtcclxuICAgIC8qKkVsZW5jbyBkZWxsZSBlc3RlbnNpb25pIGNvbnNlbnRpdGUuIFNlIHZ1b3RvIHVzYSBpbCBkZWZhdWx0IChwZGYpICovXHJcbiAgICBBbGxvd2VkRXh0ZW5zaW9uczogQXJyYXk8c3RyaW5nPjtcclxuXHJcbiAgICAvKipTZSB0cnVlIHBlcm1ldHRlIGwnaW5zZXJpbWVudG8gZGkgcGnDuSBhbGxlZ2F0aS4gSW4gcXVlc3RvIGNhc28gaSBtZXRhZGF0aSB2ZW5nb25vIHJhcHByZXNlbnRhdGkgY29tZSB1bmEgZGV0YWlsICovXHJcbiAgICBpc011bHRpQXR0YWNoOiBib29sZWFuO1xyXG5cclxuICAgIC8qKkVsZW5jbyBjYW1waSBjaGUgcG9zc29ubyByYXBwcmVzZW50YXJlIGkgbWV0YWRhdGkgZGVsbCdhbGxlZ2F0bywgYWQgZXNlbXBpbyBub21lLCBlY2MuLi4gKi9cclxuICAgIE1ldGFkYXRhRmllbGRzOiBBcnJheTxCYXNlRmllbGQ+O1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgQXZhaWxhYmxlRmlsZUV4dGVuc2lvbnM6IEFycmF5PHsga2V5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcgfT4gPSBbXHJcbiAgICB7IHZhbHVlOiAnLnBkZicsIGtleTogJ2FwcGxpY2F0aW9uL3BkZicgfSxcclxuICAgIHsgdmFsdWU6ICcuZG9jJywga2V5OiAnYXBwbGljYXRpb24vbXN3b3JkJyB9LFxyXG4gICAgeyB2YWx1ZTogJy54bHMnLCBrZXk6ICdhcHBsaWNhdGlvbi92bmQubXMtZXhjZWwnIH0sXHJcbiAgICB7IHZhbHVlOiAnLnBwdCcsIGtleTogJ2FwcGxpY2F0aW9uL3ZuZC5tcy1wb3dlcnBvaW50JyB9LFxyXG4gICAgeyB2YWx1ZTogJy5kb2N4Jywga2V5OiAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LndvcmRwcm9jZXNzaW5nbWwuZG9jdW1lbnQnIH0sXHJcbiAgICB7IHZhbHVlOiAnLnhsc3gnLCBrZXk6ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQuc3ByZWFkc2hlZXRtbC5zaGVldCcgfSxcclxuICAgIHsgdmFsdWU6ICcucHB0eCcsIGtleTogJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5wcmVzZW50YXRpb25tbC5wcmVzZW50YXRpb24nIH0sXHJcbiAgICB7IHZhbHVlOiAnLmNzdicsIGtleTogJ3RleHQvY3N2JyB9LFxyXG4gICAgeyB2YWx1ZTogJy50eHQnLCBrZXk6ICd0ZXh0L3BsYWluJyB9LFxyXG5dO1xyXG5cclxuZXhwb3J0IGNvbnN0IEF2YWlsYWJsZUltYWdlRXh0ZW5zaW9uczogQXJyYXk8eyBrZXk6IHN0cmluZywgdmFsdWU6IHN0cmluZyB9PiA9IFtcclxuICAgIHsgdmFsdWU6ICcuanBnLy5qcGVnJywga2V5OiAnaW1hZ2UvanBlZycgfSxcclxuICAgIHsgdmFsdWU6ICcucG5nJywga2V5OiAnaW1hZ2UvcG5nJyB9LFxyXG4gICAgeyB2YWx1ZTogJy5ibXAnLCBrZXk6ICdpbWFnZS9ibXAnIH0sXHJcbiAgICB7IHZhbHVlOiAnLnN2ZycsIGtleTogJ2ltYWdlL3N2Zyt4bWwnIH0sXHJcbiAgICB7IHZhbHVlOiAnLmljbycsIGtleTogJ2ltYWdlL3gtaWNvbicgfSxcclxuXTsiXX0=
|