@dotglitch/ngx-common 1.2.0 → 2.0.0

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.
Files changed (48) hide show
  1. package/esm2022/components/command-palette/breadcrumb/breadcrumb.component.mjs +4 -4
  2. package/esm2022/components/command-palette/command-palette.component.mjs +4 -4
  3. package/esm2022/components/command-palette/shortcut/shortcut.component.mjs +4 -4
  4. package/esm2022/components/dynamic-html/dynamic-html.component.mjs +4 -4
  5. package/esm2022/components/dynamic-html/dynamic-html.module.mjs +5 -5
  6. package/esm2022/components/dynamic-html/dynamic-html.service.mjs +4 -4
  7. package/esm2022/components/filemanager/file-grid/file-grid.component.mjs +4 -4
  8. package/esm2022/components/filemanager/filemanager.component.mjs +4 -4
  9. package/esm2022/components/filemanager/folder-rename/folder-rename.component.mjs +4 -4
  10. package/esm2022/components/filemanager/toolbar/breadcrumb/breadcrumb.component.mjs +4 -4
  11. package/esm2022/components/filemanager/toolbar/icon-button/icon-button.component.mjs +4 -4
  12. package/esm2022/components/filemanager/toolbar/toolbar.component.mjs +4 -4
  13. package/esm2022/components/filemanager/tree-view/tree-view.component.mjs +4 -4
  14. package/esm2022/components/lazy-loader/lazy-loader.component.mjs +4 -4
  15. package/esm2022/components/lazy-loader/lazy-loader.module.mjs +5 -5
  16. package/esm2022/components/lazy-loader/lazy-loader.service.mjs +4 -4
  17. package/esm2022/components/menu/menu.component.mjs +4 -4
  18. package/esm2022/components/parallax-card/parallax-card.component.mjs +4 -4
  19. package/esm2022/components/tabulator/tabulator.component.mjs +5 -5
  20. package/esm2022/components/tooltip/tooltip.component.mjs +4 -4
  21. package/esm2022/components/vscode/vscode.component.mjs +4 -4
  22. package/esm2022/directives/image-cache.directive.mjs +4 -4
  23. package/esm2022/directives/menu.directive.mjs +4 -4
  24. package/esm2022/directives/tooltip.directive.mjs +7 -7
  25. package/esm2022/pipes/html-bypass.pipe.mjs +4 -4
  26. package/esm2022/pipes/resource-bypass.pipe.mjs +4 -4
  27. package/esm2022/pipes/script-bypass.pipe.mjs +4 -4
  28. package/esm2022/pipes/style-bypass.pipe.mjs +4 -4
  29. package/esm2022/pipes/url-bypass.pipe.mjs +4 -4
  30. package/esm2022/public-api.mjs +1 -4
  31. package/esm2022/services/command-palette.service.mjs +4 -4
  32. package/esm2022/services/dependency.service.mjs +4 -4
  33. package/esm2022/services/dialog.service.mjs +4 -4
  34. package/esm2022/services/fetch.service.mjs +4 -4
  35. package/esm2022/services/file.service.mjs +4 -4
  36. package/esm2022/services/keyboard.service.mjs +4 -4
  37. package/esm2022/services/navigation.service.mjs +4 -4
  38. package/esm2022/services/theme.service.mjs +50 -15
  39. package/fesm2022/{dotglitch-ngx-common-folder-rename.component-6j7OjwOo.mjs → dotglitch-ngx-common-folder-rename.component-Bh1IiRvd.mjs} +5 -7
  40. package/fesm2022/dotglitch-ngx-common-folder-rename.component-Bh1IiRvd.mjs.map +1 -0
  41. package/fesm2022/dotglitch-ngx-common.mjs +165 -286
  42. package/fesm2022/dotglitch-ngx-common.mjs.map +1 -1
  43. package/package.json +1 -5
  44. package/public-api.d.ts +0 -1
  45. package/services/theme.service.d.ts +12 -2
  46. package/components/react-magic-wrapper/react-magic-wrapper.component.d.ts +0 -63
  47. package/esm2022/components/react-magic-wrapper/react-magic-wrapper.component.mjs +0 -160
  48. package/fesm2022/dotglitch-ngx-common-folder-rename.component-6j7OjwOo.mjs.map +0 -1
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@dotglitch/ngx-common",
3
3
  "private": false,
