c3-components 0.2.3 → 0.5.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.
@@ -0,0 +1,10 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./components/c3-flowing-menu/c3-flowing-menu.component";
3
+ import * as i2 from "./components/c3-flowing-menu-item/c3-flowing-menu-item.component";
4
+ import * as i3 from "./components/c3-flowing-menu-item-content/c3-flowing-menu-item-content.component";
5
+ import * as i4 from "@angular/common";
6
+ export declare class C3FlowingMenuModule {
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<C3FlowingMenuModule, never>;
8
+ static ɵmod: i0.ɵɵNgModuleDeclaration<C3FlowingMenuModule, [typeof i1.C3FlowingMenuComponent, typeof i2.C3FlowingMenuItemComponent, typeof i3.C3FlowingMenuItemContentComponent], [typeof i4.CommonModule], [typeof i1.C3FlowingMenuComponent, typeof i2.C3FlowingMenuItemComponent, typeof i3.C3FlowingMenuItemContentComponent]>;
9
+ static ɵinj: i0.ɵɵInjectorDeclaration<C3FlowingMenuModule>;
10
+ }
@@ -0,0 +1,12 @@
1
+ import { C3FlowingMenuItemComponent } from '../c3-flowing-menu-item/c3-flowing-menu-item.component';
2
+ import * as i0 from "@angular/core";
3
+ export declare class C3FlowingMenuComponent {
4
+ readonly c3FlowingMenu: import("@angular/core").Signal<readonly C3FlowingMenuItemComponent[]>;
5
+ private readonly targetContentRef;
6
+ readonly selectedIndex: import("@angular/core").WritableSignal<number>;
7
+ constructor();
8
+ selectMenu(index: number): void;
9
+ private updateView;
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<C3FlowingMenuComponent, never>;
11
+ static ɵcmp: i0.ɵɵComponentDeclaration<C3FlowingMenuComponent, "c3-flowing-menu", never, {}, {}, ["c3FlowingMenu"], never, false, never>;
12
+ }
@@ -0,0 +1,9 @@
1
+ import { TemplateRef } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class C3FlowingMenuItemComponent {
4
+ readonly menuTpl: import("@angular/core").Signal<TemplateRef<any> | undefined>;
5
+ readonly contentTpl: import("@angular/core").Signal<TemplateRef<any> | undefined>;
6
+ readonly active: import("@angular/core").WritableSignal<boolean>;
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<C3FlowingMenuItemComponent, never>;
8
+ static ɵcmp: i0.ɵɵComponentDeclaration<C3FlowingMenuItemComponent, "c3-flowing-menu-item", never, {}, {}, never, ["[menu-title]", "c3-flowing-menu-item-content"], false, never>;
9
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class C3FlowingMenuItemContentComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<C3FlowingMenuItemContentComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<C3FlowingMenuItemContentComponent, "c3-flowing-menu-item-content", never, {}, {}, never, ["*"], false, never>;
5
+ }
@@ -0,0 +1,86 @@
1
+ @use "@angular/material" as mat;
2
+
3
+ @mixin c3-flowing-menu($theme) {
4
+ $is-dark-theme: mat.get-theme-type($theme) == dark;
5
+ $menu-inactive: if($is-dark-theme, #9b9b9b, #dfdfdf);
6
+ $menu-active: if($is-dark-theme, #5f5f5f, #c0c0c0);
7
+ $menu-hover: if($is-dark-theme, #a5a5a5, #e7e7e7);
8
+ .c3-flowing-menu {
9
+ --menu-inactive: #{$menu-inactive};
10
+ --menu-active: #{$menu-active};
11
+ --menu-hover: #{$menu-hover};
12
+
13
+ display: grid;
14
+ grid-template-columns: auto 1fr;
15
+ grid-template-areas: "menu contenu";
16
+ height: 100%;
17
+
18
+ .menu {
19
+ grid-area: menu;
20
+ height: 100%;
21
+ display: flex;
22
+ flex-direction: column;
23
+ overflow-y: auto;
24
+ padding: 2rem 0;
25
+
26
+ > button {
27
+ position: relative;
28
+ margin: 0;
29
+ padding: 1rem;
30
+ background-color: var(--menu-inactive);
31
+ cursor: pointer;
32
+ min-width: 200px;
33
+ box-shadow: none;
34
+ border-radius: 0;
35
+ border-top-left-radius: 1rem;
36
+ border-bottom-left-radius: 1rem;
37
+ color: black;
38
+
39
+ &:hover {
40
+ background-color: var(--menu-hover);
41
+ }
42
+
43
+ &.active {
44
+ background-color: var(--menu-active);
45
+ box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
46
+ z-index: 1;
47
+ &::before {
48
+ content: "";
49
+ position: absolute;
50
+
51
+ background-color: transparent;
52
+ bottom: -2rem;
53
+ right: 0;
54
+ height: 2rem;
55
+ width: 1rem;
56
+ border-top-right-radius: 1rem;
57
+ box-shadow: 0 -1rem 0 0 var(--menu-active);
58
+ }
59
+ &::after {
60
+ content: "";
61
+ position: absolute;
62
+ background-color: transparent;
63
+ top: -2rem;
64
+ right: 0;
65
+ height: 2rem;
66
+ width: 1rem;
67
+ border-bottom-right-radius: 1rem;
68
+ box-shadow: 0 1rem 0 0 var(--menu-active);
69
+ }
70
+ }
71
+ }
72
+ }
73
+
74
+ .contenu {
75
+ grid-area: contenu;
76
+ padding: 1rem;
77
+ height: 100%;
78
+ overflow: auto;
79
+ background-color: var(--menu-active);
80
+ border-radius: 1rem;
81
+ @include mat.elevation(8);
82
+
83
+ transition: all 0.2s;
84
+ }
85
+ }
86
+ }
@@ -2,10 +2,12 @@
2
2
  @use "../c3-dropdown/styles/_c3-dropdown" as *;
3
3
  @use "../c3-file-viewer/styles/_c3-file-viewer" as *;
4
4
  @use "../c3-expansion/styles/_c3-expansion" as *;
5
+ @use "../c3-flowing-menu/styles/c3-flowing-menu" as *;
5
6
 
6
7
  @mixin c3-core($theme) {
7
8
  @include c3-root-variables($theme);
8
9
  @include c3-material-dropdown($theme);
9
10
  @include c3-file-viewer($theme);
10
11
  @include c3-expansion($theme);
12
+ @include c3-flowing-menu($theme);
11
13
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "c3-components",
3
- "version": "0.2.3",
3
+ "version": "0.5.0",
4
4
  "description": "C3 Components Library",
5
5
  "author": "c3ulnta0rk",
6
6
  "license": "MIT",
package/public-api.d.ts CHANGED
@@ -59,3 +59,10 @@ export * from './lib/c3-signals/c3-boolean-signal';
59
59
  * C3 Tree
60
60
  */
61
61
  export * from './lib/c3-tree/c3-tree.component';
62
+ /**
63
+ * C3 flowing menu
64
+ */
65
+ export * from './lib/c3-flowing-menu/c3-flowing-menu.module';
66
+ export * from './lib/c3-flowing-menu/components/c3-flowing-menu/c3-flowing-menu.component';
67
+ export * from './lib/c3-flowing-menu/components/c3-flowing-menu-item/c3-flowing-menu-item.component';
68
+ export * from './lib/c3-flowing-menu/components/c3-flowing-menu-item-content/c3-flowing-menu-item-content.component';