barsa-novin-ray-core 2.0.84 → 2.0.86

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.
@@ -12,9 +12,10 @@ export class RootPortalComponent extends PageBaseComponent {
12
12
  }
13
13
  ngOnInit() {
14
14
  super.ngOnInit();
15
- const offlinceActive = BarsaApi.Common.TryGetValue(BarsaApi.Offline, 'Settings.IsActive', false);
16
- const offlineTrue = BarsaApi.Common.TryGetValue(BarsaApi.Offline, 'Settings.IsOffline', false);
15
+ const offlinceActive = BarsaApi.Common.Util.TryGetValue(BarsaApi.Offline, 'Settings.IsActive', false);
16
+ const offlineTrue = BarsaApi.Common.Util.TryGetValue(BarsaApi.Offline, 'Settings.IsOffline', false);
17
17
  this.inLocalMode = offlinceActive && offlineTrue;
18
+ // this.inLocalMode = true;
18
19
  this._router.events.subscribe((event) => {
19
20
  if (event instanceof NavigationStart && event instanceof RouterEvent) {
20
21
  this._portalService.naviationStart(event);
@@ -24,6 +25,33 @@ export class RootPortalComponent extends PageBaseComponent {
24
25
  }
25
26
  });
26
27
  }
28
+ onSendOfflineDataToServer() {
29
+ BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineGoOnline, BarsaApi.BBB.Delete, function (buttonId) {
30
+ if (buttonId === 'yes') {
31
+ BarsaApi.Bw.Msg.Wait(0, BarsaApi.BBB.LoadingMaskMsg, 'wait');
32
+ BarsaApi.Offline.GoOnline(function () {
33
+ window.location.reload();
34
+ });
35
+ }
36
+ });
37
+ }
38
+ onRemoveOfflineDataAndReturnToOnline() {
39
+ BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineClearAll, BarsaApi.BBB.Delete, function (buttonId) {
40
+ if (buttonId === 'yes') {
41
+ BarsaApi.Offline.ClearAll();
42
+ window.location.reload();
43
+ }
44
+ });
45
+ }
46
+ onRemoveOfflineData() {
47
+ BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineClearUnsavedData, BarsaApi.BBB.Delete, function (buttonId) {
48
+ if (buttonId === 'yes') {
49
+ BarsaApi.Offline.CachedData.UnsavedData = {};
50
+ BarsaApi.Offline.CachedData.save();
51
+ BarsaApi.Bw.Toast.Success(BarsaApi.BBB.Action + BarsaApi.BBB.JobCompleted);
52
+ }
53
+ });
54
+ }
27
55
  addFooter(pageData) {
28
56
  if (!pageData?.Footer) {
29
57
  return;
@@ -75,11 +103,19 @@ export class RootPortalComponent extends PageBaseComponent {
75
103
  }
76
104
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: RootPortalComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
77
105
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: RootPortalComponent, selector: "bnrc-root-portal", viewQueries: [{ propertyName: "sectionRef", first: true, predicate: ["sectionRef"], descendants: true }, { propertyName: "footerRefVcr", first: true, predicate: ["footerRef"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: `
78
- <!-- @if(inLocalMode){
79
- <div style="height:100px;background:red"></div>
80
- }
81
- -->
82
- @if (imageUrl) {
106
+ @if(inLocalMode){
107
+ <div class="fd-toolbar" style="flex-wrap:wrap;padding:0.5rem;height:auto">
108
+ <button class="fd-button fd-button--attention is-compact" (click)="onRemoveOfflineData()">
109
+ حذف اطلاعات آفلاین
110
+ </button>
111
+ <button class="fd-button fd-button--negative is-compact" (click)="onRemoveOfflineDataAndReturnToOnline()">
112
+ حذف اطلاعات آفلاین و برگشت به حالت آنلاین
113
+ </button>
114
+ <button class="fd-button fd-button--positive is-compact" (click)="onSendOfflineDataToServer()">
115
+ ارسال اطلاعات آفلاین به سرور
116
+ </button>
117
+ </div>
118
+ } @if (imageUrl) {
83
119
  <div id="headerSpaceHolder" #headerSpaceHolder>
84
120
  <div id="bgOuterHolder" #bgOuterHolder>
85
121
  <div id="bgInnerHolder" style="height: 100vh">
@@ -106,11 +142,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
106
142
  args: [{
107
143
  selector: 'bnrc-root-portal',
108
144
  template: `
109
- <!-- @if(inLocalMode){
110
- <div style="height:100px;background:red"></div>
111
- }
112
- -->
113
- @if (imageUrl) {
145
+ @if(inLocalMode){
146
+ <div class="fd-toolbar" style="flex-wrap:wrap;padding:0.5rem;height:auto">
147
+ <button class="fd-button fd-button--attention is-compact" (click)="onRemoveOfflineData()">
148
+ حذف اطلاعات آفلاین
149
+ </button>
150
+ <button class="fd-button fd-button--negative is-compact" (click)="onRemoveOfflineDataAndReturnToOnline()">
151
+ حذف اطلاعات آفلاین و برگشت به حالت آنلاین
152
+ </button>
153
+ <button class="fd-button fd-button--positive is-compact" (click)="onSendOfflineDataToServer()">
154
+ ارسال اطلاعات آفلاین به سرور
155
+ </button>
156
+ </div>
157
+ } @if (imageUrl) {
114
158
  <div id="headerSpaceHolder" #headerSpaceHolder>
115
159
  <div id="bgOuterHolder" #bgOuterHolder>
116
160
  <div id="bgInnerHolder" style="height: 100vh">
@@ -140,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
140
184
  type: ViewChild,
141
185
  args: ['footerRef', { read: ViewContainerRef }]
142
186
  }] } });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-portal.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/root-portal/root-portal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\n\nimport { NavigationEnd, NavigationStart, RouterEvent } from '@angular/router';\nimport { Observable, takeUntil, tap } from 'rxjs';\n\nimport { BarsaApi, PageBaseComponent, PageDataModel } from '../abstract-classes';\ndeclare const head: any;\ndeclare const BigNumber: any;\n\n@Component({\n    selector: 'bnrc-root-portal',\n    template: `\n        <!-- @if(inLocalMode){\n        <div style=\"height:100px;background:red\"></div>\n        } \n        -->\n        @if (imageUrl) {\n        <div id=\"headerSpaceHolder\" #headerSpaceHolder>\n            <div id=\"bgOuterHolder\" #bgOuterHolder>\n                <div id=\"bgInnerHolder\" style=\"height: 100vh\">\n                    <div class=\"backgroundImage\" id=\"backgroundImage\">\n                        <img class=\"picture\" [src]=\"imageUrl\" loading=\"lazy\" />\n                        <span id=\"backgroundImageOverlay\" class=\"overlay\"></span>\n                    </div>\n                </div>\n            </div>\n        </div>\n        }\n        <section class=\"section\" id=\"mainpage\" #sectionRef>\n            <div #containerRef></div>\n        </section>\n        <div class=\"page-wrapper\">\n            <router-outlet></router-outlet>\n        </div>\n        <!-- <footer #footerRef></footer> -->\n        <ng-container #footerRef></ng-container>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RootPortalComponent extends PageBaseComponent implements OnInit {\n    @ViewChild('sectionRef') sectionRef: ElementRef;\n    @ViewChild('footerRef', { read: ViewContainerRef }) footerRefVcr: ViewContainerRef;\n    portalLoading$: Observable<boolean>;\n    modules: any;\n    isRoot = true;\n    inLocalMode = true;\n    imageUrl: string;\n    ngOnInit(): void {\n        super.ngOnInit();\n        const offlinceActive = BarsaApi.Common.TryGetValue(BarsaApi.Offline, 'Settings.IsActive', false);\n        const offlineTrue = BarsaApi.Common.TryGetValue(BarsaApi.Offline, 'Settings.IsOffline', false);\n        this.inLocalMode = offlinceActive && offlineTrue;\n\n        this._router.events.subscribe((event) => {\n            if (event instanceof NavigationStart && event instanceof RouterEvent) {\n                this._portalService.naviationStart(event);\n            }\n            if (event instanceof NavigationEnd && event instanceof RouterEvent) {\n                this._portalService.naviationEnd(event);\n            }\n        });\n    }\n    protected addFooter(pageData: PageDataModel | null): void {\n        if (!pageData?.Footer) {\n            return;\n        }\n        const footerComponent = pageData.Footer.Component;\n        this.getComponentFactory(footerComponent)\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap((controlUi) => {\n                    controlUi.instance.settings = footerComponent.Settings;\n                    controlUi.instance.activatedRoute = this._activatedRoute;\n                    if (this.footerRefVcr) {\n                        this.footerRefVcr.insert(controlUi.hostView);\n                    }\n                })\n            )\n            .subscribe();\n    }\n    protected renderPlaceHolders(pageData: PageDataModel | null): void {\n        super.renderPlaceHolders(pageData);\n        this.addFooter(pageData);\n\n        const jsfiles: string[] = [];\n        const cssfiles: string[] = [];\n        Object.keys(BarsaApi.LoginFormData).forEach((key) => {\n            if (key.startsWith('JSFile')) {\n                jsfiles.push(BarsaApi.LoginFormData[key]);\n            }\n            if (key.startsWith('CSSFile')) {\n                cssfiles.push(BarsaApi.LoginFormData[key]);\n            }\n        });\n        BigNumber.prototype.subtract = BigNumber.prototype.minus;\n        BigNumber.prototype.add = BigNumber.prototype.plus;\n        if (jsfiles.length > 0) {\n            head.load(jsfiles);\n        }\n        if (cssfiles.length > 0) {\n            cssfiles.forEach((c) => {\n                document.head.insertAdjacentHTML('beforeend', ` <link href=\"${c}\" rel=\"stylesheet\" noportal />`);\n            });\n        }\n        const { BackgroundId } = this.pageData as any;\n        if (BackgroundId) {\n            this._renderer2.addClass(this._el.nativeElement, 'root-custom-background');\n            this.imageUrl = `/IH.ashx?ty=ID&moId=&id=${BackgroundId}&si=1920&sih=1080`;\n            // this._renderer2.setStyle(\n            //     this._el.nativeElement,\n            //     'background',\n\n            // );\n            // this._renderer2.setStyle(this._el.nativeElement, 'background-size', `cover`);\n        }\n    }\n}\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-portal.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/root-portal/root-portal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\n\nimport { NavigationEnd, NavigationStart, RouterEvent } from '@angular/router';\nimport { Observable, takeUntil, tap } from 'rxjs';\n\nimport { BarsaApi, PageBaseComponent, PageDataModel } from '../abstract-classes';\ndeclare const head: any;\ndeclare const BigNumber: any;\n\n@Component({\n    selector: 'bnrc-root-portal',\n    template: `\n        @if(inLocalMode){\n        <div class=\"fd-toolbar\" style=\"flex-wrap:wrap;padding:0.5rem;height:auto\">\n            <button class=\"fd-button fd-button--attention is-compact\" (click)=\"onRemoveOfflineData()\">\n                حذف اطلاعات آفلاین\n            </button>\n            <button class=\"fd-button fd-button--negative is-compact\" (click)=\"onRemoveOfflineDataAndReturnToOnline()\">\n                حذف اطلاعات آفلاین و برگشت به حالت آنلاین\n            </button>\n            <button class=\"fd-button fd-button--positive is-compact\" (click)=\"onSendOfflineDataToServer()\">\n                ارسال اطلاعات آفلاین به سرور\n            </button>\n        </div>\n        } @if (imageUrl) {\n        <div id=\"headerSpaceHolder\" #headerSpaceHolder>\n            <div id=\"bgOuterHolder\" #bgOuterHolder>\n                <div id=\"bgInnerHolder\" style=\"height: 100vh\">\n                    <div class=\"backgroundImage\" id=\"backgroundImage\">\n                        <img class=\"picture\" [src]=\"imageUrl\" loading=\"lazy\" />\n                        <span id=\"backgroundImageOverlay\" class=\"overlay\"></span>\n                    </div>\n                </div>\n            </div>\n        </div>\n        }\n        <section class=\"section\" id=\"mainpage\" #sectionRef>\n            <div #containerRef></div>\n        </section>\n        <div class=\"page-wrapper\">\n            <router-outlet></router-outlet>\n        </div>\n        <!-- <footer #footerRef></footer> -->\n        <ng-container #footerRef></ng-container>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RootPortalComponent extends PageBaseComponent implements OnInit {\n    @ViewChild('sectionRef') sectionRef: ElementRef;\n    @ViewChild('footerRef', { read: ViewContainerRef }) footerRefVcr: ViewContainerRef;\n    portalLoading$: Observable<boolean>;\n    modules: any;\n    isRoot = true;\n    inLocalMode = true;\n    imageUrl: string;\n    ngOnInit(): void {\n        super.ngOnInit();\n        const offlinceActive = BarsaApi.Common.Util.TryGetValue(BarsaApi.Offline, 'Settings.IsActive', false);\n        const offlineTrue = BarsaApi.Common.Util.TryGetValue(BarsaApi.Offline, 'Settings.IsOffline', false);\n        this.inLocalMode = offlinceActive && offlineTrue;\n        // this.inLocalMode = true;\n\n        this._router.events.subscribe((event) => {\n            if (event instanceof NavigationStart && event instanceof RouterEvent) {\n                this._portalService.naviationStart(event);\n            }\n            if (event instanceof NavigationEnd && event instanceof RouterEvent) {\n                this._portalService.naviationEnd(event);\n            }\n        });\n    }\n    protected onSendOfflineDataToServer(): void {\n        BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineGoOnline, BarsaApi.BBB.Delete, function (buttonId) {\n            if (buttonId === 'yes') {\n                BarsaApi.Bw.Msg.Wait(0, BarsaApi.BBB.LoadingMaskMsg, 'wait');\n                BarsaApi.Offline.GoOnline(function () {\n                    window.location.reload();\n                });\n            }\n        });\n    }\n    protected onRemoveOfflineDataAndReturnToOnline(): void {\n        BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineClearAll, BarsaApi.BBB.Delete, function (buttonId) {\n            if (buttonId === 'yes') {\n                BarsaApi.Offline.ClearAll();\n                window.location.reload();\n            }\n        });\n    }\n    protected onRemoveOfflineData(): void {\n        BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineClearUnsavedData, BarsaApi.BBB.Delete, function (buttonId) {\n            if (buttonId === 'yes') {\n                BarsaApi.Offline.CachedData.UnsavedData = {};\n                BarsaApi.Offline.CachedData.save();\n                BarsaApi.Bw.Toast.Success(BarsaApi.BBB.Action + BarsaApi.BBB.JobCompleted);\n            }\n        });\n    }\n    protected addFooter(pageData: PageDataModel | null): void {\n        if (!pageData?.Footer) {\n            return;\n        }\n        const footerComponent = pageData.Footer.Component;\n        this.getComponentFactory(footerComponent)\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap((controlUi) => {\n                    controlUi.instance.settings = footerComponent.Settings;\n                    controlUi.instance.activatedRoute = this._activatedRoute;\n                    if (this.footerRefVcr) {\n                        this.footerRefVcr.insert(controlUi.hostView);\n                    }\n                })\n            )\n            .subscribe();\n    }\n    protected renderPlaceHolders(pageData: PageDataModel | null): void {\n        super.renderPlaceHolders(pageData);\n        this.addFooter(pageData);\n\n        const jsfiles: string[] = [];\n        const cssfiles: string[] = [];\n        Object.keys(BarsaApi.LoginFormData).forEach((key) => {\n            if (key.startsWith('JSFile')) {\n                jsfiles.push(BarsaApi.LoginFormData[key]);\n            }\n            if (key.startsWith('CSSFile')) {\n                cssfiles.push(BarsaApi.LoginFormData[key]);\n            }\n        });\n        BigNumber.prototype.subtract = BigNumber.prototype.minus;\n        BigNumber.prototype.add = BigNumber.prototype.plus;\n        if (jsfiles.length > 0) {\n            head.load(jsfiles);\n        }\n        if (cssfiles.length > 0) {\n            cssfiles.forEach((c) => {\n                document.head.insertAdjacentHTML('beforeend', ` <link href=\"${c}\" rel=\"stylesheet\" noportal />`);\n            });\n        }\n        const { BackgroundId } = this.pageData as any;\n        if (BackgroundId) {\n            this._renderer2.addClass(this._el.nativeElement, 'root-custom-background');\n            this.imageUrl = `/IH.ashx?ty=ID&moId=&id=${BackgroundId}&si=1920&sih=1080`;\n            // this._renderer2.setStyle(\n            //     this._el.nativeElement,\n            //     'background',\n\n            // );\n            // this._renderer2.setStyle(this._el.nativeElement, 'background-size', `cover`);\n        }\n    }\n}\n"]}
@@ -1462,15 +1462,16 @@ function calculateFreeColumnSize(columns) {
1462
1462
  function calculateColumnWidthFitToContainer(container, canView, disableContextMenuOverflow, contextMenuItems, columns) {
1463
1463
  const containerWidth = container.clientWidth;
1464
1464
  let allColWidth = 0;
1465
+ const isMobile = getDeviceIsMobile();
1465
1466
  columns
1466
1467
  .filter((c) => !c.Hidden)
1467
1468
  .forEach((col, index) => {
1468
1469
  const w = col.Width && col.Width > 0 ? col.Width : setColumnCaptionWidth(col);
1469
1470
  allColWidth += w;
1470
1471
  const percent = (w / containerWidth) * 100;
1471
- col.$FitContainerWidth = `${percent}%`;
1472
+ col.$FitContainerWidth = isMobile ? '100%' : `${percent}%`;
1472
1473
  if (index === columns.length - 1) {
1473
- col.$FitContainerWidth = 'auto';
1474
+ col.$FitContainerWidth = isMobile ? '100%' : 'auto';
1474
1475
  }
1475
1476
  });
1476
1477
  // const canViewButtonWidth = canView ? 40 : 0;
@@ -9107,13 +9108,17 @@ class FormPropsBaseComponent extends BaseComponent {
9107
9108
  this._renderer2 = _renderer2;
9108
9109
  this._vcr = _vcr;
9109
9110
  this._factoryResolver = _factoryResolver;
9111
+ this.events = new EventEmitter();
9110
9112
  }
9111
9113
  ngOnInit() {
9112
9114
  // this.mo = this._formPanelService.mo;
9113
9115
  super.ngOnInit();
9114
9116
  }
9117
+ onEvents(title, data) {
9118
+ this.events.emit({ title, data });
9119
+ }
9115
9120
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: FormPropsBaseComponent, deps: [{ token: ControlUiPipe }, { token: FormPanelService }, { token: i4.DomSanitizer }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component }); }
9116
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: FormPropsBaseComponent, selector: "bnrc-form-props-base", inputs: { breadCrumbs: "breadCrumbs", toolbarVisible: "toolbarVisible", toolbarItems: "toolbarItems", layoutActions: "layoutActions", layout94: "layout94", settings: "settings", workflowPanelUi: "workflowPanelUi", title: "title", subtitle: "subtitle", description: "description", facetList: "facetList", removeHeaderBorder: "removeHeaderBorder", removeContentPadding: "removeContentPadding", isMobile: "isMobile", avatar: "avatar", rtl: "rtl", mask: "mask", fieldDict: "fieldDict", contentDensity: "contentDensity", deviceSize: "deviceSize", dirValue: "dirValue", modernTabs: "modernTabs", mo: "mo" }, usesInheritance: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
9121
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: FormPropsBaseComponent, selector: "bnrc-form-props-base", inputs: { breadCrumbs: "breadCrumbs", toolbarVisible: "toolbarVisible", toolbarItems: "toolbarItems", layoutActions: "layoutActions", layout94: "layout94", settings: "settings", workflowPanelUi: "workflowPanelUi", title: "title", subtitle: "subtitle", description: "description", facetList: "facetList", removeHeaderBorder: "removeHeaderBorder", removeContentPadding: "removeContentPadding", isMobile: "isMobile", avatar: "avatar", rtl: "rtl", mask: "mask", canSend: "canSend", landscape: "landscape", standalone: "standalone", footerDesign: "footerDesign", workflowButtons: "workflowButtons", workflowButtonsComboMode: "workflowButtonsComboMode", fieldDict: "fieldDict", contentDensity: "contentDensity", deviceSize: "deviceSize", dirValue: "dirValue", modernTabs: "modernTabs", mo: "mo" }, outputs: { events: "events" }, usesInheritance: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
9117
9122
  }
9118
9123
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: FormPropsBaseComponent, decorators: [{
9119
9124
  type: Component,
@@ -9156,6 +9161,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
9156
9161
  type: Input
9157
9162
  }], mask: [{
9158
9163
  type: Input
9164
+ }], canSend: [{
9165
+ type: Input
9166
+ }], landscape: [{
9167
+ type: Input
9168
+ }], standalone: [{
9169
+ type: Input
9170
+ }], footerDesign: [{
9171
+ type: Input
9172
+ }], workflowButtons: [{
9173
+ type: Input
9174
+ }], workflowButtonsComboMode: [{
9175
+ type: Input
9159
9176
  }], fieldDict: [{
9160
9177
  type: Input
9161
9178
  }], contentDensity: [{
@@ -9168,6 +9185,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
9168
9185
  type: Input
9169
9186
  }], mo: [{
9170
9187
  type: Input
9188
+ }], events: [{
9189
+ type: Output
9171
9190
  }] } });
