@simpleangularcontrols/sac-bootstrap5 16.0.0-rc.2 → 16.0.0-rc.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/components/browser/browser.d.ts +6 -6
- package/controls/buttons/index.d.ts +1 -0
- package/controls/checkbox/checkbox.d.ts +5 -5
- package/controls/checkbox/radiobuttons.d.ts +5 -5
- package/controls/contextmenu/contextmenu.d.ts +6 -6
- package/controls/contextmenu/contextmenuanchor.d.ts +2 -2
- package/controls/contextmenu/contextmenucontainer.d.ts +2 -2
- package/controls/datetime/date.d.ts +6 -6
- package/controls/datetime/datetime.d.ts +6 -6
- package/controls/datetime/time.d.ts +6 -6
- package/controls/dialog/index.d.ts +1 -0
- package/controls/form/form.d.ts +3 -11
- package/controls/form/inheritform.directive.d.ts +11 -11
- package/controls/input/input.d.ts +5 -5
- package/controls/input/inputarea.d.ts +5 -5
- package/controls/input/inputcurrency.d.ts +5 -5
- package/controls/input/inputdecimal.d.ts +5 -5
- package/controls/input/inputemail.d.ts +5 -5
- package/controls/input/inputinteger.d.ts +5 -5
- package/controls/input/inputpassword.d.ts +5 -5
- package/controls/input/inputsearch.d.ts +5 -5
- package/controls/layout/formlayout.directive.d.ts +6 -0
- package/controls/layout/layout.module.d.ts +10 -0
- package/controls/layout/tocontrolwidthcss.pipe.d.ts +19 -0
- package/controls/layout/tolabelwidthcss.pipe.d.ts +13 -0
- package/controls/list/dropdown.d.ts +10 -10
- package/controls/list/listbox.d.ts +8 -8
- package/controls/multilanguage/multilanguageinput.d.ts +5 -5
- package/controls/multilanguage/multilanguageinputarea.d.ts +5 -5
- package/controls/multilanguage/multilanguagemenu.d.ts +9 -9
- package/controls/multilanguage/multilanguagemenuanchor.d.ts +2 -2
- package/controls/multilanguage/multilanguagemenucontainer.d.ts +2 -2
- package/controls/static/formcontainer.d.ts +5 -5
- package/controls/static/staticlabel.d.ts +5 -5
- package/controls/tinymce/tinymce.d.ts +7 -7
- package/controls/upload/dropzonemultiple.d.ts +7 -7
- package/controls/upload/dropzonesingle.d.ts +7 -7
- package/controls/upload/upload.d.ts +7 -7
- package/controls/upload/uploadmultiple.d.ts +7 -7
- package/controls/validation/validationsummary.d.ts +4 -4
- package/esm2022/components/browser/browser.mjs +13 -9
- package/esm2022/controls/buttons/button.mjs +3 -3
- package/esm2022/controls/buttons/index.mjs +2 -0
- package/esm2022/controls/checkbox/checkbox.mjs +16 -18
- package/esm2022/controls/checkbox/radiobuttons.mjs +17 -19
- package/esm2022/controls/contextmenu/contextmenu.mjs +10 -9
- package/esm2022/controls/contextmenu/contextmenuanchor.mjs +5 -4
- package/esm2022/controls/contextmenu/contextmenucontainer.mjs +5 -4
- package/esm2022/controls/contextmenu/contextmenuitembutton.mjs +3 -2
- package/esm2022/controls/contextmenu/contextmenuitemsplitter.mjs +1 -1
- package/esm2022/controls/datetime/date.mjs +24 -14
- package/esm2022/controls/datetime/dateselector.mjs +3 -8
- package/esm2022/controls/datetime/datetime.mjs +25 -15
- package/esm2022/controls/datetime/time.mjs +26 -16
- package/esm2022/controls/dialog/index.mjs +2 -0
- package/esm2022/controls/form/form.mjs +6 -17
- package/esm2022/controls/form/inheritform.directive.mjs +31 -28
- package/esm2022/controls/grid/paging.mjs +13 -10
- package/esm2022/controls/input/input.mjs +22 -14
- package/esm2022/controls/input/inputarea.mjs +21 -13
- package/esm2022/controls/input/inputcurrency.mjs +21 -13
- package/esm2022/controls/input/inputdecimal.mjs +22 -14
- package/esm2022/controls/input/inputemail.mjs +22 -14
- package/esm2022/controls/input/inputinteger.mjs +21 -13
- package/esm2022/controls/input/inputpassword.mjs +22 -14
- package/esm2022/controls/input/inputsearch.mjs +16 -13
- package/esm2022/controls/layout/formlayout.directive.mjs +16 -0
- package/esm2022/controls/layout/layout.module.mjs +34 -0
- package/esm2022/controls/layout/tocontrolwidthcss.pipe.mjs +59 -0
- package/esm2022/controls/layout/tolabelwidthcss.pipe.mjs +43 -0
- package/esm2022/controls/list/dropdown.mjs +27 -23
- package/esm2022/controls/list/listbox.mjs +25 -22
- package/esm2022/controls/multilanguage/multilanguageinput.mjs +21 -15
- package/esm2022/controls/multilanguage/multilanguageinputarea.mjs +20 -14
- package/esm2022/controls/multilanguage/multilanguagemenu.mjs +11 -9
- package/esm2022/controls/multilanguage/multilanguagemenuanchor.mjs +5 -4
- package/esm2022/controls/multilanguage/multilanguagemenucontainer.mjs +5 -4
- package/esm2022/controls/multilanguage/multilanguagemenuitembutton.mjs +3 -2
- package/esm2022/controls/static/formcontainer.mjs +19 -14
- package/esm2022/controls/static/staticlabel.mjs +16 -13
- package/esm2022/controls/tinymce/tinymce.mjs +25 -19
- package/esm2022/controls/upload/dropzonemultiple.mjs +25 -13
- package/esm2022/controls/upload/dropzonesingle.mjs +26 -14
- package/esm2022/controls/upload/upload.mjs +22 -13
- package/esm2022/controls/upload/uploadmultiple.mjs +23 -13
- package/esm2022/controls/validation/validationsummary.mjs +10 -17
- package/esm2022/public-api.mjs +30 -25
- package/fesm2022/simpleangularcontrols-sac-bootstrap5.mjs +714 -452
- package/fesm2022/simpleangularcontrols-sac-bootstrap5.mjs.map +1 -1
- package/package.json +4 -3
- package/public-api.d.ts +29 -24
- package/simpleangularcontrols-sac-bootstrap5-16.0.0-rc.4.tgz +0 -0
- package/simpleangularcontrols-sac-bootstrap5-16.0.0-rc.2.tgz +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injector } from '@angular/core';
|
|
2
2
|
import { IconType, SacMultilanguageInputAreaCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Componente für Mehrsprache Texte als mehrzeiliger Text
|
|
@@ -11,11 +11,11 @@ export declare class SacMultilanguageInputAreaComponent extends SacMultilanguage
|
|
|
11
11
|
*/
|
|
12
12
|
IconType: typeof IconType;
|
|
13
13
|
/**
|
|
14
|
-
*
|
|
15
|
-
* @param
|
|
16
|
-
* @param injector
|
|
14
|
+
* Constructor
|
|
15
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
16
|
+
* @param injector Injector for injecting services
|
|
17
17
|
*/
|
|
18
|
-
constructor(
|
|
18
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector);
|
|
19
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacMultilanguageInputAreaComponent, [{ optional: true; host: true; }, null]>;
|
|
20
20
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacMultilanguageInputAreaComponent, "sac-multilanguageinputarea", never, {}, {}, never, never, true, never>;
|
|
21
21
|
}
|
|
@@ -5,15 +5,6 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
* Component für Contextmenü
|
|
6
6
|
*/
|
|
7
7
|
export declare class SacMultilanguagemenuComponent extends SacContextmenuCommon {
|
|
8
|
-
/**
|
|
9
|
-
* Constructor
|
|
10
|
-
* @param _document Referenz auf HTML Document
|
|
11
|
-
* @param _ngZone Angular Zone Service
|
|
12
|
-
* @param _elementRef Referenz auf HTML Element der aktuellen Komponente
|
|
13
|
-
* @param _renderer Render Service von Angular
|
|
14
|
-
* @param _injector injector to resolve services in base component
|
|
15
|
-
*/
|
|
16
|
-
constructor(_document: any, _ngZone: NgZone, _elementRef: ElementRef<HTMLElement>, _renderer: Renderer2, _injector: Injector);
|
|
17
8
|
/**
|
|
18
9
|
* template with input box for multilangauge component
|
|
19
10
|
*/
|
|
@@ -22,6 +13,15 @@ export declare class SacMultilanguagemenuComponent extends SacContextmenuCommon
|
|
|
22
13
|
* template with markup for inline validation messages in component
|
|
23
14
|
*/
|
|
24
15
|
validationtemplate: TemplateRef<any>;
|
|
16
|
+
/**
|
|
17
|
+
* Constructor
|
|
18
|
+
* @param document Referenz auf HTML Document
|
|
19
|
+
* @param ngZone Angular Zone Service
|
|
20
|
+
* @param elementRef Referenz auf HTML Element der aktuellen Komponente
|
|
21
|
+
* @param renderer Render Service von Angular
|
|
22
|
+
* @param injector injector to resolve services in base component
|
|
23
|
+
*/
|
|
24
|
+
constructor(document: any, ngZone: NgZone, elementRef: ElementRef<HTMLElement>, renderer: Renderer2, injector: Injector);
|
|
25
25
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacMultilanguagemenuComponent, never>;
|
|
26
26
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacMultilanguagemenuComponent, "[sac-multilanguagemenu]", never, { "inputtemplate": { "alias": "inputtemplate"; "required": false; }; "validationtemplate": { "alias": "validationtemplate"; "required": false; }; }, {}, never, ["*"], true, never>;
|
|
27
27
|
}
|
|
@@ -7,9 +7,9 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
export declare class SacMultilanguagemenuAnchorDirective extends SacContextmenuAnchorCommon {
|
|
8
8
|
/**
|
|
9
9
|
* Konstruktor
|
|
10
|
-
* @param
|
|
10
|
+
* @param elementRef HTML DOM Referenz
|
|
11
11
|
*/
|
|
12
|
-
constructor(
|
|
12
|
+
constructor(elementRef: ElementRef<HTMLElement>);
|
|
13
13
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacMultilanguagemenuAnchorDirective, never>;
|
|
14
14
|
static ɵdir: i0.ɵɵDirectiveDeclaration<SacMultilanguagemenuAnchorDirective, "[sacMultilanguageMenuAnchor]", never, {}, {}, never, never, true, never>;
|
|
15
15
|
}
|
|
@@ -7,9 +7,9 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
export declare class SacMultilanguagemenuContainerDirective extends SacContextMenuContrainerCommon {
|
|
8
8
|
/**
|
|
9
9
|
* Konstruktor
|
|
10
|
-
* @param
|
|
10
|
+
* @param elementRef Referenz auf DOM Element
|
|
11
11
|
*/
|
|
12
|
-
constructor(
|
|
12
|
+
constructor(elementRef: ElementRef<HTMLElement>);
|
|
13
13
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacMultilanguagemenuContainerDirective, never>;
|
|
14
14
|
static ɵdir: i0.ɵɵDirectiveDeclaration<SacMultilanguagemenuContainerDirective, "[sacMultilanguageMenuContainer]", never, {}, {}, never, never, true, never>;
|
|
15
15
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injector } from '@angular/core';
|
|
2
|
-
import { SacFormDirective } from '../form/form';
|
|
3
2
|
import { SacStaticFormContainerCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Component für einbindung eines beliebigen Controls in die Form Struktur
|
|
@@ -18,11 +18,11 @@ import * as i0 from "@angular/core";
|
|
|
18
18
|
**/
|
|
19
19
|
export declare class SacStaticFormContainerComponent extends SacStaticFormContainerCommon {
|
|
20
20
|
/**
|
|
21
|
-
*
|
|
22
|
-
* @param
|
|
23
|
-
* @param injector Injector
|
|
21
|
+
* Constructor
|
|
22
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
23
|
+
* @param injector Injector for injecting services
|
|
24
24
|
*/
|
|
25
|
-
constructor(
|
|
25
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector);
|
|
26
26
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacStaticFormContainerComponent, [{ optional: true; host: true; }, null]>;
|
|
27
27
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacStaticFormContainerComponent, "sac-staticformcontainer", never, {}, {}, never, ["*"], true, never>;
|
|
28
28
|
}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { Injector } from '@angular/core';
|
|
2
2
|
import { SacStaticLabelCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Komponente für statischen Text in einem Formular
|
|
7
7
|
*/
|
|
8
8
|
export declare class SacStaticLabelComponent extends SacStaticLabelCommon {
|
|
9
9
|
/**
|
|
10
|
-
*
|
|
11
|
-
* @param
|
|
12
|
-
* @param injector
|
|
10
|
+
* Constructor
|
|
11
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
12
|
+
* @param injector Injector for injecting services
|
|
13
13
|
*/
|
|
14
|
-
constructor(
|
|
14
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector);
|
|
15
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacStaticLabelComponent, [{ optional: true; host: true; }, null]>;
|
|
16
16
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacStaticLabelComponent, "sac-staticlabel", never, {}, {}, never, never, true, never>;
|
|
17
17
|
}
|
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
import { Injector, NgZone } from '@angular/core';
|
|
2
2
|
import { SacTinyMceCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* TinyMCE Komponente
|
|
7
7
|
*/
|
|
8
8
|
export declare class SacTinyMceComponent extends SacTinyMceCommon {
|
|
9
9
|
/**
|
|
10
|
-
*
|
|
11
|
-
* @param
|
|
12
|
-
* @param injector
|
|
13
|
-
* @param ngZone ngZone
|
|
10
|
+
* Constructor
|
|
11
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
12
|
+
* @param injector Injector for injecting services
|
|
13
|
+
* @param ngZone ngZone to manage external javascripts
|
|
14
14
|
*/
|
|
15
|
-
constructor(
|
|
15
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector, ngZone: NgZone);
|
|
16
16
|
/**
|
|
17
17
|
* overwrite tinymce defaults
|
|
18
|
-
* @returns
|
|
18
|
+
* @returns boostrap5 has no overwrites
|
|
19
19
|
*/
|
|
20
20
|
overwriteDefaultSettings(): {};
|
|
21
21
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacTinyMceComponent, [{ optional: true; host: true; }, null, null]>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injector, NgZone, OnInit, Renderer2 } from '@angular/core';
|
|
2
2
|
import { SacDropzoneMultipleCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Dropzone Komponente für mehrere Uploads
|
|
@@ -8,13 +8,13 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
*/
|
|
9
9
|
export declare class SacDropzoneMultipleComponent extends SacDropzoneMultipleCommon implements OnInit {
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
12
|
-
* @param
|
|
13
|
-
* @param injector
|
|
14
|
-
* @param renderer Angular
|
|
15
|
-
* @param ngZone ngZone
|
|
11
|
+
* Constructor
|
|
12
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
13
|
+
* @param injector Injector for injecting services
|
|
14
|
+
* @param renderer Angular rendering engine
|
|
15
|
+
* @param ngZone ngZone to manage external javascripts
|
|
16
16
|
*/
|
|
17
|
-
constructor(
|
|
17
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector, renderer: Renderer2, ngZone: NgZone);
|
|
18
18
|
/**
|
|
19
19
|
* Initialisiert das Control
|
|
20
20
|
*/
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injector, NgZone, OnInit, Renderer2 } from '@angular/core';
|
|
2
2
|
import { SacDropzoneSingleCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Dropzone Komponente für den Upload eines Files
|
|
@@ -8,13 +8,13 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
*/
|
|
9
9
|
export declare class SacDropzoneSingleComponent extends SacDropzoneSingleCommon implements OnInit {
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
12
|
-
* @param
|
|
13
|
-
* @param injector
|
|
14
|
-
* @param renderer Angular
|
|
15
|
-
* @param ngZone ngZone
|
|
11
|
+
* Constructor
|
|
12
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
13
|
+
* @param injector Injector for injecting services
|
|
14
|
+
* @param renderer Angular rendering engine
|
|
15
|
+
* @param ngZone ngZone to manage external javascripts
|
|
16
16
|
*/
|
|
17
|
-
constructor(
|
|
17
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector, renderer: Renderer2, ngZone: NgZone);
|
|
18
18
|
/**
|
|
19
19
|
* Initialisiert das Control
|
|
20
20
|
*/
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injector, NgZone, Renderer2 } from '@angular/core';
|
|
2
2
|
import { SacUploadSingleCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Upload Komponten
|
|
@@ -8,13 +8,13 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
*/
|
|
9
9
|
export declare class SacUploadComponent extends SacUploadSingleCommon {
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
12
|
-
* @param
|
|
13
|
-
* @param injector
|
|
14
|
-
* @param renderer Angular
|
|
15
|
-
* @param ngZone ngZone
|
|
11
|
+
* Constructor
|
|
12
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
13
|
+
* @param injector Injector for injecting services
|
|
14
|
+
* @param renderer Angular rendering engine
|
|
15
|
+
* @param ngZone ngZone to manage external javascripts
|
|
16
16
|
*/
|
|
17
|
-
constructor(
|
|
17
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector, renderer: Renderer2, ngZone: NgZone);
|
|
18
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacUploadComponent, [{ optional: true; host: true; }, null, null, null]>;
|
|
19
19
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacUploadComponent, "sac-upload", never, {}, {}, never, never, true, never>;
|
|
20
20
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Injector, NgZone, Renderer2 } from '@angular/core';
|
|
2
2
|
import { SacUploadMultipleCommon } from '@simpleangularcontrols/sac-common';
|
|
3
|
-
import {
|
|
3
|
+
import { SacFormLayoutDirective } from '../layout/formlayout.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Upload Komponente für den Upload mehrer Files
|
|
@@ -8,13 +8,13 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
*/
|
|
9
9
|
export declare class SacUploadMultipleComponent extends SacUploadMultipleCommon {
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
12
|
-
* @param
|
|
13
|
-
* @param injector
|
|
14
|
-
* @param renderer Angular
|
|
15
|
-
* @param ngZone ngZone
|
|
11
|
+
* Constructor
|
|
12
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
13
|
+
* @param injector Injector for injecting services
|
|
14
|
+
* @param renderer Angular rendering engine
|
|
15
|
+
* @param ngZone ngZone to manage external javascripts
|
|
16
16
|
*/
|
|
17
|
-
constructor(
|
|
17
|
+
constructor(formLayout: SacFormLayoutDirective, injector: Injector, renderer: Renderer2, ngZone: NgZone);
|
|
18
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacUploadMultipleComponent, [{ optional: true; host: true; }, null, null, null]>;
|
|
19
19
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacUploadMultipleComponent, "sac-uploadmultiple", never, {}, {}, never, never, true, never>;
|
|
20
20
|
}
|
|
@@ -7,11 +7,11 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
*/
|
|
8
8
|
export declare class SacValidationSummaryComponent extends SacValidationSummaryCommon {
|
|
9
9
|
/**
|
|
10
|
-
*
|
|
11
|
-
* @param
|
|
12
|
-
* @param injector
|
|
10
|
+
* Constructor
|
|
11
|
+
* @param formControl Instance of Form Component to receive invalid form controls
|
|
12
|
+
* @param injector Injector for injecting services
|
|
13
13
|
*/
|
|
14
|
-
constructor(
|
|
14
|
+
constructor(formControl: SacFormDirective, injector: Injector);
|
|
15
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<SacValidationSummaryComponent, [{ optional: true; host: true; }, null]>;
|
|
16
16
|
static ɵcmp: i0.ɵɵComponentDeclaration<SacValidationSummaryComponent, "sac-validationsummary", never, {}, {}, never, never, true, never>;
|
|
17
17
|
}
|
|
@@ -17,6 +17,8 @@ import * as i3 from "@angular/forms";
|
|
|
17
17
|
* Server File Browser Komponente
|
|
18
18
|
*/
|
|
19
19
|
class SacBrowserComponent extends SacFileBrowserCommon {
|
|
20
|
+
// #endregion Properties
|
|
21
|
+
// #region Constructors
|
|
20
22
|
/**
|
|
21
23
|
* Konstruktor
|
|
22
24
|
* @param httpClient HTTP Client
|
|
@@ -27,14 +29,8 @@ class SacBrowserComponent extends SacFileBrowserCommon {
|
|
|
27
29
|
super(httpClient, injector);
|
|
28
30
|
this.confirmService = confirmService;
|
|
29
31
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
* @param anzahl Grösse des Array
|
|
33
|
-
* @returns Array
|
|
34
|
-
*/
|
|
35
|
-
count(anzahl) {
|
|
36
|
-
return new Array(anzahl);
|
|
37
|
-
}
|
|
32
|
+
// #endregion Constructors
|
|
33
|
+
// #region Public Methods
|
|
38
34
|
/**
|
|
39
35
|
* Confirm Action wenn ein File gelöscht werden soll
|
|
40
36
|
* @param file File das gelöscht werden soll.
|
|
@@ -85,6 +81,14 @@ class SacBrowserComponent extends SacFileBrowserCommon {
|
|
|
85
81
|
});
|
|
86
82
|
});
|
|
87
83
|
}
|
|
84
|
+
/**
|
|
85
|
+
* Erzeugt ein Array von einer bestimmten grösse
|
|
86
|
+
* @param anzahl Grösse des Array
|
|
87
|
+
* @returns Array
|
|
88
|
+
*/
|
|
89
|
+
count(anzahl) {
|
|
90
|
+
return new Array(anzahl);
|
|
91
|
+
}
|
|
88
92
|
/**
|
|
89
93
|
* Methode wird aufgerufen, wenn eine Datei verschoben wird
|
|
90
94
|
* @param uploadid Upload ID
|
|
@@ -118,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
118
122
|
type: ViewChild,
|
|
119
123
|
args: [SacDropzoneMultipleComponent, { static: false }]
|
|
120
124
|
}] } });
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browser.js","sourceRoot":"","sources":["../../../../../projects/sac-bootstrap5/src/components/browser/browser.ts","../../../../../projects/sac-bootstrap5/src/components/browser/browser.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AsyncPipe,\r\n  NgClass,\r\n  NgForOf,\r\n  NgIf,\r\n  NgTemplateOutlet,\r\n} from '@angular/common';\r\nimport { HttpClient, HttpClientModule } from '@angular/common/http';\r\nimport { Component, Injector, ViewChild } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport {\r\n  IBrowserFile,\r\n  IBrowserNode,\r\n  SacFileBrowserCommon,\r\n} from '@simpleangularcontrols/sac-common';\r\nimport { Observable, forkJoin } from 'rxjs';\r\nimport { ServiceConfirm } from '../../controls/confirm/confirm.service';\r\nimport { SacContextmenuComponent } from '../../controls/contextmenu';\r\nimport { SacContextmenuItemButtonComponent } from '../../controls/contextmenu/contextmenuitembutton';\r\nimport { SacContextmenuItemSplitterComponent } from '../../controls/contextmenu/contextmenuitemsplitter';\r\nimport { SacDropzoneMultipleComponent } from '../../controls/upload/dropzonemultiple';\r\n\r\n/**\r\n * Server File Browser Komponente\r\n */\r\n@Component({\r\n  selector: 'sac-filebrowser',\r\n  templateUrl: './browser.html',\r\n  standalone: true,\r\n  imports: [\r\n    NgTemplateOutlet,\r\n    NgIf,\r\n    NgForOf,\r\n    NgClass,\r\n    AsyncPipe,\r\n    FormsModule,\r\n    HttpClientModule,\r\n    SacContextmenuComponent,\r\n    SacContextmenuItemButtonComponent,\r\n    SacContextmenuItemSplitterComponent,\r\n    SacDropzoneMultipleComponent,\r\n  ],\r\n  providers: [ServiceConfirm],\r\n})\r\nexport class SacBrowserComponent extends SacFileBrowserCommon {\r\n  /**\r\n   * Referenz auf Upload Component\r\n   */\r\n  @ViewChild(SacDropzoneMultipleComponent, { static: false })\r\n  private uploadComponent: SacDropzoneMultipleComponent;\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param httpClient HTTP Client\r\n   * @param injector Angular Dependency Injection Service\r\n   * @param confirmService Confirm Service\r\n   */\r\n  constructor(\r\n    httpClient: HttpClient,\r\n    injector: Injector,\r\n    private confirmService: ServiceConfirm\r\n  ) {\r\n    super(httpClient, injector);\r\n  }\r\n\r\n  /**\r\n   * Erzeugt ein Array von einer bestimmten grösse\r\n   * @param anzahl Grösse des Array\r\n   * @returns Array\r\n   */\r\n  public count(anzahl: number): Array<void> {\r\n    return new Array(anzahl);\r\n  }\r\n\r\n  /**\r\n   * Confirm Action wenn ein File gelöscht werden soll\r\n   * @param file File das gelöscht werden soll.\r\n   * @returns Observable ob File gelöscht werden kann.\r\n   */\r\n  confirmDeleteFile(file: IBrowserFile): Observable<boolean> {\r\n    return new Observable<boolean>((observer) => {\r\n      forkJoin({\r\n        title: this.lngResourceService.GetString('FILEBROWSER_DELETE'),\r\n        message: this.lngResourceService.GetString(\r\n          'FILEBROWSER_CONFIRM_DELETEFILE'\r\n        ),\r\n      }).subscribe((text) => {\r\n        this.confirmService\r\n          .ConfirmMessage(text.title, text.message)\r\n          .subscribe((result) => {\r\n            if (result === 'yes') {\r\n              observer.next(true);\r\n            } else {\r\n              observer.next(false);\r\n            }\r\n            observer.complete();\r\n          });\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Confirm Action wenn ein Ordner gelöscht werden soll\r\n   * @param node Ordner der gelöscht werden soll\r\n   * @returns Observable ob Ordner gelöscht kann.\r\n   */\r\n  confirmDeleteNode(node: IBrowserNode): Observable<boolean> {\r\n    return new Observable<boolean>((observer) => {\r\n      forkJoin({\r\n        title: this.lngResourceService.GetString('FILEBROWSER_DELETE'),\r\n        message: this.lngResourceService.GetString(\r\n          'FILEBROWSER_CONFIRM_DELETEFOLDER'\r\n        ),\r\n      }).subscribe((text) => {\r\n        this.confirmService\r\n          .ConfirmMessage(text.title, text.message)\r\n          .subscribe((result) => {\r\n            if (result === 'yes') {\r\n              observer.next(true);\r\n            } else {\r\n              observer.next(false);\r\n            }\r\n            observer.complete();\r\n          });\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Methode wird aufgerufen, wenn eine Datei verschoben wird\r\n   * @param uploadid Upload ID\r\n   */\r\n  uploadedFileMoved(uploadid: string): void {\r\n    const item = this.uploadComponent.uploads.find(\r\n      (itm) => itm.documentid === uploadid\r\n    );\r\n\r\n    if (item) {\r\n      this.uploadComponent.cancel(item.uploadId);\r\n    }\r\n  }\r\n}\r\n","<div class=\"row\">\r\n  <div class=\"col-12 col-md-5 col-lg-4\">\r\n    <ul class=\"list-group list-group-flush\">\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"treeItem\"\r\n        [ngTemplateOutletContext]=\"{node: rootNode, deep: 0}\"\r\n      ></ng-template>\r\n    </ul>\r\n\r\n    <ng-template #treeItem let-node=\"node\" let-deep=\"deep\">\r\n      <li\r\n        class=\"list-group-item py-1 px-2 d-flex align-items-center\"\r\n        [class.list-group-item-secondary]=\"node === selectedNode\"\r\n        (click)=\"selectNode(node)\"\r\n        style=\"cursor: pointer\"\r\n      >\r\n        <div class=\"mx-3\" *ngFor=\"let i of count(deep)\"></div>\r\n        <div\r\n          (click)=\"switchExpandNode(node);$event.stopPropagation();\"\r\n          class=\"me-2\"\r\n          [ngClass]=\"node.ChildNodes.length === 0 ? iconFolderEmpty: (!node.IsExpanded && node.ChildNodes.length > 0 ? iconFolderCollabsed : (node.IsExpanded && node.ChildNodes.length > 0 ? iconFolderOpen : ''))\"\r\n        ></div>\r\n        <ng-container *ngIf=\"!node.IsEditMode\">\r\n          <div class=\"flex-grow-1\">{{ node.Name }}</div>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"node.IsEditMode\">\r\n          <div class=\"flex-grow-1\" ngForm>\r\n            <input\r\n              name=\"editFolder\"\r\n              class=\"form-control form-control-sm\"\r\n              [ngModel]=\"node.Name\"\r\n              [ngModelOptions]=\"{updateOn: 'blur'}\"\r\n              (ngModelChange)=\"renameNode(node, $event)\"\r\n              (keydown.enter)=\"$event.target.blur();false;\"\r\n              (blur)=\"renameNode(node, null)\"\r\n              (click)=\"$event.stopPropagation()\"\r\n            />\r\n          </div>\r\n        </ng-container>\r\n        <div class=\"flex-shrink-0\">\r\n          <a\r\n            *ngIf=\"node.Path !== '/' && allowfolderrename\"\r\n            class=\"btn btn-sm btn-link text-secondary\"\r\n            (click)=\"editNode(node);$event.stopPropagation();\"\r\n          >\r\n            <i [class]=\"iconEdit\"></i>\r\n          </a>\r\n          <sac-contextmenu cssclass=\"d-inline-block\">\r\n            <sac-contextmenubutton\r\n              *ngIf=\"allowfoldercreate\"\r\n              text=\"{{ lngResourceService.GetString('FILEBROWSER_NEWFOLDER') | async }}\"\r\n              [icon]=\"iconFolderNew\"\r\n              (clicked)=\"newNode(node)\"\r\n            ></sac-contextmenubutton>\r\n            <sac-contextmenubutton\r\n              *ngIf=\"node.Path !== '/' && allowfolderdelete\"\r\n              text=\"{{ lngResourceService.GetString('FILEBROWSER_DELETE') | async }}\"\r\n              [icon]=\"iconDelete\"\r\n              (clicked)=\"deleteNode(node)\"\r\n            ></sac-contextmenubutton>\r\n            <sac-contextmenusplitter\r\n              *ngIf=\"allowfoldercreate || (node.Path !== '/' && allowfolderdelete)\"\r\n            ></sac-contextmenusplitter>\r\n            <sac-contextmenubutton\r\n              text=\"{{ lngResourceService.GetString('FILEBROWSER_REFRESH') | async }}\"\r\n              [icon]=\"iconRefresh\"\r\n              (clicked)=\"refreshNode(node)\"\r\n            ></sac-contextmenubutton>\r\n          </sac-contextmenu>\r\n        </div>\r\n      </li>\r\n\r\n      <ng-container *ngIf=\"node.IsExpanded\">\r\n        <ng-template\r\n          *ngFor=\"let child of node.ChildNodes\"\r\n          [ngTemplateOutlet]=\"treeItem\"\r\n          [ngTemplateOutletContext]=\"{node: child, deep: deep + 1}\"\r\n        ></ng-template>\r\n      </ng-container>\r\n    </ng-template>\r\n  </div>\r\n  <div class=\"col-12 col-md-7 col-lg-8\">\r\n    <ng-container *ngIf=\"selectedNode && selectedNode.Files\">\r\n      <div *ngIf=\"allowfileupload\" ngForm>\r\n        <sac-dropzonemultiple\r\n          [disablelabel]=\"true\"\r\n          [endpoint]=\"apiurl + '/uploadregister'\"\r\n          name=\"upload\"\r\n          uploadheight=\"5rem\"\r\n          [ngModel]=\"uploads\"\r\n          (ngModelChange)=\"uploadComplete(selectedNode,$event)\"\r\n          [allowedtypes]=\"allowedtypes\"\r\n          >{{ lngResourceService.GetString('FILEBROWSER_UPLOAD') | async\r\n          }}</sac-dropzonemultiple\r\n        >\r\n      </div>\r\n      <div class=\"table-responsive\">\r\n        <table class=\"table table-striped table-hover align-middle\">\r\n          <thead>\r\n            <th>\r\n              {{ lngResourceService.GetString('FILEBROWSER_GRID_FILE') | async\r\n              }}\r\n            </th>\r\n            <th>\r\n              {{ lngResourceService.GetString('FILEBROWSER_GRID_SIZE') | async\r\n              }}\r\n            </th>\r\n            <th style=\"width: 80px\"></th>\r\n          </thead>\r\n          <tbody>\r\n            <ng-container *ngIf=\"selectedNode.Files.length === 0\">\r\n              <tr>\r\n                <td colspan=\"3\">\r\n                  {{ lngResourceService.GetString('FILEBROWSER_NO_FILES') |\r\n                  async }}\r\n                </td>\r\n              </tr>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"selectedNode.Files.length > 0\">\r\n              <tr\r\n                *ngFor=\"let item of selectedNode.Files\"\r\n                (click)=\"selectFile(item)\"\r\n                [class.table-primary]=\"selectedFileItem === item\"\r\n              >\r\n                <td [class.p-2]=\"item.IsEditMode\">\r\n                  <ng-container *ngIf=\"!item.IsEditMode\">\r\n                    {{ item.Filename }}\r\n                  </ng-container>\r\n                  <ng-container *ngIf=\"item.IsEditMode\">\r\n                    <div>\r\n                      <input\r\n                        name=\"editFolder\"\r\n                        class=\"form-control form-control-sm\"\r\n                        [ngModel]=\"item.Filename\"\r\n                        [ngModelOptions]=\"{updateOn: 'blur'}\"\r\n                        (ngModelChange)=\"renameFile(item, $event)\"\r\n                        (keydown.enter)=\"$event.target.blur();false\"\r\n                        (blur)=\"renameFile(item, null)\"\r\n                        (click)=\"$event.stopPropagation();\"\r\n                      />\r\n                    </div>\r\n                  </ng-container>\r\n                </td>\r\n                <td>{{ item.Size}}</td>\r\n                <td class=\"p-2\">\r\n                  <div class=\"btn-toolbar\" role=\"toolbar\">\r\n                    <div class=\"btn-group ml-auto\" role=\"group\">\r\n                      <a\r\n                        *ngIf=\"allowfilerename\"\r\n                        class=\"btn btn-sm btn-link text-secondary\"\r\n                        (click)=\"editFile(item);$event.stopPropagation();\"\r\n                        ><i [class]=\"iconEdit\"></i\r\n                      ></a>\r\n                    </div>\r\n                    <div class=\"btn-group\" role=\"group\">\r\n                      <a\r\n                        *ngIf=\"allowfiledelete\"\r\n                        class=\"btn btn-sm btn-link text-secondary\"\r\n                        (click)=\"deleteFile(item);$event.stopPropagation();\"\r\n                        ><i [class]=\"iconDelete\"></i\r\n                      ></a>\r\n                    </div>\r\n                  </div>\r\n                </td>\r\n              </tr>\r\n            </ng-container>\r\n          </tbody>\r\n        </table>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browser.js","sourceRoot":"","sources":["../../../../../projects/sac-bootstrap5/src/components/browser/browser.ts","../../../../../projects/sac-bootstrap5/src/components/browser/browser.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AsyncPipe,\r\n  NgClass,\r\n  NgForOf,\r\n  NgIf,\r\n  NgTemplateOutlet,\r\n} from '@angular/common';\r\nimport { HttpClient, HttpClientModule } from '@angular/common/http';\r\nimport { Component, Injector, ViewChild } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport {\r\n  IBrowserFile,\r\n  IBrowserNode,\r\n  SacFileBrowserCommon,\r\n} from '@simpleangularcontrols/sac-common';\r\nimport { Observable, forkJoin } from 'rxjs';\r\nimport { ServiceConfirm } from '../../controls/confirm/confirm.service';\r\nimport { SacContextmenuComponent } from '../../controls/contextmenu';\r\nimport { SacContextmenuItemButtonComponent } from '../../controls/contextmenu/contextmenuitembutton';\r\nimport { SacContextmenuItemSplitterComponent } from '../../controls/contextmenu/contextmenuitemsplitter';\r\nimport { SacDropzoneMultipleComponent } from '../../controls/upload/dropzonemultiple';\r\n\r\n/**\r\n * Server File Browser Komponente\r\n */\r\n@Component({\r\n  selector: 'sac-filebrowser',\r\n  templateUrl: './browser.html',\r\n  standalone: true,\r\n  imports: [\r\n    NgTemplateOutlet,\r\n    NgIf,\r\n    NgForOf,\r\n    NgClass,\r\n    AsyncPipe,\r\n    FormsModule,\r\n    HttpClientModule,\r\n    SacContextmenuComponent,\r\n    SacContextmenuItemButtonComponent,\r\n    SacContextmenuItemSplitterComponent,\r\n    SacDropzoneMultipleComponent,\r\n  ],\r\n  providers: [ServiceConfirm],\r\n})\r\nexport class SacBrowserComponent extends SacFileBrowserCommon {\r\n  // #region Properties\r\n\r\n  /**\r\n   * Referenz auf Upload Component\r\n   */\r\n  @ViewChild(SacDropzoneMultipleComponent, { static: false })\r\n  private uploadComponent: SacDropzoneMultipleComponent;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param httpClient HTTP Client\r\n   * @param injector Angular Dependency Injection Service\r\n   * @param confirmService Confirm Service\r\n   */\r\n  constructor(\r\n    httpClient: HttpClient,\r\n    injector: Injector,\r\n    private confirmService: ServiceConfirm\r\n  ) {\r\n    super(httpClient, injector);\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * Confirm Action wenn ein File gelöscht werden soll\r\n   * @param file File das gelöscht werden soll.\r\n   * @returns Observable ob File gelöscht werden kann.\r\n   */\r\n  public confirmDeleteFile(file: IBrowserFile): Observable<boolean> {\r\n    return new Observable<boolean>((observer) => {\r\n      forkJoin({\r\n        title: this.lngResourceService.GetString('FILEBROWSER_DELETE'),\r\n        message: this.lngResourceService.GetString(\r\n          'FILEBROWSER_CONFIRM_DELETEFILE'\r\n        ),\r\n      }).subscribe((text) => {\r\n        this.confirmService\r\n          .ConfirmMessage(text.title, text.message)\r\n          .subscribe((result) => {\r\n            if (result === 'yes') {\r\n              observer.next(true);\r\n            } else {\r\n              observer.next(false);\r\n            }\r\n            observer.complete();\r\n          });\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Confirm Action wenn ein Ordner gelöscht werden soll\r\n   * @param node Ordner der gelöscht werden soll\r\n   * @returns Observable ob Ordner gelöscht kann.\r\n   */\r\n  public confirmDeleteNode(node: IBrowserNode): Observable<boolean> {\r\n    return new Observable<boolean>((observer) => {\r\n      forkJoin({\r\n        title: this.lngResourceService.GetString('FILEBROWSER_DELETE'),\r\n        message: this.lngResourceService.GetString(\r\n          'FILEBROWSER_CONFIRM_DELETEFOLDER'\r\n        ),\r\n      }).subscribe((text) => {\r\n        this.confirmService\r\n          .ConfirmMessage(text.title, text.message)\r\n          .subscribe((result) => {\r\n            if (result === 'yes') {\r\n              observer.next(true);\r\n            } else {\r\n              observer.next(false);\r\n            }\r\n            observer.complete();\r\n          });\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Erzeugt ein Array von einer bestimmten grösse\r\n   * @param anzahl Grösse des Array\r\n   * @returns Array\r\n   */\r\n  public count(anzahl: number): Array<void> {\r\n    return new Array(anzahl);\r\n  }\r\n\r\n  /**\r\n   * Methode wird aufgerufen, wenn eine Datei verschoben wird\r\n   * @param uploadid Upload ID\r\n   */\r\n  public uploadedFileMoved(uploadid: string): void {\r\n    const item = this.uploadComponent.uploads.find(\r\n      (itm) => itm.documentid === uploadid\r\n    );\r\n\r\n    if (item) {\r\n      this.uploadComponent.cancel(item.uploadId);\r\n    }\r\n  }\r\n\r\n  // #endregion Public Methods\r\n}\r\n","<div class=\"row\">\r\n  <div class=\"col-12 col-md-5 col-lg-4\">\r\n    <ul class=\"list-group list-group-flush\">\r\n      <ng-template\r\n        [ngTemplateOutlet]=\"treeItem\"\r\n        [ngTemplateOutletContext]=\"{node: rootNode, deep: 0}\"\r\n      ></ng-template>\r\n    </ul>\r\n\r\n    <ng-template #treeItem let-node=\"node\" let-deep=\"deep\">\r\n      <li\r\n        class=\"list-group-item py-1 px-2 d-flex align-items-center\"\r\n        [class.list-group-item-secondary]=\"node === selectedNode\"\r\n        (click)=\"selectNode(node)\"\r\n        style=\"cursor: pointer\"\r\n      >\r\n        <div class=\"mx-3\" *ngFor=\"let i of count(deep)\"></div>\r\n        <div\r\n          (click)=\"switchExpandNode(node);$event.stopPropagation();\"\r\n          class=\"me-2\"\r\n          [ngClass]=\"node.ChildNodes.length === 0 ? iconFolderEmpty: (!node.IsExpanded && node.ChildNodes.length > 0 ? iconFolderCollabsed : (node.IsExpanded && node.ChildNodes.length > 0 ? iconFolderOpen : ''))\"\r\n        ></div>\r\n        <ng-container *ngIf=\"!node.IsEditMode\">\r\n          <div class=\"flex-grow-1\">{{ node.Name }}</div>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"node.IsEditMode\">\r\n          <div class=\"flex-grow-1\" ngForm>\r\n            <input\r\n              name=\"editFolder\"\r\n              class=\"form-control form-control-sm\"\r\n              [ngModel]=\"node.Name\"\r\n              [ngModelOptions]=\"{updateOn: 'blur'}\"\r\n              (ngModelChange)=\"renameNode(node, $event)\"\r\n              (keydown.enter)=\"$event.target.blur();false;\"\r\n              (blur)=\"renameNode(node, null)\"\r\n              (click)=\"$event.stopPropagation()\"\r\n            />\r\n          </div>\r\n        </ng-container>\r\n        <div class=\"flex-shrink-0\">\r\n          <a\r\n            *ngIf=\"node.Path !== '/' && allowfolderrename\"\r\n            class=\"btn btn-sm btn-link text-secondary\"\r\n            (click)=\"editNode(node);$event.stopPropagation();\"\r\n          >\r\n            <i [class]=\"iconEdit\"></i>\r\n          </a>\r\n          <sac-contextmenu cssclass=\"d-inline-block\">\r\n            <sac-contextmenubutton\r\n              *ngIf=\"allowfoldercreate\"\r\n              text=\"{{ lngResourceService.GetString('FILEBROWSER_NEWFOLDER') | async }}\"\r\n              [icon]=\"iconFolderNew\"\r\n              (clicked)=\"newNode(node)\"\r\n            ></sac-contextmenubutton>\r\n            <sac-contextmenubutton\r\n              *ngIf=\"node.Path !== '/' && allowfolderdelete\"\r\n              text=\"{{ lngResourceService.GetString('FILEBROWSER_DELETE') | async }}\"\r\n              [icon]=\"iconDelete\"\r\n              (clicked)=\"deleteNode(node)\"\r\n            ></sac-contextmenubutton>\r\n            <sac-contextmenusplitter\r\n              *ngIf=\"allowfoldercreate || (node.Path !== '/' && allowfolderdelete)\"\r\n            ></sac-contextmenusplitter>\r\n            <sac-contextmenubutton\r\n              text=\"{{ lngResourceService.GetString('FILEBROWSER_REFRESH') | async }}\"\r\n              [icon]=\"iconRefresh\"\r\n              (clicked)=\"refreshNode(node)\"\r\n            ></sac-contextmenubutton>\r\n          </sac-contextmenu>\r\n        </div>\r\n      </li>\r\n\r\n      <ng-container *ngIf=\"node.IsExpanded\">\r\n        <ng-template\r\n          *ngFor=\"let child of node.ChildNodes\"\r\n          [ngTemplateOutlet]=\"treeItem\"\r\n          [ngTemplateOutletContext]=\"{node: child, deep: deep + 1}\"\r\n        ></ng-template>\r\n      </ng-container>\r\n    </ng-template>\r\n  </div>\r\n  <div class=\"col-12 col-md-7 col-lg-8\">\r\n    <ng-container *ngIf=\"selectedNode && selectedNode.Files\">\r\n      <div *ngIf=\"allowfileupload\" ngForm>\r\n        <sac-dropzonemultiple\r\n          [disablelabel]=\"true\"\r\n          [endpoint]=\"apiurl + '/uploadregister'\"\r\n          name=\"upload\"\r\n          uploadheight=\"5rem\"\r\n          [ngModel]=\"uploads\"\r\n          (ngModelChange)=\"uploadComplete(selectedNode,$event)\"\r\n          [allowedtypes]=\"allowedtypes\"\r\n          >{{ lngResourceService.GetString('FILEBROWSER_UPLOAD') | async\r\n          }}</sac-dropzonemultiple\r\n        >\r\n      </div>\r\n      <div class=\"table-responsive\">\r\n        <table class=\"table table-striped table-hover align-middle\">\r\n          <thead>\r\n            <th>\r\n              {{ lngResourceService.GetString('FILEBROWSER_GRID_FILE') | async\r\n              }}\r\n            </th>\r\n            <th>\r\n              {{ lngResourceService.GetString('FILEBROWSER_GRID_SIZE') | async\r\n              }}\r\n            </th>\r\n            <th style=\"width: 80px\"></th>\r\n          </thead>\r\n          <tbody>\r\n            <ng-container *ngIf=\"selectedNode.Files.length === 0\">\r\n              <tr>\r\n                <td colspan=\"3\">\r\n                  {{ lngResourceService.GetString('FILEBROWSER_NO_FILES') |\r\n                  async }}\r\n                </td>\r\n              </tr>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"selectedNode.Files.length > 0\">\r\n              <tr\r\n                *ngFor=\"let item of selectedNode.Files\"\r\n                (click)=\"selectFile(item)\"\r\n                [class.table-primary]=\"selectedFileItem === item\"\r\n              >\r\n                <td [class.p-2]=\"item.IsEditMode\">\r\n                  <ng-container *ngIf=\"!item.IsEditMode\">\r\n                    {{ item.Filename }}\r\n                  </ng-container>\r\n                  <ng-container *ngIf=\"item.IsEditMode\">\r\n                    <div>\r\n                      <input\r\n                        name=\"editFolder\"\r\n                        class=\"form-control form-control-sm\"\r\n                        [ngModel]=\"item.Filename\"\r\n                        [ngModelOptions]=\"{updateOn: 'blur'}\"\r\n                        (ngModelChange)=\"renameFile(item, $event)\"\r\n                        (keydown.enter)=\"$event.target.blur();false\"\r\n                        (blur)=\"renameFile(item, null)\"\r\n                        (click)=\"$event.stopPropagation();\"\r\n                      />\r\n                    </div>\r\n                  </ng-container>\r\n                </td>\r\n                <td>{{ item.Size}}</td>\r\n                <td class=\"p-2\">\r\n                  <div class=\"btn-toolbar\" role=\"toolbar\">\r\n                    <div class=\"btn-group ml-auto\" role=\"group\">\r\n                      <a\r\n                        *ngIf=\"allowfilerename\"\r\n                        class=\"btn btn-sm btn-link text-secondary\"\r\n                        (click)=\"editFile(item);$event.stopPropagation();\"\r\n                        ><i [class]=\"iconEdit\"></i\r\n                      ></a>\r\n                    </div>\r\n                    <div class=\"btn-group\" role=\"group\">\r\n                      <a\r\n                        *ngIf=\"allowfiledelete\"\r\n                        class=\"btn btn-sm btn-link text-secondary\"\r\n                        (click)=\"deleteFile(item);$event.stopPropagation();\"\r\n                        ><i [class]=\"iconDelete\"></i\r\n                      ></a>\r\n                    </div>\r\n                  </div>\r\n                </td>\r\n              </tr>\r\n            </ng-container>\r\n          </tbody>\r\n        </table>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -9,11 +9,11 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
*/
|
|
10
10
|
class SacButtonComponent extends SacButtonCommon {
|
|
11
11
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SacButtonComponent, isStandalone: true, selector: "sac-button", usesInheritance: true, ngImport: i0, template: "<button
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SacButtonComponent, isStandalone: true, selector: "sac-button", usesInheritance: true, ngImport: i0, template: "<button\r\n [id]=\"name\"\r\n type=\"button\"\r\n class=\"btn d-flex justify-content-center align-items-center\"\r\n [attr.disabled]=\"_isdisabled || isloading ? 'disabled' : null\"\r\n (click)=\"buttonClick()\"\r\n [class.btn-primary]=\"role === 'primary'\"\r\n [class.btn-secondary]=\"role === 'secondary' || role === 'default'\"\r\n [class.btn-success]=\"role === 'success'\"\r\n [class.btn-danger]=\"role === 'danger'\"\r\n [class.btn-warning]=\"role === 'warning'\"\r\n [class.btn-info]=\"role === 'info'\"\r\n [class.btn-link]=\"role === 'link'\"\r\n>\r\n <span\r\n *ngIf=\"isloading\"\r\n class=\"spinner-border spinner-border-sm me-2\"\r\n role=\"status\"\r\n aria-hidden=\"true\"\r\n ></span>\r\n <i *ngIf=\"!isloading && icon !== ''\" [ngClass]=\"icon\" class=\"me-2\"></i\r\n >{{text}}\r\n</button>\r\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
13
13
|
}
|
|
14
14
|
export { SacButtonComponent };
|
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacButtonComponent, decorators: [{
|
|
16
16
|
type: Component,
|
|
17
|
-
args: [{ selector: 'sac-button', standalone: true, imports: [NgIf, NgClass], template: "<button
|
|
17
|
+
args: [{ selector: 'sac-button', standalone: true, imports: [NgIf, NgClass], template: "<button\r\n [id]=\"name\"\r\n type=\"button\"\r\n class=\"btn d-flex justify-content-center align-items-center\"\r\n [attr.disabled]=\"_isdisabled || isloading ? 'disabled' : null\"\r\n (click)=\"buttonClick()\"\r\n [class.btn-primary]=\"role === 'primary'\"\r\n [class.btn-secondary]=\"role === 'secondary' || role === 'default'\"\r\n [class.btn-success]=\"role === 'success'\"\r\n [class.btn-danger]=\"role === 'danger'\"\r\n [class.btn-warning]=\"role === 'warning'\"\r\n [class.btn-info]=\"role === 'info'\"\r\n [class.btn-link]=\"role === 'link'\"\r\n>\r\n <span\r\n *ngIf=\"isloading\"\r\n class=\"spinner-border spinner-border-sm me-2\"\r\n role=\"status\"\r\n aria-hidden=\"true\"\r\n ></span>\r\n <i *ngIf=\"!isloading && icon !== ''\" [ngClass]=\"icon\" class=\"me-2\"></i\r\n >{{text}}\r\n</button>\r\n" }]
|
|
18
18
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2FjLWJvb3RzdHJhcDUvc3JjL2NvbnRyb2xzL2J1dHRvbnMvYnV0dG9uLnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2FjLWJvb3RzdHJhcDUvc3JjL2NvbnRyb2xzL2J1dHRvbnMvYnV0dG9uLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDcEUsT0FBTyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFFaEQ7Ozs7R0FJRztBQUNILE1BTWEsa0JBQW1CLFNBQVEsZUFBZTsrR0FBMUMsa0JBQWtCO21HQUFsQixrQkFBa0IsNkZDZi9CLDIwQkF1QkEsNENEVmMsSUFBSSw2RkFBRSxPQUFPOztTQUVkLGtCQUFrQjs0RkFBbEIsa0JBQWtCO2tCQU45QixTQUFTOytCQUNJLFlBQVksY0FFVixJQUFJLFdBQ1AsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2FjQnV0dG9uQ29tbW9uIH0gZnJvbSAnQHNpbXBsZWFuZ3VsYXJjb250cm9scy9zYWMtY29tbW9uJztcclxuaW1wb3J0IHsgTmdJZiwgTmdDbGFzcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG4vKipcclxuICogQnV0dG9uIENvbXBvbmVudFxyXG4gKiBcclxuICogPGV4YW1wbGUtdXJsPmh0dHA6Ly9sb2NhbGhvc3QvZGVtby9teXNhbXBsZS5jb21wb25lbnQuaHRtbDwvZXhhbXBsZS11cmw+XHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnc2FjLWJ1dHRvbicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYnV0dG9uLmh0bWwnLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIGltcG9ydHM6IFtOZ0lmLCBOZ0NsYXNzXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNhY0J1dHRvbkNvbXBvbmVudCBleHRlbmRzIFNhY0J1dHRvbkNvbW1vbiB7XHJcblxyXG59XHJcbiIsIjxidXR0b25cclxuICBbaWRdPVwibmFtZVwiXHJcbiAgdHlwZT1cImJ1dHRvblwiXHJcbiAgY2xhc3M9XCJidG4gZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgYWxpZ24taXRlbXMtY2VudGVyXCJcclxuICBbYXR0ci5kaXNhYmxlZF09XCJfaXNkaXNhYmxlZCB8fCBpc2xvYWRpbmcgPyAnZGlzYWJsZWQnIDogbnVsbFwiXHJcbiAgKGNsaWNrKT1cImJ1dHRvbkNsaWNrKClcIlxyXG4gIFtjbGFzcy5idG4tcHJpbWFyeV09XCJyb2xlID09PSAncHJpbWFyeSdcIlxyXG4gIFtjbGFzcy5idG4tc2Vjb25kYXJ5XT1cInJvbGUgPT09ICdzZWNvbmRhcnknIHx8IHJvbGUgPT09ICdkZWZhdWx0J1wiXHJcbiAgW2NsYXNzLmJ0bi1zdWNjZXNzXT1cInJvbGUgPT09ICdzdWNjZXNzJ1wiXHJcbiAgW2NsYXNzLmJ0bi1kYW5nZXJdPVwicm9sZSA9PT0gJ2RhbmdlcidcIlxyXG4gIFtjbGFzcy5idG4td2FybmluZ109XCJyb2xlID09PSAnd2FybmluZydcIlxyXG4gIFtjbGFzcy5idG4taW5mb109XCJyb2xlID09PSAnaW5mbydcIlxyXG4gIFtjbGFzcy5idG4tbGlua109XCJyb2xlID09PSAnbGluaydcIlxyXG4+XHJcbiAgPHNwYW5cclxuICAgICpuZ0lmPVwiaXNsb2FkaW5nXCJcclxuICAgIGNsYXNzPVwic3Bpbm5lci1ib3JkZXIgc3Bpbm5lci1ib3JkZXItc20gbWUtMlwiXHJcbiAgICByb2xlPVwic3RhdHVzXCJcclxuICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXHJcbiAgPjwvc3Bhbj5cclxuICA8aSAqbmdJZj1cIiFpc2xvYWRpbmcgJiYgaWNvbiAhPT0gJydcIiBbbmdDbGFzc109XCJpY29uXCIgY2xhc3M9XCJtZS0yXCI+PC9pXHJcbiAgPnt7dGV4dH19XHJcbjwvYnV0dG9uPlxyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { SacButtonComponent } from './button';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zYWMtYm9vdHN0cmFwNS9zcmMvY29udHJvbHMvYnV0dG9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTYWNCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbic7XHJcbiJdfQ==
|
|
@@ -1,24 +1,26 @@
|
|
|
1
1
|
import { Component, forwardRef, Host, Optional } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
// import { SacBaseModelControl } from '../../common/basemodelcontrol';
|
|
4
|
-
import { SacCheckboxCommon } from '@simpleangularcontrols/sac-common';
|
|
5
|
-
import { SacFormDirective } from '../form/form';
|
|
6
4
|
import { NgClass, NgIf } from '@angular/common';
|
|
5
|
+
import { SacCheckboxCommon } from '@simpleangularcontrols/sac-common';
|
|
6
|
+
import { SacToControlWidthCssPipe } from '../layout/tocontrolwidthcss.pipe';
|
|
7
|
+
import { SacToLabelWidthCssPipe } from '../layout/tolabelwidthcss.pipe';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "../
|
|
9
|
+
import * as i1 from "../layout/formlayout.directive";
|
|
9
10
|
/**
|
|
10
11
|
* Checkbox Kompontente
|
|
11
12
|
*/
|
|
12
13
|
class SacCheckboxComponent extends SacCheckboxCommon {
|
|
14
|
+
// #region Constructors
|
|
13
15
|
/**
|
|
14
|
-
*
|
|
15
|
-
* @param
|
|
16
|
-
* @param injector
|
|
16
|
+
* Constructor
|
|
17
|
+
* @param formLayout SacFormLayout to define scoped layout settings
|
|
18
|
+
* @param injector Injector for injecting services
|
|
17
19
|
*/
|
|
18
|
-
constructor(
|
|
19
|
-
super(
|
|
20
|
+
constructor(formLayout, injector) {
|
|
21
|
+
super(formLayout, injector);
|
|
20
22
|
}
|
|
21
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacCheckboxComponent, deps: [{ token: i1.
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacCheckboxComponent, deps: [{ token: i1.SacFormLayoutDirective, host: true, optional: true }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
24
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SacCheckboxComponent, isStandalone: true, selector: "sac-checkbox", providers: [
|
|
23
25
|
{
|
|
24
26
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -30,9 +32,7 @@ class SacCheckboxComponent extends SacCheckboxCommon {
|
|
|
30
32
|
useExisting: forwardRef(() => SacCheckboxComponent),
|
|
31
33
|
multi: true,
|
|
32
34
|
},
|
|
33
|
-
], usesInheritance: true, ngImport: i0, template: "<div
|
|
34
|
-
{ provide: ControlContainer, useExisting: SacFormDirective },
|
|
35
|
-
] }); }
|
|
35
|
+
], usesInheritance: true, ngImport: i0, template: "<div\r\n class=\"row align-items-center\"\r\n [class.g-0]=\"disablelabel\"\r\n [class.mb-3]=\"!stacked\"\r\n>\r\n <div\r\n class=\"col-12 col-form-label col-form-label-sm\"\r\n [ngClass]=\"[!disablelabel && !stacked ? (this.labelSizes | toLabelWidthCss) : 'sr-only' ]\"\r\n >\r\n <label *ngIf=\"!disablelabel && !stacked\" for=\"{{name}}\">{{label}}</label>\r\n </div>\r\n <div\r\n class=\"col-12\"\r\n [ngClass]=\"[!disablelabel && !stacked ? (this.labelSizes | toControlWidthCss) : '']\"\r\n >\r\n <div class=\"form-check\">\r\n <input\r\n class=\"form-check-input form-check-input-sm\"\r\n id=\"{{name}}\"\r\n name=\"{{name}}\"\r\n type=\"checkbox\"\r\n [checked]=\"value\"\r\n (blur)=\"onTouch()\"\r\n (change)=\"setValue($event.target.checked)\"\r\n [disabled]=\"isdisabled\"\r\n />\r\n <label for=\"{{name}}\" class=\"form-check-label\">\r\n <ng-container *ngIf=\"checkboxtext\">{{checkboxtext}}</ng-container>\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: SacToControlWidthCssPipe, name: "toControlWidthCss" }, { kind: "pipe", type: SacToLabelWidthCssPipe, name: "toLabelWidthCss" }] }); }
|
|
36
36
|
}
|
|
37
37
|
export { SacCheckboxComponent };
|
|
38
38
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacCheckboxComponent, decorators: [{
|
|
@@ -48,12 +48,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
48
48
|
useExisting: forwardRef(() => SacCheckboxComponent),
|
|
49
49
|
multi: true,
|
|
50
50
|
},
|
|
51
|
-
],
|
|
52
|
-
|
|
53
|
-
], standalone: true, imports: [NgClass, NgIf], template: "<div class=\"row mb-3 align-items-center\" [class.g-0]=\"disablelabel\">\r\n <div class=\"col-12 col-form-label col-form-label-sm\" [ngClass]=\"[disablelabel === false ? 'col-sm-' + labelsize : 'sr-only' ]\">\r\n <ng-container *ngIf=\"!disablelabel\">{{label}}</ng-container>\r\n </div>\r\n <div class=\"col-12\" [ngClass]=\"[disablelabel === false ? 'col-sm-' + _inputsize : 'col-sm-12']\">\r\n <div class=\"form-check\">\r\n <input class=\"form-check-input form-check-input-sm\" id=\"{{name}}\" name=\"{{name}}\" type=\"checkbox\" [checked]=\"value\"\r\n (blur)=\"onTouch()\" (change)=\"setValue($event.target.checked)\" [disabled]=\"isdisabled\" />\r\n <label for=\"{{name}}\" class=\"form-check-label\">\r\n <ng-container *ngIf=\"checkboxtext\">{{checkboxtext}}</ng-container>\r\n </label>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
54
|
-
}], ctorParameters: function () { return [{ type: i1.SacFormDirective, decorators: [{
|
|
51
|
+
], standalone: true, imports: [NgClass, NgIf, SacToControlWidthCssPipe, SacToLabelWidthCssPipe], template: "<div\r\n class=\"row align-items-center\"\r\n [class.g-0]=\"disablelabel\"\r\n [class.mb-3]=\"!stacked\"\r\n>\r\n <div\r\n class=\"col-12 col-form-label col-form-label-sm\"\r\n [ngClass]=\"[!disablelabel && !stacked ? (this.labelSizes | toLabelWidthCss) : 'sr-only' ]\"\r\n >\r\n <label *ngIf=\"!disablelabel && !stacked\" for=\"{{name}}\">{{label}}</label>\r\n </div>\r\n <div\r\n class=\"col-12\"\r\n [ngClass]=\"[!disablelabel && !stacked ? (this.labelSizes | toControlWidthCss) : '']\"\r\n >\r\n <div class=\"form-check\">\r\n <input\r\n class=\"form-check-input form-check-input-sm\"\r\n id=\"{{name}}\"\r\n name=\"{{name}}\"\r\n type=\"checkbox\"\r\n [checked]=\"value\"\r\n (blur)=\"onTouch()\"\r\n (change)=\"setValue($event.target.checked)\"\r\n [disabled]=\"isdisabled\"\r\n />\r\n <label for=\"{{name}}\" class=\"form-check-label\">\r\n <ng-container *ngIf=\"checkboxtext\">{{checkboxtext}}</ng-container>\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n" }]
|
|
52
|
+
}], ctorParameters: function () { return [{ type: i1.SacFormLayoutDirective, decorators: [{
|
|
55
53
|
type: Host
|
|
56
54
|
}, {
|
|
57
55
|
type: Optional
|
|
58
56
|
}] }, { type: i0.Injector }]; } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zYWMtYm9vdHN0cmFwNS9zcmMvY29udHJvbHMvY2hlY2tib3gvY2hlY2tib3gudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zYWMtYm9vdHN0cmFwNS9zcmMvY29udHJvbHMvY2hlY2tib3gvY2hlY2tib3guaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQVksUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxhQUFhLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSx1RUFBdUU7QUFDdkUsT0FBTyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUV0RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7O0FBRXhFOztHQUVHO0FBQ0gsTUFtQmEsb0JBQXFCLFNBQVEsaUJBQWlCO0lBQ3pELHVCQUF1QjtJQUV2Qjs7OztPQUlHO0lBQ0gsWUFDc0IsVUFBa0MsRUFDdEQsUUFBa0I7UUFFbEIsS0FBSyxDQUFDLFVBQVUsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUM5QixDQUFDOytHQWJVLG9CQUFvQjttR0FBcEIsb0JBQW9CLDJEQWZwQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLEtBQUssRUFBRSxJQUFJO2dCQUNYLFdBQVcsRUFBRSxvQkFBb0I7YUFDbEM7WUFDRDtnQkFDRSxPQUFPLEVBQUUsYUFBYTtnQkFDdEIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztnQkFDbkQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGlEQzNCSCx5akNBZ0NBLDRDREhZLE9BQU8sb0ZBQUUsSUFBSSx3RkFBRSx3QkFBd0IscURBQUUsc0JBQXNCOztTQUU5RCxvQkFBb0I7NEZBQXBCLG9CQUFvQjtrQkFuQmhDLFNBQVM7K0JBQ0UsY0FBYyxhQUdiO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLEtBQUssRUFBRSxJQUFJOzRCQUNYLFdBQVcsc0JBQXNCO3lCQUNsQzt3QkFDRDs0QkFDRSxPQUFPLEVBQUUsYUFBYTs0QkFDdEIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUscUJBQXFCLENBQUM7NEJBQ25ELEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGLGNBQ1csSUFBSSxXQUNQLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSx3QkFBd0IsRUFBRSxzQkFBc0IsQ0FBQzs7MEJBV3ZFLElBQUk7OzBCQUFJLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGZvcndhcmRSZWYsIEhvc3QsIEluamVjdG9yLCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOR19WQUxJREFUT1JTLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuLy8gaW1wb3J0IHsgU2FjQmFzZU1vZGVsQ29udHJvbCB9IGZyb20gJy4uLy4uL2NvbW1vbi9iYXNlbW9kZWxjb250cm9sJztcclxuaW1wb3J0IHsgTmdDbGFzcywgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFNhY0NoZWNrYm94Q29tbW9uIH0gZnJvbSAnQHNpbXBsZWFuZ3VsYXJjb250cm9scy9zYWMtY29tbW9uJztcclxuaW1wb3J0IHsgU2FjRm9ybUxheW91dERpcmVjdGl2ZSB9IGZyb20gJy4uL2xheW91dC9mb3JtbGF5b3V0LmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IFNhY1RvQ29udHJvbFdpZHRoQ3NzUGlwZSB9IGZyb20gJy4uL2xheW91dC90b2NvbnRyb2x3aWR0aGNzcy5waXBlJztcclxuaW1wb3J0IHsgU2FjVG9MYWJlbFdpZHRoQ3NzUGlwZSB9IGZyb20gJy4uL2xheW91dC90b2xhYmVsd2lkdGhjc3MucGlwZSc7XHJcblxyXG4vKipcclxuICogQ2hlY2tib3ggS29tcG9udGVudGVcclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2FjLWNoZWNrYm94JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tib3guaHRtbCcsXHJcbiAgLy8gVmFsdWUgQWNjZXNzIFByb3ZpZGVyIHJlZ2lzdHJpZXJlbiwgZGFtaXQgV2VydCB2aWEgTW9kZWwgZ2VzY2hyaWViZW4gdW5kIGdlbGVzZW4gd2VyZGVuIGthbm5cclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgICB1c2VFeGlzdGluZzogU2FjQ2hlY2tib3hDb21wb25lbnQsXHJcbiAgICB9LFxyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxJREFUT1JTLFxyXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBTYWNDaGVja2JveENvbXBvbmVudCksXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgfSxcclxuICBdLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW05nQ2xhc3MsIE5nSWYsIFNhY1RvQ29udHJvbFdpZHRoQ3NzUGlwZSwgU2FjVG9MYWJlbFdpZHRoQ3NzUGlwZV0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTYWNDaGVja2JveENvbXBvbmVudCBleHRlbmRzIFNhY0NoZWNrYm94Q29tbW9uIHtcclxuICAvLyAjcmVnaW9uIENvbnN0cnVjdG9yc1xyXG5cclxuICAvKipcclxuICAgKiBDb25zdHJ1Y3RvclxyXG4gICAqIEBwYXJhbSBmb3JtTGF5b3V0IFNhY0Zvcm1MYXlvdXQgdG8gZGVmaW5lIHNjb3BlZCBsYXlvdXQgc2V0dGluZ3NcclxuICAgKiBAcGFyYW0gaW5qZWN0b3IgSW5qZWN0b3IgZm9yIGluamVjdGluZyBzZXJ2aWNlc1xyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQEhvc3QoKSBAT3B0aW9uYWwoKSBmb3JtTGF5b3V0OiBTYWNGb3JtTGF5b3V0RGlyZWN0aXZlLFxyXG4gICAgaW5qZWN0b3I6IEluamVjdG9yXHJcbiAgKSB7XHJcbiAgICBzdXBlcihmb3JtTGF5b3V0LCBpbmplY3Rvcik7XHJcbiAgfVxyXG5cclxuICAvLyAjZW5kcmVnaW9uIENvbnN0cnVjdG9yc1xyXG59XHJcbiIsIjxkaXZcclxuICBjbGFzcz1cInJvdyBhbGlnbi1pdGVtcy1jZW50ZXJcIlxyXG4gIFtjbGFzcy5nLTBdPVwiZGlzYWJsZWxhYmVsXCJcclxuICBbY2xhc3MubWItM109XCIhc3RhY2tlZFwiXHJcbj5cclxuICA8ZGl2XHJcbiAgICBjbGFzcz1cImNvbC0xMiBjb2wtZm9ybS1sYWJlbCBjb2wtZm9ybS1sYWJlbC1zbVwiXHJcbiAgICBbbmdDbGFzc109XCJbIWRpc2FibGVsYWJlbCAmJiAhc3RhY2tlZCA/ICh0aGlzLmxhYmVsU2l6ZXMgfCB0b0xhYmVsV2lkdGhDc3MpIDogJ3NyLW9ubHknIF1cIlxyXG4gID5cclxuICAgIDxsYWJlbCAqbmdJZj1cIiFkaXNhYmxlbGFiZWwgJiYgIXN0YWNrZWRcIiBmb3I9XCJ7e25hbWV9fVwiPnt7bGFiZWx9fTwvbGFiZWw+XHJcbiAgPC9kaXY+XHJcbiAgPGRpdlxyXG4gICAgY2xhc3M9XCJjb2wtMTJcIlxyXG4gICAgW25nQ2xhc3NdPVwiWyFkaXNhYmxlbGFiZWwgJiYgIXN0YWNrZWQgPyAgKHRoaXMubGFiZWxTaXplcyB8IHRvQ29udHJvbFdpZHRoQ3NzKSA6ICcnXVwiXHJcbiAgPlxyXG4gICAgPGRpdiBjbGFzcz1cImZvcm0tY2hlY2tcIj5cclxuICAgICAgPGlucHV0XHJcbiAgICAgICAgY2xhc3M9XCJmb3JtLWNoZWNrLWlucHV0IGZvcm0tY2hlY2staW5wdXQtc21cIlxyXG4gICAgICAgIGlkPVwie3tuYW1lfX1cIlxyXG4gICAgICAgIG5hbWU9XCJ7e25hbWV9fVwiXHJcbiAgICAgICAgdHlwZT1cImNoZWNrYm94XCJcclxuICAgICAgICBbY2hlY2tlZF09XCJ2YWx1ZVwiXHJcbiAgICAgICAgKGJsdXIpPVwib25Ub3VjaCgpXCJcclxuICAgICAgICAoY2hhbmdlKT1cInNldFZhbHVlKCRldmVudC50YXJnZXQuY2hlY2tlZClcIlxyXG4gICAgICAgIFtkaXNhYmxlZF09XCJpc2Rpc2FibGVkXCJcclxuICAgICAgLz5cclxuICAgICAgPGxhYmVsIGZvcj1cInt7bmFtZX19XCIgY2xhc3M9XCJmb3JtLWNoZWNrLWxhYmVsXCI+XHJcbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImNoZWNrYm94dGV4dFwiPnt7Y2hlY2tib3h0ZXh0fX08L25nLWNvbnRhaW5lcj5cclxuICAgICAgPC9sYWJlbD5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|