@ruc-lib/drawer 3.1.0 → 3.2.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.
package/README.md CHANGED
@@ -38,32 +38,38 @@ Please ensure you install the correct version of `@ruc-lib/drawer` based on your
38
38
 
39
39
  | Angular Version | Compatible `@ruc-lib/drawer` Version |
40
40
  |--------------------|------------------------------------------|
41
- | 15.x.x | `npm install @ruc-lib/drawer@^3.0.0` |
42
- | 16.x.x | `npm install @ruc-lib/drawer@^3.0.0` |
41
+ | 15.x.x | `npm install @ruc-lib/drawer@^3.2.0` |
42
+ | 16.x.x | `npm install @ruc-lib/drawer@^3.2.0` |
43
43
 
44
44
 
45
45
  ## Usage
46
46
 
47
- ### 1. Import the Component
48
- In your Angular component file (e.g., `app.component.ts`), import the `RuclibDrawerComponent`:
49
-
50
- ```typescript
51
- import { Component } from '@angular/core';
52
-
53
- // For Complete Library
54
- import { RuclibDrawerComponent } from '@uxpractice/ruc-lib/drawer';
55
-
56
- // For Individual Package
57
- import { RuclibDrawerComponent } from '@ruc-lib/drawer';
58
-
59
- @Component({
60
- selector: 'app-root',
61
- imports: [RuclibDrawerComponent],
62
- templateUrl: './app.component.html',
63
- })
64
- export class AppComponent {
65
- // Component code here
66
- }
47
+ ### 1. Import the Module
48
+ In your Angular module file (e.g., `app.module.ts`), import the `RuclibDrawerModule`:
49
+
50
+ ```typescript
51
+ // For Complete Library
52
+ import { RuclibDrawerModule } from '@uxpractice/ruc-lib/drawer';
53
+
54
+ // For Individual Package
55
+ import { RuclibDrawerModule } from '@ruc-lib/drawer';
56
+
57
+ import { AppComponent } from './app.component';
58
+ import { NgModule } from '@angular/core';
59
+ import { BrowserModule } from '@angular/platform-browser';
60
+ import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
61
+
62
+ @NgModule({
63
+ declarations: [AppComponent],
64
+ imports: [
65
+ BrowserModule,
66
+ BrowserAnimationsModule,
67
+ RuclibDrawerModule
68
+ ],
69
+ providers: [],
70
+ bootstrap: [AppComponent]
71
+ })
72
+ export class AppModule {}
67
73
  ```
68
74
 
69
75
  ### 2. Use the Component
@@ -229,4 +235,4 @@ Contributions are welcome! Feel free to open issues or pull requests for any enh
229
235
 
230
236
  # Acknowledgements
231
237
 
232
- Thank you for choosing the Drawer Component Library. If you have any feedback or suggestions, please let us know!
238
+ Thank you for choosing the Drawer Component Library. If you have any feedback or suggestions, please let us know!
@@ -0,0 +1,5 @@
1
+ export * from './lib/ruclib-drawer.module';
2
+ export * from './lib/ruclib-drawer/ruclib-drawer.component';
3
+ export * from './model/default-values';
4
+ export * from './interface/drawer';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3J1Y2xpYi1kcmF3ZXIubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcnVjbGliLWRyYXdlci9ydWNsaWItZHJhd2VyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWwvZGVmYXVsdC12YWx1ZXMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZS9kcmF3ZXInOyJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.js","sourceRoot":"","sources":["../../../src/interface/drawer.ts"],"names":[],"mappings":"","sourcesContent":["import { MatDrawerMode } from \"@angular/material/sidenav\";\r\nimport { Type } from \"@angular/core\";\r\n\r\n/**\r\n * Defines the dimensions for a button, including text and icon sizing.\r\n */\r\nexport interface ButtonDimensions {\r\n  /**\r\n   * The width of the button.\r\n   * @example '120px', '5em'\r\n   * @optional\r\n   */\r\n  width?: string;      // e.g., '120px', '5em'\r\n  /**\r\n   * The height of the button.\r\n   * @example '40px', '2.5em'\r\n   * @optional\r\n   */\r\n  height?: string;     // e.g., '40px', '2.5em'\r\n  /**\r\n   * The padding of the button. Primarily for the main toggle button.\r\n   * @example '0 10px'\r\n   * @optional\r\n   */\r\n  padding?: string;    // e.g., '0 10px' (Mostly for toggle button)\r\n  /**\r\n   * The font size for text within the button.\r\n   * @example '14px'\r\n   * @optional\r\n   */\r\n  fontSize?: string;   // e.g., '14px' (For text in toggle button)\r\n  /**\r\n   * The size of the icon within the button.\r\n   * @example '20px'\r\n   * @optional\r\n   */\r\n  iconSize?: string;   // e.g., '20px' (For icons in toggle or close button)\r\n}\r\n\r\n/**\r\n * Defines the dimensions for an icon button, like a close button.\r\n */\r\nexport interface IconDimensions { // Simplified for icon buttons like close\r\n  /**\r\n   * The width of the icon button.\r\n   * @example '32px'\r\n   * @optional\r\n   */\r\n  width?: string;      // e.g., '32px'\r\n  /**\r\n   * The height of the icon button.\r\n   * @example '32px'\r\n   * @optional\r\n   */\r\n  height?: string;     // e.g., '32px'\r\n  /**\r\n   * The size of the icon itself within the button.\r\n   * @example '18px'\r\n   * @optional\r\n   */\r\n  iconSize?: string;   // e.g., '18px'\r\n}\r\n\r\n/**\r\n * Defines the input properties for the RuclibDrawerComponent.\r\n */\r\nexport interface RuclibDrawerInput {\r\n  /**\r\n   * Position of the drawer.\r\n   * @default 'left'\r\n   * @optional\r\n   */\r\n  drawerPosition?: 'left' | 'right' | 'top' | 'bottom'; // Default 'left'\r\n  /**\r\n   * Mode of the drawer.\r\n   * `side`: Drawer stays open and reduces the content area.\r\n   * `over`: Drawer floats over the content.\r\n   * `push`: Drawer pushes the content away.\r\n   * @optional\r\n   */\r\n  mode?: MatDrawerMode; // 'side', 'over', 'push'\r\n  /**\r\n   * Whether the drawer is initially opened.\r\n   * @optional\r\n   */\r\n  initialOpenedState?: boolean;\r\n  /**\r\n   * Width of the drawer, used when `drawerPosition` is 'left' or 'right'.\r\n   * @example '250px', '30vw'\r\n   * @optional\r\n   */\r\n  drawerWidth?: string; // Used for left/right drawers\r\n  /**\r\n   * Height of the drawer, used when `drawerPosition` is 'top' or 'bottom'.\r\n   * @example '200px', '40vh'\r\n   * @optional\r\n   */\r\n  drawerHeight?: string; // Used for top/bottom drawers\r\n  /**\r\n   * Content to be displayed in the drawer and main area.\r\n   * @optional\r\n   */\r\n  content?: {\r\n    /**\r\n     * Title displayed within the drawer.\r\n     * @optional\r\n     */\r\n    drawerTitle?: string;\r\n    /**\r\n     * HTML content for the body of the drawer. Used if `drawerContentComponent` is not provided.\r\n     * @optional\r\n     */\r\n    drawerBody?: string; // HTML content\r\n    /**\r\n     * An Angular component to be rendered as the drawer's body content.\r\n     * If provided, `drawerBody` (HTML string) will be ignored for the drawer.\r\n     * @optional\r\n     */\r\n    drawerContentComponent?: Type<any>;\r\n    /**\r\n     * HTML content for the main application area beside/under the drawer.\r\n     * @optional\r\n     */\r\n    mainBody?: string;   // HTML content\r\n  };\r\n  /**\r\n   * Data to be passed to the `drawerContentComponent` instance.\r\n   * The dynamic component should have an @Input() property to receive this data.\r\n   */\r\n  drawerContentComponentData?: any;\r\n  /**\r\n   * Whether to disable the toggle button in the main content area.\r\n   * @optional\r\n   */\r\n  disableToggleButtonInMainContent?: boolean;\r\n  /**\r\n   * Text for the toggle button, supporting different text for open and close states.\r\n   * Also used for aria-label.\r\n   * @optional\r\n   */\r\n  toggleButtonText?: {\r\n    /**\r\n     * Text for the button when the drawer is closed (action to open).\r\n     * @optional\r\n     */\r\n    open?: string;\r\n    /**\r\n     * Text for the button when the drawer is open (action to close).\r\n     * @optional\r\n     */\r\n    close?: string; // Used for text display and aria-label\r\n  };\r\n  /**\r\n   * Material icon name for the toggle button.\r\n   * @example 'menu', 'settings'\r\n   * @optional\r\n   */\r\n  toggleButtonIcon?: string; // Material icon name\r\n  /**\r\n   * URL for an image to be used in the toggle button.\r\n   * @optional\r\n   */\r\n  toggleButtonImageUrl?: string;\r\n  /**\r\n   * Alt text for the toggle button image.\r\n   * @optional\r\n   */\r\n  toggleButtonImageAlt?: string;\r\n  /**\r\n   * Whether the drawer has a backdrop, especially in 'over' mode.\r\n   * @optional\r\n   */\r\n  hasBackdrop?: boolean;\r\n  /**\r\n   * Custom background color for the backdrop.\r\n   * @example 'rgba(0,0,0,0.5)', '#333333'\r\n   * @optional\r\n   */\r\n  backdropBackgroundColor?: string;\r\n  /**\r\n   * Whether to show a close icon (e.g., 'x') inside the drawer.\r\n   * @optional\r\n   */\r\n  showCloseIcon?: boolean;\r\n  /**\r\n   * Whether to disable closing the drawer by pressing the Escape key or clicking on the backdrop.\r\n   * @optional\r\n   */\r\n  disableClose?: boolean;\r\n  /**\r\n   * Duration for the drawer's open/close animation.\r\n   * @example '300ms', '0.5s'\r\n   * @optional Defaults to Material's default (usually around 400ms for MatDrawer, or 300ms for custom animations).\r\n   */\r\n  animationDuration?: string; // e.g., '300ms', '0.5s'. Default is Material's default (usually 400ms)\r\n  /**\r\n   * Custom dimensions for the main toggle button.\r\n   * @optional\r\n   */\r\n  toggleButtonDimensions?: ButtonDimensions; // Custom dimensions for the main toggle button\r\n  /**\r\n   * Custom dimensions for the close icon button inside the drawer.\r\n   * @optional\r\n   */\r\n  closeButtonDimensions?: IconDimensions;  // Custom dimensions for the close icon button\r\n}"]}