9172
9191
 
9173
9192
  class LinearListHelper extends BaseComponent {
@@ -10216,7 +10235,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
10216
10235
 
10217
10236
  class DynamicFormComponent extends BaseDynamicComponent {
10218
10237
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: DynamicFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
10219
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: DynamicFormComponent, selector: "bnrc-dynamic-form-component", inputs: { breadCrumbs: "breadCrumbs", toolbarVisible: "toolbarVisible", toolbarItems: "toolbarItems", layoutActions: "layoutActions", layout94: "layout94", settings: "settings", workflowPanelUi: "workflowPanelUi", title: "title", subtitle: "subtitle", description: "description", facetList: "facetList", removeHeaderBorder: "removeHeaderBorder", removeContentPadding: "removeContentPadding", isMobile: "isMobile", avatar: "avatar", rtl: "rtl", mask: "mask", mo: "mo", contentDensity: "contentDensity", deviceSize: "deviceSize", dirValue: "dirValue", fieldDict: "fieldDict", modernTabs: "modernTabs" }, usesInheritance: true, ngImport: i0, template: `<ng-container #componentContainer></ng-container>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
10238
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: DynamicFormComponent, selector: "bnrc-dynamic-form-component", inputs: { breadCrumbs: "breadCrumbs", toolbarVisible: "toolbarVisible", toolbarItems: "toolbarItems", layoutActions: "layoutActions", workflowButtons: "workflowButtons", buttons: "buttons", layout94: "layout94", footerDesign: "footerDesign", settings: "settings", workflowPanelUi: "workflowPanelUi", title: "title", subtitle: "subtitle", description: "description", facetList: "facetList", removeHeaderBorder: "removeHeaderBorder", removeContentPadding: "removeContentPadding", isMobile: "isMobile", avatar: "avatar", rtl: "rtl", mask: "mask", mo: "mo", contentDensity: "contentDensity", deviceSize: "deviceSize", dirValue: "dirValue", fieldDict: "fieldDict", modernTabs: "modernTabs" }, usesInheritance: true, ngImport: i0, template: `<ng-container #componentContainer></ng-container>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
10220
10239
  }
10221
10240
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: DynamicFormComponent, decorators: [{
10222
10241
  type: Component,
@@ -10233,8 +10252,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
10233
10252
  type: Input
10234
10253
  }], layoutActions: [{
10235
10254
  type: Input
10255
+ }], workflowButtons: [{
10256
+ type: Input
10257
+ }], buttons: [{
10258
+ type: Input
10236
10259
  }], layout94: [{
10237
10260
  type: Input
10261
+ }], footerDesign: [{
10262
+ type: Input
10238
10263
  }], settings: [{
10239
10264
  type: Input
10240
10265
  }], workflowPanelUi: [{
@@ -11245,9 +11270,10 @@ class RootPortalComponent extends PageBaseComponent {
11245
11270
  }
11246
11271
  ngOnInit() {
11247
11272
  super.ngOnInit();
11248
- const offlinceActive = BarsaApi.Common.TryGetValue(BarsaApi.Offline, 'Settings.IsActive', false);
11249
- const offlineTrue = BarsaApi.Common.TryGetValue(BarsaApi.Offline, 'Settings.IsOffline', false);
11273
+ const offlinceActive = BarsaApi.Common.Util.TryGetValue(BarsaApi.Offline, 'Settings.IsActive', false);
11274
+ const offlineTrue = BarsaApi.Common.Util.TryGetValue(BarsaApi.Offline, 'Settings.IsOffline', false);
11250
11275
  this.inLocalMode = offlinceActive && offlineTrue;
11276
+ // this.inLocalMode = true;
11251
11277
  this._router.events.subscribe((event) => {
11252
11278
  if (event instanceof NavigationStart && event instanceof RouterEvent) {
11253
11279
  this._portalService.naviationStart(event);
@@ -11257,6 +11283,33 @@ class RootPortalComponent extends PageBaseComponent {
11257
11283
  }
11258
11284
  });
11259
11285
  }
11286
+ onSendOfflineDataToServer() {
11287
+ BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineGoOnline, BarsaApi.BBB.Delete, function (buttonId) {
11288
+ if (buttonId === 'yes') {
11289
+ BarsaApi.Bw.Msg.Wait(0, BarsaApi.BBB.LoadingMaskMsg, 'wait');
11290
+ BarsaApi.Offline.GoOnline(function () {
11291
+ window.location.reload();
11292
+ });
11293
+ }
11294
+ });
11295
+ }
11296
+ onRemoveOfflineDataAndReturnToOnline() {
11297
+ BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineClearAll, BarsaApi.BBB.Delete, function (buttonId) {
11298
+ if (buttonId === 'yes') {
11299
+ BarsaApi.Offline.ClearAll();
11300
+ window.location.reload();
11301
+ }
11302
+ });
11303
+ }
11304
+ onRemoveOfflineData() {
11305
+ BarsaApi.Bw.Msg.YesNo(BarsaApi.BBB.OfflineClearUnsavedData, BarsaApi.BBB.Delete, function (buttonId) {
11306
+ if (buttonId === 'yes') {
11307
+ BarsaApi.Offline.CachedData.UnsavedData = {};
11308
+ BarsaApi.Offline.CachedData.save();
11309
+ BarsaApi.Bw.Toast.Success(BarsaApi.BBB.Action + BarsaApi.BBB.JobCompleted);
11310
+ }
11311
+ });
11312
+ }
11260
11313
  addFooter(pageData) {
11261
11314
  if (!pageData?.Footer) {
11262
11315
  return;
@@ -11308,11 +11361,19 @@ class RootPortalComponent extends PageBaseComponent {
11308
11361
  }
11309
11362
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: RootPortalComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
11310
11363
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: RootPortalComponent, selector: "bnrc-root-portal", viewQueries: [{ propertyName: "sectionRef", first: true, predicate: ["sectionRef"], descendants: true }, { propertyName: "footerRefVcr", first: true, predicate: ["footerRef"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: `
11311
- <!-- @if(inLocalMode){
11312
- <div style="height:100px;background:red"></div>
11313
- }
11314
- -->
11315
- @if (imageUrl) {
11364
+ @if(inLocalMode){
11365
+ <div class="fd-toolbar" style="flex-wrap:wrap;padding:0.5rem;height:auto">
11366
+ <button class="fd-button fd-button--attention is-compact" (click)="onRemoveOfflineData()">
11367
+ حذف اطلاعات آفلاین
11368
+ </button>
11369
+ <button class="fd-button fd-button--negative is-compact" (click)="onRemoveOfflineDataAndReturnToOnline()">
11370
+ حذف اطلاعات آفلاین و برگشت به حالت آنلاین
11371
+ </button>
11372
+ <button class="fd-button fd-button--positive is-compact" (click)="onSendOfflineDataToServer()">
11373
+ ارسال اطلاعات آفلاین به سرور
11374
+ </button>
11375
+ </div>
11376
+ } @if (imageUrl) {
11316
11377
  <div id="headerSpaceHolder" #headerSpaceHolder>
11317
11378
  <div id="bgOuterHolder" #bgOuterHolder>
11318
11379
  <div id="bgInnerHolder" style="height: 100vh">
@@ -11339,11 +11400,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
11339
11400
  args: [{
11340
11401
  selector: 'bnrc-root-portal',
11341
11402
  template: `
11342
- <!-- @if(inLocalMode){
11343
- <div style="height:100px;background:red"></div>
11344
- }
11345
- -->
11346
- @if (imageUrl) {
11403
+ @if(inLocalMode){
11404
+ <div class="fd-toolbar" style="flex-wrap:wrap;padding:0.5rem;height:auto">
11405
+ <button class="fd-button fd-button--attention is-compact" (click)="onRemoveOfflineData()">
11406
+ حذف اطلاعات آفلاین
11407
+ </button>
11408
+ <button class="fd-button fd-button--negative is-compact" (click)="onRemoveOfflineDataAndReturnToOnline()">
11409
+ حذف اطلاعات آفلاین و برگشت به حالت آنلاین
11410
+ </button>
11411
+ <button class="fd-button fd-button--positive is-compact" (click)="onSendOfflineDataToServer()">
11412
+ ارسال اطلاعات آفلاین به سرور
11413
+ </button>
11414
+ </div>
11415
+ } @if (imageUrl) {
11347
11416
  <div id="headerSpaceHolder" #headerSpaceHolder>
11348
11417
  <div id="bgOuterHolder" #bgOuterHolder>
11349
11418
  <div id="bgInnerHolder" style="height: 100vh">