- Implemented DeesInputFileupload component with file upload functionality, including drag-and-drop support, file previews, and clear all option. - Developed DeesInputRichtext component featuring a rich text editor with a formatting toolbar, link management, and word count display. - Created demo for DeesInputRichtext showcasing various use cases including basic editing, placeholder text, different heights, and disabled state. - Added styles for both components to ensure a consistent and user-friendly interface. - Introduced types for toolbar buttons in the rich text editor for better type safety and maintainability.
		
			
				
	
	
		
			220 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			220 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {
 | |
|   DeesElement,
 | |
|   type TemplateResult,
 | |
|   property,
 | |
|   customElement,
 | |
|   html,
 | |
|   css,
 | |
|   cssManager,
 | |
|   state,
 | |
| } from '@design.estate/dees-element';
 | |
| import * as interfaces from './interfaces/index.js';
 | |
| import * as plugins from './00plugins.js';
 | |
| import type { DeesAppuiBar } from './dees-appui-appbar/index.js';
 | |
| import type { DeesAppuiMainmenu } from './dees-appui-mainmenu.js';
 | |
| import type { DeesAppuiMainselector } from './dees-appui-mainselector.js';
 | |
| import type { DeesAppuiMaincontent } from './dees-appui-maincontent.js';
 | |
| import type { DeesAppuiActivitylog } from './dees-appui-activitylog.js';
 | |
| import { demoFunc } from './dees-appui-base.demo.js';
 | |
| 
 | |
| // Import child components
 | |
| import './dees-appui-appbar/index.js';
 | |
| import './dees-appui-mainmenu.js';
 | |
| import './dees-appui-mainselector.js';
 | |
| import './dees-appui-maincontent.js';
 | |
| import './dees-appui-activitylog.js';
 | |
| 
 | |
| @customElement('dees-appui-base')
 | |