4
- "version": "1.2.0",
4
+ "version": "2.0.0",
5
5
  "repository": {
6
6
  "url": "https://github.com/knackstedt/dotglitch-ngx/tree/main/packages/common"
7
7
  },
@@ -28,13 +28,9 @@
28
28
  },
29
29
  "dependencies": {
30
30
  "angular-split": ">=15.0.0",
31
- "localforage": ">=1.10.0",
32
31
  "monaco-editor": ">=0.40.0",
33
32
  "ngx-scrollbar": ">=12.0.0",
34
33
  "path-browserify": ">=1.0.0",
35
- "react": ">=18.0.0",
36
- "react-dom": ">=18.0.0",
37
- "tabulator-tables": ">=5.5.0",
38
34
  "tslib": "^2.6.2",
39
35
  "ulidx": ">=2.0.0"
40
36
  },
package/public-api.d.ts CHANGED
@@ -49,7 +49,6 @@ export * from './components/filemanager/filemanager.component';
49
49
  export * from './components/tabulator/tabulator.component';
50
50
  export * from './components/vscode/vscode.component';
51
51
  export * from './components/parallax-card/parallax-card.component';
52
- export * from './components/react-magic-wrapper/react-magic-wrapper.component';
53
52
  export * from './components/menu/menu.component';
54
53
  export * from './components/types';
55
54
  export { ConsoleLogger, LogIcon } from './utils/index';
@@ -1,7 +1,17 @@
1
1
  import { BehaviorSubject } from 'rxjs';
2
2
  import * as i0 from "@angular/core";
