mis-crystal-design-system 18.0.8-test-5 → 18.0.9
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/button/button.directive.scss +69 -0
- package/drawer/drawer.scss +20 -0
- package/dropdown/dropdown.component.d.ts +10 -2
- package/esm2022/dropdown/dropdown.component.mjs +124 -76
- package/esm2022/phone-input/phone-input.component.mjs +2 -2
- package/esm2022/table/public_api.mjs +3 -4
- package/esm2022/table/table.component.mjs +76 -114
- package/esm2022/table/table.module.mjs +4 -25
- package/fesm2022/mis-crystal-design-system-dropdown.mjs +123 -75
- package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-phone-input.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +80 -274
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/input/mis-input.component.scss +180 -0
- package/modal/modal.scss +9 -0
- package/package.json +7 -7
- package/styles/fonts/icomoon.eot +0 -0
- package/styles/fonts/icomoon.svg +315 -0
- package/styles/fonts/icomoon.ttf +0 -0
- package/styles/fonts/icomoon.woff +0 -0
- package/styles/mis-borders-backgrounds.scss +764 -0
- package/styles/mis-color-constants.scss +149 -0
- package/styles/mis-flex.scss +321 -0
- package/styles/mis-fonts.scss +124 -0
- package/styles/mis-icons.scss +1054 -0
- package/styles/mis-mixins.scss +46 -0
- package/styles/mis-old-icon-styles.scss +498 -0
- package/styles/mis-spacing-sizing.scss +2590 -0
- package/styles/mis-typography.scss +462 -0
- package/table/public_api.d.ts +2 -3
- package/table/table.component.d.ts +1 -10
- package/table/table.module.d.ts +4 -5
- package/esm2022/table/sort-icons.directive.mjs +0 -139
- package/table/sort-icons.directive.d.ts +0 -36
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import { Directive, input, output, signal, } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class SortIconsDirective {
|
|
4
|
-
constructor(el, renderer) {
|
|
5
|
-
this.el = el;
|
|
6
|
-
this.renderer = renderer;
|
|
7
|
-
// Convert inputs to signals
|
|
8
|
-
this.column = input();
|
|
9
|
-
this.activeSort = input();
|
|
10
|
-
this.activeSorts = input();
|
|
11
|
-
this.multiColumnSort = input(false);
|
|
12
|
-
// Convert output to signal
|
|
13
|
-
this.sortChange = output();
|
|
14
|
-
this.multiSortChange = output();
|
|
15
|
-
// Internal state as signals
|
|
16
|
-
this.currentDirection = signal('');
|
|
17
|
-
}
|
|
18
|
-
ngOnInit() {
|
|
19
|
-
// Create a container for the icons
|
|
20
|
-
const container = this.renderer.createElement('div');
|
|
21
|
-
this.renderer?.setStyle(container, 'display', 'inline-flex');
|
|
22
|
-
this.renderer?.setStyle(container, 'align-items', 'center');
|
|
23
|
-
const iconContainer = this.renderer.createElement('div');
|
|
24
|
-
this.renderer?.setStyle(iconContainer, 'display', 'inline-flex');
|
|
25
|
-
this.renderer?.setStyle(iconContainer, 'flex-direction', 'column');
|
|
26
|
-
this.renderer?.setStyle(iconContainer, 'align-items', 'center');
|
|
27
|
-
this.upIcon = this.renderer.createElement('img');
|
|
28
|
-
this.renderer?.setAttribute(this.upIcon, 'src', this.column()?.sortAscIcon);
|
|
29
|
-
this.renderer?.setStyle(this.upIcon, 'opacity', '0.5');
|
|
30
|
-
this.renderer?.setStyle(this.upIcon, 'transition', 'opacity 0.3s ease');
|
|
31
|
-
this.renderer?.setStyle(this.upIcon, 'width', '9px');
|
|
32
|
-
this.renderer?.setStyle(this.upIcon, 'cursor', 'pointer');
|
|
33
|
-
this.renderer?.listen(this.upIcon, 'click', () => this.setSortDirection('ASC'));
|
|
34
|
-
this.downIcon = this.renderer.createElement('img');
|
|
35
|
-
this.renderer?.setAttribute(this.downIcon, 'src', this.column()?.sortDescIcon);
|
|
36
|
-
this.renderer?.setStyle(this.downIcon, 'opacity', '0.5');
|
|
37
|
-
this.renderer?.setStyle(this.downIcon, 'transition', 'opacity 0.3s ease');
|
|
38
|
-
this.renderer?.setStyle(this.downIcon, 'width', '9px');
|
|
39
|
-
this.renderer?.setStyle(this.downIcon, 'cursor', 'pointer');
|
|
40
|
-
this.renderer?.listen(this.downIcon, 'click', () => this.setSortDirection('DESC'));
|
|
41
|
-
this.renderer?.appendChild(iconContainer, this.upIcon);
|
|
42
|
-
this.renderer?.appendChild(iconContainer, this.downIcon);
|
|
43
|
-
this.renderer?.appendChild(container, iconContainer);
|
|
44
|
-
if (this.multiColumnSort()) {
|
|
45
|
-
this.sortOrderElement = this.renderer.createElement('span');
|
|
46
|
-
this.renderer?.setStyle(this.sortOrderElement, 'font-size', '12px');
|
|
47
|
-
this.renderer?.setStyle(this.sortOrderElement, 'font-weight', 'bold');
|
|
48
|
-
this.renderer?.setStyle(this.sortOrderElement, 'color', '#000');
|
|
49
|
-
this.renderer?.appendChild(container, this.sortOrderElement);
|
|
50
|
-
}
|
|
51
|
-
this.renderer?.appendChild(this.el.nativeElement, container);
|
|
52
|
-
this.updateIconStyles();
|
|
53
|
-
}
|
|
54
|
-
ngOnChanges(changes) {
|
|
55
|
-
if (changes['activeSort'] || changes['activeSorts']) {
|
|
56
|
-
this.updateIconStyles();
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
setSortDirection(direction) {
|
|
60
|
-
if (this.multiColumnSort()) {
|
|
61
|
-
this.handleMultiColumnSort(direction);
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
64
|
-
this.handleSingleColumnSort(direction);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
handleSingleColumnSort(direction) {
|
|
68
|
-
if (this.currentDirection() === direction) {
|
|
69
|
-
this.currentDirection.set(''); // Reset sorting if the same direction is clicked
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
this.currentDirection.set(direction);
|
|
73
|
-
}
|
|
74
|
-
this.sortChange.emit({
|
|
75
|
-
column: this.column()?.data || '',
|
|
76
|
-
direction: this.currentDirection()
|
|
77
|
-
});
|
|
78
|
-
this.updateIconStyles();
|
|
79
|
-
}
|
|
80
|
-
handleMultiColumnSort(direction) {
|
|
81
|
-
const existingSortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);
|
|
82
|
-
if (existingSortIndex !== -1) {
|
|
83
|
-
if (this.activeSorts()[existingSortIndex].direction !== direction) {
|
|
84
|
-
this.activeSorts()[existingSortIndex].direction = direction;
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
else {
|
|
91
|
-
this.activeSorts().push({
|
|
92
|
-
column: this.column()?.data || '',
|
|
93
|
-
direction
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
this.multiSortChange.emit([...this.activeSorts()]);
|
|
97
|
-
this.updateIconStyles();
|
|
98
|
-
}
|
|
99
|
-
updateIconStyles() {
|
|
100
|
-
if (this.multiColumnSort()) {
|
|
101
|
-
this.updateMultiColumnIconStyles();
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
this.updateSingleColumnIconStyles();
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
updateSingleColumnIconStyles() {
|
|
108
|
-
const isActiveColumn = this.activeSort()?.column === this.column()?.data;
|
|
109
|
-
setTimeout(() => {
|
|
110
|
-
this.renderer?.setStyle(this.upIcon, 'opacity', isActiveColumn && this.currentDirection() === 'ASC' ? '1' : '0.5');
|
|
111
|
-
this.renderer?.setStyle(this.downIcon, 'opacity', isActiveColumn && this.currentDirection() === 'DESC' ? '1' : '0.5');
|
|
112
|
-
}, 0);
|
|
113
|
-
}
|
|
114
|
-
updateMultiColumnIconStyles() {
|
|
115
|
-
const columnSort = this.activeSorts().find(sort => sort.column === this.column()?.data);
|
|
116
|
-
setTimeout(() => {
|
|
117
|
-
this.renderer?.setStyle(this.upIcon, 'opacity', columnSort?.direction === 'ASC' ? '1' : '0.5');
|
|
118
|
-
this.renderer?.setStyle(this.downIcon, 'opacity', columnSort?.direction === 'DESC' ? '1' : '0.5');
|
|
119
|
-
if (this.sortOrderElement) {
|
|
120
|
-
const sortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);
|
|
121
|
-
if (sortIndex !== -1) {
|
|
122
|
-
this.renderer?.setProperty(this.sortOrderElement, 'textContent', (sortIndex + 1).toString());
|
|
123
|
-
}
|
|
124
|
-
else {
|
|
125
|
-
this.renderer?.setProperty(this.sortOrderElement, 'textContent', '');
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}, 0);
|
|
129
|
-
}
|
|
130
|
-
static { this.ɵfac = function SortIconsDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SortIconsDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Renderer2)); }; }
|
|
131
|
-
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SortIconsDirective, selectors: [["", "appSortIcons", ""]], inputs: { column: [1, "column"], activeSort: [1, "activeSort"], activeSorts: [1, "activeSorts"], multiColumnSort: [1, "multiColumnSort"] }, outputs: { sortChange: "sortChange", multiSortChange: "multiSortChange" }, features: [i0.ɵɵNgOnChangesFeature] }); }
|
|
132
|
-
}
|
|
133
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SortIconsDirective, [{
|
|
134
|
-
type: Directive,
|
|
135
|
-
args: [{
|
|
136
|
-
selector: '[appSortIcons]',
|
|
137
|
-
}]
|
|
138
|
-
}], () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], null); })();
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-icons.directive.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/sort-icons.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  input,\n  output,\n  signal,\n} from '@angular/core';\n\nexport interface SortState {\n  column: string;\n  direction: 'ASC' | 'DESC' | '';\n}\n\nexport interface SortColumn {\n  data: string;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\n\n@Directive({\n  selector: '[appSortIcons]',\n})\nexport class SortIconsDirective implements OnInit, OnChanges {\n  // Convert inputs to signals\n  column = input<SortColumn>();\n  activeSort = input<SortState>();\n  activeSorts = input<SortState[]>();\n  multiColumnSort = input<boolean>(false);\n  \n  // Convert output to signal\n  sortChange = output<SortState>();\n  multiSortChange = output<SortState[]>();\n\n  // Internal state as signals\n  currentDirection = signal<'ASC' | 'DESC' | ''>('');\n\n  // Assets\n  private upIcon!: HTMLImageElement;\n  private downIcon!: HTMLImageElement;\n  private sortOrderElement?: HTMLSpanElement;\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\n\n  ngOnInit() {\n    \n    // Create a container for the icons\n    const container = this.renderer.createElement('div');\n    this.renderer?.setStyle(container, 'display', 'inline-flex');\n    this.renderer?.setStyle(container, 'align-items', 'center');\n\n    const iconContainer = this.renderer.createElement('div');\n    this.renderer?.setStyle(iconContainer, 'display', 'inline-flex');\n    this.renderer?.setStyle(iconContainer, 'flex-direction', 'column');\n    this.renderer?.setStyle(iconContainer, 'align-items', 'center');\n\n    this.upIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.upIcon, 'src', this.column()?.sortAscIcon);\n    this.renderer?.setStyle(this.upIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.upIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.upIcon, 'width', '9px');\n    this.renderer?.setStyle(this.upIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.upIcon, 'click', () => this.setSortDirection('ASC'));\n\n    this.downIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.downIcon, 'src', this.column()?.sortDescIcon);\n    this.renderer?.setStyle(this.downIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.downIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.downIcon, 'width', '9px');\n    this.renderer?.setStyle(this.downIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.downIcon, 'click', () => this.setSortDirection('DESC'));\n\n    this.renderer?.appendChild(iconContainer, this.upIcon);\n    this.renderer?.appendChild(iconContainer, this.downIcon);\n    this.renderer?.appendChild(container, iconContainer);\n\n    if (this.multiColumnSort()) {\n      this.sortOrderElement = this.renderer.createElement('span');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-size', '12px');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-weight', 'bold');\n      this.renderer?.setStyle(this.sortOrderElement, 'color', '#000');\n      this.renderer?.appendChild(container, this.sortOrderElement);\n    }\n\n    this.renderer?.appendChild(this.el.nativeElement, container);\n    this.updateIconStyles();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['activeSort'] || changes['activeSorts']) {\n      this.updateIconStyles();\n    }\n  }\n\n  private setSortDirection(direction: 'ASC' | 'DESC'): void {\n    if (this.multiColumnSort()) {\n      this.handleMultiColumnSort(direction);\n    } else {\n      this.handleSingleColumnSort(direction);\n    }\n  }\n\n  private handleSingleColumnSort(direction: 'ASC' | 'DESC'): void {\n    if (this.currentDirection() === direction) {\n      this.currentDirection.set(''); // Reset sorting if the same direction is clicked\n    } else {\n      this.currentDirection.set(direction);\n    }\n\n    this.sortChange.emit({ \n      column: this.column()?.data || '', \n      direction: this.currentDirection()\n    });\n    this.updateIconStyles();\n  }\n\n  private handleMultiColumnSort(direction: 'ASC' | 'DESC'): void {\n    const existingSortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);\n    \n    if (existingSortIndex !== -1) {\n      if (this.activeSorts()[existingSortIndex].direction !== direction) {\n        this.activeSorts()[existingSortIndex].direction = direction;\n      } else {\n        return;\n      }\n    } else {\n      this.activeSorts().push({ \n        column: this.column()?.data || '', \n        direction\n      });\n    }\n    this.multiSortChange.emit([...this.activeSorts()]);\n    this.updateIconStyles();\n  }\n\n  private updateIconStyles(): void {\n    if (this.multiColumnSort()) {\n      this.updateMultiColumnIconStyles();\n    } else {\n      this.updateSingleColumnIconStyles();\n    }\n  }\n\n  private updateSingleColumnIconStyles(): void {\n    const isActiveColumn = this.activeSort()?.column === this.column()?.data;\n\n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'DESC' ? '1' : '0.5'\n      );\n    }, 0);\n  }\n\n  private updateMultiColumnIconStyles(): void {\n    const columnSort = this.activeSorts().find(sort => sort.column === this.column()?.data);\n    \n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        columnSort?.direction === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        columnSort?.direction === 'DESC' ? '1' : '0.5'\n      );\n\n      if (this.sortOrderElement) {\n        const sortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);\n        if (sortIndex !== -1) {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', (sortIndex + 1).toString());\n        } else {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', '');\n        }\n      }\n    }, 0);\n  }\n}"]}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { ElementRef, OnChanges, OnInit, Renderer2, SimpleChanges } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export interface SortState {
|
|
4
|
-
column: string;
|
|
5
|
-
direction: 'ASC' | 'DESC' | '';
|
|
6
|
-
}
|
|
7
|
-
export interface SortColumn {
|
|
8
|
-
data: string;
|
|
9
|
-
sortAscIcon?: string;
|
|
10
|
-
sortDescIcon?: string;
|
|
11
|
-
}
|
|
12
|
-
export declare class SortIconsDirective implements OnInit, OnChanges {
|
|
13
|
-
private el;
|
|
14
|
-
private renderer;
|
|
15
|
-
column: import("@angular/core").InputSignal<SortColumn>;
|
|
16
|
-
activeSort: import("@angular/core").InputSignal<SortState>;
|
|
17
|
-
activeSorts: import("@angular/core").InputSignal<SortState[]>;
|
|
18
|
-
multiColumnSort: import("@angular/core").InputSignal<boolean>;
|
|
19
|
-
sortChange: import("@angular/core").OutputEmitterRef<SortState>;
|
|
20
|
-
multiSortChange: import("@angular/core").OutputEmitterRef<SortState[]>;
|
|
21
|
-
currentDirection: import("@angular/core").WritableSignal<"" | "ASC" | "DESC">;
|
|
22
|
-
private upIcon;
|
|
23
|
-
private downIcon;
|
|
24
|
-
private sortOrderElement?;
|
|
25
|
-
constructor(el: ElementRef, renderer: Renderer2);
|
|
26
|
-
ngOnInit(): void;
|
|
27
|
-
ngOnChanges(changes: SimpleChanges): void;
|
|
28
|
-
private setSortDirection;
|
|
29
|
-
private handleSingleColumnSort;
|
|
30
|
-
private handleMultiColumnSort;
|
|
31
|
-
private updateIconStyles;
|
|
32
|
-
private updateSingleColumnIconStyles;
|
|
33
|
-
private updateMultiColumnIconStyles;
|
|
34
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<SortIconsDirective, never>;
|
|
35
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<SortIconsDirective, "[appSortIcons]", never, { "column": { "alias": "column"; "required": false; "isSignal": true; }; "activeSort": { "alias": "activeSort"; "required": false; "isSignal": true; }; "activeSorts": { "alias": "activeSorts"; "required": false; "isSignal": true; }; "multiColumnSort": { "alias": "multiColumnSort"; "required": false; "isSignal": true; }; }, { "sortChange": "sortChange"; "multiSortChange": "multiSortChange"; }, never, never, false, never>;
|
|
36
|
-
}
|