| export class DeesAppuiBase extends DeesElement {
 | |
|   public static demo = demoFunc;
 | |
| 
 | |
|   // Properties for appbar
 | |
|   @property({ type: Array })
 | |
|   public appbarMenuItems: interfaces.IAppBarMenuItem[] = [];
 | |
| 
 | |
|   @property({ type: String })
 | |
|   public appbarBreadcrumbs: string = '';
 | |
| 
 | |
|   @property({ type: String })
 | |
|   public appbarBreadcrumbSeparator: string = ' > ';
 | |
| 
 | |
|   @property({ type: Boolean })
 | |
|   public appbarShowWindowControls: boolean = true;
 | |
| 
 | |
| 
 | |
|   @property({ type: Object })
 | |
|   public appbarUser?: {
 | |
|     name: string;
 | |
|     email?: string;
 | |
|     avatar?: string;
 | |
|     status?: 'online' | 'offline' | 'busy' | 'away';
 | |
|   };
 | |
| 
 | |
|   @property({ type: Array })
 | |
|   public appbarProfileMenuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = [];
 | |
| 
 | |
|   @property({ type: Boolean })
 | |
|   public appbarShowSearch: boolean = false;
 | |
| 
 | |
|   // Properties for mainmenu
 | |
|   @property({ type: Array })
 | |
|   public mainmenuTabs: interfaces.ITab[] = [];
 | |
| 
 | |
|   @property({ type: Object })
 | |
|   public mainmenuSelectedTab?: interfaces.ITab;
 | |
| 
 | |
|   // Properties for mainselector
 | |
|   @property({ type: Array })
 | |
|   public mainselectorOptions: (interfaces.ISelectionOption | { divider: true })[] = [];
 | |
| 
 | |
|   @property({ type: Object })
 | |
|   public mainselectorSelectedOption?: interfaces.ISelectionOption;
 | |
| 
 | |
|   // Properties for maincontent
 | |
|   @property({ type: Array })
 | |
|   public maincontentTabs: interfaces.ITab[] = [];
 | |
| 
 | |
|   // References to child components
 | |
|   @state()
 | |
|   public appbar?: DeesAppuiBar;
 | |
| 
 | |
|   @state()
 | |
|   public mainmenu?: DeesAppuiMainmenu;
 | |
| 
 | |
|   @state()
 | |
|   public mainselector?: DeesAppuiMainselector;
 | |
| 
 | |
|   @state()
 | |
|   public maincontent?: DeesAppuiMaincontent;
 | |
| 
 | |
|   @state()
 | |
|   public activitylog?: DeesAppuiActivitylog;
 | |
| 
 | |
|   public static styles = [
 | |
|     cssManager.defaultStyles,
 | |
|     css`
 | |
|       :host {
 | |
|         position: absolute;
 | |
|         height: 100%;
 | |
|         width: 100%;
 | |
|         background: ${cssManager.bdTheme('#f0f0f0', '#1a1a1a')};
 | |
|       }
 | |
|       .maingrid {
 | |
|         position: absolute;
 | |
|         top: 40px;
 | |
|         height: calc(100% - 40px);
 | |
|         width: 100%;
 | |
|         display: grid;
 | |
|         grid-template-columns: 60px 240px 1fr 240px;
 | |
|       }
 | |
|     `,
 | |
|   ];
 | |
| 
 | |
|   // INSTANCE
 | |
|   public render(): TemplateResult {
 | |
|     return html`
 | |
|       <style></style>
 | |
|       <dees-appui-appbar
 | |
|         .menuItems=${this.appbarMenuItems}
 | |
|         .breadcrumbs=${this.appbarBreadcrumbs}
 | |
|         .breadcrumbSeparator=${this.appbarBreadcrumbSeparator}
 | |
|         .showWindowControls=${this.appbarShowWindowControls}
 | |
|         .user=${this.appbarUser}
 | |
|         .profileMenuItems=${this.appbarProfileMenuItems}
 | |
|         .showSearch=${this.appbarShowSearch}
 | |
|         @menu-select=${(e: CustomEvent) => this.handleAppbarMenuSelect(e)}
 | |
|         @breadcrumb-navigate=${(e: CustomEvent) => this.handleAppbarBreadcrumbNavigate(e)}
 | |
|         @search-click=${() => this.handleAppbarSearchClick()}
 | |
|         @user-menu-open=${() => this.handleAppbarUserMenuOpen()}
 | |
|         @profile-menu-select=${(e: CustomEvent) => this.handleAppbarProfileMenuSelect(e)}
 | |
|       ></dees-appui-appbar>
 | |
|       <div class="maingrid">
 | |
|         <dees-appui-mainmenu
 | |
|           .tabs=${this.mainmenuTabs}
 | |
|           .selectedTab=${this.mainmenuSelectedTab}
 | |
|           @tab-select=${(e: CustomEvent) => this.handleMainmenuTabSelect(e)}
 | |
|         ></dees-appui-mainmenu>
 | |
|         <dees-appui-mainselector
 | |
|           .selectionOptions=${this.mainselectorOptions}
 | |
|           .selectedOption=${this.mainselectorSelectedOption}
 | |
|           @option-select=${(e: CustomEvent) => this.handleMainselectorOptionSelect(e)}
 | |
|         ></dees-appui-mainselector>
 | |
|         <dees-appui-maincontent
 | |
|           .tabs=${this.maincontentTabs}
 | |
|         >
 | |
|           <slot name="maincontent"></slot>
 | |
|         </dees-appui-maincontent>
 | |
|         <dees-appui-activitylog></dees-appui-activitylog>
 | |
|       </div>
 | |
|     `;
 | |
|   }
 | |
| 
 | |
|   async firstUpdated() {
 | |
|     // Get references to child components
 | |
|     this.appbar = this.shadowRoot.querySelector('dees-appui-appbar');
 | |
|     this.mainmenu = this.shadowRoot.querySelector('dees-appui-mainmenu');
 | |
|     this.mainselector = this.shadowRoot.querySelector('dees-appui-mainselector');
 | |
|     this.maincontent = this.shadowRoot.querySelector('dees-appui-maincontent');
 | |
|     this.activitylog = this.shadowRoot.querySelector('dees-appui-activitylog');
 | |
|   }
 | |
| 
 | |
|   // Event handlers for appbar
 | |
|   private handleAppbarMenuSelect(e: CustomEvent) {
 | |
|     this.dispatchEvent(new CustomEvent('appbar-menu-select', {
 | |
|       detail: e.detail,
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| 
 | |
|   private handleAppbarBreadcrumbNavigate(e: CustomEvent) {
 | |
|     this.dispatchEvent(new CustomEvent('appbar-breadcrumb-navigate', {
 | |
|       detail: e.detail,
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| 
 | |
|   private handleAppbarSearchClick() {
 | |
|     this.dispatchEvent(new CustomEvent('appbar-search-click', {
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| 
 | |
|   private handleAppbarUserMenuOpen() {
 | |
|     this.dispatchEvent(new CustomEvent('appbar-user-menu-open', {
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| 
 | |
|   private handleAppbarProfileMenuSelect(e: CustomEvent) {
 | |
|     this.dispatchEvent(new CustomEvent('appbar-profile-menu-select', {
 | |
|       detail: e.detail,
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| 
 | |
|   // Event handlers for mainmenu
 | |
|   private handleMainmenuTabSelect(e: CustomEvent) {
 | |
|     this.mainmenuSelectedTab = e.detail.tab;
 | |
|     this.dispatchEvent(new CustomEvent('mainmenu-tab-select', {
 | |
|       detail: e.detail,
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| 
 | |
|   // Event handlers for mainselector
 | |
|   private handleMainselectorOptionSelect(e: CustomEvent) {
 | |
|     this.mainselectorSelectedOption = e.detail.option;
 | |
|     this.dispatchEvent(new CustomEvent('mainselector-option-select', {
 | |
|       detail: e.detail,
 | |
|       bubbles: true,
 | |
|       composed: true
 | |
|     }));
 | |
|   }
 | |
| }
 |