barsa-develop-components 2.2.2 → 2.2.4
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/esm2022/barsa-develop-components.mjs +5 -0
- package/esm2022/lib/accept-reject/accept-reject.component.mjs +68 -0
- package/esm2022/lib/avatar/avatar.component.mjs +29 -0
- package/esm2022/lib/barcode-format-pipe.mjs +25 -0
- package/esm2022/lib/barcode-reader/barcode-reader.component.mjs +62 -0
- package/esm2022/lib/barcode-reader-dialog/barcode-reader-dialog.component.mjs +82 -0
- package/esm2022/lib/barcode-reader-video/barcode-reader-video.component.mjs +66 -0
- package/esm2022/lib/barcode.service.mjs +330 -0
- package/esm2022/lib/barsa-develop-components.module.mjs +292 -0
- package/esm2022/lib/barsa-document-list-item/barsa-document-list-item.component.mjs +104 -0
- package/esm2022/lib/barsa-documents/barsa-documents.component.mjs +159 -0
- package/esm2022/lib/barsa-geographic-location/barsa-geographic-location.component.mjs +173 -0
- package/esm2022/lib/card-content-image-and-title/card-content-image-and-title.component.mjs +50 -0
- package/esm2022/lib/card-content-line-chart/card-content-line-chart.component.mjs +36 -0
- package/esm2022/lib/card-header-big-image-title-and-subtitle/card-header-big-image-title-and-subtitle.component.mjs +19 -0
- package/esm2022/lib/card-header-kpi/card-header-kpi.component.mjs +40 -0
- package/esm2022/lib/card-header-logo-title-subtitle/card-header-logo-title-subtitle.component.mjs +45 -0
- package/esm2022/lib/checkbox-button/checkbox-button.component.mjs +23 -0
- package/esm2022/lib/column-chip/column-chip.component.mjs +44 -0
- package/esm2022/lib/column-form-viewer/column-form-viewer.component.mjs +88 -0
- package/esm2022/lib/column-progressbar/column-progressbar.component.mjs +87 -0
- package/esm2022/lib/enum-info-micro-proccess-flow/enum-info-micro-proccess-flow.component.mjs +18 -0
- package/esm2022/lib/footer/footer.component.mjs +43 -0
- package/esm2022/lib/form-card/form-card.component.mjs +17 -0
- package/esm2022/lib/form-chart-content/form-chart-content.component.mjs +36 -0
- package/esm2022/lib/form-content-quick-view/form-content-quick-view.component.mjs +102 -0
- package/esm2022/lib/form-report-view/form-report-view.component.mjs +25 -0
- package/esm2022/lib/form-report-view-item/form-report-view-item.component.mjs +45 -0
- package/esm2022/lib/g4b-details/g4b-details.component.mjs +28 -0
- package/esm2022/lib/g4b-estelam/g4b-estelam.component.mjs +30 -0
- package/esm2022/lib/geographic-location/geographic-location.component.mjs +88 -0
- package/esm2022/lib/login-form/login-form.component.mjs +55 -0
- package/esm2022/lib/login-social-conncetions/login-social-conncetions.component.mjs +30 -0
- package/esm2022/lib/master-detail-card-form/master-detail-card-form.component.mjs +17 -0
- package/esm2022/lib/media-file-uploader/media-file-uploader.component.mjs +238 -0
- package/esm2022/lib/micro-proccess-flow/micro-proccess-flow.component.mjs +52 -0
- package/esm2022/lib/micro-process-flow-view/micro-process-flow-view.component.mjs +24 -0
- package/esm2022/lib/mo-info-micro-proccess-flow/mo-info-micro-proccess-flow.component.mjs +23 -0
- package/esm2022/lib/models/document-item.mjs +2 -0
- package/esm2022/lib/models/documents-setting.mjs +2 -0
- package/esm2022/lib/models/form-report-view-setting.mjs +2 -0
- package/esm2022/lib/models/index.mjs +8 -0
- package/esm2022/lib/models/micro-process-flow-view-setting.mjs +2 -0
- package/esm2022/lib/models/person.mjs +2 -0
- package/esm2022/lib/models/service-desk-view-of-services-setting.mjs +2 -0
- package/esm2022/lib/models/tab-process-view-setting.mjs +2 -0
- package/esm2022/lib/pipes/datasource-to-flow-item.mjs +23 -0
- package/esm2022/lib/pipes/index.mjs +3 -0
- package/esm2022/lib/pipes/mo-list-to-flow-item.pipe.mjs +23 -0
- package/esm2022/lib/query-string-form-observable/query-string-form-observable.component.mjs +37 -0
- package/esm2022/lib/query-string-observable/query-string-observable.component.mjs +22 -0
- package/esm2022/lib/report-button-view/report-button-view.component.mjs +37 -0
- package/esm2022/lib/report-line-chart-view/report-line-chart-view.component.mjs +12 -0
- package/esm2022/lib/report-tab-view/report-tab-view.component.mjs +27 -0
- package/esm2022/lib/resend-verification-code/resend-verification-code.component.mjs +62 -0
- package/esm2022/lib/service-desk-card-content-mojavezhay-akhz-shode/service-desk-card-content-mojavezhay-akhz-shode.component.mjs +28 -0
- package/esm2022/lib/service-desk-form-layout-content-mojavez/service-desk-form-layout-content-mojavez.component.mjs +110 -0
- package/esm2022/lib/service-desk-header/service-desk-header.component.mjs +238 -0
- package/esm2022/lib/service-desk-servcie-detail/service-desk-servcie-detail.component.mjs +142 -0
- package/esm2022/lib/service-desk-view-of-services/service-desk-view-of-services.component.mjs +37 -0
- package/esm2022/lib/setting-form/setting-form.component.mjs +64 -0
- package/esm2022/lib/subform-in-row-report/subform-in-row-report.component.mjs +73 -0
- package/esm2022/lib/tab-process-view/tab-process-view.component.mjs +48 -0
- package/esm2022/lib/table-view-vertical-columns/table-view-vertical-columns.component.mjs +16 -0
- package/esm2022/lib/timer-count-down/timer-count-down.component.mjs +104 -0
- package/esm2022/lib/token-report-view/token-report-view.component.mjs +27 -0
- package/esm2022/lib/ui-enum-segmented-button/ui-enum-segmented-button.component.mjs +25 -0
- package/esm2022/lib/ui-num-rate/ui-num-rate.component.mjs +29 -0
- package/esm2022/lib/ui-person/ui-person.component.mjs +160 -0
- package/esm2022/lib/ui-person/ui-person.pipe.mjs +41 -0
- package/esm2022/lib/ui-pictures-carousel/ui-pictures-carousel.component.mjs +17 -0
- package/esm2022/lib/ui-text-field-search/ui-text-field-search.component.mjs +42 -0
- package/esm2022/lib/ulv-context-menu-item-show-file-content/ulv-context-menu-item-show-file-content.component.mjs +69 -0
- package/esm2022/public-api.mjs +64 -0
- package/package.json +3 -1
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
|
|
2
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import { UiMoInfoSubFormUiComponent } from 'barsa-sap-ui';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "barsa-novin-ray-core";
|
|
7
|
+
import * as i3 from "@fundamental-ngx/core/dialog";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/title";
|
|
9
|
+
import * as i5 from "../barsa-geographic-location/barsa-geographic-location.component";
|
|
10
|
+
export class GeographicLocationComponent extends UiMoInfoSubFormUiComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
this.fullscreen = false;
|
|
14
|
+
}
|
|
15
|
+
get latitudeUi() {
|
|
16
|
+
return this.customFormPanelUi._dictFieldUi.Latitude;
|
|
17
|
+
}
|
|
18
|
+
get longitudeUi() {
|
|
19
|
+
return this.customFormPanelUi._dictFieldUi.Longitude;
|
|
20
|
+
}
|
|
21
|
+
openDialog(dialog) {
|
|
22
|
+
this._dialogService.open(dialog, {
|
|
23
|
+
responsivePadding: true,
|
|
24
|
+
fullScreen: true,
|
|
25
|
+
mobile: true,
|
|
26
|
+
ariaLabelledBy: 'map',
|
|
27
|
+
ariaDescribedBy: 'choose location',
|
|
28
|
+
focusTrapped: true
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
super.ngOnInit();
|
|
33
|
+
this._setDefaultLatAndLong(this.latitudeUi?.value, this.longitudeUi?.value);
|
|
34
|
+
}
|
|
35
|
+
onFullscreen() {
|
|
36
|
+
this.fullscreen = true;
|
|
37
|
+
this.openDialog(this.dialogTemplate);
|
|
38
|
+
}
|
|
39
|
+
onExistFullscreen() {
|
|
40
|
+
this.fullscreen = false;
|
|
41
|
+
this._cdr.detectChanges();
|
|
42
|
+
}
|
|
43
|
+
onOpenChange(isOpen) {
|
|
44
|
+
this.fullscreen = isOpen;
|
|
45
|
+
}
|
|
46
|
+
onErrorNavigatorLocation(err) {
|
|
47
|
+
const err2 = `خطا در دریافت موقعیت مکانی جاری. (${err.message})`;
|
|
48
|
+
BarsaApi.Bw.Toast.Error(err2);
|
|
49
|
+
}
|
|
50
|
+
onMove(e) {
|
|
51
|
+
this._movePos = { latitude: e.latlng.lat, longitude: e.latlng.lng };
|
|
52
|
+
}
|
|
53
|
+
onMoveEnd(e) {
|
|
54
|
+
this._handleMarkerChange(this._movePos);
|
|
55
|
+
}
|
|
56
|
+
onMarkerChange(e) {
|
|
57
|
+
this._handleMarkerChange(e);
|
|
58
|
+
}
|
|
59
|
+
_handleMarkerChange(e) {
|
|
60
|
+
const { latitude, longitude } = e;
|
|
61
|
+
this.latitudeUi.value = latitude;
|
|
62
|
+
this.longitudeUi.value = longitude;
|
|
63
|
+
this._valueChanged();
|
|
64
|
+
}
|
|
65
|
+
_setDefaultLatAndLong(lat, lng) {
|
|
66
|
+
if (lat && lng) {
|
|
67
|
+
this.latValue = lat;
|
|
68
|
+
this.lngValue = lng;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
_titleChanged() {
|
|
72
|
+
this._setDefaultLatAndLong(this.latitudeUi?.value, this.longitudeUi?.value);
|
|
73
|
+
}
|
|
74
|
+
_valueChanged() {
|
|
75
|
+
this.latitudeUi.fireEvent('change', this.latitudeUi, this.latitudeUi.value);
|
|
76
|
+
this.longitudeUi.fireEvent('change', this.longitudeUi, this.longitudeUi.value);
|
|
77
|
+
}
|
|
78
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GeographicLocationComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: GeographicLocationComponent, selector: "bdc-geographic-location", viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["confirmationDialog"], descendants: true }], usesInheritance: true, ngImport: i0, template: "@if (customFormPanelUi) {\r\n<bnrc-form style=\"display: none\" *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\r\n} @if (!fullscreen) {\r\n<ng-container *ngTemplateOutlet=\"map; context: { inDialog: false }\"></ng-container>\r\n}\r\n\r\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #confirmationDialog>\r\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\r\n <fd-dialog-header>\r\n <h1 id=\"fd-dialog-header-10\" fd-title>{{ 'Map' | bbbTranslate }}</h1>\r\n </fd-dialog-header>\r\n <fd-dialog-body>\r\n <ng-container *ngTemplateOutlet=\"map; context: { inDialog: true, dialog: dialog }\"></ng-container>\r\n </fd-dialog-body>\r\n </fd-dialog>\r\n</ng-template>\r\n\r\n<ng-template #map let-inDialog=\"inDialog\" let-dialog=\"dialog\">\r\n <bdc-barsa-geographic-location\r\n [style.height]=\"inDialog ? 'height: 100% !important' : null\"\r\n [defaultLocation]=\"[35.7568, 51.412]\"\r\n [latitude]=\"latValue\"\r\n [longitude]=\"lngValue\"\r\n [showExitFullscreenButton]=\"true\"\r\n [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\r\n [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\r\n [disableOrReadonly]=\"(disableOrReadonly$ | async) === true\"\r\n [draggable]=\"customFieldInfo.Draggable === true\"\r\n (markerChange)=\"onMarkerChange($event)\"\r\n (move)=\"onMove($event)\"\r\n (errorEvent)=\"onErrorNavigatorLocation($event)\"\r\n (moveEnd)=\"onMoveEnd($event)\"\r\n (exitFullscreen)=\"onExistFullscreen(); dialog && dialog.close('Continue')\"\r\n ></bdc-barsa-geographic-location>\r\n</ng-template>\r\n", styles: [":host{display:block;position:relative}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.FormComponent, selector: "bnrc-form", inputs: ["params", "customFormPanelUi", "formPanelCtrl", "UlvMainCtrlr", "formPanelCtrlId", "saveOnChange", "inlineEditInReport"], outputs: ["titleChanged", "moChanged", "formClose", "uiComponent", "formRendered", "bruleAction", "beforeTransition", "afterTransition"] }, { kind: "directive", type: i2.UntilInViewDirective, selector: "[untilInView]", inputs: ["untilInView", "intersectionDebounce"] }, { kind: "component", type: i3.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i3.DialogBodyComponent, selector: "fd-dialog-body", inputs: ["disablePaddings"] }, { kind: "component", type: i3.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i4.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "component", type: i5.BarsaGeographicLocationComponent, selector: "bdc-barsa-geographic-location", inputs: ["disableOrReadonly", "setAutomaticLocation", "showLocationButton", "showFullscreenButton", "showExitFullscreenButton", "draggable", "defaultLocation", "latitude", "longitude"], outputs: ["move", "moveEnd", "fullscreen", "exitFullscreen", "errorEvent", "markerChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
80
|
+
}
|
|
81
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GeographicLocationComponent, decorators: [{
|
|
82
|
+
type: Component,
|
|
83
|
+
args: [{ selector: 'bdc-geographic-location', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "@if (customFormPanelUi) {\r\n<bnrc-form style=\"display: none\" *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\r\n} @if (!fullscreen) {\r\n<ng-container *ngTemplateOutlet=\"map; context: { inDialog: false }\"></ng-container>\r\n}\r\n\r\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #confirmationDialog>\r\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\r\n <fd-dialog-header>\r\n <h1 id=\"fd-dialog-header-10\" fd-title>{{ 'Map' | bbbTranslate }}</h1>\r\n </fd-dialog-header>\r\n <fd-dialog-body>\r\n <ng-container *ngTemplateOutlet=\"map; context: { inDialog: true, dialog: dialog }\"></ng-container>\r\n </fd-dialog-body>\r\n </fd-dialog>\r\n</ng-template>\r\n\r\n<ng-template #map let-inDialog=\"inDialog\" let-dialog=\"dialog\">\r\n <bdc-barsa-geographic-location\r\n [style.height]=\"inDialog ? 'height: 100% !important' : null\"\r\n [defaultLocation]=\"[35.7568, 51.412]\"\r\n [latitude]=\"latValue\"\r\n [longitude]=\"lngValue\"\r\n [showExitFullscreenButton]=\"true\"\r\n [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\r\n [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\r\n [disableOrReadonly]=\"(disableOrReadonly$ | async) === true\"\r\n [draggable]=\"customFieldInfo.Draggable === true\"\r\n (markerChange)=\"onMarkerChange($event)\"\r\n (move)=\"onMove($event)\"\r\n (errorEvent)=\"onErrorNavigatorLocation($event)\"\r\n (moveEnd)=\"onMoveEnd($event)\"\r\n (exitFullscreen)=\"onExistFullscreen(); dialog && dialog.close('Continue')\"\r\n ></bdc-barsa-geographic-location>\r\n</ng-template>\r\n", styles: [":host{display:block;position:relative}\n"] }]
|
|
84
|
+
}], propDecorators: { dialogTemplate: [{
|
|
85
|
+
type: ViewChild,
|
|
86
|
+
args: ['confirmationDialog']
|
|
87
|
+
}] } });
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geographic-location.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/geographic-location/geographic-location.component.ts","../../../../../projects/barsa-develop-components/src/lib/geographic-location/geographic-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, TemplateRef, ViewChild } from '@angular/core';\r\nimport { BarsaApi } from 'barsa-novin-ray-core';\r\nimport { UiMoInfoSubFormUiComponent } from 'barsa-sap-ui';\r\n\r\n@Component({\r\n    selector: 'bdc-geographic-location',\r\n    templateUrl: './geographic-location.component.html',\r\n    styleUrls: ['./geographic-location.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class GeographicLocationComponent extends UiMoInfoSubFormUiComponent implements OnInit {\r\n    @ViewChild('confirmationDialog') dialogTemplate: TemplateRef<any>;\r\n    fullscreen = false;\r\n\r\n    latValue;\r\n    lngValue;\r\n    customFormPanelUi: any;\r\n    private _movePos: { latitude: any; longitude: any };\r\n    get latitudeUi(): any {\r\n        return this.customFormPanelUi._dictFieldUi.Latitude;\r\n    }\r\n    get longitudeUi(): any {\r\n        return this.customFormPanelUi._dictFieldUi.Longitude;\r\n    }\r\n\r\n    openDialog(dialog: TemplateRef<any>): void {\r\n        this._dialogService.open(dialog, {\r\n            responsivePadding: true,\r\n            fullScreen: true,\r\n            mobile: true,\r\n            ariaLabelledBy: 'map',\r\n            ariaDescribedBy: 'choose location',\r\n            focusTrapped: true\r\n        });\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this._setDefaultLatAndLong(this.latitudeUi?.value, this.longitudeUi?.value);\r\n    }\r\n    onFullscreen(): void {\r\n        this.fullscreen = true;\r\n        this.openDialog(this.dialogTemplate);\r\n    }\r\n    onExistFullscreen(): void {\r\n        this.fullscreen = false;\r\n        this._cdr.detectChanges();\r\n    }\r\n    onOpenChange(isOpen): void {\r\n        this.fullscreen = isOpen;\r\n    }\r\n    onErrorNavigatorLocation(err): void {\r\n        const err2 = `خطا در دریافت موقعیت مکانی جاری. (${err.message})`;\r\n        BarsaApi.Bw.Toast.Error(err2);\r\n    }\r\n    onMove(e): void {\r\n        this._movePos = { latitude: e.latlng.lat, longitude: e.latlng.lng };\r\n    }\r\n    onMoveEnd(e): void {\r\n        this._handleMarkerChange(this._movePos);\r\n    }\r\n    onMarkerChange(e: { latitude; longitude }): void {\r\n        this._handleMarkerChange(e);\r\n    }\r\n    protected _handleMarkerChange(e: { latitude; longitude }): void {\r\n        const { latitude, longitude } = e;\r\n        this.latitudeUi.value = latitude;\r\n        this.longitudeUi.value = longitude;\r\n        this._valueChanged();\r\n    }\r\n    protected _setDefaultLatAndLong(lat: number, lng: number): void {\r\n        if (lat && lng) {\r\n            this.latValue = lat;\r\n            this.lngValue = lng;\r\n        }\r\n    }\r\n    protected _titleChanged(): void {\r\n        this._setDefaultLatAndLong(this.latitudeUi?.value, this.longitudeUi?.value);\r\n    }\r\n    protected _valueChanged(): void {\r\n        this.latitudeUi.fireEvent('change', this.latitudeUi, this.latitudeUi.value);\r\n        this.longitudeUi.fireEvent('change', this.longitudeUi, this.longitudeUi.value);\r\n    }\r\n}\r\n","@if (customFormPanelUi) {\r\n<bnrc-form style=\"display: none\" *untilInView=\"el\" [customFormPanelUi]=\"customFormPanelUi\"></bnrc-form>\r\n} @if (!fullscreen) {\r\n<ng-container *ngTemplateOutlet=\"map; context: { inDialog: false }\"></ng-container>\r\n}\r\n\r\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #confirmationDialog>\r\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\r\n        <fd-dialog-header>\r\n            <h1 id=\"fd-dialog-header-10\" fd-title>{{ 'Map' | bbbTranslate }}</h1>\r\n        </fd-dialog-header>\r\n        <fd-dialog-body>\r\n            <ng-container *ngTemplateOutlet=\"map; context: { inDialog: true, dialog: dialog }\"></ng-container>\r\n        </fd-dialog-body>\r\n    </fd-dialog>\r\n</ng-template>\r\n\r\n<ng-template #map let-inDialog=\"inDialog\" let-dialog=\"dialog\">\r\n    <bdc-barsa-geographic-location\r\n        [style.height]=\"inDialog ? 'height: 100% !important' : null\"\r\n        [defaultLocation]=\"[35.7568, 51.412]\"\r\n        [latitude]=\"latValue\"\r\n        [longitude]=\"lngValue\"\r\n        [showExitFullscreenButton]=\"true\"\r\n        [showLocationButton]=\"customFieldInfo.ShowLocationButton\"\r\n        [setAutomaticLocation]=\"customFieldInfo.GetCurrentLocation\"\r\n        [disableOrReadonly]=\"(disableOrReadonly$ | async) === true\"\r\n        [draggable]=\"customFieldInfo.Draggable === true\"\r\n        (markerChange)=\"onMarkerChange($event)\"\r\n        (move)=\"onMove($event)\"\r\n        (errorEvent)=\"onErrorNavigatorLocation($event)\"\r\n        (moveEnd)=\"onMoveEnd($event)\"\r\n        (exitFullscreen)=\"onExistFullscreen(); dialog && dialog.close('Continue')\"\r\n    ></bdc-barsa-geographic-location>\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, HostListener } from '@angular/core';
|
|
2
|
+
import { map, takeUntil } from 'rxjs/operators';
|
|
3
|
+
import { BarsaApi, FormBaseComponent, FormPanelService, getDeviceIsMobile } from 'barsa-novin-ray-core';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "barsa-sap-ui";
|
|
6
|
+
import * as i2 from "@fundamental-ngx/core/dynamic-side-content";
|
|
7
|
+
import * as i3 from "@fundamental-ngx/core/layout-grid";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "barsa-novin-ray-core";
|
|
10
|
+
export class LoginFormComponent extends FormBaseComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
this._desktopmode = !getDeviceIsMobile();
|
|
14
|
+
this.onKeyEnter = (_) => {
|
|
15
|
+
const layoutItem = this._controlUiPipe.transform(' ورود', this.layout94);
|
|
16
|
+
if (layoutItem) {
|
|
17
|
+
layoutItem.FieldUi.fireEvent('click', layoutItem.FieldUi);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
this._activatedRoute.queryParams.pipe(takeUntil(this._onDestroy$)).subscribe((params) => {
|
|
23
|
+
BarsaApi.Bw.SetCultureByDisplayName(params.culture);
|
|
24
|
+
});
|
|
25
|
+
const root = document.documentElement;
|
|
26
|
+
root.style.setProperty('--absolute-page-top', '0px');
|
|
27
|
+
super.ngOnInit();
|
|
28
|
+
this.layout94$.subscribe((layout94) => {
|
|
29
|
+
this.layout94 = layout94;
|
|
30
|
+
});
|
|
31
|
+
this.size$ = this._portalService.deviceSize$.pipe(map((deviceSize) => {
|
|
32
|
+
switch (deviceSize) {
|
|
33
|
+
case 's':
|
|
34
|
+
return 'sm';
|
|
35
|
+
case 'm':
|
|
36
|
+
return 'md';
|
|
37
|
+
default:
|
|
38
|
+
return 'xl';
|
|
39
|
+
}
|
|
40
|
+
}));
|
|
41
|
+
}
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
43
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LoginFormComponent, selector: "bdc-login-form", host: { listeners: { "keydown.enter": "onKeyEnter($event)" }, properties: { "class.desktopmode": "this._desktopmode" } }, providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "@if (mo$ | async; as mo) { @if (mo.IsLogging) {\r\n<bsu-mask></bsu-mask>\r\n} @if ((size$ | async) === 'sm') {\r\n<fd-layout-grid [class.mobile]=\"isMobile\">\r\n <div [fdLayoutGridCol]=\"1\"></div>\r\n <div [fdLayoutGridCol]=\"10\">\r\n <bsu-ly-layout-container-of-root\r\n [config]=\"layout94$ | async\"\r\n [isPanel]=\"false\"\r\n [isRoot]=\"true\"\r\n [class.desktopMode]=\"!(isMobile === true)\"\r\n ></bsu-ly-layout-container-of-root>\r\n </div>\r\n <div [fdLayoutGridCol]=\"1\"></div>\r\n</fd-layout-grid>\r\n} @else {\r\n<fd-dynamic-side-content [size]=\"(size$ | async)!!\">\r\n <fd-dynamic-side-content-side>\r\n <bsu-ly-layout-container-of-root\r\n [config]=\"layout94$ | async\"\r\n [isPanel]=\"false\"\r\n [isRoot]=\"true\"\r\n ></bsu-ly-layout-container-of-root>\r\n </fd-dynamic-side-content-side>\r\n <fd-dynamic-side-content-main>\r\n <!-- <ng-container *ngIf=\"'\u0639\u06A9\u0633 \u067E\u0633 \u0632\u0645\u06CC\u0646\u0647' | controlUi: layout94 as layoutConfig\">\r\n <bsu-layout-control\r\n [caption]=\"'\u0639\u06A9\u0633 \u067E\u0633 \u0632\u0645\u06CC\u0646\u0647'\"\r\n [config]=\"layoutConfig\"\r\n [showLabel]=\"false\"\r\n [inlineEdit]=\"true\"\r\n ></bsu-layout-control>\r\n </ng-container> -->\r\n @if ('\u0639\u06A9\u0633 \u067E\u0633 \u0632\u0645\u06CC\u0646\u0647' | controlUi: layout94; as layoutConfig) {\r\n <div\r\n id=\"bgLogin\"\r\n [style.backgroundImage]=\"\r\n 'url(' +\r\n (mo.Background?.FileId | picFieldSrc: 'PictureFileInfo':null:layoutConfig.FieldUi.Setting.FieldDefId) +\r\n ')'\r\n \"\r\n ></div>\r\n }\r\n </fd-dynamic-side-content-main>\r\n</fd-dynamic-side-content>\r\n} }\r\n", styles: ["@charset \"UTF-8\";:host{display:block;background-color:#fff}:host ::ng-deep bsu-ly-simple-label{text-align:center}:host ::ng-deep bsu-ly-simple-label:nth-of-type(1){margin-top:15px}:host ::ng-deep bsu-ui-picture-file{text-align:center}:host ::ng-deep .wrap-content>.container-field{max-width:100%!important}fd-dynamic-side-content{min-height:100vh}fd-dynamic-side-content-side{box-shadow:0 3px 5px -1px #0003,0 6px 10px #00000024,0 1px 18px #0000001f}bsu-ly-layout-container-of-root{padding:0 1rem;box-sizing:border-box;display:flex;align-items:center;height:100%}#bgLogin{width:100%;height:100%;background-position:center;background-size:cover;background-repeat:no-repeat}@media (max-width: 599px){:host ::ng-deep bsu-layout-control{min-width:auto!important}:host ::ng-deep bsu-ly-layout-container-of-root{padding:0}}@media (max-height: 670px){:host.desktopmode bsu-ly-layout-container-of-root{padding:0}:host.desktopmode bsu-ly-layout-container-of-root ::ng-deep bsu-ly-empty-space{display:none}:host.desktopmode bsu-ly-layout-container-of-root ::ng-deep bsu-layout-control[caption=\\644\\648\\6af\\648]{display:none}}fd-layout-grid.mobile{overflow:auto;height:100vh}\n"], dependencies: [{ kind: "component", type: i1.LyLayoutContainerOfRootComponent, selector: "bsu-ly-layout-container-of-root" }, { kind: "component", type: i1.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "component", type: i2.DynamicSideContentComponent, selector: "fd-dynamic-side-content", inputs: ["position", "size", "id"] }, { kind: "component", type: i2.DynamicSideContentSideComponent, selector: "fd-dynamic-side-content-side", inputs: ["id"] }, { kind: "component", type: i2.DynamicSideContentMainComponent, selector: "fd-dynamic-side-content-main", inputs: ["id"] }, { kind: "component", type: i3.LayoutGridComponent, selector: "fd-layout-grid, [fdLayoutGrid]", inputs: ["class", "noGap", "noHorizontalGap", "noVerticalGap"] }, { kind: "directive", type: i3.LayoutGridColDirective, selector: "[fd-layout-grid-col], [fdLayoutGridCol]", inputs: ["fdLayoutGridCol", "colGrow", "colMd", "colLg", "colXl", "colOffset", "colOffsetMd", "colOffsetLg", "colOffsetXl", "class"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.PictureFieldSourcePipe, name: "picFieldSrc" }, { kind: "pipe", type: i5.ControlUiPipe, name: "controlUi" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
44
|
+
}
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginFormComponent, decorators: [{
|
|
46
|
+
type: Component,
|
|
47
|
+
args: [{ selector: 'bdc-login-form', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], standalone: false, template: "@if (mo$ | async; as mo) { @if (mo.IsLogging) {\r\n<bsu-mask></bsu-mask>\r\n} @if ((size$ | async) === 'sm') {\r\n<fd-layout-grid [class.mobile]=\"isMobile\">\r\n <div [fdLayoutGridCol]=\"1\"></div>\r\n <div [fdLayoutGridCol]=\"10\">\r\n <bsu-ly-layout-container-of-root\r\n [config]=\"layout94$ | async\"\r\n [isPanel]=\"false\"\r\n [isRoot]=\"true\"\r\n [class.desktopMode]=\"!(isMobile === true)\"\r\n ></bsu-ly-layout-container-of-root>\r\n </div>\r\n <div [fdLayoutGridCol]=\"1\"></div>\r\n</fd-layout-grid>\r\n} @else {\r\n<fd-dynamic-side-content [size]=\"(size$ | async)!!\">\r\n <fd-dynamic-side-content-side>\r\n <bsu-ly-layout-container-of-root\r\n [config]=\"layout94$ | async\"\r\n [isPanel]=\"false\"\r\n [isRoot]=\"true\"\r\n ></bsu-ly-layout-container-of-root>\r\n </fd-dynamic-side-content-side>\r\n <fd-dynamic-side-content-main>\r\n <!-- <ng-container *ngIf=\"'\u0639\u06A9\u0633 \u067E\u0633 \u0632\u0645\u06CC\u0646\u0647' | controlUi: layout94 as layoutConfig\">\r\n <bsu-layout-control\r\n [caption]=\"'\u0639\u06A9\u0633 \u067E\u0633 \u0632\u0645\u06CC\u0646\u0647'\"\r\n [config]=\"layoutConfig\"\r\n [showLabel]=\"false\"\r\n [inlineEdit]=\"true\"\r\n ></bsu-layout-control>\r\n </ng-container> -->\r\n @if ('\u0639\u06A9\u0633 \u067E\u0633 \u0632\u0645\u06CC\u0646\u0647' | controlUi: layout94; as layoutConfig) {\r\n <div\r\n id=\"bgLogin\"\r\n [style.backgroundImage]=\"\r\n 'url(' +\r\n (mo.Background?.FileId | picFieldSrc: 'PictureFileInfo':null:layoutConfig.FieldUi.Setting.FieldDefId) +\r\n ')'\r\n \"\r\n ></div>\r\n }\r\n </fd-dynamic-side-content-main>\r\n</fd-dynamic-side-content>\r\n} }\r\n", styles: ["@charset \"UTF-8\";:host{display:block;background-color:#fff}:host ::ng-deep bsu-ly-simple-label{text-align:center}:host ::ng-deep bsu-ly-simple-label:nth-of-type(1){margin-top:15px}:host ::ng-deep bsu-ui-picture-file{text-align:center}:host ::ng-deep .wrap-content>.container-field{max-width:100%!important}fd-dynamic-side-content{min-height:100vh}fd-dynamic-side-content-side{box-shadow:0 3px 5px -1px #0003,0 6px 10px #00000024,0 1px 18px #0000001f}bsu-ly-layout-container-of-root{padding:0 1rem;box-sizing:border-box;display:flex;align-items:center;height:100%}#bgLogin{width:100%;height:100%;background-position:center;background-size:cover;background-repeat:no-repeat}@media (max-width: 599px){:host ::ng-deep bsu-layout-control{min-width:auto!important}:host ::ng-deep bsu-ly-layout-container-of-root{padding:0}}@media (max-height: 670px){:host.desktopmode bsu-ly-layout-container-of-root{padding:0}:host.desktopmode bsu-ly-layout-container-of-root ::ng-deep bsu-ly-empty-space{display:none}:host.desktopmode bsu-ly-layout-container-of-root ::ng-deep bsu-layout-control[caption=\\644\\648\\6af\\648]{display:none}}fd-layout-grid.mobile{overflow:auto;height:100vh}\n"] }]
|
|
48
|
+
}], propDecorators: { _desktopmode: [{
|
|
49
|
+
type: HostBinding,
|
|
50
|
+
args: ['class.desktopmode']
|
|
51
|
+
}], onKeyEnter: [{
|
|
52
|
+
type: HostListener,
|
|
53
|
+
args: ['keydown.enter', ['$event']]
|
|
54
|
+
}] } });
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1kZXZlbG9wLWNvbXBvbmVudHMvc3JjL2xpYi9sb2dpbi1mb3JtL2xvZ2luLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvbG9naW4tZm9ybS9sb2dpbi1mb3JtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV0RyxPQUFPLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7OztBQVV4RyxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsaUJBQWlCO0lBUnpEOztRQVNzQyxpQkFBWSxHQUFHLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUV0RSxlQUFVLEdBQUcsQ0FBQyxDQUFDLEVBQVEsRUFBRTtZQUNyQixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3pFLElBQUksVUFBVSxFQUFFLENBQUM7Z0JBQ2IsVUFBVSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM5RCxDQUFDO1FBQ0wsQ0FBQyxDQUFDO0tBMEJMO0lBdkJHLFFBQVE7UUFDSixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQ3BGLFFBQVEsQ0FBQyxFQUFFLENBQUMsdUJBQXVCLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3hELENBQUMsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUN0QyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNyRCxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUNsQyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUM3QixDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUM3QyxHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtZQUNmLFFBQVEsVUFBVSxFQUFFLENBQUM7Z0JBQ2pCLEtBQUssR0FBRztvQkFDSixPQUFPLElBQUksQ0FBQztnQkFDaEIsS0FBSyxHQUFHO29CQUNKLE9BQU8sSUFBSSxDQUFDO2dCQUNoQjtvQkFDSSxPQUFPLElBQUksQ0FBQztZQUNwQixDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQ0wsQ0FBQztJQUNOLENBQUM7K0dBakNRLGtCQUFrQjttR0FBbEIsa0JBQWtCLG1LQUhoQixDQUFDLGdCQUFnQixDQUFDLGlEQ1ZqQyx5NERBOENBOzs0RkRqQ2Esa0JBQWtCO2tCQVI5QixTQUFTOytCQUNJLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDLENBQUMsZ0JBQWdCLENBQUMsY0FDakIsS0FBSzs4QkFHaUIsWUFBWTtzQkFBN0MsV0FBVzt1QkFBQyxtQkFBbUI7Z0JBRWhDLFVBQVU7c0JBRFQsWUFBWTt1QkFBQyxlQUFlLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSG9zdExpc3RlbmVyLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBtYXAsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgQmFyc2FBcGksIEZvcm1CYXNlQ29tcG9uZW50LCBGb3JtUGFuZWxTZXJ2aWNlLCBnZXREZXZpY2VJc01vYmlsZSB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdiZGMtbG9naW4tZm9ybScsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vbG9naW4tZm9ybS5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9sb2dpbi1mb3JtLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHByb3ZpZGVyczogW0Zvcm1QYW5lbFNlcnZpY2VdLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIExvZ2luRm9ybUNvbXBvbmVudCBleHRlbmRzIEZvcm1CYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuZGVza3RvcG1vZGUnKSBfZGVza3RvcG1vZGUgPSAhZ2V0RGV2aWNlSXNNb2JpbGUoKTtcclxuICAgIEBIb3N0TGlzdGVuZXIoJ2tleWRvd24uZW50ZXInLCBbJyRldmVudCddKVxyXG4gICAgb25LZXlFbnRlciA9IChfKTogdm9pZCA9PiB7XHJcbiAgICAgICAgY29uc3QgbGF5b3V0SXRlbSA9IHRoaXMuX2NvbnRyb2xVaVBpcGUudHJhbnNmb3JtKCcg2YjYsdmI2K8nLCB0aGlzLmxheW91dDk0KTtcclxuICAgICAgICBpZiAobGF5b3V0SXRlbSkge1xyXG4gICAgICAgICAgICBsYXlvdXRJdGVtLkZpZWxkVWkuZmlyZUV2ZW50KCdjbGljaycsIGxheW91dEl0ZW0uRmllbGRVaSk7XHJcbiAgICAgICAgfVxyXG4gICAgfTtcclxuICAgIHNpemUkOiBPYnNlcnZhYmxlPCd4bCcgfCAnbWQnIHwgJ3NtJz47XHJcblxyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5fYWN0aXZhdGVkUm91dGUucXVlcnlQYXJhbXMucGlwZSh0YWtlVW50aWwodGhpcy5fb25EZXN0cm95JCkpLnN1YnNjcmliZSgocGFyYW1zKSA9PiB7XHJcbiAgICAgICAgICAgIEJhcnNhQXBpLkJ3LlNldEN1bHR1cmVCeURpc3BsYXlOYW1lKHBhcmFtcy5jdWx0dXJlKTtcclxuICAgICAgICB9KTtcclxuICAgICAgICBjb25zdCByb290ID0gZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50O1xyXG4gICAgICAgIHJvb3Quc3R5bGUuc2V0UHJvcGVydHkoJy0tYWJzb2x1dGUtcGFnZS10b3AnLCAnMHB4Jyk7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgICAgICB0aGlzLmxheW91dDk0JC5zdWJzY3JpYmUoKGxheW91dDk0KSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMubGF5b3V0OTQgPSBsYXlvdXQ5NDtcclxuICAgICAgICB9KTtcclxuICAgICAgICB0aGlzLnNpemUkID0gdGhpcy5fcG9ydGFsU2VydmljZS5kZXZpY2VTaXplJC5waXBlKFxyXG4gICAgICAgICAgICBtYXAoKGRldmljZVNpemUpID0+IHtcclxuICAgICAgICAgICAgICAgIHN3aXRjaCAoZGV2aWNlU2l6ZSkge1xyXG4gICAgICAgICAgICAgICAgICAgIGNhc2UgJ3MnOlxyXG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gJ3NtJztcclxuICAgICAgICAgICAgICAgICAgICBjYXNlICdtJzpcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuICdtZCc7XHJcbiAgICAgICAgICAgICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuICd4bCc7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0pXHJcbiAgICAgICAgKTtcclxuICAgIH1cclxufVxyXG4iLCJAaWYgKG1vJCB8IGFzeW5jOyBhcyBtbykgeyBAaWYgKG1vLklzTG9nZ2luZykge1xyXG48YnN1LW1hc2s+PC9ic3UtbWFzaz5cclxufSBAaWYgKChzaXplJCB8IGFzeW5jKSA9PT0gJ3NtJykge1xyXG48ZmQtbGF5b3V0LWdyaWQgW2NsYXNzLm1vYmlsZV09XCJpc01vYmlsZVwiPlxyXG4gICAgPGRpdiBbZmRMYXlvdXRHcmlkQ29sXT1cIjFcIj48L2Rpdj5cclxuICAgIDxkaXYgW2ZkTGF5b3V0R3JpZENvbF09XCIxMFwiPlxyXG4gICAgICAgIDxic3UtbHktbGF5b3V0LWNvbnRhaW5lci1vZi1yb290XHJcbiAgICAgICAgICAgIFtjb25maWddPVwibGF5b3V0OTQkIHwgYXN5bmNcIlxyXG4gICAgICAgICAgICBbaXNQYW5lbF09XCJmYWxzZVwiXHJcbiAgICAgICAgICAgIFtpc1Jvb3RdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgIFtjbGFzcy5kZXNrdG9wTW9kZV09XCIhKGlzTW9iaWxlID09PSB0cnVlKVwiXHJcbiAgICAgICAgPjwvYnN1LWx5LWxheW91dC1jb250YWluZXItb2Ytcm9vdD5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBbZmRMYXlvdXRHcmlkQ29sXT1cIjFcIj48L2Rpdj5cclxuPC9mZC1sYXlvdXQtZ3JpZD5cclxufSBAZWxzZSB7XHJcbjxmZC1keW5hbWljLXNpZGUtY29udGVudCBbc2l6ZV09XCIoc2l6ZSQgfCBhc3luYykhIVwiPlxyXG4gICAgPGZkLWR5bmFtaWMtc2lkZS1jb250ZW50LXNpZGU+XHJcbiAgICAgICAgPGJzdS1seS1sYXlvdXQtY29udGFpbmVyLW9mLXJvb3RcclxuICAgICAgICAgICAgW2NvbmZpZ109XCJsYXlvdXQ5NCQgfCBhc3luY1wiXHJcbiAgICAgICAgICAgIFtpc1BhbmVsXT1cImZhbHNlXCJcclxuICAgICAgICAgICAgW2lzUm9vdF09XCJ0cnVlXCJcclxuICAgICAgICA+PC9ic3UtbHktbGF5b3V0LWNvbnRhaW5lci1vZi1yb290PlxyXG4gICAgPC9mZC1keW5hbWljLXNpZGUtY29udGVudC1zaWRlPlxyXG4gICAgPGZkLWR5bmFtaWMtc2lkZS1jb250ZW50LW1haW4+XHJcbiAgICAgICAgPCEtLSA8bmctY29udGFpbmVyICpuZ0lmPVwiJ9i52qnYsyDZvtizINiy2YXbjNmG2YcnIHwgY29udHJvbFVpOiBsYXlvdXQ5NCBhcyBsYXlvdXRDb25maWdcIj5cclxuICAgICAgICA8YnN1LWxheW91dC1jb250cm9sXHJcbiAgICAgICAgICBbY2FwdGlvbl09XCIn2LnaqdizINm+2LMg2LLZhduM2YbZhydcIlxyXG4gICAgICAgICAgW2NvbmZpZ109XCJsYXlvdXRDb25maWdcIlxyXG4gICAgICAgICAgW3Nob3dMYWJlbF09XCJmYWxzZVwiXHJcbiAgICAgICAgICBbaW5saW5lRWRpdF09XCJ0cnVlXCJcclxuICAgICAgICA+PC9ic3UtbGF5b3V0LWNvbnRyb2w+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPiAtLT5cclxuICAgICAgICBAaWYgKCfYudqp2LMg2b7YsyDYstmF24zZhtmHJyB8IGNvbnRyb2xVaTogbGF5b3V0OTQ7IGFzIGxheW91dENvbmZpZykge1xyXG4gICAgICAgIDxkaXZcclxuICAgICAgICAgICAgaWQ9XCJiZ0xvZ2luXCJcclxuICAgICAgICAgICAgW3N0eWxlLmJhY2tncm91bmRJbWFnZV09XCJcclxuICAgICAgICAgICAgICAgICd1cmwoJyArXHJcbiAgICAgICAgICAgICAgICAobW8uQmFja2dyb3VuZD8uRmlsZUlkIHwgcGljRmllbGRTcmM6ICdQaWN0dXJlRmlsZUluZm8nOm51bGw6bGF5b3V0Q29uZmlnLkZpZWxkVWkuU2V0dGluZy5GaWVsZERlZklkKSArXHJcbiAgICAgICAgICAgICAgICAnKSdcclxuICAgICAgICAgICAgXCJcclxuICAgICAgICA+PC9kaXY+XHJcbiAgICAgICAgfVxyXG4gICAgPC9mZC1keW5hbWljLXNpZGUtY29udGVudC1tYWluPlxyXG48L2ZkLWR5bmFtaWMtc2lkZS1jb250ZW50PlxyXG59IH1cclxuIl19
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding } from '@angular/core';
|
|
2
|
+
import { ReportBaseComponent, BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "barsa-novin-ray-core";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/button";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
export class LoginSocialConncetionsComponent extends ReportBaseComponent {
|
|
8
|
+
constructor(_ulvMainService, _portalService, reportValuePipe) {
|
|
9
|
+
super(_portalService, _ulvMainService);
|
|
10
|
+
this._ulvMainService = _ulvMainService;
|
|
11
|
+
this._portalService = _portalService;
|
|
12
|
+
this.reportValuePipe = reportValuePipe;
|
|
13
|
+
this.rtl = BarsaApi.LoginFormData.IsRtl;
|
|
14
|
+
}
|
|
15
|
+
onClick(mo) {
|
|
16
|
+
const provider = this.reportValuePipe.transform('Name', mo, this.allColumns, true);
|
|
17
|
+
const returnUrl = encodeURIComponent(window.location.href);
|
|
18
|
+
BarsaApi.Bw.NavigateTo(`/api/openId/signin?provider=${provider}&returnUrl=${returnUrl}`);
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginSocialConncetionsComponent, deps: [{ token: i1.UlvMainService }, { token: i1.PortalService }, { token: i1.MoReportValuePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
21
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LoginSocialConncetionsComponent, selector: "bdc-login-social-conncetions", host: { properties: { "attr.rtl": "this.rtl" } }, usesInheritance: true, ngImport: i0, template: "@for (mo of moDataList$ | async; track mo) {\r\n<button\r\n fd-button\r\n [label]=\"'Display Text' | rval: mo:allColumns\"\r\n [fdType]=\"'FdType' | rval: mo:allColumns:true\"\r\n (click)=\"onClick(mo)\"\r\n>\r\n <img\r\n style=\"max-width: 28px\"\r\n [src]=\"('Logo' | rval: mo:allColumns)?.FileId | picFieldSrc: 'GetPictureFromFileInfo':null\"\r\n />\r\n</button>\r\n}\r\n", styles: [":host{display:flex;flex-wrap:wrap;width:100%;justify-content:stretch;margin-top:1rem;column-gap:5px;row-gap:5px}button{flex-grow:1;flex-direction:row-reverse}button img{padding:5px}fd-toolbar{width:100%}\n"], dependencies: [{ kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.MoReportValuePipe, name: "rval" }, { kind: "pipe", type: i1.PictureFieldSourcePipe, name: "picFieldSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginSocialConncetionsComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'bdc-login-social-conncetions', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "@for (mo of moDataList$ | async; track mo) {\r\n<button\r\n fd-button\r\n [label]=\"'Display Text' | rval: mo:allColumns\"\r\n [fdType]=\"'FdType' | rval: mo:allColumns:true\"\r\n (click)=\"onClick(mo)\"\r\n>\r\n <img\r\n style=\"max-width: 28px\"\r\n [src]=\"('Logo' | rval: mo:allColumns)?.FileId | picFieldSrc: 'GetPictureFromFileInfo':null\"\r\n />\r\n</button>\r\n}\r\n", styles: [":host{display:flex;flex-wrap:wrap;width:100%;justify-content:stretch;margin-top:1rem;column-gap:5px;row-gap:5px}button{flex-grow:1;flex-direction:row-reverse}button img{padding:5px}fd-toolbar{width:100%}\n"] }]
|
|
26
|
+
}], ctorParameters: () => [{ type: i1.UlvMainService }, { type: i1.PortalService }, { type: i1.MoReportValuePipe }], propDecorators: { rtl: [{
|
|
27
|
+
type: HostBinding,
|
|
28
|
+
args: ['attr.rtl']
|
|
29
|
+
}] } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tc29jaWFsLWNvbm5jZXRpb25zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWRldmVsb3AtY29tcG9uZW50cy9zcmMvbGliL2xvZ2luLXNvY2lhbC1jb25uY2V0aW9ucy9sb2dpbi1zb2NpYWwtY29ubmNldGlvbnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvbG9naW4tc29jaWFsLWNvbm5jZXRpb25zL2xvZ2luLXNvY2lhbC1jb25uY2V0aW9ucy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVoRixPQUFPLEVBQ0gsbUJBQW1CLEVBQ25CLFFBQVEsRUFLWCxNQUFNLHNCQUFzQixDQUFDOzs7OztBQVE5QixNQUFNLE9BQU8sK0JBQWdDLFNBQVEsbUJBQW1CO0lBRXBFLFlBQ2MsZUFBK0IsRUFDL0IsY0FBNkIsRUFDL0IsZUFBa0M7UUFFMUMsS0FBSyxDQUFDLGNBQWMsRUFBRSxlQUFlLENBQUMsQ0FBQztRQUo3QixvQkFBZSxHQUFmLGVBQWUsQ0FBZ0I7UUFDL0IsbUJBQWMsR0FBZCxjQUFjLENBQWU7UUFDL0Isb0JBQWUsR0FBZixlQUFlLENBQW1CO1FBSnJCLFFBQUcsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQztJQU81RCxDQUFDO0lBQ0QsT0FBTyxDQUFDLEVBQXVCO1FBQzNCLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVuRixNQUFNLFNBQVMsR0FBRyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNELFFBQVEsQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLCtCQUErQixRQUFRLGNBQWMsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUM3RixDQUFDOytHQWRRLCtCQUErQjttR0FBL0IsK0JBQStCLDZJQ2pCNUMsd1pBYUE7OzRGRElhLCtCQUErQjtrQkFQM0MsU0FBUzsrQkFDSSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsS0FBSzsrSUFHUSxHQUFHO3NCQUEzQixXQUFXO3VCQUFDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHtcclxuICAgIFJlcG9ydEJhc2VDb21wb25lbnQsXHJcbiAgICBCYXJzYUFwaSxcclxuICAgIFVsdk1haW5TZXJ2aWNlLFxyXG4gICAgTW9SZXBvcnRWYWx1ZVBpcGUsXHJcbiAgICBNZXRhb2JqZWN0RGF0YU1vZGVsLFxyXG4gICAgUG9ydGFsU2VydmljZVxyXG59IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JkYy1sb2dpbi1zb2NpYWwtY29ubmNldGlvbnMnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2xvZ2luLXNvY2lhbC1jb25uY2V0aW9ucy5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9sb2dpbi1zb2NpYWwtY29ubmNldGlvbnMuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIExvZ2luU29jaWFsQ29ubmNldGlvbnNDb21wb25lbnQgZXh0ZW5kcyBSZXBvcnRCYXNlQ29tcG9uZW50IHtcclxuICAgIEBIb3N0QmluZGluZygnYXR0ci5ydGwnKSBydGwgPSBCYXJzYUFwaS5Mb2dpbkZvcm1EYXRhLklzUnRsO1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHJvdGVjdGVkIF91bHZNYWluU2VydmljZTogVWx2TWFpblNlcnZpY2UsXHJcbiAgICAgICAgcHJvdGVjdGVkIF9wb3J0YWxTZXJ2aWNlOiBQb3J0YWxTZXJ2aWNlLFxyXG4gICAgICAgIHByaXZhdGUgcmVwb3J0VmFsdWVQaXBlOiBNb1JlcG9ydFZhbHVlUGlwZVxyXG4gICAgKSB7XHJcbiAgICAgICAgc3VwZXIoX3BvcnRhbFNlcnZpY2UsIF91bHZNYWluU2VydmljZSk7XHJcbiAgICB9XHJcbiAgICBvbkNsaWNrKG1vOiBNZXRhb2JqZWN0RGF0YU1vZGVsKTogdm9pZCB7XHJcbiAgICAgICAgY29uc3QgcHJvdmlkZXIgPSB0aGlzLnJlcG9ydFZhbHVlUGlwZS50cmFuc2Zvcm0oJ05hbWUnLCBtbywgdGhpcy5hbGxDb2x1bW5zLCB0cnVlKTtcclxuXHJcbiAgICAgICAgY29uc3QgcmV0dXJuVXJsID0gZW5jb2RlVVJJQ29tcG9uZW50KHdpbmRvdy5sb2NhdGlvbi5ocmVmKTtcclxuICAgICAgICBCYXJzYUFwaS5Cdy5OYXZpZ2F0ZVRvKGAvYXBpL29wZW5JZC9zaWduaW4/cHJvdmlkZXI9JHtwcm92aWRlcn0mcmV0dXJuVXJsPSR7cmV0dXJuVXJsfWApO1xyXG4gICAgfVxyXG59XHJcbiIsIkBmb3IgKG1vIG9mIG1vRGF0YUxpc3QkIHwgYXN5bmM7IHRyYWNrIG1vKSB7XHJcbjxidXR0b25cclxuICAgIGZkLWJ1dHRvblxyXG4gICAgW2xhYmVsXT1cIidEaXNwbGF5IFRleHQnIHwgcnZhbDogbW86YWxsQ29sdW1uc1wiXHJcbiAgICBbZmRUeXBlXT1cIidGZFR5cGUnIHwgcnZhbDogbW86YWxsQ29sdW1uczp0cnVlXCJcclxuICAgIChjbGljayk9XCJvbkNsaWNrKG1vKVwiXHJcbj5cclxuICAgIDxpbWdcclxuICAgICAgICBzdHlsZT1cIm1heC13aWR0aDogMjhweFwiXHJcbiAgICAgICAgW3NyY109XCIoJ0xvZ28nIHwgcnZhbDogbW86YWxsQ29sdW1ucyk/LkZpbGVJZCB8IHBpY0ZpZWxkU3JjOiAnR2V0UGljdHVyZUZyb21GaWxlSW5mbyc6bnVsbFwiXHJcbiAgICAvPlxyXG48L2J1dHRvbj5cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { FormPropsBaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "barsa-sap-ui";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/card";
|
|
6
|
+
export class MasterDetailCardFormComponent extends FormPropsBaseComponent {
|
|
7
|
+
ngOnInit() {
|
|
8
|
+
super.ngOnInit();
|
|
9
|
+
}
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MasterDetailCardFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MasterDetailCardFormComponent, selector: "bdc-master-detail-card-form", usesInheritance: true, ngImport: i0, template: "<fd-card class=\"master-tab\">\r\n <bsu-ly-tab-page [config]=\"modernTabs[0]\"></bsu-ly-tab-page>\r\n</fd-card>\r\n<fd-card class=\"details-tab\">\r\n <bsu-ly-tab-page [config]=\"modernTabs[1]\"></bsu-ly-tab-page>\r\n</fd-card>\r\n", styles: [":host{display:flex;width:100%;height:100%;column-gap:.525rem}fd-card.master-tab,fd-card.details-tab{height:100%}.master-tab{max-width:400px}.details-tab{width:100%}\n"], dependencies: [{ kind: "component", type: i1.LyTabPageComponent, selector: "bsu-ly-tab-page", inputs: ["renderItems", "tablist"] }, { kind: "component", type: i2.CardComponent, selector: "fd-card", inputs: ["badge", "badgeIcon", "badgeColor", "badgeColorSecondary", "badgeStatus", "badgeAriaLabel", "secondBadge", "secondBadgeIcon", "secondBadgeColor", "secondBadgeColorSecondary", "secondBadgeStatus", "secondBadgeAriaLabel", "isLoading", "cardType", "id", "ariaRoledescription", "ariaDescription", "ariaLabel", "role", "interactive", "selected", "ariaPosinset", "ariaSetsize"], outputs: ["ariaPosinsetChange", "ariaSetsizeChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MasterDetailCardFormComponent, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ selector: 'bdc-master-detail-card-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-card class=\"master-tab\">\r\n <bsu-ly-tab-page [config]=\"modernTabs[0]\"></bsu-ly-tab-page>\r\n</fd-card>\r\n<fd-card class=\"details-tab\">\r\n <bsu-ly-tab-page [config]=\"modernTabs[1]\"></bsu-ly-tab-page>\r\n</fd-card>\r\n", styles: [":host{display:flex;width:100%;height:100%;column-gap:.525rem}fd-card.master-tab,fd-card.details-tab{height:100%}.master-tab{max-width:400px}.details-tab{width:100%}\n"] }]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFzdGVyLWRldGFpbC1jYXJkLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0vbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0vbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7OztBQVM5RCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsc0JBQXNCO0lBQ3JFLFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDckIsQ0FBQzsrR0FIUSw2QkFBNkI7bUdBQTdCLDZCQUE2QiwwRkNWMUMsK09BTUE7OzRGRElhLDZCQUE2QjtrQkFQekMsU0FBUzsrQkFDSSw2QkFBNkIsbUJBR3RCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtUHJvcHNCYXNlQ29tcG9uZW50IH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JkYy1tYXN0ZXItZGV0YWlsLWNhcmQtZm9ybScsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vbWFzdGVyLWRldGFpbC1jYXJkLWZvcm0uY29tcG9uZW50LmNzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgICBzdGFuZGFsb25lOiBmYWxzZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTWFzdGVyRGV0YWlsQ2FyZEZvcm1Db21wb25lbnQgZXh0ZW5kcyBGb3JtUHJvcHNCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICB9XHJcbn1cclxuIiwiPGZkLWNhcmQgY2xhc3M9XCJtYXN0ZXItdGFiXCI+XHJcbiAgICA8YnN1LWx5LXRhYi1wYWdlIFtjb25maWddPVwibW9kZXJuVGFic1swXVwiPjwvYnN1LWx5LXRhYi1wYWdlPlxyXG48L2ZkLWNhcmQ+XHJcbjxmZC1jYXJkIGNsYXNzPVwiZGV0YWlscy10YWJcIj5cclxuICAgIDxic3UtbHktdGFiLXBhZ2UgW2NvbmZpZ109XCJtb2Rlcm5UYWJzWzFdXCI+PC9ic3UtbHktdGFiLXBhZ2U+XHJcbjwvZmQtY2FyZD5cclxuIl19
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, TemplateRef, ViewChild } from '@angular/core';
|
|
2
|
+
import { AudioRecordingService, BarsaApi, UploadService, VideoRecordingService } from 'barsa-novin-ray-core';
|
|
3
|
+
import { UiPdfViewerComponent } from 'barsa-sap-ui';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@fundamental-ngx/core/button";
|
|
7
|
+
import * as i3 from "@fundamental-ngx/core/card";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/nested-list";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/progress-indicator";
|
|
10
|
+
import * as i6 from "barsa-novin-ray-core";
|
|
11
|
+
export class MediaFileUploaderComponent extends UiPdfViewerComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
super(...arguments);
|
|
14
|
+
this.isPlaying = false;
|
|
15
|
+
this.displayControls = true;
|
|
16
|
+
this.isRecording = false;
|
|
17
|
+
this.audioConf = { audio: true };
|
|
18
|
+
this.videoConf = { video: { facingMode: 'user', width: 320 }, audio: true };
|
|
19
|
+
this.recordType = 'audio';
|
|
20
|
+
}
|
|
21
|
+
get video() {
|
|
22
|
+
return this.videoElement?.nativeElement;
|
|
23
|
+
}
|
|
24
|
+
get fileInput() {
|
|
25
|
+
return this.photoElement?.nativeElement;
|
|
26
|
+
}
|
|
27
|
+
ngOnInit() {
|
|
28
|
+
super.ngOnInit();
|
|
29
|
+
this._videoRecoder.recordingFailed().subscribe(() => {
|
|
30
|
+
this.isRecording = false;
|
|
31
|
+
this._cdr.detectChanges();
|
|
32
|
+
});
|
|
33
|
+
this._videoRecoder.getRecordedTime().subscribe((time) => {
|
|
34
|
+
this.recordedTime = time;
|
|
35
|
+
this._cdr.detectChanges();
|
|
36
|
+
});
|
|
37
|
+
this._videoRecoder.getStream().subscribe((stream) => {
|
|
38
|
+
this.videoStream = stream;
|
|
39
|
+
this._cdr.detectChanges();
|
|
40
|
+
});
|
|
41
|
+
this._videoRecoder.getRecordedBlob().subscribe((data) => {
|
|
42
|
+
this.fileBlob = data.blob;
|
|
43
|
+
this.fileName = data.title;
|
|
44
|
+
this.valueUrl = this._domSanitizer.bypassSecurityTrustUrl(data.url);
|
|
45
|
+
this._cdr.detectChanges();
|
|
46
|
+
});
|
|
47
|
+
this._audioRecorder.recordingFailed().subscribe(() => {
|
|
48
|
+
this.isRecording = false;
|
|
49
|
+
this._cdr.detectChanges();
|
|
50
|
+
});
|
|
51
|
+
this._audioRecorder.getRecordedTime().subscribe((time) => {
|
|
52
|
+
this.recordedTime = time;
|
|
53
|
+
this._cdr.detectChanges();
|
|
54
|
+
});
|
|
55
|
+
this._audioRecorder.getRecordedBlob().subscribe((data) => {
|
|
56
|
+
this.fileBlob = data.blob;
|
|
57
|
+
this.fileName = data.title;
|
|
58
|
+
this.valueUrl = this._domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(data.blob));
|
|
59
|
+
this._cdr.detectChanges();
|
|
60
|
+
});
|
|
61
|
+
let glyph = '';
|
|
62
|
+
switch (this.recordType) {
|
|
63
|
+
case 'audio':
|
|
64
|
+
glyph = 'attachment-audio';
|
|
65
|
+
break;
|
|
66
|
+
case 'video':
|
|
67
|
+
glyph = 'attachment-video';
|
|
68
|
+
break;
|
|
69
|
+
default:
|
|
70
|
+
glyph = 'attachment-photo';
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
this.glyph = glyph;
|
|
74
|
+
this.fileName = this.value?.FileName;
|
|
75
|
+
this.recordType = this.parameters?.MediaType$Caption || 'audio';
|
|
76
|
+
}
|
|
77
|
+
onDelete() {
|
|
78
|
+
super.onDelete();
|
|
79
|
+
this.onClearRecord();
|
|
80
|
+
}
|
|
81
|
+
onClearRecord() {
|
|
82
|
+
this.abortVideoRecording();
|
|
83
|
+
this.abortAudioRecording();
|
|
84
|
+
this.fileBlob = null;
|
|
85
|
+
this.valueUrl = null;
|
|
86
|
+
this._cdr.detectChanges();
|
|
87
|
+
}
|
|
88
|
+
onToggleRecord() {
|
|
89
|
+
if (this.recordType === 'audio') {
|
|
90
|
+
if (this.isRecording) {
|
|
91
|
+
this.stopAudioRecording();
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.startAudioRecording();
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
else if (this.recordType === 'video') {
|
|
98
|
+
this.video.hidden = false;
|
|
99
|
+
if (this.isRecording) {
|
|
100
|
+
this.stopVideoRecording();
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
this.startVideoRecording();
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
else if (this.recordType === 'photo') {
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
onTakePhoto() {
|
|
110
|
+
if (this.fileInput?.files?.length) {
|
|
111
|
+
const file = this.fileInput.files.item(0);
|
|
112
|
+
if (file) {
|
|
113
|
+
this.fileName = file.name;
|
|
114
|
+
this._uploadFile([file]).subscribe();
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
onUpload() {
|
|
119
|
+
const videoFile = new File([this.fileBlob], this.fileName);
|
|
120
|
+
this._uploadFile([videoFile]).subscribe();
|
|
121
|
+
}
|
|
122
|
+
startVideoRecording() {
|
|
123
|
+
if (!this.isRecording) {
|
|
124
|
+
this.video.controls = false;
|
|
125
|
+
this.isRecording = true;
|
|
126
|
+
this._videoRecoder
|
|
127
|
+
.startRecording(this.videoConf)
|
|
128
|
+
.then((stream) => {
|
|
129
|
+
// this.video.src = window.URL.createObjectURL(stream);
|
|
130
|
+
this.video.srcObject = stream;
|
|
131
|
+
this.video.play();
|
|
132
|
+
})
|
|
133
|
+
.catch(function (err) {
|
|
134
|
+
console.log(err.name + ': ' + err.message);
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
abortVideoRecording() {
|
|
139
|
+
if (this.isRecording && this.recordType === 'video') {
|
|
140
|
+
this.isRecording = false;
|
|
141
|
+
this._videoRecoder.abortRecording();
|
|
142
|
+
}
|
|
143
|
+
if (this.video) {
|
|
144
|
+
const video = this.video;
|
|
145
|
+
video.controls = false;
|
|
146
|
+
video.hidden = true;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
stopVideoRecording() {
|
|
150
|
+
if (this.isRecording && this.recordType === 'video') {
|
|
151
|
+
this._videoRecoder.stopRecording();
|
|
152
|
+
const video = this.video;
|
|
153
|
+
video.srcObject = this.valueUrl;
|
|
154
|
+
video.controls = true;
|
|
155
|
+
this.isRecording = false;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
clearVideoRecordedData() {
|
|
159
|
+
this.valueUrl = null;
|
|
160
|
+
const video = this.video;
|
|
161
|
+
video.srcObject = null;
|
|
162
|
+
video.controls = false;
|
|
163
|
+
this._cdr.detectChanges();
|
|
164
|
+
}
|
|
165
|
+
downloadVideoRecordedData() {
|
|
166
|
+
this._downloadFile(this.fileBlob, 'video/mp4', this.fileName);
|
|
167
|
+
}
|
|
168
|
+
startAudioRecording() {
|
|
169
|
+
if (!this.isRecording) {
|
|
170
|
+
this.isRecording = true;
|
|
171
|
+
this._audioRecorder.startRecording();
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
abortAudioRecording() {
|
|
175
|
+
if (this.isRecording && this.recordType === 'audio') {
|
|
176
|
+
this.isRecording = false;
|
|
177
|
+
this._audioRecorder.abortRecording();
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
stopAudioRecording() {
|
|
181
|
+
if (this.isRecording && this.recordType === 'audio') {
|
|
182
|
+
this._audioRecorder.stopRecording();
|
|
183
|
+
this.isRecording = false;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
clearAudioRecordedData() {
|
|
187
|
+
this.valueUrl = null;
|
|
188
|
+
}
|
|
189
|
+
downloadAudioRecordedData() {
|
|
190
|
+
this._downloadFile(this.fileBlob, 'audio/mp3', this.fileName);
|
|
191
|
+
}
|
|
192
|
+
ngOnDestroy() {
|
|
193
|
+
this.abortAudioRecording();
|
|
194
|
+
}
|
|
195
|
+
_downloadFile(data, type, filename) {
|
|
196
|
+
const blob = new Blob([data], { type });
|
|
197
|
+
const url = window.URL.createObjectURL(blob);
|
|
198
|
+
// this.video.srcObject = stream;
|
|
199
|
+
// const url = data;
|
|
200
|
+
const anchor = document.createElement('a');
|
|
201
|
+
anchor.download = filename;
|
|
202
|
+
anchor.href = url;
|
|
203
|
+
document.body.appendChild(anchor);
|
|
204
|
+
anchor.click();
|
|
205
|
+
document.body.removeChild(anchor);
|
|
206
|
+
}
|
|
207
|
+
_downloadFileIdCompleted(response) {
|
|
208
|
+
super._downloadFileIdCompleted(response);
|
|
209
|
+
if (this.valueUrl) {
|
|
210
|
+
if (this.recordType === 'video') {
|
|
211
|
+
this.video.controls = true;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
_refresh(_) {
|
|
216
|
+
if (BarsaApi.Ext.isEmpty(this.value)) {
|
|
217
|
+
return;
|
|
218
|
+
}
|
|
219
|
+
const fileId = this.value.Id;
|
|
220
|
+
this.DownloadFileId(fileId, true, '', null, false);
|
|
221
|
+
}
|
|
222
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MediaFileUploaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
223
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MediaFileUploaderComponent, selector: "bdc-media-file-uploader", providers: [AudioRecordingService, VideoRecordingService, UploadService], viewQueries: [{ propertyName: "videoElement", first: true, predicate: ["videoElement"], descendants: true }, { propertyName: "photoElement", first: true, predicate: ["photoElement"], descendants: true }, { propertyName: "dialogContainer", first: true, predicate: ["container"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<fd-card class=\"upload\" [ngClass]=\"recordType\">\r\n <fd-card-content class=\"file-content\">\r\n <div [class.no-recording]=\"!isRecording && valueUrl\" [ngClass]=\"recordType\" class=\"media-wrapper\">\r\n <div class=\"icon\">\r\n @if (!value && !valueUrl && !isRecording) {\r\n <i style=\"left: 45%; position: absolute\" fd-nested-list-icon [glyph]=\"glyph\"></i>\r\n }\r\n </div>\r\n @if (recordType === 'video') {\r\n <video #videoElement [class.video-novalue]=\"!valueUrl\">\r\n @if (!isRecording && valueUrl) {\r\n <source [src]=\"valueUrl\" />\r\n } @if (!value && !valueUrl && !isRecording) {\r\n <i style=\"left: 45%; position: absolute\" fd-nested-list-icon [glyph]=\"glyph\"></i>\r\n }\r\n </video>\r\n } @if (!isRecording && valueUrl && recordType === 'audio') {\r\n <audio controls>\r\n <source [src]=\"valueUrl\" type=\"audio/mp3\" />\r\n </audio>\r\n } @if (recordType === 'photo') {\r\n <input\r\n #photoElement\r\n type=\"file\"\r\n accept=\"image/*\"\r\n id=\"file-input\"\r\n capture=\"environment\"\r\n (change)=\"onTakePhoto()\"\r\n />\r\n }\r\n </div>\r\n @if (isRecording || valueUrl) {\r\n <div class=\"media-info\">\r\n <div>\r\n {{ !isRecording ? '' : ('Recording' | bbbTranslate) }} <strong>{{ recordedTime }}</strong>\r\n </div>\r\n <div>{{ fileName }}</div>\r\n </div>\r\n } @if (uploadingState$ | async; as uploadingState) { @if (uploadingState.state === 'Uploading') {\r\n <div class=\"progress\">\r\n <div>\r\n <fd-progress-indicator\r\n state=\"informative\"\r\n [valueNow]=\"uploadingState?.progress\"\r\n ></fd-progress-indicator>\r\n </div>\r\n </div>\r\n } }\r\n <div class=\"btn-wrapper\">\r\n @if (!value && !valueUrl) {\r\n <button\r\n class=\"btn-record\"\r\n fd-button\r\n [glyph]=\"isRecording ? 'stop' : 'record'\"\r\n [fdType]=\"isRecording ? 'attention' : 'ghost'\"\r\n (click)=\"onToggleRecord()\"\r\n ></button>\r\n } @if (!value && valueUrl) {\r\n <div class=\"btn-toolbar\">\r\n <button fd-button [glyph]=\"'delete'\" fdType=\"negative\" (click)=\"onClearRecord()\"></button>\r\n <button fd-button [label]=\"'Upload' | bbbTranslate\" [glyph]=\"'upload'\" (click)=\"onUpload()\"></button>\r\n </div>\r\n } @if (value) {\r\n <div class=\"btn-toolbar\">\r\n @if (value) {\r\n <button fd-button [glyph]=\"'delete'\" fdType=\"negative\" (click)=\"onDelete()\"></button>\r\n } @if (value) {\r\n <button fd-button [glyph]=\"'download'\" fdType=\"standard\" (click)=\"onDownload()\"></button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </fd-card-content>\r\n</fd-card>\r\n", styles: [":host .upload{display:flex;justify-content:center;align-items:center;flex-direction:column;max-width:380px;position:relative}:host .upload .file-content{width:100%}:host .upload i:before{color:#0a6ed1!important;font-size:2rem}fd-card.audio{min-height:120px;max-height:120px}fd-card.video{min-height:340px;max-height:340px}.icon{display:flex;align-items:center;justify-content:center;position:absolute;top:45%;left:45%}.video-novalue{border:1px dashed var(--sapObjectHeader_BorderColor);min-height:240px}audio,video{width:100%}.progress{position:absolute;width:100%;height:100%;background-color:#e4e4e4c7;z-index:4;display:flex;justify-content:center;align-items:center;top:0;left:0}.progress div{flex:.5}.file-content{width:100%;height:100%;display:flex;flex-direction:column;padding:1rem}.media-wrapper{flex-grow:1}.btn-wrapper{align-self:center}.btn-record{flex-shrink:1}.btn-toolbar{flex-grow:1;display:flex;column-gap:1rem}.media-info{flex-shrink:1;display:flex;width:100%;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i3.CardComponent, selector: "fd-card", inputs: ["badge", "badgeIcon", "badgeColor", "badgeColorSecondary", "badgeStatus", "badgeAriaLabel", "secondBadge", "secondBadgeIcon", "secondBadgeColor", "secondBadgeColorSecondary", "secondBadgeStatus", "secondBadgeAriaLabel", "isLoading", "cardType", "id", "ariaRoledescription", "ariaDescription", "ariaLabel", "role", "interactive", "selected", "ariaPosinset", "ariaSetsize"], outputs: ["ariaPosinsetChange", "ariaSetsizeChange"] }, { kind: "component", type: i3.CardContentComponent, selector: "fd-card-content" }, { kind: "component", type: i4.NestedListIconComponent, selector: "[fdNestedDirectivesIcon], [fd-nested-list-icon]", inputs: ["role"] }, { kind: "component", type: i5.ProgressIndicatorComponent, selector: "fd-progress-indicator", inputs: ["valueText", "unit", "valueMin", "valueMax", "valueNow", "state", "animate"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
224
|
+
}
|
|
225
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MediaFileUploaderComponent, decorators: [{
|
|
226
|
+
type: Component,
|
|
227
|
+
args: [{ selector: 'bdc-media-file-uploader', changeDetection: ChangeDetectionStrategy.OnPush, providers: [AudioRecordingService, VideoRecordingService, UploadService], standalone: false, template: "<fd-card class=\"upload\" [ngClass]=\"recordType\">\r\n <fd-card-content class=\"file-content\">\r\n <div [class.no-recording]=\"!isRecording && valueUrl\" [ngClass]=\"recordType\" class=\"media-wrapper\">\r\n <div class=\"icon\">\r\n @if (!value && !valueUrl && !isRecording) {\r\n <i style=\"left: 45%; position: absolute\" fd-nested-list-icon [glyph]=\"glyph\"></i>\r\n }\r\n </div>\r\n @if (recordType === 'video') {\r\n <video #videoElement [class.video-novalue]=\"!valueUrl\">\r\n @if (!isRecording && valueUrl) {\r\n <source [src]=\"valueUrl\" />\r\n } @if (!value && !valueUrl && !isRecording) {\r\n <i style=\"left: 45%; position: absolute\" fd-nested-list-icon [glyph]=\"glyph\"></i>\r\n }\r\n </video>\r\n } @if (!isRecording && valueUrl && recordType === 'audio') {\r\n <audio controls>\r\n <source [src]=\"valueUrl\" type=\"audio/mp3\" />\r\n </audio>\r\n } @if (recordType === 'photo') {\r\n <input\r\n #photoElement\r\n type=\"file\"\r\n accept=\"image/*\"\r\n id=\"file-input\"\r\n capture=\"environment\"\r\n (change)=\"onTakePhoto()\"\r\n />\r\n }\r\n </div>\r\n @if (isRecording || valueUrl) {\r\n <div class=\"media-info\">\r\n <div>\r\n {{ !isRecording ? '' : ('Recording' | bbbTranslate) }} <strong>{{ recordedTime }}</strong>\r\n </div>\r\n <div>{{ fileName }}</div>\r\n </div>\r\n } @if (uploadingState$ | async; as uploadingState) { @if (uploadingState.state === 'Uploading') {\r\n <div class=\"progress\">\r\n <div>\r\n <fd-progress-indicator\r\n state=\"informative\"\r\n [valueNow]=\"uploadingState?.progress\"\r\n ></fd-progress-indicator>\r\n </div>\r\n </div>\r\n } }\r\n <div class=\"btn-wrapper\">\r\n @if (!value && !valueUrl) {\r\n <button\r\n class=\"btn-record\"\r\n fd-button\r\n [glyph]=\"isRecording ? 'stop' : 'record'\"\r\n [fdType]=\"isRecording ? 'attention' : 'ghost'\"\r\n (click)=\"onToggleRecord()\"\r\n ></button>\r\n } @if (!value && valueUrl) {\r\n <div class=\"btn-toolbar\">\r\n <button fd-button [glyph]=\"'delete'\" fdType=\"negative\" (click)=\"onClearRecord()\"></button>\r\n <button fd-button [label]=\"'Upload' | bbbTranslate\" [glyph]=\"'upload'\" (click)=\"onUpload()\"></button>\r\n </div>\r\n } @if (value) {\r\n <div class=\"btn-toolbar\">\r\n @if (value) {\r\n <button fd-button [glyph]=\"'delete'\" fdType=\"negative\" (click)=\"onDelete()\"></button>\r\n } @if (value) {\r\n <button fd-button [glyph]=\"'download'\" fdType=\"standard\" (click)=\"onDownload()\"></button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </fd-card-content>\r\n</fd-card>\r\n", styles: [":host .upload{display:flex;justify-content:center;align-items:center;flex-direction:column;max-width:380px;position:relative}:host .upload .file-content{width:100%}:host .upload i:before{color:#0a6ed1!important;font-size:2rem}fd-card.audio{min-height:120px;max-height:120px}fd-card.video{min-height:340px;max-height:340px}.icon{display:flex;align-items:center;justify-content:center;position:absolute;top:45%;left:45%}.video-novalue{border:1px dashed var(--sapObjectHeader_BorderColor);min-height:240px}audio,video{width:100%}.progress{position:absolute;width:100%;height:100%;background-color:#e4e4e4c7;z-index:4;display:flex;justify-content:center;align-items:center;top:0;left:0}.progress div{flex:.5}.file-content{width:100%;height:100%;display:flex;flex-direction:column;padding:1rem}.media-wrapper{flex-grow:1}.btn-wrapper{align-self:center}.btn-record{flex-shrink:1}.btn-toolbar{flex-grow:1;display:flex;column-gap:1rem}.media-info{flex-shrink:1;display:flex;width:100%;justify-content:space-between}\n"] }]
|
|
228
|
+
}], propDecorators: { videoElement: [{
|
|
229
|
+
type: ViewChild,
|
|
230
|
+
args: ['videoElement']
|
|
231
|
+
}], photoElement: [{
|
|
232
|
+
type: ViewChild,
|
|
233
|
+
args: ['photoElement']
|
|
234
|
+
}], dialogContainer: [{
|
|
235
|
+
type: ViewChild,
|
|
236
|
+
args: ['container', { read: TemplateRef }]
|
|
237
|
+
}] } });
|
|
238
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-file-uploader.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/media-file-uploader/media-file-uploader.component.ts","../../../../../projects/barsa-develop-components/src/lib/media-file-uploader/media-file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, TemplateRef, ViewChild } from '@angular/core';\r\nimport { AudioRecordingService, BarsaApi, UploadService, VideoRecordingService } from 'barsa-novin-ray-core';\r\nimport { UiPdfViewerComponent } from 'barsa-sap-ui';\r\n\r\n@Component({\r\n    selector: 'bdc-media-file-uploader',\r\n    templateUrl: './media-file-uploader.component.html',\r\n    styleUrls: ['./media-file-uploader.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [AudioRecordingService, VideoRecordingService, UploadService],\r\n    standalone: false\r\n})\r\nexport class MediaFileUploaderComponent extends UiPdfViewerComponent implements OnInit {\r\n    @ViewChild('videoElement') videoElement: any;\r\n    @ViewChild('photoElement') photoElement: any;\r\n    @ViewChild('container', { read: TemplateRef })\r\n    dialogContainer: TemplateRef<any>;\r\n\r\n    isPlaying = false;\r\n    displayControls = true;\r\n    isRecording = false;\r\n    recordedTime;\r\n    fileBlob;\r\n    fileName;\r\n    audioStream;\r\n    videoStream: MediaStream;\r\n    audioConf = { audio: true };\r\n    videoConf = { video: { facingMode: 'user', width: 320 }, audio: true };\r\n    glyph: string;\r\n    recordType = 'audio';\r\n\r\n    get video(): HTMLMediaElement {\r\n        return this.videoElement?.nativeElement;\r\n    }\r\n    get fileInput(): HTMLInputElement {\r\n        return this.photoElement?.nativeElement;\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this._videoRecoder.recordingFailed().subscribe(() => {\r\n            this.isRecording = false;\r\n            this._cdr.detectChanges();\r\n        });\r\n\r\n        this._videoRecoder.getRecordedTime().subscribe((time) => {\r\n            this.recordedTime = time;\r\n            this._cdr.detectChanges();\r\n        });\r\n\r\n        this._videoRecoder.getStream().subscribe((stream) => {\r\n            this.videoStream = stream;\r\n            this._cdr.detectChanges();\r\n        });\r\n\r\n        this._videoRecoder.getRecordedBlob().subscribe((data) => {\r\n            this.fileBlob = data.blob;\r\n            this.fileName = data.title;\r\n            this.valueUrl = this._domSanitizer.bypassSecurityTrustUrl(data.url);\r\n            this._cdr.detectChanges();\r\n        });\r\n\r\n        this._audioRecorder.recordingFailed().subscribe(() => {\r\n            this.isRecording = false;\r\n            this._cdr.detectChanges();\r\n        });\r\n\r\n        this._audioRecorder.getRecordedTime().subscribe((time) => {\r\n            this.recordedTime = time;\r\n            this._cdr.detectChanges();\r\n        });\r\n\r\n        this._audioRecorder.getRecordedBlob().subscribe((data) => {\r\n            this.fileBlob = data.blob;\r\n            this.fileName = data.title;\r\n            this.valueUrl = this._domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(data.blob));\r\n            this._cdr.detectChanges();\r\n        });\r\n        let glyph = '';\r\n        switch (this.recordType) {\r\n            case 'audio':\r\n                glyph = 'attachment-audio';\r\n                break;\r\n            case 'video':\r\n                glyph = 'attachment-video';\r\n                break;\r\n            default:\r\n                glyph = 'attachment-photo';\r\n                break;\r\n        }\r\n        this.glyph = glyph;\r\n        this.fileName = this.value?.FileName;\r\n        this.recordType = this.parameters?.MediaType$Caption || 'audio';\r\n    }\r\n\r\n    onDelete(): void {\r\n        super.onDelete();\r\n        this.onClearRecord();\r\n    }\r\n    onClearRecord(): void {\r\n        this.abortVideoRecording();\r\n        this.abortAudioRecording();\r\n        this.fileBlob = null;\r\n        this.valueUrl = null;\r\n        this._cdr.detectChanges();\r\n    }\r\n    onToggleRecord(): void {\r\n        if (this.recordType === 'audio') {\r\n            if (this.isRecording) {\r\n                this.stopAudioRecording();\r\n            } else {\r\n                this.startAudioRecording();\r\n            }\r\n        } else if (this.recordType === 'video') {\r\n            this.video.hidden = false;\r\n            if (this.isRecording) {\r\n                this.stopVideoRecording();\r\n            } else {\r\n                this.startVideoRecording();\r\n            }\r\n        } else if (this.recordType === 'photo') {\r\n        }\r\n    }\r\n    onTakePhoto(): void {\r\n        if (this.fileInput?.files?.length) {\r\n            const file = this.fileInput.files.item(0);\r\n            if (file) {\r\n                this.fileName = file.name;\r\n                this._uploadFile([file]).subscribe();\r\n            }\r\n        }\r\n    }\r\n    onUpload(): void {\r\n        const videoFile: File = new File([this.fileBlob], this.fileName);\r\n        this._uploadFile([videoFile]).subscribe();\r\n    }\r\n    startVideoRecording(): void {\r\n        if (!this.isRecording) {\r\n            this.video.controls = false;\r\n            this.isRecording = true;\r\n            this._videoRecoder\r\n                .startRecording(this.videoConf)\r\n                .then((stream) => {\r\n                    // this.video.src = window.URL.createObjectURL(stream);\r\n                    this.video.srcObject = stream;\r\n                    this.video.play();\r\n                })\r\n                .catch(function (err) {\r\n                    console.log(err.name + ': ' + err.message);\r\n                });\r\n        }\r\n    }\r\n\r\n    abortVideoRecording(): void {\r\n        if (this.isRecording && this.recordType === 'video') {\r\n            this.isRecording = false;\r\n            this._videoRecoder.abortRecording();\r\n        }\r\n        if (this.video) {\r\n            const video = this.video;\r\n            video.controls = false;\r\n            video.hidden = true;\r\n        }\r\n    }\r\n\r\n    stopVideoRecording(): void {\r\n        if (this.isRecording && this.recordType === 'video') {\r\n            this._videoRecoder.stopRecording();\r\n            const video: any = this.video;\r\n            video.srcObject = this.valueUrl;\r\n            video.controls = true;\r\n            this.isRecording = false;\r\n        }\r\n    }\r\n\r\n    clearVideoRecordedData(): void {\r\n        this.valueUrl = null;\r\n        const video = this.video;\r\n        video.srcObject = null;\r\n        video.controls = false;\r\n        this._cdr.detectChanges();\r\n    }\r\n\r\n    downloadVideoRecordedData(): void {\r\n        this._downloadFile(this.fileBlob, 'video/mp4', this.fileName);\r\n    }\r\n\r\n    startAudioRecording(): void {\r\n        if (!this.isRecording) {\r\n            this.isRecording = true;\r\n            this._audioRecorder.startRecording();\r\n        }\r\n    }\r\n\r\n    abortAudioRecording(): void {\r\n        if (this.isRecording && this.recordType === 'audio') {\r\n            this.isRecording = false;\r\n            this._audioRecorder.abortRecording();\r\n        }\r\n    }\r\n\r\n    stopAudioRecording(): void {\r\n        if (this.isRecording && this.recordType === 'audio') {\r\n            this._audioRecorder.stopRecording();\r\n            this.isRecording = false;\r\n        }\r\n    }\r\n\r\n    clearAudioRecordedData(): void {\r\n        this.valueUrl = null;\r\n    }\r\n\r\n    downloadAudioRecordedData(): void {\r\n        this._downloadFile(this.fileBlob, 'audio/mp3', this.fileName);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.abortAudioRecording();\r\n    }\r\n\r\n    _downloadFile(data: any, type: string, filename: string): any {\r\n        const blob = new Blob([data], { type });\r\n        const url = window.URL.createObjectURL(blob);\r\n        // this.video.srcObject = stream;\r\n        // const url = data;\r\n        const anchor = document.createElement('a');\r\n        anchor.download = filename;\r\n        anchor.href = url;\r\n        document.body.appendChild(anchor);\r\n        anchor.click();\r\n        document.body.removeChild(anchor);\r\n    }\r\n    protected _downloadFileIdCompleted(response): void {\r\n        super._downloadFileIdCompleted(response);\r\n        if (this.valueUrl) {\r\n            if (this.recordType === 'video') {\r\n                this.video.controls = true;\r\n            }\r\n        }\r\n    }\r\n    protected _refresh(_?: boolean): void {\r\n        if (BarsaApi.Ext.isEmpty(this.value)) {\r\n            return;\r\n        }\r\n        const fileId = this.value.Id;\r\n        this.DownloadFileId(fileId, true, '', null, false);\r\n    }\r\n}\r\n","<fd-card class=\"upload\" [ngClass]=\"recordType\">\r\n    <fd-card-content class=\"file-content\">\r\n        <div [class.no-recording]=\"!isRecording && valueUrl\" [ngClass]=\"recordType\" class=\"media-wrapper\">\r\n            <div class=\"icon\">\r\n                @if (!value && !valueUrl && !isRecording) {\r\n                <i style=\"left: 45%; position: absolute\" fd-nested-list-icon [glyph]=\"glyph\"></i>\r\n                }\r\n            </div>\r\n            @if (recordType === 'video') {\r\n            <video #videoElement [class.video-novalue]=\"!valueUrl\">\r\n                @if (!isRecording && valueUrl) {\r\n                <source [src]=\"valueUrl\" />\r\n                } @if (!value && !valueUrl && !isRecording) {\r\n                <i style=\"left: 45%; position: absolute\" fd-nested-list-icon [glyph]=\"glyph\"></i>\r\n                }\r\n            </video>\r\n            } @if (!isRecording && valueUrl && recordType === 'audio') {\r\n            <audio controls>\r\n                <source [src]=\"valueUrl\" type=\"audio/mp3\" />\r\n            </audio>\r\n            } @if (recordType === 'photo') {\r\n            <input\r\n                #photoElement\r\n                type=\"file\"\r\n                accept=\"image/*\"\r\n                id=\"file-input\"\r\n                capture=\"environment\"\r\n                (change)=\"onTakePhoto()\"\r\n            />\r\n            }\r\n        </div>\r\n        @if (isRecording || valueUrl) {\r\n        <div class=\"media-info\">\r\n            <div>\r\n                {{ !isRecording ? '' : ('Recording' | bbbTranslate) }} <strong>{{ recordedTime }}</strong>\r\n            </div>\r\n            <div>{{ fileName }}</div>\r\n        </div>\r\n        } @if (uploadingState$ | async; as uploadingState) { @if (uploadingState.state === 'Uploading') {\r\n        <div class=\"progress\">\r\n            <div>\r\n                <fd-progress-indicator\r\n                    state=\"informative\"\r\n                    [valueNow]=\"uploadingState?.progress\"\r\n                ></fd-progress-indicator>\r\n            </div>\r\n        </div>\r\n        } }\r\n        <div class=\"btn-wrapper\">\r\n            @if (!value && !valueUrl) {\r\n            <button\r\n                class=\"btn-record\"\r\n                fd-button\r\n                [glyph]=\"isRecording ? 'stop' : 'record'\"\r\n                [fdType]=\"isRecording ? 'attention' : 'ghost'\"\r\n                (click)=\"onToggleRecord()\"\r\n            ></button>\r\n            } @if (!value && valueUrl) {\r\n            <div class=\"btn-toolbar\">\r\n                <button fd-button [glyph]=\"'delete'\" fdType=\"negative\" (click)=\"onClearRecord()\"></button>\r\n                <button fd-button [label]=\"'Upload' | bbbTranslate\" [glyph]=\"'upload'\" (click)=\"onUpload()\"></button>\r\n            </div>\r\n            } @if (value) {\r\n            <div class=\"btn-toolbar\">\r\n                @if (value) {\r\n                <button fd-button [glyph]=\"'delete'\" fdType=\"negative\" (click)=\"onDelete()\"></button>\r\n                } @if (value) {\r\n                <button fd-button [glyph]=\"'download'\" fdType=\"standard\" (click)=\"onDownload()\"></button>\r\n                }\r\n            </div>\r\n            }\r\n        </div>\r\n    </fd-card-content>\r\n</fd-card>\r\n"]}
|