@ruc-lib/drawer 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.
package/README.md ADDED
@@ -0,0 +1,141 @@
1
+ # ruclib-drawer
2
+
3
+ This library provides a flexible and customizable drawer component for your Angular applications. Users can integrate the drawer component using Angular selectors with ease. Below are the features, usage instructions, and integration details:
4
+
5
+ ## RUC Library Installation Guide
6
+
7
+ Users can easily install the RUC (Ruxptest Library) from npm. Additionally, they can also choose to install individual components based on their requirements.
8
+
9
+ ## Install complete library
10
+
11
+ `npm install @uxpractice/ruc-lib`
12
+
13
+ ## Install individual component
14
+
15
+ If users only need the drawer component, they can install it separately
16
+
17
+ `npm install @ruc-lib/drawer`
18
+
19
+ ## Usage
20
+
21
+ To use the drawer component in your project, follow the integration guidelines provided in the documentation. Customize the drawer as per your requirements by adjusting the configuration options.
22
+
23
+ ## Using Selector
24
+
25
+ 1. Import `DrawerModule` into `app.module.ts` file.
26
+ `( import { RuclibDrawerModule } from '@ruc-lib/drawer'; OR import { RuclibDrawerModule } from '@ uxpractice /ruc-lib/drawer'; )`
27
+ 2. Use the drawer selector in your HTML file.
28
+ 3. Handle input and output bindings accordingly.
29
+
30
+ ```
31
+ <uxp-ruclib-drawer
32
+ (rucEvent)="passEvent($event)"
33
+ [rucInputData]="inputObjectDataDrawer"
34
+ [customTheme]="customTheme">
35
+ </uxp-ruclib-drawer>
36
+ ```
37
+
38
+ # Input and Output
39
+
40
+ ## Input and Output
41
+
42
+ Inputs:
43
+ • rucInputData: Data to be passed to the drawer.
44
+ • customTheme: Custom styling/theme for the drawer.
45
+
46
+ Outputs:
47
+ • rucEvent: Event emitted from the drawer.
48
+
49
+
50
+ ## rucInputData configurations options-
51
+
52
+ ```
53
+ DrawerDefaultConfig {
54
+ drawerPosition: string = 'left',
55
+ mode: string = 'over',
56
+ initialOpenedState: boolean = false,
57
+ drawerWidth: string = '250px',
58
+ drawerHeight: string = '',
59
+ content: {
60
+ drawerTitle: string = 'Drawer Title',
61
+ drawerBody: string = '<p>This is the <strong>body</strong> content of the drawer.</p><p>It can contain <em>HTML</em>.</p>',
62
+ mainBody: string = '<h2>Main Content Area</h2><p>This is where the main application content would go.</p>',
63
+ },
64
+ disableToggleButtonInMainContent: boolean = false,
65
+ toggleButtonText: object = {
66
+ open: string = 'Open Drawer',
67
+ close: string = 'Close Drawer',
68
+ },
69
+ hasBackdrop: boolean = true,
70
+ backdropBackgroundColor: string = 'rgba(129, 124, 124, 0.6)',
71
+ showCloseIcon: boolean = true,
72
+ disableClose: boolean = false,
73
+ animationDuration: string = '300ms',
74
+ toggleButtonIcon: string = '',
75
+ toggleButtonImageAlt: string = '',
76
+ toggleButtonImageUrl: string = '',
77
+ toggleButtonDimensions: ButtonDimensions = {
78
+ width: string = 'auto',
79
+ height: string = '40px',
80
+ padding: string = '10px',
81
+ fontSize: string = '13px',
82
+ iconSize: string = '24px',
83
+ },
84
+ closeButtonDimensions: IconDimensions = {
85
+ width: string = '40px',
86
+ height: string = '40px',
87
+ iconSize: string = '24px',
88
+ },
89
+ };
90
+ ```
91
+
92
+ # Default value be like –
93
+
94
+ ```
95
+ export const mockDrawerInput = {
96
+ drawerPosition: 'left',
97
+ mode: 'over',
98
+ initialOpenedState: false,
99
+ drawerWidth: '250px',
100
+ drawerHeight: '',
101
+ content: {
102
+ drawerTitle: 'Drawer Title',
103
+ drawerBody: '<p>This is the <strong>body</strong> content of the drawer.</p><p>It can contain <em>HTML</em>.</p>',
104
+ mainBody: '<h2>Main Content Area</h2><p>This is where the main application content would go.</p>',
105
+ },
106
+ disableToggleButtonInMainContent: false,
107
+ toggleButtonText: {
108
+ open: 'Open Drawer',
109
+ close: 'Close Drawer',
110
+ },
111
+ hasBackdrop: true,
112
+ backdropBackgroundColor: 'rgba(129, 124, 124, 0.6)',
113
+ showCloseIcon: true,
114
+ disableClose: false,
115
+ animationDuration: '300ms',
116
+ toggleButtonIcon: '',
117
+ toggleButtonImageAlt: '',
118
+ toggleButtonImageUrl: '',
119
+ toggleButtonDimensions: {
120
+ width: 'auto',
121
+ height: '40px',
122
+ padding: '10px',
123
+ fontSize: '13px',
124
+ iconSize: '24px',
125
+ },
126
+ closeButtonDimensions: {
127
+ width: '40px',
128
+ height: '40px',
129
+ iconSize: '24px',
130
+ },
131
+ };
132
+ ```
133
+
134
+
135
+ # Contribution
136
+
137
+ Contributions are welcome! Feel free to open issues or pull requests for any enhancements or fixes.
138
+
139
+ # Acknowledgements
140
+
141
+ Thank you for choosing the Drawer Component Library. If you have any feedback or suggestions, please let us know!
@@ -0,0 +1,4 @@
1
+ export * from './lib/ruclib-drawer.module';
2
+ export * from './lib/ruclib-drawer/ruclib-drawer.component';
3
+ export * from './model/default-values';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9ydWNsaWItZHJhd2VyLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3J1Y2xpYi1kcmF3ZXIvcnVjbGliLWRyYXdlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL21vZGVsL2RlZmF1bHQtdmFsdWVzJzsiXX0=
@@ -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}"]}