3
- type AppTheme = "light" | "dark";
4
- export declare class ThemeService extends BehaviorSubject<AppTheme> {
3
+ type AppTheme = "light" | "dark" | 'auto';
4
+ export declare class ThemeService {
5
+ readonly themes: {
6
+ label: string;
7
+ id: string;
8
+ }[];
9
+ selectedTheme: any;
10
+ /**
11
+ * This theme will always only be 'dark' or 'light'.
12
+ * For use with canvases and similar libraries.
13
+ */
14
+ theme: BehaviorSubject<"light" | "dark">;
5
15
  constructor();
6
16
  setTheme(t: AppTheme): void;
7
17
  static ɵfac: i0.ɵɵFactoryDeclaration<ThemeService, never>;
@@ -1,63 +0,0 @@
1
- import { AfterViewInit, ApplicationRef, Injector, NgZone, OnChanges, OnDestroy, SimpleChanges, Type, ViewContainerRef } from '@angular/core';
2
- import * as React from 'react';
3
- import { ThemeService } from '../../services/theme.service';
4
- import * as i0 from "@angular/core";
5
- /**
6
- * Extend this component to automatically generate
7
- * bindings to a React component.
8
- *
9
- * ! You _must_ override the property `ngReactComponent`
10
- * Failure to do so will result in errors
11
- * `override readonly ngReactComponent = ReactFlowWrappableComponent;`
12
- */
13
- export declare class ReactMagicWrapperComponent implements OnChanges, OnDestroy, AfterViewInit {
14
- private readonly ngContainer;
15
- private readonly ngTheme;
16
- private readonly ngZone;
17
- /**
18
- * Wrap an angular component inside of a React memo object.
19
- * Will attempt to bind @Input and @Output properties if provided,
20
- * and will bind the react arguments directly as @Input properties.
21
- *
22
- * @experimental
23
- * @param componentClass Angular component
24
- * @param envInjector An `EnvironmentInjector` instance to be used for the component
25
- * @param injector An `ElementInjector` instance
26
- * @param _inputs
27
- * @param _outputs
28
- * @returns
29
- */
30
- static WrapAngularComponent: ({ component, appRef, injector, ngZone, staticInputs, staticOutputs, preSiblings, postSiblings, additionalChildren, rootElementName, containerElementName }: {
31
- component: Type<any>;
32
- appRef: Omit<ApplicationRef, '_runningTick'>;
33
- injector: Injector;
34
- ngZone: NgZone;
35
- staticInputs?: {
36
- [key: string]: any;
37
- };
38
- staticOutputs?: {
39
- [key: string]: Function;
40
- };
41
- preSiblings?: React.ReactNode[];
42
- postSiblings?: React.ReactNode[];
43
- additionalChildren?: React.ReactNode[];
44
- rootElementName?: Parameters<typeof React.createElement>[0];
45
- containerElementName?: string;
46
- }) => React.NamedExoticComponent<object>;
47
- /**
48
- * The react component to be wrapped.
49
- * ! Must be overridden for this wrapper to work
50
- */
51
- ngReactComponent: React.FunctionComponent<any> | React.ComponentClass<any> | string;
52
- private _root;
53
- theme: string;
54
- private ngSubscriptions;
55
- constructor(ngContainer: ViewContainerRef, ngTheme: ThemeService, ngZone: NgZone);
56
- ngOnInit(): void;
57
- ngOnChanges(changes?: SimpleChanges): void;
58
- ngAfterViewInit(): void;
59
- ngOnDestroy(): void;
60
- private _render;
61
- static ɵfac: i0.ɵɵFactoryDeclaration<ReactMagicWrapperComponent, never>;
62
- static ɵcmp: i0.ɵɵComponentDeclaration<ReactMagicWrapperComponent, "app-react-magic-wrapper", never, {}, {}, never, never, true, never>;
63
- }
@@ -1,160 +0,0 @@
1
- import { Component, createComponent } from '@angular/core';
2
- import * as React from 'react';
3
- import { createRoot } from 'react-dom/client';
4
- import { ulid } from 'ulidx';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "../../services/theme.service";
7
- /**
8
- * Extend this component to automatically generate
9
- * bindings to a React component.
10
- *
11
- * ! You _must_ override the property `ngReactComponent`
12
- * Failure to do so will result in errors
13
- * `override readonly ngReactComponent = ReactFlowWrappableComponent;`
14
- */
15
- export class ReactMagicWrapperComponent {
16
- /**
17
- * Wrap an angular component inside of a React memo object.
18
- * Will attempt to bind @Input and @Output properties if provided,
19
- * and will bind the react arguments directly as @Input properties.
20
- *
21
- * @experimental
22
- * @param componentClass Angular component
23
- * @param envInjector An `EnvironmentInjector` instance to be used for the component
24
- * @param injector An `ElementInjector` instance
25
- * @param _inputs
26
- * @param _outputs
27
- * @returns
28
- */
29
- static { this.WrapAngularComponent = ({ component, appRef, injector, ngZone, staticInputs, staticOutputs, preSiblings, postSiblings, additionalChildren, rootElementName, containerElementName }) => React.memo((args) => {
30
- const id = ulid();
31
- React.useEffect(() => {
32
- try {
33
- const componentInstance = createComponent(component, {
34
- environmentInjector: appRef.injector,
35
- elementInjector: injector,
36
- hostElement: document.getElementById(id)
37
- });
38
- appRef.attachView(componentInstance.hostView);
39
- // @ts-ignore
40
- // component.hostView = hostView;
41
- Object.assign(staticInputs, args);
42
- const { inputs, outputs } = component['ɵcmp'];
43
- // Returns a list of entries that need to be set
44
- // This makes it so that unnecessary setters are not invoked.
45
- const updated = Object.entries(inputs).filter(([parentKey, childKey]) => {
46
- return componentInstance.instance[childKey] != staticInputs[parentKey];
47
- });
48
- updated.forEach(([parentKey, childKey]) => {
49
- if (staticInputs.hasOwnProperty(parentKey))
50
- componentInstance.instance[childKey] = staticInputs[parentKey];
51
- });
52
- const outputSubscriptions = {};
53
- // Get a list of unregistered outputs
54
- const newOutputs = Object.entries(outputs).filter(([parentKey, childKey]) => {
55
- return !outputSubscriptions[parentKey];
56
- });
57
- // Reverse bind via subscription
58
- newOutputs.forEach(([parentKey, childKey]) => {
59
- if (!staticOutputs.hasOwnProperty(parentKey))
60
- return;
61
- const target = componentInstance.instance[childKey];
62
- const outputs = staticOutputs;
63
- const sub = target.subscribe((...args) => {
64
- // Run the callback in the provided zone
65
- ngZone.run(() => {
66
- outputs[parentKey](...args);
67
- });
68
- }); // Subscription
69
- outputSubscriptions[parentKey] = sub;
70
- });
71
- // Wrap the destroy method to safely release the subscriptions
72
- const originalDestroy = componentInstance.onDestroy?.bind(componentInstance);
73
- componentInstance.onDestroy = (cb) => {
74
- Object.values(outputSubscriptions).forEach(s => s.unsubscribe());
75
- originalDestroy?.(cb);
76
- };
77
- componentInstance.changeDetectorRef.detectChanges();
78
- }
79
- catch (err) {
80
- console.error(err);
81
- }
82
- }, []);
83
- const elements = [
84
- ...(preSiblings || []),
85
- React.createElement(containerElementName || "div", { id }),
86
- ...(postSiblings || []),
87
- ...(additionalChildren || [])
88
- ].filter(e => e);
89
- return React.createElement(rootElementName || "div", {}, ...elements);
90
- }); }
91
- constructor(ngContainer, ngTheme, ngZone) {
92
- this.ngContainer = ngContainer;
93
- this.ngTheme = ngTheme;
94
- this.ngZone = ngZone;
95
- this.ngSubscriptions = [
96
- this.ngTheme.subscribe(t => {
97
- this.theme = t;
98
- this.ngOnChanges();
99
- })
100
- ];
101
- }
102
- ngOnInit() {
103
- if (!this.ngReactComponent) {
104
- throw new Error("ReactMagicWrapperComponent cannot start without a provided ngReactComponent!");
105
- }
106
- }
107
- ngOnChanges(changes) {
108
- this._render();
109
- }
110
- ngAfterViewInit() {
111
- this._render();
112
- }
113
- ngOnDestroy() {
114
- this._root?.unmount();
115
- this.ngSubscriptions.forEach(s => s.unsubscribe());
116
- }
117
- _render() {
118
- if (!this.ngReactComponent) {
119
- console.log("Render no component. May be context issue");
120
- return;
121
- }
122
- ;
123
- this.ngZone.runOutsideAngular(() => {
124
- try {
125
- this._root ??= createRoot(this.ngContainer.element.nativeElement);
126
- // List all keys that do not start with `_` nor `ng`
127
- const keys = Object.keys(this).filter(k => !/^(?:_|ng)/.test(k));
128
- // Get all property keys from the class
129
- const propKeys = keys.filter(k => !k.startsWith("on"));
130
- // Get all event handler keys from the class
131
- const evtKeys = keys.filter(k => k.startsWith("on"));
132
- const props = {};
133
- // Project all key properties onto `props`
134
- propKeys.forEach(k => props[k] = this[k]);
135
- // Attempt to ensure no zone is lost during the event emitter fires
136
- this.ngZone.runGuarded(() => {
137
- // Bind all event handlers.
138
- // ! important Angular uses EventEmitter, React uses
139
- // a different method of event binding
140
- evtKeys.forEach(k => props[k] = (...args) => this[k].next(args));
141
- });
142
- this._root.render(React.createElement(this.ngReactComponent, { props: props }));
143
- }
144
- catch (err) {
145
- console.error(err);
146
- }
147
- });
148
- }
149
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ReactMagicWrapperComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.ThemeService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
150
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: ReactMagicWrapperComponent, isStandalone: true, selector: "app-react-magic-wrapper", usesOnChanges: true, ngImport: i0, template: ``, isInline: true }); }
151
- }
152
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ReactMagicWrapperComponent, decorators: [{
153
- type: Component,
154
- args: [{
155
- selector: 'app-react-magic-wrapper',
156
- template: ``,
157
- standalone: true
158
- }]
159
- }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i1.ThemeService }, { type: i0.NgZone }] });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"react-magic-wrapper.component.js","sourceRoot":"","sources":["../../../../../packages/common/src/components/react-magic-wrapper/react-magic-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ApplicationRef, Component, ComponentFactoryResolver, EnvironmentInjector, EventEmitter, Injector, NgZone, OnChanges, OnDestroy, SimpleChanges, Type, ViewContainerRef, ViewRef, createComponent } from '@angular/core';\nimport * as React from 'react';\nimport { createRoot, Root } from 'react-dom/client';\n\nimport { ThemeService } from '../../services/theme.service';\nimport { ulid } from 'ulidx';\nimport { Subscription } from 'rxjs';\n\n/**\n * Extend this component to automatically generate\n * bindings to a React component.\n *\n * ! You _must_ override the property `ngReactComponent`\n * Failure to do so will result in errors\n * `override readonly ngReactComponent = ReactFlowWrappableComponent;`\n */\n@Component({\n    selector: 'app-react-magic-wrapper',\n    template: ``,\n    standalone: true\n})\nexport class ReactMagicWrapperComponent implements OnChanges, OnDestroy, AfterViewInit {\n\n    /**\n     * Wrap an angular component inside of a React memo object.\n     * Will attempt to bind @Input and @Output properties if provided,\n     * and will bind the react arguments directly as @Input properties.\n     *\n     * @experimental\n     * @param componentClass Angular component\n     * @param envInjector    An `EnvironmentInjector` instance to be used for the component\n     * @param injector       An `ElementInjector` instance\n     * @param _inputs\n     * @param _outputs\n     * @returns\n     */\n    static WrapAngularComponent = ({\n        component,\n        appRef,\n        injector,\n        ngZone,\n        staticInputs,\n        staticOutputs,\n        preSiblings,\n        postSiblings,\n        additionalChildren,\n        rootElementName,\n        containerElementName\n    }: {\n        component: Type<any>,\n        appRef: Omit<ApplicationRef, '_runningTick'>,\n        injector: Injector,\n        ngZone: NgZone,\n        staticInputs?: { [key: string]: any },\n        staticOutputs?: { [key: string]: Function },\n        preSiblings?: React.ReactNode[],\n        postSiblings?: React.ReactNode[],\n        additionalChildren?: React.ReactNode[],\n        rootElementName?: Parameters<typeof React.createElement>[0],\n        containerElementName?: string\n    }) => React.memo((args) => {\n\n        const id = ulid();\n        React.useEffect(() => {\n            try {\n\n                const componentInstance = createComponent(component, {\n                    environmentInjector: appRef.injector,\n                    elementInjector: injector,\n                    hostElement: document.getElementById(id)\n                });\n\n                appRef.attachView(componentInstance.hostView);\n                // @ts-ignore\n                // component.hostView = hostView;\n\n                Object.assign(staticInputs, args);\n\n                const { inputs, outputs } = component['ɵcmp'];\n\n                // Returns a list of entries that need to be set\n                // This makes it so that unnecessary setters are not invoked.\n                const updated = Object.entries(inputs).filter(([parentKey, childKey]: [string, string]) => {\n                    return componentInstance.instance[childKey] != staticInputs[parentKey];\n                });\n\n                updated.forEach(([parentKey, childKey]: [string, string]) => {\n                    if (staticInputs.hasOwnProperty(parentKey))\n                        componentInstance.instance[childKey] = staticInputs[parentKey];\n                });\n\n                const outputSubscriptions: { [key: string]: Subscription } = {};\n                // Get a list of unregistered outputs\n                const newOutputs = Object.entries(outputs).filter(([parentKey, childKey]: [string, string]) => {\n                    return !outputSubscriptions[parentKey];\n                });\n\n                // Reverse bind via subscription\n                newOutputs.forEach(([parentKey, childKey]: [string, string]) => {\n                    if (!staticOutputs.hasOwnProperty(parentKey)) return;\n\n                    const target: EventEmitter<unknown> = componentInstance.instance[childKey];\n                    const outputs = staticOutputs;\n\n                    const sub = target.subscribe((...args) => {\n                        // Run the callback in the provided zone\n                        ngZone.run(() => {\n                            outputs[parentKey](...args);\n                        })\n                    }); // Subscription\n\n                    outputSubscriptions[parentKey] = sub;\n                });\n\n                // Wrap the destroy method to safely release the subscriptions\n                const originalDestroy = componentInstance.onDestroy?.bind(componentInstance);\n                componentInstance.onDestroy = (cb) => {\n                    Object.values(outputSubscriptions).forEach(s => s.unsubscribe());\n                    originalDestroy?.(cb);\n                }\n\n                componentInstance.changeDetectorRef.detectChanges();\n            }\n            catch(err) {\n                console.error(err)\n            }\n        }, []);\n\n        const elements = [\n            ...(preSiblings || []),\n            React.createElement(containerElementName || \"div\", { id }),\n            ...(postSiblings || []),\n            ...(additionalChildren || [])\n        ].filter(e => e);\n\n        return React.createElement(rootElementName || \"div\", { }, ...elements);\n    });\n\n    /**\n     * The react component to be wrapped.\n     * ! Must be overridden for this wrapper to work\n     */\n    ngReactComponent: React.FunctionComponent<any> | React.ComponentClass<any> | string;\n\n    private _root: Root;\n    public theme: string;\n    private ngSubscriptions = [\n        this.ngTheme.subscribe(t => {\n            this.theme = t;\n            this.ngOnChanges();\n        })\n    ];\n\n    constructor(\n        private readonly ngContainer: ViewContainerRef,\n        private readonly ngTheme: ThemeService,\n        private readonly ngZone: NgZone\n    ) {\n    }\n\n    ngOnInit() {\n        if (!this.ngReactComponent) {\n            throw new Error(\"ReactMagicWrapperComponent cannot start without a provided ngReactComponent!\");\n        }\n    }\n\n    ngOnChanges(changes?: SimpleChanges): void {\n        this._render();\n    }\n\n    ngAfterViewInit() {\n        this._render();\n    }\n\n    ngOnDestroy() {\n        this._root?.unmount();\n        this.ngSubscriptions.forEach(s => s.unsubscribe());\n    }\n\n    private _render() {\n        if (!this.ngReactComponent) {\n            console.log(\"Render no component. May be context issue\")\n            return\n        };\n\n        this.ngZone.runOutsideAngular(() => {\n            try {\n                this._root ??= createRoot(this.ngContainer.element.nativeElement);\n\n                // List all keys that do not start with `_` nor `ng`\n                const keys = Object.keys(this).filter(k => !/^(?:_|ng)/.test(k));\n\n                // Get all property keys from the class\n                const propKeys = keys.filter(k => !k.startsWith(\"on\"));\n                // Get all event handler keys from the class\n                const evtKeys = keys.filter(k => k.startsWith(\"on\"));\n\n                const props = {};\n                // Project all key properties onto `props`\n                propKeys.forEach(k => props[k] = this[k]);\n\n                // Attempt to ensure no zone is lost during the event emitter fires\n                this.ngZone.runGuarded(() => {\n                    // Bind all event handlers.\n                    // ! important Angular uses EventEmitter, React uses\n                    // a different method of event binding\n                    evtKeys.forEach(k => props[k] = (...args) => this[k].next(args));\n                })\n\n                this._root.render(React.createElement(this.ngReactComponent, { props: props as any }));\n            }\n            catch(err) {\n                console.error(err)\n            }\n        })\n    }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"dotglitch-ngx-common-folder-rename.component-6j7OjwOo.mjs","sources":["../../../packages/common/src/components/filemanager/folder-rename/folder-rename.component.ts","../../../packages/common/src/components/filemanager/folder-rename/folder-rename.component.html"],"sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialogRef } from '@angular/material/dialog';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { NgxFileManagerConfiguration } from '../filemanager.component';\nimport { Fetch } from '../../../public-api';\n\n@Component({\n selector: 'app-folder-rename',\n templateUrl: './folder-rename.component.html',\n styleUrls: ['./folder-rename.component.scss'],\n imports: [\n MatInputModule,\n MatIconModule,\n MatButtonModule,\n FormsModule\n ],\n standalone: true\n})\nexport class FolderRenameComponent implements OnInit {\n\n @Input() path: string;\n @Input() name: string = '';\n @Input() config: NgxFileManagerConfiguration;\n\n isRename = false;\n\n constructor(\n public dialog: MatDialogRef<any>,\n private fetch: Fetch\n ) { }\n\n ngOnInit() {\n this.isRename = this.name.length > 0;\n }\n\n onSave() {\n if (this.isRename) {\n const url = this.config.apiSettings.renameEntryUrlTemplate\n ? this.config.apiSettings.renameEntryUrlTemplate(this.path + this.name)\n : this.config.apiSettings.renameEntryUrl\n\n this.fetch.post(url, { path: this.path + '/' + this.name });\n }\n else {\n const url = this.config.apiSettings.createDirectoryUrlTemplate\n ? this.config.apiSettings.createDirectoryUrlTemplate(this.path + this.name)\n : this.config.apiSettings.createDirectoryUrl\n\n this.fetch.post(url, {path: this.path +'/'+ this.name});\n }\n this.dialog.close(true);\n }\n}\n","<mat-form-field style=\"width: 280px;\">\n <mat-label>Name</mat-label>\n <input matInput type=\"text\" [(ngModel)]=\"name\" (keyup)=\"$event.key == 'Enter' && onSave()\">\n</mat-form-field>\n\n<div style=\"align-self: end;\">\n <button mat-flat-button (click)=\"onSave()\"><mat-icon>check</mat-icon>Ok</button>\n <button mat-flat-button (click)=\"dialog.close()\"><mat-icon>cancel</mat-icon>Cancel</button>\n</div>\n"],"names":["i2.Fetch","i5","i6"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAqBa,qBAAqB,CAAA;IAQ9B,WACW,CAAA,MAAyB,EACxB,KAAY,EAAA;QADb,IAAM,CAAA,MAAA,GAAN,MAAM,CAAmB;QACxB,IAAK,CAAA,KAAA,GAAL,KAAK,CAAO;QAPf,IAAI,CAAA,IAAA,GAAW,EAAE,CAAC;QAG3B,IAAQ,CAAA,QAAA,GAAG,KAAK,CAAC;KAKZ;IAEL,QAAQ,GAAA;QACJ,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;KACxC;IAED,MAAM,GAAA;AACF,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,sBAAsB;AACtD,kBAAE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;kBACrE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,cAAc,CAAA;YAE5C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;SAC/D;aACI;YACD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,0BAA0B;AACpD,kBAAE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,0BAA0B,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;kBACzE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,kBAAkB,CAAA;YAEtD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,GAAE,GAAG,GAAE,IAAI,CAAC,IAAI,EAAC,CAAC,CAAC;SAC3D;AACD,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;KAC3B;8GAjCQ,qBAAqB,EAAA,IAAA,EAAA,CAAA,EAAA,KAAA,EAAA,EAAA,CAAA,YAAA,EAAA,EAAA,EAAA,KAAA,EAAAA,KAAA,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;kGAArB,qBAAqB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,MAAA,EAAA,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EAAA,MAAA,EAAA,MAAA,EAAA,QAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,ECrBlC,8aASA,EDKQ,MAAA,EAAA,CAAA,0DAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,cAAc,0nBACd,aAAa,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,SAAA,EAAA,SAAA,EAAA,UAAA,CAAA,EAAA,QAAA,EAAA,CAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EACb,eAAe,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,EAAA,CAAA,SAAA,EAAA,QAAA,EAAA,6GAAA,EAAA,QAAA,EAAA,CAAA,WAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EACf,WAAW,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,oBAAA,EAAA,QAAA,EAAA,8MAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,2CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,qDAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,UAAA,EAAA,SAAA,EAAA,gBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,eAAA,CAAA,EAAA,QAAA,EAAA,CAAA,SAAA,CAAA,EAAA,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAIN,qBAAqB,EAAA,UAAA,EAAA,CAAA;kBAZjC,SAAS;AACI,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,mBAAmB,EAGpB,OAAA,EAAA;wBACL,cAAc;wBACd,aAAa;wBACb,eAAe;wBACf,WAAW;AACd,qBAAA,EAAA,UAAA,EACW,IAAI,EAAA,QAAA,EAAA,8aAAA,EAAA,MAAA,EAAA,CAAA,0DAAA,CAAA,EAAA,CAAA;kGAIP,IAAI,EAAA,CAAA;sBAAZ,KAAK;gBACG,IAAI,EAAA,CAAA;sBAAZ,KAAK;gBACG,MAAM,EAAA,CAAA;sBAAd,KAAK;;;;;"}