inugami-ng 0.0.12 → 0.0.13
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/fesm2022/inugami-ng-components-inu-svg-asset.mjs +163 -0
- package/fesm2022/inugami-ng-components-inu-svg-asset.mjs.map +1 -0
- package/fesm2022/inugami-ng-components-inu-svg-isometric.mjs +790 -0
- package/fesm2022/inugami-ng-components-inu-svg-isometric.mjs.map +1 -0
- package/fesm2022/inugami-ng-components-inu-svg-switzerland.mjs +14 -3
- package/fesm2022/inugami-ng-components-inu-svg-switzerland.mjs.map +1 -1
- package/fesm2022/inugami-ng-pipes.mjs +38 -0
- package/fesm2022/inugami-ng-pipes.mjs.map +1 -0
- package/fesm2022/inugami-ng-services.mjs +426 -1
- package/fesm2022/inugami-ng-services.mjs.map +1 -1
- package/package.json +13 -1
- package/styles/inu-default-style.css +1 -0
- package/types/inugami-ng-components-inu-svg-asset.d.ts +33 -0
- package/types/inugami-ng-components-inu-svg-isometric.d.ts +105 -0
- package/types/inugami-ng-components-inu-svg-switzerland.d.ts +1 -0
- package/types/inugami-ng-models.d.ts +115 -1
- package/types/inugami-ng-pipes.d.ts +12 -0
- package/types/inugami-ng-services.d.ts +7 -2
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, viewChild, computed, effect, HostListener, Component } from '@angular/core';
|
|
3
|
+
import { InuTemplateRegistryService } from 'inugami-ng/directives';
|
|
4
|
+
import { SVG_MATH, SVG_BUILDER, SvgAssetUtils, SVG_TRANSFORM } from 'inugami-ng/services';
|
|
5
|
+
|
|
6
|
+
class InuSvgAsset {
|
|
7
|
+
//====================================================================================================================
|
|
8
|
+
// ATTRIBUTES
|
|
9
|
+
//====================================================================================================================
|
|
10
|
+
assetSet = input('', ...(ngDevMode ? [{ debugName: "assetSet" }] : []));
|
|
11
|
+
asset = input(undefined, ...(ngDevMode ? [{ debugName: "asset" }] : []));
|
|
12
|
+
type = input('default', ...(ngDevMode ? [{ debugName: "type" }] : []));
|
|
13
|
+
state = input('default', ...(ngDevMode ? [{ debugName: "state" }] : []));
|
|
14
|
+
styleclass = input('', ...(ngDevMode ? [{ debugName: "styleclass" }] : []));
|
|
15
|
+
//
|
|
16
|
+
component = viewChild('component', ...(ngDevMode ? [{ debugName: "component" }] : []));
|
|
17
|
+
container = viewChild('container', ...(ngDevMode ? [{ debugName: "container" }] : []));
|
|
18
|
+
_styleClass = computed(() => {
|
|
19
|
+
return [
|
|
20
|
+
'inu-svg',
|
|
21
|
+
'inu-svg-asset',
|
|
22
|
+
this.styleclass() ? this.styleclass() : ''
|
|
23
|
+
].join(' ');
|
|
24
|
+
}, ...(ngDevMode ? [{ debugName: "_styleClass" }] : []));
|
|
25
|
+
//--- SVG components
|
|
26
|
+
height = 64;
|
|
27
|
+
width = 64;
|
|
28
|
+
parent = null;
|
|
29
|
+
locator = null;
|
|
30
|
+
defs = null;
|
|
31
|
+
canvas = null;
|
|
32
|
+
graph = null;
|
|
33
|
+
//====================================================================================================================
|
|
34
|
+
// INIT
|
|
35
|
+
//====================================================================================================================
|
|
36
|
+
constructor() {
|
|
37
|
+
effect(() => {
|
|
38
|
+
this.asset();
|
|
39
|
+
this.type();
|
|
40
|
+
this.state();
|
|
41
|
+
if (this.graph) {
|
|
42
|
+
this.updateValues();
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
ngOnChanges(changes) {
|
|
47
|
+
this.updateValues();
|
|
48
|
+
}
|
|
49
|
+
ngAfterViewInit() {
|
|
50
|
+
const component = this.component();
|
|
51
|
+
const container = this.container();
|
|
52
|
+
if (component && container) {
|
|
53
|
+
this.resolveParentSize(component, container);
|
|
54
|
+
this.initializeLayout(container);
|
|
55
|
+
this.resize();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
onResize() {
|
|
59
|
+
const component = this.component();
|
|
60
|
+
const container = this.container();
|
|
61
|
+
if (component && container) {
|
|
62
|
+
this.resolveParentSize(component, container);
|
|
63
|
+
this.resize();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//====================================================================================================================
|
|
67
|
+
// RENDERING
|
|
68
|
+
//====================================================================================================================
|
|
69
|
+
resolveParentSize(component, container) {
|
|
70
|
+
if (component?.nativeElement && component?.nativeElement.parentNode && component?.nativeElement.parentNode.parentNode) {
|
|
71
|
+
this.parent = component?.nativeElement.parentNode.parentNode;
|
|
72
|
+
}
|
|
73
|
+
if (this.parent) {
|
|
74
|
+
let parentSize = SVG_MATH.size(this.parent);
|
|
75
|
+
this.height = parentSize.height;
|
|
76
|
+
this.width = parentSize.width;
|
|
77
|
+
}
|
|
78
|
+
container?.nativeElement.setAttribute('style', `display: block; height:${this.height}px;width:${this.width}px`);
|
|
79
|
+
}
|
|
80
|
+
initializeLayout(container) {
|
|
81
|
+
this.defs = SVG_BUILDER.createDefs(container?.nativeElement);
|
|
82
|
+
this.locator = SVG_BUILDER.createGroup(container?.nativeElement, { styleClass: 'locator' });
|
|
83
|
+
this.canvas = SVG_BUILDER.createGroup(this.locator, { styleClass: 'canvas' });
|
|
84
|
+
const filter = SVG_BUILDER.createFilter(this.defs, 'shadow', { style: 'color-interpolation-filters: sRGB;' });
|
|
85
|
+
const gaussian = SVG_BUILDER.createNode('feGaussianBlur', filter);
|
|
86
|
+
if (gaussian) {
|
|
87
|
+
gaussian.setAttribute('stdDeviation', '1');
|
|
88
|
+
}
|
|
89
|
+
if (this.canvas) {
|
|
90
|
+
this.graph = SVG_BUILDER.createGroup(this.canvas, { styleClass: 'graph' });
|
|
91
|
+
}
|
|
92
|
+
this.updateValues();
|
|
93
|
+
}
|
|
94
|
+
//====================================================================================================================
|
|
95
|
+
// UPDATE VALUES
|
|
96
|
+
//====================================================================================================================
|
|
97
|
+
updateValues() {
|
|
98
|
+
const asset = this.asset();
|
|
99
|
+
if (!asset || !this.graph) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
this.graph.replaceChildren();
|
|
103
|
+
const type = this.type();
|
|
104
|
+
let state = this.state();
|
|
105
|
+
let currentType = asset.types.find(t => t.name == type);
|
|
106
|
+
if (!currentType) {
|
|
107
|
+
currentType = asset.types.find(t => t.name == 'default');
|
|
108
|
+
}
|
|
109
|
+
if (!currentType) {
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
let currentState = currentType.states.find(t => t.name == state);
|
|
113
|
+
if (!currentState) {
|
|
114
|
+
state = 'default';
|
|
115
|
+
}
|
|
116
|
+
const node = SVG_BUILDER.createGroup(this.graph);
|
|
117
|
+
SvgAssetUtils.createAsset({
|
|
118
|
+
parent: this.graph,
|
|
119
|
+
node: node,
|
|
120
|
+
asset: {
|
|
121
|
+
assetSet: this.assetSet(),
|
|
122
|
+
assetName: asset.name,
|
|
123
|
+
type: type,
|
|
124
|
+
state: state,
|
|
125
|
+
x: 0,
|
|
126
|
+
y: 0
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
setTimeout(() => this.resize(), 0);
|
|
130
|
+
}
|
|
131
|
+
//====================================================================================================================
|
|
132
|
+
// TOOLS
|
|
133
|
+
//====================================================================================================================
|
|
134
|
+
resize() {
|
|
135
|
+
if (this.locator && this.parent) {
|
|
136
|
+
SVG_TRANSFORM.center(this.locator, this.parent, true, true);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.8", ngImport: i0, type: InuSvgAsset, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
140
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "21.0.8", type: InuSvgAsset, isStandalone: true, selector: "inu-svg-asset", inputs: { assetSet: { classPropertyName: "assetSet", publicName: "assetSet", isSignal: true, isRequired: false, transformFunction: null }, asset: { classPropertyName: "asset", publicName: "asset", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: true, isRequired: false, transformFunction: null }, styleclass: { classPropertyName: "styleclass", publicName: "styleclass", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "window:resize": "onResize()" } }, providers: [InuTemplateRegistryService], viewQueries: [{ propertyName: "component", first: true, predicate: ["component"], descendants: true, isSignal: true }, { propertyName: "container", first: true, predicate: ["container"], descendants: true, isSignal: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
141
|
+
<div [class]="_styleClass()" #component>
|
|
142
|
+
<svg #container xmlns="http://www.w3.org/2000/svg"></svg>
|
|
143
|
+
</div>
|
|
144
|
+
`, isInline: true, styles: [""] });
|
|
145
|
+
}
|
|
146
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.8", ngImport: i0, type: InuSvgAsset, decorators: [{
|
|
147
|
+
type: Component,
|
|
148
|
+
args: [{ selector: 'inu-svg-asset', standalone: true, providers: [InuTemplateRegistryService], imports: [], template: `
|
|
149
|
+
<div [class]="_styleClass()" #component>
|
|
150
|
+
<svg #container xmlns="http://www.w3.org/2000/svg"></svg>
|
|
151
|
+
</div>
|
|
152
|
+
` }]
|
|
153
|
+
}], ctorParameters: () => [], propDecorators: { assetSet: [{ type: i0.Input, args: [{ isSignal: true, alias: "assetSet", required: false }] }], asset: [{ type: i0.Input, args: [{ isSignal: true, alias: "asset", required: false }] }], type: [{ type: i0.Input, args: [{ isSignal: true, alias: "type", required: false }] }], state: [{ type: i0.Input, args: [{ isSignal: true, alias: "state", required: false }] }], styleclass: [{ type: i0.Input, args: [{ isSignal: true, alias: "styleclass", required: false }] }], component: [{ type: i0.ViewChild, args: ['component', { isSignal: true }] }], container: [{ type: i0.ViewChild, args: ['container', { isSignal: true }] }], onResize: [{
|
|
154
|
+
type: HostListener,
|
|
155
|
+
args: ['window:resize']
|
|
156
|
+
}] } });
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* Generated bundle index. Do not edit.
|
|
160
|
+
*/
|
|
161
|
+
|
|
162
|
+
export { InuSvgAsset };
|
|
163
|
+
//# sourceMappingURL=inugami-ng-components-inu-svg-asset.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inugami-ng-components-inu-svg-asset.mjs","sources":["../../../projects/inugami-ng/components/inu-svg-asset/inu-svg-asset.ts","../../../projects/inugami-ng/components/inu-svg-asset/inugami-ng-components-inu-svg-asset.ts"],"sourcesContent":["import {\n AfterViewInit,\n Component,\n computed,\n effect,\n ElementRef,\n HostListener,\n input,\n OnChanges, signal,\n SimpleChanges,\n viewChild\n} from '@angular/core';\nimport {InuTemplateRegistryService} from 'inugami-ng/directives';\nimport {SVG_ASSETS, SVG_BUILDER, SVG_MATH, SVG_TRANSFORM, SvgAssetUtils} from 'inugami-ng/services';\nimport {SvgAsset} from 'inugami-svg-assets';\nimport {SvgAssetDTOOptions} from 'inugami-ng/models';\n\n@Component({\n selector: 'inu-svg-asset',\n standalone: true,\n providers: [InuTemplateRegistryService],\n imports: [],\n template: `\n <div [class]=\"_styleClass()\" #component>\n <svg #container xmlns=\"http://www.w3.org/2000/svg\"></svg>\n </div>\n `,\n styleUrl: './inu-svg-asset.scss',\n})\nexport class InuSvgAsset implements AfterViewInit, OnChanges {\n\n //====================================================================================================================\n // ATTRIBUTES\n //====================================================================================================================\n assetSet = input<string>('');\n asset = input<SvgAsset | undefined>(undefined);\n type = input<string | undefined>('default');\n state = input<string | undefined>('default');\n styleclass = input<string>('');\n //\n private component = viewChild<ElementRef<HTMLElement>>('component');\n private container = viewChild<ElementRef<HTMLElement>>('container');\n _styleClass = computed<string>(() => {\n return [\n 'inu-svg',\n 'inu-svg-asset',\n this.styleclass() ? this.styleclass() : ''\n ].join(' ');\n })\n\n //--- SVG components\n height: number = 64;\n width: number = 64;\n parent: HTMLElement | null = null;\n locator: SVGElement | null = null;\n defs: SVGElement | null = null;\n canvas: SVGElement | null = null;\n graph: SVGElement | null = null;\n\n //====================================================================================================================\n // INIT\n //====================================================================================================================\n\n constructor() {\n effect(() => {\n this.asset();\n this.type();\n this.state();\n\n if (this.graph) {\n this.updateValues();\n }\n });\n }\n\n ngOnChanges(changes: SimpleChanges) {\n this.updateValues();\n }\n\n ngAfterViewInit(): void {\n const component = this.component();\n const container = this.container();\n if (component && container) {\n this.resolveParentSize(component, container);\n this.initializeLayout(container);\n this.resize();\n }\n }\n\n @HostListener('window:resize')\n onResize() {\n const component = this.component();\n const container = this.container();\n if (component && container) {\n this.resolveParentSize(component, container);\n this.resize();\n }\n }\n\n\n //====================================================================================================================\n // RENDERING\n //====================================================================================================================\n private resolveParentSize(component: ElementRef<HTMLElement>, container: ElementRef<HTMLElement>) {\n if (component?.nativeElement && component?.nativeElement.parentNode && component?.nativeElement.parentNode.parentNode) {\n this.parent = component?.nativeElement.parentNode.parentNode as HTMLElement;\n }\n\n if (this.parent) {\n let parentSize = SVG_MATH.size(this.parent);\n this.height = parentSize.height;\n this.width = parentSize.width;\n }\n\n container?.nativeElement.setAttribute('style', `display: block; height:${this.height}px;width:${this.width}px`);\n }\n\n private initializeLayout(container: ElementRef<HTMLElement>) {\n this.defs = SVG_BUILDER.createDefs(container?.nativeElement);\n this.locator = SVG_BUILDER.createGroup(container?.nativeElement, {styleClass: 'locator'});\n this.canvas = SVG_BUILDER.createGroup(this.locator, {styleClass: 'canvas'});\n\n const filter = SVG_BUILDER.createFilter(this.defs, 'shadow', {style: 'color-interpolation-filters: sRGB;'});\n const gaussian = SVG_BUILDER.createNode('feGaussianBlur', filter);\n if (gaussian) {\n gaussian.setAttribute('stdDeviation', '1');\n }\n if (this.canvas) {\n this.graph = SVG_BUILDER.createGroup(this.canvas, {styleClass: 'graph'});\n }\n\n this.updateValues();\n }\n\n\n //====================================================================================================================\n // UPDATE VALUES\n //====================================================================================================================\n public updateValues() {\n const asset = this.asset();\n if (!asset || !this.graph) {\n return;\n }\n this.graph.replaceChildren();\n\n const type = this.type();\n let state = this.state();\n let currentType = asset.types.find(t => t.name == type);\n if (!currentType) {\n currentType = asset.types.find(t => t.name == 'default');\n }\n if (!currentType) {\n return;\n }\n let currentState = currentType.states.find(t => t.name == state);\n if (!currentState) {\n state = 'default';\n }\n\n const node = SVG_BUILDER.createGroup(this.graph);\n SvgAssetUtils.createAsset(<SvgAssetDTOOptions>{\n parent: this.graph,\n node: node,\n asset: {\n assetSet: this.assetSet(),\n assetName: asset.name,\n type: type,\n state: state,\n x: 0,\n y: 0\n }\n });\n\n setTimeout(() => this.resize(), 0);\n }\n\n\n //====================================================================================================================\n // TOOLS\n //====================================================================================================================\n public resize(): void {\n if (this.locator && this.parent) {\n SVG_TRANSFORM.center(this.locator, this.parent, true, true);\n }\n }\n\n\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|