Compare commits

...

18 Commits

Author SHA1 Message Date
0f9bc67a8e v2.0.5
Some checks failed
Default (tags) / security (push) Failing after 16s
Default (tags) / test (push) Failing after 17s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-12-06 14:09:21 +00:00
b33d51cebf fix(build): Bump devDependencies: update @git.zone/tsbundle and @git.zone/tswatch to patched versions 2025-12-06 14:09:21 +00:00
021e0fda3d v2.0.4
Some checks failed
Default (tags) / security (push) Failing after 19s
Default (tags) / test (push) Failing after 13s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-12-06 13:54:17 +00:00
2ed0d8e0f2 fix(imports): Normalize and fix relative import paths for web components to ensure correct module resolution 2025-12-06 13:54:17 +00:00
5e4514c913 chore: remove obsolete files and documentation from the project 2025-12-05 10:20:29 +00:00
d1bc562b5c Refactor import paths for consistency and clarity across multiple components
- Updated import paths in dees-panel, dees-pdf, dees-progressbar, dees-searchbar, dees-shopping-productcard, dees-simple-appdash, dees-speechbubble, dees-statsgrid, dees-table, dees-toast, dees-updater, and dees-windowlayer to use consistent directory structure.
- Created index.ts files for various components to streamline imports and improve modularity.
- Ensured all imports point to the correct subdirectory structure, enhancing maintainability and readability of the codebase.
2025-12-05 10:19:37 +00:00
7adad49cb1 feat(structure): adjust 2025-12-05 10:19:11 +00:00
d07fec834f v2.0.3
Some checks failed
Default (tags) / security (push) Failing after 17s
Default (tags) / test (push) Failing after 14s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-12-03 09:22:35 +00:00
6f54bd228c fix(dependencies): Bump dependencies and developer tooling versions 2025-12-03 09:22:35 +00:00
ca7aa12218 v2.0.2
Some checks failed
Default (tags) / security (push) Failing after 16s
Default (tags) / test (push) Failing after 17s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-11-30 23:57:14 +00:00
c2ee19308d fix(dees-stepper): Make step validation abortable and cancel active step listeners when navigating 2025-11-30 23:57:14 +00:00
5e27449e50 v2.0.1
Some checks failed
Default (tags) / security (push) Failing after 17s
Default (tags) / test (push) Failing after 18s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-11-30 23:46:39 +00:00
d69f777b25 fix(dees-stepper): Improve dees-stepper visual style and transitions 2025-11-30 23:46:39 +00:00
caa954a539 update 2025-11-30 23:39:04 +00:00
997520f3ba v2.0.0
Some checks failed
Default (tags) / security (push) Failing after 20s
Default (tags) / test (push) Failing after 12s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-11-17 13:27:12 +00:00
92f69e2aa6 BREAKING CHANGE(decorators): Migrate to TC39 standard decorators (accessor) across components, update tsconfig and bump dependencies 2025-11-17 13:27:11 +00:00
70c29c778c 1.12.6
Some checks failed
Default (tags) / security (push) Failing after 26s
Default (tags) / test (push) Failing after 17s
Default (tags) / release (push) Has been skipped
Default (tags) / metadata (push) Has been skipped
2025-10-23 23:46:40 +00:00
0fc302699e fix(dependencies): Bump FontAwesome to ^7.1.0 2025-10-23 23:46:40 +00:00
199 changed files with 3023 additions and 2537 deletions

1
.serena/.gitignore vendored
View File

@@ -1 +0,0 @@
/cache

View File

@@ -1,6 +0,0 @@
Before finishing a task:
- Run `pnpm run build` to ensure TypeScript compile + bundling succeed.
- Verify `dist_ts_web/` and `dist_bundle/bundle.js` updated.
- Optionally run `pnpm run test` and inspect failures.
- Avoid changing public APIs unless required; keep changes scoped.
- Update readme or inline docs only if user-facing behavior changes.

View File

@@ -1,11 +0,0 @@
Project: @design.estate/dees-catalog
Purpose: A component library of dynamic Web Components (TypeScript) for building modern web apps.
Tech stack: TypeScript (ES2022, NodeNext), decorators, custom elements via @design.estate/dees-element (Lit-style), bundling with esbuild via @git.zone/tsbundle, TypeScript building via @git.zone/tsbuild (tsfolders), tests with @git.zone/tstest, various UI libs (tiptap, apexcharts, monaco-editor runtime via CDN), DOM helpers via @design.estate/dees-domtools.
Structure:
- ts_web/: source of web components and pages
- dist_ts_web/: transpiled TS output
- dist_bundle/: production bundle (bundle.js + map)
- test/: tests
- html/: static demo assets
Key configs: tsconfig.json sets ES2022, NodeNext module/resolution, decorators enabled, skipLibCheck enabled to avoid third-party d.ts issues.
Entrypoints: ts_web/index.ts for bundling; custom elements annotated with @customElement.

View File

@@ -1,5 +0,0 @@
Language: TypeScript, ES2022 target, NodeNext module + resolution.
Patterns: Web Components with @customElement decorators; class-based components extending DeesElement; styles via css/cssManager; template render via html tagged literal.
Typing: Prefer explicit types where practical; tolerate `any` for external browser-injected libs (e.g., monaco) to keep build healthy.
Config: skipLibCheck enabled to avoid third-party d.ts breakages; exclude built declaration outputs.
Formatting/Linting: Not explicitly configured; follow existing style (2-space indents, single quotes often, semicolons present).

View File

@@ -1,6 +0,0 @@
Build: pnpm run build
Watch: pnpm run watch
Test: pnpm run test
Docs: pnpm run buildDocs
Inspect bundle size: ls -lh dist_bundle/bundle.js
Open demo (if applicable): serve static `html/` with any web server

View File

@@ -1,67 +0,0 @@
# language of the project (csharp, python, rust, java, typescript, go, cpp, or ruby)
# * For C, use cpp
# * For JavaScript, use typescript
# Special requirements:
# * csharp: Requires the presence of a .sln file in the project folder.
language: typescript
# whether to use the project's gitignore file to ignore files
# Added on 2025-04-07
ignore_all_files_in_gitignore: true
# list of additional paths to ignore
# same syntax as gitignore, so you can use * and **
# Was previously called `ignored_dirs`, please update your config if you are using that.
# Added (renamed) on 2025-04-07
ignored_paths: []
# whether the project is in read-only mode
# If set to true, all editing tools will be disabled and attempts to use them will result in an error
# Added on 2025-04-18
read_only: false
# list of tool names to exclude. We recommend not excluding any tools, see the readme for more details.
# Below is the complete list of tools for convenience.
# To make sure you have the latest list of tools, and to view their descriptions,
# execute `uv run scripts/print_tool_overview.py`.
#
# * `activate_project`: Activates a project by name.
# * `check_onboarding_performed`: Checks whether project onboarding was already performed.
# * `create_text_file`: Creates/overwrites a file in the project directory.
# * `delete_lines`: Deletes a range of lines within a file.
# * `delete_memory`: Deletes a memory from Serena's project-specific memory store.
# * `execute_shell_command`: Executes a shell command.
# * `find_referencing_code_snippets`: Finds code snippets in which the symbol at the given location is referenced.
# * `find_referencing_symbols`: Finds symbols that reference the symbol at the given location (optionally filtered by type).
# * `find_symbol`: Performs a global (or local) search for symbols with/containing a given name/substring (optionally filtered by type).
# * `get_current_config`: Prints the current configuration of the agent, including the active and available projects, tools, contexts, and modes.
# * `get_symbols_overview`: Gets an overview of the top-level symbols defined in a given file.
# * `initial_instructions`: Gets the initial instructions for the current project.
# Should only be used in settings where the system prompt cannot be set,
# e.g. in clients you have no control over, like Claude Desktop.
# * `insert_after_symbol`: Inserts content after the end of the definition of a given symbol.
# * `insert_at_line`: Inserts content at a given line in a file.
# * `insert_before_symbol`: Inserts content before the beginning of the definition of a given symbol.
# * `list_dir`: Lists files and directories in the given directory (optionally with recursion).
# * `list_memories`: Lists memories in Serena's project-specific memory store.
# * `onboarding`: Performs onboarding (identifying the project structure and essential tasks, e.g. for testing or building).
# * `prepare_for_new_conversation`: Provides instructions for preparing for a new conversation (in order to continue with the necessary context).
# * `read_file`: Reads a file within the project directory.
# * `read_memory`: Reads the memory with the given name from Serena's project-specific memory store.
# * `remove_project`: Removes a project from the Serena configuration.
# * `replace_lines`: Replaces a range of lines within a file with new content.
# * `replace_symbol_body`: Replaces the full definition of a symbol.
# * `restart_language_server`: Restarts the language server, may be necessary when edits not through Serena happen.
# * `search_for_pattern`: Performs a search for a pattern in the project.
# * `summarize_changes`: Provides instructions for summarizing the changes made to the codebase.
# * `switch_modes`: Activates modes by providing a list of their names
# * `think_about_collected_information`: Thinking tool for pondering the completeness of collected information.
# * `think_about_task_adherence`: Thinking tool for determining whether the agent is still on track with the current task.
# * `think_about_whether_you_are_done`: Thinking tool for determining whether the task is truly completed.
# * `write_memory`: Writes a named memory (for future reference) to Serena's project-specific memory store.
excluded_tools: []
# initial prompt for the project. It will always be given to the LLM upon activating the project
# (contrary to the memories, which are loaded on demand).
initial_prompt: ""
project_name: "dees-catalog"

View File

@@ -1,5 +1,63 @@
# Changelog # Changelog
## 2025-12-06 - 2.0.5 - fix(build)
Bump devDependencies: update @git.zone/tsbundle and @git.zone/tswatch to patched versions
- Update @git.zone/tsbundle from ^2.6.2 to ^2.6.3
- Update @git.zone/tswatch from ^2.2.2 to ^2.2.3
## 2025-12-06 - 2.0.4 - fix(imports)
Normalize and fix relative import paths for web components to ensure correct module resolution
- Replaced numerous './<component>.js' imports with explicit '../<component>/<component>.js' paths across many elements and demos to fix module resolution.
- Updated imports for core shared components such as dees-icon, dees-panel, dees-contextmenu, dees-windowlayer, dees-windowcontrols and several app-ui components (appbar, maincontent, mainselector, activitylog, mobilenavigation, modal, pdf, profilepicture, statsgrid, etc.).
- No runtime behavior changes — this is a refactor to import paths to address build/bundling and resolution issues.
## 2025-12-03 - 2.0.3 - fix(dependencies)
Bump dependencies and developer tooling versions
- Upgrade lucide from ^0.553.0 to ^0.555.0
- Bump @git.zone/tsbuild from ^3.1.0 to ^3.1.2
- Bump @git.zone/tsbundle from ^2.5.2 to ^2.6.2
- Bump @git.zone/tstest from ^2.8.1 to ^3.1.3
- Bump @git.zone/tswatch from ^2.2.1 to ^2.2.2
- Upgrade @types/node from ^22.0.0 to ^24.10.1
- Patch release: increment package version to 2.0.3
## 2025-11-30 - 2.0.2 - fix(dees-stepper)
Make step validation abortable and cancel active step listeners when navigating
- Extend IStep.validationFunc signature to accept an optional AbortSignal so validation handlers can be cancelled.
- Store an AbortController on the selected step and pass its signal into validationFunc when invoked.
- Abort the step's AbortController when navigating to the previous or next step to cancel any active listeners or async operations.
## 2025-11-30 - 2.0.1 - fix(dees-stepper)
Improve dees-stepper visual style and transitions
- Smooth animation: extend .step transition duration and use a cubic-bezier curve for smoother motion.
- Add .step.entrance class with a shorter easing for entrance animations to keep entrance timing distinct.
- Visual tweaks: reduce border-radius from 18px to 12px and increase inner content padding to 32px.
- Color and border updates: adjust background and border colors for light/dark themes to more consistent values.
- Shadow simplification: replace theme-dependent heavy shadows with a single subtle shadow (0 8px 32px rgba(0,0,0,0.4)).
- Remove selected-state border/box-shadow overrides (selection visuals simplified).
- Remove background-clip: padding-box to simplify rendering.
## 2025-11-17 - 2.0.0 - BREAKING CHANGE(decorators)
Migrate to TC39 standard decorators (accessor) across components, update tsconfig and bump dependencies
- Replaced experimental decorator-backed class fields with the TC39-compatible "accessor" form across ~69 web component files (properties and state fields) to follow Lit 3.x recommendations.
- Updated tsconfig.json to remove experimentalDecorators and useDefineForClassFields, aligning compiler settings with the standard decorators migration.
- Fixed optional/nullable fields to explicit `Type | undefined = undefined` where necessary to preserve runtime behavior and typing.
- Adjusted/remove usages of some non-reactive decorators/@query patterns to be compatible with the new decorator model (notable changes in a few components).
- Bumped several dependencies and devDependencies (examples: @design.estate/dees-domtools, @design.estate/dees-element, @design.estate/dees-wcctools, @git.zone/tsbuild, @git.zone/tstest, apexcharts, lucide).
- Added migration notes and testing summary to readme.hints.md documenting the TC39 decorators migration and verification steps.
## 2025-10-23 - 1.12.6 - fix(dependencies)
Bump FontAwesome to ^7.1.0 and add local claude settings
- Updated @fortawesome packages (@fortawesome/fontawesome-svg-core, @fortawesome/free-brands-svg-icons, @fortawesome/free-regular-svg-icons, @fortawesome/free-solid-svg-icons) to ^7.1.0 in package.json
- Added .claude/settings.local.json to configure local Claude/tooling permissions for repository operations
## 2025-09-23 - 1.12.5 - fix(ci) ## 2025-09-23 - 1.12.5 - fix(ci)
Add local permissions settings for development Add local permissions settings for development

View File

@@ -1,6 +1,6 @@
{ {
"name": "@design.estate/dees-catalog", "name": "@design.estate/dees-catalog",
"version": "1.12.5", "version": "2.0.5",
"private": false, "private": false,
"description": "A comprehensive library that provides dynamic web components for building sophisticated and modern web applications using JavaScript and TypeScript.", "description": "A comprehensive library that provides dynamic web components for building sophisticated and modern web applications using JavaScript and TypeScript.",
"main": "dist_ts_web/index.js", "main": "dist_ts_web/index.js",
@@ -16,13 +16,13 @@
"author": "Lossless GmbH", "author": "Lossless GmbH",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@design.estate/dees-domtools": "^2.3.3", "@design.estate/dees-domtools": "^2.3.6",
"@design.estate/dees-element": "^2.1.2", "@design.estate/dees-element": "^2.1.3",
"@design.estate/dees-wcctools": "^1.2.0", "@design.estate/dees-wcctools": "^1.2.1",
"@fortawesome/fontawesome-svg-core": "^7.0.1", "@fortawesome/fontawesome-svg-core": "^7.1.0",
"@fortawesome/free-brands-svg-icons": "^7.0.1", "@fortawesome/free-brands-svg-icons": "^7.1.0",
"@fortawesome/free-regular-svg-icons": "^7.0.1", "@fortawesome/free-regular-svg-icons": "^7.1.0",
"@fortawesome/free-solid-svg-icons": "^7.0.1", "@fortawesome/free-solid-svg-icons": "^7.1.0",
"@push.rocks/smarti18n": "^1.0.4", "@push.rocks/smarti18n": "^1.0.4",
"@push.rocks/smartpromise": "^4.2.0", "@push.rocks/smartpromise": "^4.2.0",
"@push.rocks/smartstring": "^4.1.0", "@push.rocks/smartstring": "^4.1.0",
@@ -32,26 +32,26 @@
"@tiptap/extension-typography": "^2.23.0", "@tiptap/extension-typography": "^2.23.0",
"@tiptap/extension-underline": "^2.23.0", "@tiptap/extension-underline": "^2.23.0",
"@tiptap/starter-kit": "^2.23.0", "@tiptap/starter-kit": "^2.23.0",
"@tsclass/tsclass": "^9.2.0", "@tsclass/tsclass": "^9.3.0",
"@webcontainer/api": "1.2.0", "@webcontainer/api": "1.2.0",
"apexcharts": "^5.3.5", "apexcharts": "^5.3.6",
"highlight.js": "11.11.1", "highlight.js": "11.11.1",
"ibantools": "^4.5.1", "ibantools": "^4.5.1",
"lit": "^3.3.1", "lit": "^3.3.1",
"lucide": "^0.544.0", "lucide": "^0.555.0",
"monaco-editor": "0.52.2", "monaco-editor": "0.52.2",
"pdfjs-dist": "^4.10.38", "pdfjs-dist": "^4.10.38",
"xterm": "^5.3.0", "xterm": "^5.3.0",
"xterm-addon-fit": "^0.8.0" "xterm-addon-fit": "^0.8.0"
}, },
"devDependencies": { "devDependencies": {
"@git.zone/tsbuild": "^2.6.8", "@git.zone/tsbuild": "^3.1.2",
"@git.zone/tsbundle": "^2.5.1", "@git.zone/tsbundle": "^2.6.3",
"@git.zone/tstest": "^2.3.8", "@git.zone/tstest": "^3.1.3",
"@git.zone/tswatch": "^2.2.1", "@git.zone/tswatch": "^2.2.3",
"@push.rocks/projectinfo": "^5.0.2", "@push.rocks/projectinfo": "^5.0.2",
"@push.rocks/tapbundle": "^6.0.3", "@push.rocks/tapbundle": "^6.0.3",
"@types/node": "^22.0.0" "@types/node": "^24.10.1"
}, },
"files": [ "files": [
"ts/**/*", "ts/**/*",

3882
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,4 +0,0 @@
onlyBuiltDependencies:
- esbuild
- mongodb-memory-server
- puppeteer

View File

@@ -604,4 +604,80 @@ import { zIndexLayers } from './00zindex.js';
z-index: ${zIndexLayers.overlay.modal}; z-index: ${zIndexLayers.overlay.modal};
``` ```
This system ensures proper stacking order for all overlay components and prevents z-index conflicts. This system ensures proper stacking order for all overlay components and prevents z-index conflicts.
## TC39 Standard Decorators Migration (2025-01-17)
Successfully migrated from experimental TypeScript decorators to standard TC39 decorators as recommended by Lit 3.x documentation.
### Migration Overview:
#### 1. Changes Made:
- **Added `accessor` keyword** to all `@property` and `@state` decorated fields across 69 component files
- **Updated tsconfig.json**: Removed `experimentalDecorators: true` and `useDefineForClassFields: false`
- **Fixed optional properties**: Changed `accessor prop?: Type` to `accessor prop: Type | undefined = undefined`
- **Removed incompatible decorators**: Removed `@query` and non-reactive `@state` decorators from regular fields
#### 2. Key Pattern Changes:
**Before (Experimental Decorators):**
```typescript
@property({ type: String })
public value: string = '';
@property({ type: Boolean })
public disabled?: boolean;
```
**After (Standard TC39 Decorators):**
```typescript
@property({ type: String })
accessor value: string = '';
@property({ type: Boolean })
accessor disabled: boolean | undefined = undefined;
```
#### 3. Important Rules:
- **@property and @state**: MUST use `accessor` keyword for reactive properties
- **@query decorators**: Should NOT use `accessor` (they work with regular fields)
- **Optional properties**: Cannot use `?` syntax with accessor, must use `| undefined = undefined`
- **Private fields**: Non-reactive private fields should not use decorators
#### 4. TypeScript Configuration:
```json
{
"compilerOptions": {
"target": "ES2022",
"module": "NodeNext",
"moduleResolution": "NodeNext"
}
}
```
Note: `experimentalDecorators` defaults to false, and `useDefineForClassFields` defaults to true with ES2022 target.
#### 5. Build Results:
- ✅ Build successful with standard decorators
- ✅ Tests passing (7/8 - same as before migration)
- ✅ No bundle size changes reported
- ✅ All components working correctly
#### 6. Files Modified:
- 69 component files with decorator updates
- 16 files with optional property fixes
- 3 files with @query decorator removals
- tsconfig.json configuration update
### Why This Migration:
According to Lit's documentation (https://lit.dev/docs/components/decorators/#decorator-versions):
- TC39 standard decorators are the future-proof approach
- Provides better TypeScript integration
- Aligns with JavaScript specification
- While bundle sizes are slightly larger, the standardization benefits outweigh this
### Testing:
- All unit tests passing
- Manual testing of key components verified
- No regressions detected
- Focus management and interactions working correctly

View File

@@ -3,6 +3,6 @@
*/ */
export const commitinfo = { export const commitinfo = {
name: '@design.estate/dees-catalog', name: '@design.estate/dees-catalog',
version: '1.12.5', version: '2.0.5',
description: 'A comprehensive library that provides dynamic web components for building sophisticated and modern web applications using JavaScript and TypeScript.' description: 'A comprehensive library that provides dynamic web components for building sophisticated and modern web applications using JavaScript and TypeScript.'
} }

View File

@@ -1,4 +1,4 @@
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import { import {
DeesElement, DeesElement,
type TemplateResult, type TemplateResult,
@@ -10,8 +10,8 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import { DeesContextmenu } from './dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
import './dees-icon.js'; import '../dees-icon/dees-icon.js';
@customElement('dees-appui-activitylog') @customElement('dees-appui-activitylog')
export class DeesAppuiActivitylog extends DeesElement { export class DeesAppuiActivitylog extends DeesElement {

View File

@@ -0,0 +1 @@
export * from '../dees-appui-activitylog/dees-appui-activitylog.js';

View File

@@ -15,9 +15,9 @@ import { appuiAppbarStyles } from './styles.js';
import { renderAppuiAppbar } from './template.js'; import { renderAppuiAppbar } from './template.js';
// Import required components // Import required components
import '../dees-icon.js'; import '../dees-icon/dees-icon.js';
import '../dees-windowcontrols.js'; import '../dees-windowcontrols/dees-windowcontrols.js';
import '../dees-appui-profiledropdown.js'; import '../dees-appui-profiledropdown/dees-appui-profiledropdown.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -31,47 +31,47 @@ export class DeesAppuiBar extends DeesElement {
// INSTANCE PROPERTIES // INSTANCE PROPERTIES
@property({ type: Array }) @property({ type: Array })
public menuItems: interfaces.IAppBarMenuItem[] = []; accessor menuItems: interfaces.IAppBarMenuItem[] = [];
@property({ type: String }) @property({ type: String })
public breadcrumbs: string = ''; accessor breadcrumbs: string = '';
@property({ type: String }) @property({ type: String })
public breadcrumbSeparator: string = ' > '; accessor breadcrumbSeparator: string = ' > ';
@property({ type: Boolean }) @property({ type: Boolean })
public showWindowControls: boolean = true; accessor showWindowControls: boolean = true;
@property({ type: Object }) @property({ type: Object })
public user?: { accessor user: {
name: string; name: string;
email?: string; email?: string;
avatar?: string; avatar?: string;
status?: 'online' | 'offline' | 'busy' | 'away'; status?: 'online' | 'offline' | 'busy' | 'away';
}; } | undefined = undefined;
@property({ type: Array }) @property({ type: Array })
public profileMenuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = []; accessor profileMenuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = [];
@property({ type: Boolean }) @property({ type: Boolean })
public showSearch: boolean = false; accessor showSearch: boolean = false;
// STATE // STATE
@state() @state()
private activeMenu: string | null = null; accessor activeMenu: string | null = null;
@state() @state()
private openDropdowns: Set<string> = new Set(); accessor openDropdowns: Set<string> = new Set();
@state() @state()
private focusedItem: string | null = null; accessor focusedItem: string | null = null;
@state() @state()
private focusedDropdownItem: number = -1; accessor focusedDropdownItem: number = -1;
@state() @state()
private isProfileDropdownOpen: boolean = false; accessor isProfileDropdownOpen: boolean = false;
public static styles = appuiAppbarStyles; public static styles = appuiAppbarStyles;

View File

@@ -1,9 +1,9 @@
import { html, css } from '@design.estate/dees-element'; import { html, css } from '@design.estate/dees-element';
import type { DeesAppuiBase } from './dees-appui-base.js'; import type { DeesAppuiBase } from '../dees-appui-base/dees-appui-base.js';
import type { IAppBarMenuItem } from './interfaces/appbarmenuitem.js'; import type { IAppBarMenuItem } from '../interfaces/appbarmenuitem.js';
import type { ITab } from './interfaces/tab.js'; import type { ITab } from '../interfaces/tab.js';
import type { ISelectionOption } from './interfaces/selectionoption.js'; import type { ISelectionOption } from '../interfaces/selectionoption.js';
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
export const demoFunc = () => { export const demoFunc = () => {

View File

@@ -8,21 +8,21 @@ import {
cssManager, cssManager,
state, state,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as interfaces from './interfaces/index.js'; import * as interfaces from '../interfaces/index.js';
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import type { DeesAppuiBar } from './dees-appui-appbar/index.js'; import type { DeesAppuiBar } from '../dees-appui-appbar/index.js';
import type { DeesAppuiMainmenu } from './dees-appui-mainmenu.js'; import type { DeesAppuiMainmenu } from '../dees-appui-mainmenu/dees-appui-mainmenu.js';
import type { DeesAppuiMainselector } from './dees-appui-mainselector.js'; import type { DeesAppuiMainselector } from '../dees-appui-mainselector/dees-appui-mainselector.js';
import type { DeesAppuiMaincontent } from './dees-appui-maincontent.js'; import type { DeesAppuiMaincontent } from '../dees-appui-maincontent/dees-appui-maincontent.js';
import type { DeesAppuiActivitylog } from './dees-appui-activitylog.js'; import type { DeesAppuiActivitylog } from '../dees-appui-activitylog/dees-appui-activitylog.js';
import { demoFunc } from './dees-appui-base.demo.js'; import { demoFunc } from './dees-appui-base.demo.js';
// Import child components // Import child components
import './dees-appui-appbar/index.js'; import '../dees-appui-appbar/index.js';
import './dees-appui-mainmenu.js'; import '../dees-appui-mainmenu/dees-appui-mainmenu.js';
import './dees-appui-mainselector.js'; import '../dees-appui-mainselector/dees-appui-mainselector.js';
import './dees-appui-maincontent.js'; import '../dees-appui-maincontent/dees-appui-maincontent.js';
import './dees-appui-activitylog.js'; import '../dees-appui-activitylog/dees-appui-activitylog.js';
@customElement('dees-appui-base') @customElement('dees-appui-base')
export class DeesAppuiBase extends DeesElement { export class DeesAppuiBase extends DeesElement {
@@ -30,65 +30,65 @@ export class DeesAppuiBase extends DeesElement {
// Properties for appbar // Properties for appbar
@property({ type: Array }) @property({ type: Array })
public appbarMenuItems: interfaces.IAppBarMenuItem[] = []; accessor appbarMenuItems: interfaces.IAppBarMenuItem[] = [];
@property({ type: String }) @property({ type: String })
public appbarBreadcrumbs: string = ''; accessor appbarBreadcrumbs: string = '';
@property({ type: String }) @property({ type: String })
public appbarBreadcrumbSeparator: string = ' > '; accessor appbarBreadcrumbSeparator: string = ' > ';
@property({ type: Boolean }) @property({ type: Boolean })
public appbarShowWindowControls: boolean = true; accessor appbarShowWindowControls: boolean = true;
@property({ type: Object }) @property({ type: Object })
public appbarUser?: { accessor appbarUser: {
name: string; name: string;
email?: string; email?: string;
avatar?: string; avatar?: string;
status?: 'online' | 'offline' | 'busy' | 'away'; status?: 'online' | 'offline' | 'busy' | 'away';
}; } | undefined = undefined;
@property({ type: Array }) @property({ type: Array })
public appbarProfileMenuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = []; accessor appbarProfileMenuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = [];
@property({ type: Boolean }) @property({ type: Boolean })
public appbarShowSearch: boolean = false; accessor appbarShowSearch: boolean = false;
// Properties for mainmenu // Properties for mainmenu
@property({ type: Array }) @property({ type: Array })
public mainmenuTabs: interfaces.ITab[] = []; accessor mainmenuTabs: interfaces.ITab[] = [];
@property({ type: Object }) @property({ type: Object })
public mainmenuSelectedTab?: interfaces.ITab; accessor mainmenuSelectedTab: interfaces.ITab | undefined = undefined;
// Properties for mainselector // Properties for mainselector
@property({ type: Array }) @property({ type: Array })
public mainselectorOptions: (interfaces.ISelectionOption | { divider: true })[] = []; accessor mainselectorOptions: (interfaces.ISelectionOption | { divider: true })[] = [];
@property({ type: Object }) @property({ type: Object })
public mainselectorSelectedOption?: interfaces.ISelectionOption; accessor mainselectorSelectedOption: interfaces.ISelectionOption | undefined = undefined;
// Properties for maincontent // Properties for maincontent
@property({ type: Array }) @property({ type: Array })
public maincontentTabs: interfaces.ITab[] = []; accessor maincontentTabs: interfaces.ITab[] = [];
// References to child components // References to child components
@state() @state()
public appbar?: DeesAppuiBar; accessor appbar: DeesAppuiBar | undefined = undefined;
@state() @state()
public mainmenu?: DeesAppuiMainmenu; accessor mainmenu: DeesAppuiMainmenu | undefined = undefined;
@state() @state()
public mainselector?: DeesAppuiMainselector; accessor mainselector: DeesAppuiMainselector | undefined = undefined;
@state() @state()
public maincontent?: DeesAppuiMaincontent; accessor maincontent: DeesAppuiMaincontent | undefined = undefined;
@state() @state()
public activitylog?: DeesAppuiActivitylog; accessor activitylog: DeesAppuiActivitylog | undefined = undefined;
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-base/dees-appui-base.js';

View File

@@ -1,4 +1,4 @@
import * as interfaces from './interfaces/index.js'; import * as interfaces from '../interfaces/index.js';
import { import {
DeesElement, DeesElement,
@@ -11,8 +11,8 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import './dees-appui-tabs.js'; import '../dees-appui-tabs/dees-appui-tabs.js';
import type { DeesAppuiTabs } from './dees-appui-tabs.js'; import type { DeesAppuiTabs } from '../dees-appui-tabs/dees-appui-tabs.js';
@customElement('dees-appui-maincontent') @customElement('dees-appui-maincontent')
export class DeesAppuiMaincontent extends DeesElement { export class DeesAppuiMaincontent extends DeesElement {
@@ -35,12 +35,12 @@ export class DeesAppuiMaincontent extends DeesElement {
@property({ @property({
type: Array, type: Array,
}) })
public tabs: interfaces.ITab[] = [ accessor tabs: interfaces.ITab[] = [
{ key: '⚠️ Please set tabs', action: () => console.warn('No tabs configured for maincontent') }, { key: '⚠️ Please set tabs', action: () => console.warn('No tabs configured for maincontent') },
]; ];
@property({ type: Object }) @property({ type: Object })
public selectedTab: interfaces.ITab | null = null; accessor selectedTab: interfaces.ITab | null = null;
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-maincontent/dees-appui-maincontent.js';

View File

@@ -1,6 +1,6 @@
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import * as interfaces from './interfaces/index.js'; import * as interfaces from '../interfaces/index.js';
import { zIndexLayers } from './00zindex.js'; import { zIndexLayers } from '../00zindex.js';
import { import {
DeesElement, DeesElement,
@@ -11,7 +11,7 @@ import {
css, css,
cssManager, cssManager,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import { DeesContextmenu } from './dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
/** /**
* the most left menu * the most left menu
@@ -34,12 +34,12 @@ export class DeesAppuiMainmenu extends DeesElement {
// INSTANCE // INSTANCE
@property({ type: Array }) @property({ type: Array })
public tabs: interfaces.ITab[] = [ accessor tabs: interfaces.ITab[] = [
{ key: '⚠️ Please set tabs', iconName: 'lucide:alertTriangle', action: () => console.warn('No tabs configured for mainmenu') }, { key: '⚠️ Please set tabs', iconName: 'lucide:alertTriangle', action: () => console.warn('No tabs configured for mainmenu') },
]; ];
@property() @property()
public selectedTab: interfaces.ITab; accessor selectedTab: interfaces.ITab;
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-mainmenu/dees-appui-mainmenu.js';

View File

@@ -1,8 +1,8 @@
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import * as interfaces from './interfaces/index.js'; import * as interfaces from '../interfaces/index.js';
import { DeesContextmenu } from './dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
import './dees-icon.js'; import '../dees-icon/dees-icon.js';
import { import {
DeesElement, DeesElement,
@@ -34,12 +34,12 @@ export class DeesAppuiMainselector extends DeesElement {
// INSTANCE // INSTANCE
@property({ type: Array }) @property({ type: Array })
public selectionOptions: (interfaces.ISelectionOption | { divider: true })[] = [ accessor selectionOptions: (interfaces.ISelectionOption | { divider: true })[] = [
{ key: '⚠️ Please set selection options', action: () => console.warn('No selection options configured for mainselector') }, { key: '⚠️ Please set selection options', action: () => console.warn('No selection options configured for mainselector') },
]; ];
@property() @property()
public selectedOption: interfaces.ISelectionOption = null; accessor selectedOption: interfaces.ISelectionOption = null;
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-mainselector/dees-appui-mainselector.js';

View File

@@ -1,5 +1,5 @@
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import { zIndexLayers } from './00zindex.js'; import { zIndexLayers } from '../00zindex.js';
import { import {
DeesElement, DeesElement,
@@ -36,21 +36,21 @@ export class DeesAppuiProfileDropdown extends DeesElement {
`; `;
@property({ type: Object }) @property({ type: Object })
public user?: { accessor user: {
name: string; name: string;
email?: string; email?: string;
avatar?: string; avatar?: string;
status?: 'online' | 'offline' | 'busy' | 'away'; status?: 'online' | 'offline' | 'busy' | 'away';
}; } | undefined = undefined;
@property({ type: Array }) @property({ type: Array })
public menuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = []; accessor menuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string } | { divider: true })[] = [];
@property({ type: Boolean, reflect: true }) @property({ type: Boolean, reflect: true })
public isOpen: boolean = false; accessor isOpen: boolean = false;
@property({ type: String }) @property({ type: String })
public position: 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left' = 'top-right'; accessor position: 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left' = 'top-right';
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-profiledropdown/dees-appui-profiledropdown.js';

View File

@@ -1,4 +1,4 @@
import * as interfaces from './interfaces/index.js'; import * as interfaces from '../interfaces/index.js';
import { import {
DeesElement, DeesElement,
@@ -107,16 +107,16 @@ export class DeesAppuiTabs extends DeesElement {
@property({ @property({
type: Array, type: Array,
}) })
public tabs: interfaces.ITab[] = []; accessor tabs: interfaces.ITab[] = [];
@property({ type: Object }) @property({ type: Object })
public selectedTab: interfaces.ITab | null = null; accessor selectedTab: interfaces.ITab | null = null;
@property({ type: Boolean }) @property({ type: Boolean })
public showTabIndicator: boolean = true; accessor showTabIndicator: boolean = true;
@property({ type: String }) @property({ type: String })
public tabStyle: 'horizontal' | 'vertical' = 'horizontal'; accessor tabStyle: 'horizontal' | 'vertical' = 'horizontal';
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-tabs/dees-appui-tabs.js';

View File

@@ -1,4 +1,4 @@
import * as interfaces from './interfaces/index.js'; import * as interfaces from '../interfaces/index.js';
import { import {
DeesElement, DeesElement,
@@ -11,8 +11,8 @@ import {
state, state,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import './dees-appui-tabs.js'; import '../dees-appui-tabs/dees-appui-tabs.js';
import type { DeesAppuiTabs } from './dees-appui-tabs.js'; import type { DeesAppuiTabs } from '../dees-appui-tabs/dees-appui-tabs.js';
export interface IAppViewTab extends interfaces.ITab { export interface IAppViewTab extends interfaces.ITab {
content?: TemplateResult | (() => TemplateResult); content?: TemplateResult | (() => TemplateResult);
@@ -60,13 +60,13 @@ export class DeesAppuiView extends DeesElement {
// INSTANCE // INSTANCE
@property({ type: Object }) @property({ type: Object })
public viewConfig: IAppView; accessor viewConfig: IAppView;
@state() @state()
private selectedTab: IAppViewTab | null = null; accessor selectedTab: IAppViewTab | null = null;
@state() @state()
private tabs: DeesAppuiTabs; accessor tabs: DeesAppuiTabs;
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-appui-view/dees-appui-view.js';

View File

@@ -23,13 +23,13 @@ export class DeesBadge extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property({ type: String }) @property({ type: String })
public type: 'default' | 'primary' | 'success' | 'warning' | 'error' = 'default'; accessor type: 'default' | 'primary' | 'success' | 'warning' | 'error' = 'default';
@property({ type: String }) @property({ type: String })
public text: string = ''; accessor text: string = '';
@property({ type: Boolean }) @property({ type: Boolean })
public rounded: boolean = false; accessor rounded: boolean = false;
constructor() { constructor() {
super(); super();

View File

@@ -0,0 +1 @@
export * from '../dees-badge/dees-badge.js';

View File

@@ -21,7 +21,7 @@ export class DeesButtonExit extends DeesElement {
@property({ @property({
type: Number type: Number
}) })
public size: number = 24; accessor size: number = 24;
public styles = [ public styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-button-exit/dees-button-exit.js';

View File

@@ -22,10 +22,10 @@ export class DeesButtonGroup extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property() @property()
public label: string = ''; accessor label: string = '';
@property() @property()
public direction: 'horizontal' | 'vertical' = 'horizontal'; accessor direction: 'horizontal' | 'vertical' = 'horizontal';
constructor() { constructor() {
super(); super();

View File

@@ -0,0 +1 @@
export * from '../dees-button-group/dees-button-group.js';

View File

@@ -1,11 +1,11 @@
import { html, css, cssManager, domtools } from '@design.estate/dees-element'; import { html, css, cssManager, domtools } from '@design.estate/dees-element';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
import './dees-panel.js'; import '../dees-panel/dees-panel.js';
import './dees-form.js'; import '../dees-form/dees-form.js';
import './dees-form-submit.js'; import '../dees-form-submit/dees-form-submit.js';
import './dees-input-text.js'; import '../dees-input-text/dees-input-text.js';
import './dees-icon.js'; import '../dees-icon/dees-icon.js';
import type { DeesButton } from './dees-button.js'; import type { DeesButton } from '../dees-button/dees-button.js';
export const demoFunc = () => html` export const demoFunc = () => html`
<style> <style>

View File

@@ -29,42 +29,42 @@ export class DeesButton extends DeesElement {
return true; return true;
} }
}) })
public text: string; accessor text: string;
@property() @property()
public eventDetailData: string; accessor eventDetailData: string;
@property({ @property({
type: Boolean, type: Boolean,
reflect: true, reflect: true,
}) })
public disabled = false; accessor disabled = false;
@property({ @property({
type: Boolean type: Boolean
}) })
public isHidden = false; accessor isHidden = false;
@property({ @property({
type: String type: String
}) })
public type: 'default' | 'destructive' | 'outline' | 'secondary' | 'ghost' | 'link' | 'normal' | 'highlighted' | 'discreet' | 'big' = 'default'; accessor type: 'default' | 'destructive' | 'outline' | 'secondary' | 'ghost' | 'link' | 'normal' | 'highlighted' | 'discreet' | 'big' = 'default';
@property({
type: String
})
public size: 'default' | 'sm' | 'lg' | 'icon' = 'default';
@property({ @property({
type: String type: String
}) })
public status: 'normal' | 'pending' | 'success' | 'error' = 'normal'; accessor size: 'default' | 'sm' | 'lg' | 'icon' = 'default';
@property({
type: String
})
accessor status: 'normal' | 'pending' | 'success' | 'error' = 'normal';
@property({ @property({
type: Boolean, type: Boolean,
reflect: true reflect: true
}) })
public insideForm: boolean = false; accessor insideForm: boolean = false;
constructor() { constructor() {
super(); super();

View File

@@ -0,0 +1 @@
export * from '../dees-button/dees-button.js';

View File

@@ -25,36 +25,36 @@ export class DeesChartArea extends DeesElement {
// instance // instance
@state() @state()
public chart: ApexCharts; accessor chart: ApexCharts;
@property() @property()
public label: string = 'Untitled Chart'; accessor label: string = 'Untitled Chart';
@property({ type: Array }) @property({ type: Array })
public series: ApexAxisChartSeries = []; accessor series: ApexAxisChartSeries = [];
// Override getter to return internal chart data // Override getter to return internal chart data
get chartSeries(): ApexAxisChartSeries { get chartSeries(): ApexAxisChartSeries {
return this.internalChartData.length > 0 ? this.internalChartData : this.series; return this.internalChartData.length > 0 ? this.internalChartData : this.series;
} }
@property({ attribute: false }) @property({ attribute: false })
public yAxisFormatter: (value: number) => string = (val) => `${val} Mbps`; accessor yAxisFormatter: (value: number) => string = (val) => `${val} Mbps`;
@property({ type: Number }) @property({ type: Number })
public rollingWindow: number = 0; // 0 means no rolling window accessor rollingWindow: number = 0; // 0 means no rolling window
@property({ type: Boolean }) @property({ type: Boolean })
public realtimeMode: boolean = false; accessor realtimeMode: boolean = false;
@property({ type: String }) @property({ type: String })
public yAxisScaling: 'fixed' | 'dynamic' | 'percentage' = 'dynamic'; accessor yAxisScaling: 'fixed' | 'dynamic' | 'percentage' = 'dynamic';
@property({ type: Number }) @property({ type: Number })
public yAxisMax: number = 100; // Used when yAxisScaling is 'fixed' or 'percentage' accessor yAxisMax: number = 100; // Used when yAxisScaling is 'fixed' or 'percentage'
@property({ type: Number }) @property({ type: Number })
public autoScrollInterval: number = 1000; // Auto-scroll interval in milliseconds (0 to disable) accessor autoScrollInterval: number = 1000; // Auto-scroll interval in milliseconds (0 to disable)
private resizeObserver: ResizeObserver; private resizeObserver: ResizeObserver;
private resizeTimeout: number; private resizeTimeout: number;

View File

@@ -1,5 +1,5 @@
import { html } from '@design.estate/dees-element'; import { html } from '@design.estate/dees-element';
import type { DeesChartLog } from './dees-chart-log.js'; import type { DeesChartLog } from '../dees-chart-log/dees-chart-log.js';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
export const demoFunc = () => { export const demoFunc = () => {

View File

@@ -30,16 +30,16 @@ export class DeesChartLog extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property() @property()
public label: string = 'Server Logs'; accessor label: string = 'Server Logs';
@property({ type: Array }) @property({ type: Array })
public logEntries: ILogEntry[] = []; accessor logEntries: ILogEntry[] = [];
@property({ type: Boolean }) @property({ type: Boolean })
public autoScroll: boolean = true; accessor autoScroll: boolean = true;
@property({ type: Number }) @property({ type: Number })
public maxEntries: number = 1000; accessor maxEntries: number = 1000;
private logContainer: HTMLDivElement; private logContainer: HTMLDivElement;

View File

@@ -0,0 +1 @@
export * from '../dees-chart-log/dees-chart-log.js';

View File

@@ -26,25 +26,25 @@ export class DeesChips extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property() @property()
public selectionMode: 'none' | 'single' | 'multiple' = 'single'; accessor selectionMode: 'none' | 'single' | 'multiple' = 'single';
@property({ @property({
type: Boolean, type: Boolean,
}) })
public chipsAreRemovable: boolean = false; accessor chipsAreRemovable: boolean = false;
@property({ @property({
type: Array, type: Array,
}) })
public selectableChips: Tag[] = []; accessor selectableChips: Tag[] = [];
@property() @property()
public selectedChip: Tag = null; accessor selectedChip: Tag = null;
@property({ @property({
type: Array, type: Array,
}) })
public selectedChips: Tag[] = []; accessor selectedChips: Tag[] = [];
constructor() { constructor() {
super(); super();

View File

@@ -0,0 +1 @@
export * from '../dees-chips/dees-chips.js';

View File

@@ -1,7 +1,7 @@
import { html } from '@design.estate/dees-element'; import { html } from '@design.estate/dees-element';
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import { DeesContextmenu } from './dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
export const demoFunc = () => html` export const demoFunc = () => html`
<style> <style>

View File

@@ -1,4 +1,4 @@
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import { demoFunc } from './dees-contextmenu.demo.js'; import { demoFunc } from './dees-contextmenu.demo.js';
import { import {
customElement, customElement,
@@ -13,9 +13,9 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import { DeesWindowLayer } from './dees-windowlayer.js'; import { DeesWindowLayer } from '../dees-windowlayer/dees-windowlayer.js';
import { zIndexLayers } from './00zindex.js'; import { zIndexLayers } from '../00zindex.js';
import './dees-icon.js'; import '../dees-icon/dees-icon.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -127,7 +127,7 @@ export class DeesContextmenu extends DeesElement {
@property({ @property({
type: Array, type: Array,
}) })
public menuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string; disabled?: boolean; submenu?: (plugins.tsclass.website.IMenuItem & { shortcut?: string; disabled?: boolean } | { divider: true })[]; divider?: never } | { divider: true })[] = []; accessor menuItems: (plugins.tsclass.website.IMenuItem & { shortcut?: string; disabled?: boolean; submenu?: (plugins.tsclass.website.IMenuItem & { shortcut?: string; disabled?: boolean } | { divider: true })[]; divider?: never } | { divider: true })[] = [];
windowLayer: DeesWindowLayer; windowLayer: DeesWindowLayer;
private submenu: DeesContextmenu | null = null; private submenu: DeesContextmenu | null = null;

View File

@@ -0,0 +1 @@
export * from '../dees-contextmenu/dees-contextmenu.js';

View File

@@ -1,5 +1,5 @@
import type { DashboardWidget } from './types.js'; import type { DashboardWidget } from './types.js';
import { DeesContextmenu } from '../dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
import type { DeesDashboardgrid } from './dees-dashboardgrid.js'; import type { DeesDashboardgrid } from './dees-dashboardgrid.js';
import * as plugins from '../00plugins.js'; import * as plugins from '../00plugins.js';

View File

@@ -7,8 +7,8 @@ import {
type TemplateResult, type TemplateResult,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import '../dees-icon.js'; import '../dees-icon/dees-icon.js';
import '../dees-contextmenu.js'; import '../dees-contextmenu/dees-contextmenu.js';
import { demoFunc } from './dees-dashboardgrid.demo.js'; import { demoFunc } from './dees-dashboardgrid.demo.js';
import { dashboardGridStyles } from './styles.js'; import { dashboardGridStyles } from './styles.js';
import { import {
@@ -71,49 +71,49 @@ export class DeesDashboardgrid extends DeesElement {
public static styles = dashboardGridStyles; public static styles = dashboardGridStyles;
@property({ type: Array }) @property({ type: Array })
public widgets: DashboardWidget[] = []; accessor widgets: DashboardWidget[] = [];
@property({ type: Number }) @property({ type: Number })
public cellHeight: number = 80; accessor cellHeight: number = 80;
@property({ type: Object }) @property({ type: Object })
public margin: DashboardMargin = 10; accessor margin: DashboardMargin = 10;
@property({ type: Number }) @property({ type: Number })
public columns: number = 12; accessor columns: number = 12;
@property({ type: Boolean }) @property({ type: Boolean })
public editable: boolean = true; accessor editable: boolean = true;
@property({ type: Boolean, reflect: true }) @property({ type: Boolean, reflect: true })
public enableAnimation: boolean = true; accessor enableAnimation: boolean = true;
@property({ type: String }) @property({ type: String })
public cellHeightUnit: CellHeightUnit = 'px'; accessor cellHeightUnit: CellHeightUnit = 'px';
@property({ type: Boolean }) @property({ type: Boolean })
public rtl: boolean = false; accessor rtl: boolean = false;
@property({ type: Boolean }) @property({ type: Boolean })
public showGridLines: boolean = false; accessor showGridLines: boolean = false;
@property({ attribute: false }) @property({ attribute: false })
public layouts?: Record<string, DashboardLayoutItem[]>; accessor layouts: Record<string, DashboardLayoutItem[]> | undefined = undefined;
@property({ type: String }) @property({ type: String })
public activeBreakpoint: string = 'base'; accessor activeBreakpoint: string = 'base';
@state() @state()
private placeholderPosition: DashboardLayoutItem | null = null; accessor placeholderPosition: DashboardLayoutItem | null = null;
@state() @state()
private metrics: GridCellMetrics | null = null; accessor metrics: GridCellMetrics | null = null;
@state() @state()
private resolvedMargins: DashboardResolvedMargins | null = null; accessor resolvedMargins: DashboardResolvedMargins | null = null;
@state() @state()
private previewWidgets: DashboardWidget[] | null = null; accessor previewWidgets: DashboardWidget[] | null = null;
private containerBounds: DOMRect | null = null; private containerBounds: DOMRect | null = null;
private dragState: DragState | null = null; private dragState: DragState | null = null;

View File

@@ -8,14 +8,14 @@ import {
state, state,
cssManager, cssManager,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import { cssGeistFontFamily, cssMonoFontFamily } from './00fonts.js'; import { cssGeistFontFamily, cssMonoFontFamily } from '../00fonts.js';
import hlight from 'highlight.js'; import hlight from 'highlight.js';
import * as smartstring from '@push.rocks/smartstring'; import * as smartstring from '@push.rocks/smartstring';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import { DeesContextmenu } from './dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -28,13 +28,13 @@ export class DeesDataviewCodebox extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property() @property()
public progLang: string = 'typescript'; accessor progLang: string = 'typescript';
@property({ @property({
type: String, type: String,
reflect: true, reflect: true,
}) })
public codeToDisplay: string = ''; accessor codeToDisplay: string = '';
constructor() { constructor() {
super(); super();
@@ -228,7 +228,6 @@ export class DeesDataviewCodebox extends DeesElement {
`; `;
} }
@state()
private codeToDisplayStore = ''; private codeToDisplayStore = '';
public async updated(_changedProperties) { public async updated(_changedProperties) {

View File

@@ -0,0 +1 @@
export * from '../dees-dataview-codebox/dees-dataview-codebox.js';

View File

@@ -1,5 +1,5 @@
import * as colors from './00colors.js'; import * as colors from '../00colors.js';
import * as plugins from './00plugins.js'; import * as plugins from '../00plugins.js';
import { demoFunc } from './dees-dataview-statusobject.demo.js'; import { demoFunc } from './dees-dataview-statusobject.demo.js';
import { import {
@@ -15,7 +15,7 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as tsclass from '@tsclass/tsclass'; import * as tsclass from '@tsclass/tsclass';
import { DeesContextmenu } from './dees-contextmenu.js'; import { DeesContextmenu } from '../dees-contextmenu/dees-contextmenu.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -27,7 +27,7 @@ declare global {
export class DeesDataviewStatusobject extends DeesElement { export class DeesDataviewStatusobject extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property({ type: Object }) statusObject: tsclass.code.IStatusObject; @property({ type: Object }) accessor statusObject: tsclass.code.IStatusObject;
public static styles = [ public static styles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-dataview-statusobject/dees-dataview-statusobject.js';

View File

@@ -0,0 +1 @@
export * from '../dees-editor-markdown/dees-editor-markdown.js';

View File

@@ -0,0 +1 @@
export * from '../dees-editor-markdownoutlet/dees-editor-markdownoutlet.js';

View File

@@ -33,17 +33,17 @@ export class DeesEditor extends DeesElement {
@property({ @property({
type: String type: String
}) })
public content = "function hello() {\n\talert('Hello world!');\n}"; accessor content = "function hello() {\n\talert('Hello world!');\n}";
@property({ @property({
type: Object type: Object
}) })
public contentSubject = new domtools.plugins.smartrx.rxjs.Subject<string>(); accessor contentSubject = new domtools.plugins.smartrx.rxjs.Subject<string>();
@property({ @property({
type: Boolean type: Boolean
}) })
public wordWrap: monaco.editor.IStandaloneEditorConstructionOptions['wordWrap'] = 'off'; accessor wordWrap: monaco.editor.IStandaloneEditorConstructionOptions['wordWrap'] = 'off';
constructor() { constructor() {
super(); super();

View File

@@ -7,7 +7,7 @@ import {
cssManager, cssManager,
property, property,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import type { DeesForm } from './dees-form.js'; import type { DeesForm } from '../dees-form/dees-form.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -23,17 +23,17 @@ export class DeesFormSubmit extends DeesElement {
type: Boolean, type: Boolean,
reflect: true, reflect: true,
}) })
public disabled = false; accessor disabled = false;
@property({ @property({
type: String, type: String,
}) })
public text: string; accessor text: string;
@property({ @property({
type: String, type: String,
}) })
public status: 'normal' | 'pending' | 'success' | 'error' = 'normal'; accessor status: 'normal' | 'pending' | 'success' | 'error' = 'normal';
constructor() { constructor() {
super(); super();

View File

@@ -0,0 +1 @@
export * from '../dees-form-submit/dees-form-submit.js';

View File

@@ -1,5 +1,5 @@
import { html, css, domtools, cssManager } from '@design.estate/dees-element'; import { html, css, domtools, cssManager } from '@design.estate/dees-element';
import type { DeesForm } from './dees-form.js'; import type { DeesForm } from '../dees-form/dees-form.js';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
export const demoFunc = () => html` export const demoFunc = () => html`

View File

@@ -8,19 +8,19 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import { DeesInputCheckbox } from './dees-input-checkbox.js'; import { DeesInputCheckbox } from '../dees-input-checkbox/dees-input-checkbox.js';
import { DeesInputDatepicker } from './dees-input-datepicker/index.js'; import { DeesInputDatepicker } from '../dees-input-datepicker/index.js';
import { DeesInputText } from './dees-input-text.js'; import { DeesInputText } from '../dees-input-text/dees-input-text.js';
import { DeesInputQuantitySelector } from './dees-input-quantityselector.js'; import { DeesInputQuantitySelector } from '../dees-input-quantityselector/dees-input-quantityselector.js';
import { DeesInputRadiogroup } from './dees-input-radiogroup.js'; import { DeesInputRadiogroup } from '../dees-input-radiogroup/dees-input-radiogroup.js';
import { DeesInputDropdown } from './dees-input-dropdown.js'; import { DeesInputDropdown } from '../dees-input-dropdown/dees-input-dropdown.js';
import { DeesInputFileupload } from './dees-input-fileupload/index.js'; import { DeesInputFileupload } from '../dees-input-fileupload/index.js';
import { DeesInputIban } from './dees-input-iban.js'; import { DeesInputIban } from '../dees-input-iban/dees-input-iban.js';
import { DeesInputMultitoggle } from './dees-input-multitoggle.js'; import { DeesInputMultitoggle } from '../dees-input-multitoggle/dees-input-multitoggle.js';
import { DeesInputPhone } from './dees-input-phone.js'; import { DeesInputPhone } from '../dees-input-phone/dees-input-phone.js';
import { DeesInputTypelist } from './dees-input-typelist.js'; import { DeesInputTypelist } from '../dees-input-typelist/dees-input-typelist.js';
import { DeesFormSubmit } from './dees-form-submit.js'; import { DeesFormSubmit } from '../dees-form-submit/dees-form-submit.js';
import { DeesTable } from './dees-table/index.js'; import { DeesTable } from '../dees-table/index.js';
import { demoFunc } from './dees-form.demo.js'; import { demoFunc } from './dees-form.demo.js';
// Unified set for form input types // Unified set for form input types
@@ -72,7 +72,7 @@ export class DeesForm extends DeesElement {
* When true, sets all child inputs to horizontal layout * When true, sets all child inputs to horizontal layout
*/ */
@property({ type: Boolean, reflect: true, attribute: 'horizontal-layout' }) @property({ type: Boolean, reflect: true, attribute: 'horizontal-layout' })
public horizontalLayout: boolean = false; accessor horizontalLayout: boolean = false;
public render(): TemplateResult { public render(): TemplateResult {
return html` return html`

View File

@@ -0,0 +1 @@
export * from '../dees-form/dees-form.js';

View File

@@ -10,7 +10,7 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import { demoFunc } from './dees-heading.demo.js'; import { demoFunc } from './dees-heading.demo.js';
import { cssCalSansFontFamily } from './00fonts.js'; import { cssCalSansFontFamily } from '../00fonts.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -28,7 +28,7 @@ export class DeesHeading extends DeesElement {
* Heading level: 1-6 for h1-h6, or 'hr' for horizontal rule style * Heading level: 1-6 for h1-h6, or 'hr' for horizontal rule style
*/ */
@property({ type: String, reflect: true }) @property({ type: String, reflect: true })
public level: '1' | '2' | '3' | '4' | '5' | '6' | 'hr' | 'hr-small' = '1'; accessor level: '1' | '2' | '3' | '4' | '5' | '6' | 'hr' | 'hr-small' = '1';
// STATIC STYLES // STATIC STYLES
public static styles: CSSResult[] = [ public static styles: CSSResult[] = [

View File

@@ -0,0 +1 @@
export * from '../dees-heading/dees-heading.js';

View File

@@ -23,7 +23,7 @@ export class DeesHint extends DeesElement {
public static demo = demoFunc; public static demo = demoFunc;
@property({ type: String }) @property({ type: String })
public type: 'info' | 'warn' | 'error' | 'critical' = 'info'; accessor type: 'info' | 'warn' | 'error' | 'critical' = 'info';
constructor() { constructor() {
super(); super();

View File

@@ -0,0 +1 @@
export * from '../dees-hint/dees-hint.js';

View File

@@ -1,5 +1,5 @@
import { html } from '@design.estate/dees-element'; import { html } from '@design.estate/dees-element';
import { icons, type IconWithPrefix } from './dees-icon.js'; import { icons, type IconWithPrefix } from '../dees-icon/dees-icon.js';
import * as lucideIcons from 'lucide'; import * as lucideIcons from 'lucide';
export const demoFunc = () => { export const demoFunc = () => {

View File

@@ -190,7 +190,7 @@ export class DeesIcon extends DeesElement {
toAttribute: (value: TIconKey): string => value toAttribute: (value: TIconKey): string => value
} }
}) })
public iconFA?: TIconKey; accessor iconFA: TIconKey | undefined = undefined;
/** /**
* The preferred icon property. Use format "fa:iconName" or "lucide:iconName" * The preferred icon property. Use format "fa:iconName" or "lucide:iconName"
@@ -203,16 +203,16 @@ export class DeesIcon extends DeesElement {
toAttribute: (value: IconWithPrefix): string => value toAttribute: (value: IconWithPrefix): string => value
} }
}) })
public icon?: IconWithPrefix; accessor icon: IconWithPrefix | undefined = undefined;
@property({ type: Number }) @property({ type: Number })
public iconSize: number; accessor iconSize: number;
@property({ type: String }) @property({ type: String })
public color: string = 'currentColor'; accessor color: string = 'currentColor';
@property({ type: Number }) @property({ type: Number })
public strokeWidth: number = 2; accessor strokeWidth: number = 2;
// For tracking when we need to re-render // For tracking when we need to re-render
private lastIcon: IconWithPrefix | TIconKey | null = null; private lastIcon: IconWithPrefix | TIconKey | null = null;

View File

@@ -0,0 +1 @@
export * from '../dees-icon/dees-icon.js';

View File

@@ -19,31 +19,31 @@ export abstract class DeesInputBase<T = any> extends DeesElement {
* - auto: Detect from parent context * - auto: Detect from parent context
*/ */
@property({ type: String }) @property({ type: String })
public layoutMode: 'vertical' | 'horizontal' | 'auto' = 'auto'; accessor layoutMode: 'vertical' | 'horizontal' | 'auto' = 'auto';
/** /**
* Position of the label relative to the input * Position of the label relative to the input
*/ */
@property({ type: String }) @property({ type: String })
public labelPosition: 'top' | 'left' | 'right' | 'none' = 'top'; accessor labelPosition: 'top' | 'left' | 'right' | 'none' = 'top';
/** /**
* Common properties for all inputs * Common properties for all inputs
*/ */
@property({ type: String }) @property({ type: String })
public key: string; accessor key: string;
@property({ type: String }) @property({ type: String })
public label: string; accessor label: string;
@property({ type: Boolean }) @property({ type: Boolean })
public required: boolean = false; accessor required: boolean = false;
@property({ type: Boolean }) @property({ type: Boolean })
public disabled: boolean = false; accessor disabled: boolean = false;
@property({ type: String }) @property({ type: String })
public description: string; accessor description: string;
/** /**
* Common styles for all input components * Common styles for all input components

View File

@@ -0,0 +1 @@
export * from '../dees-input-base/dees-input-base.js';

View File

@@ -1,8 +1,8 @@
import { html, css, cssManager } from '@design.estate/dees-element'; import { html, css, cssManager } from '@design.estate/dees-element';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
import './dees-panel.js'; import '../dees-panel/dees-panel.js';
import type { DeesInputCheckbox } from './dees-input-checkbox.js'; import type { DeesInputCheckbox } from '../dees-input-checkbox/dees-input-checkbox.js';
import './dees-button.js'; import '../dees-button/dees-button.js';
export const demoFunc = () => html` export const demoFunc = () => html`
<dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => { <dees-demowrapper .runAfterRender=${async (elementArg: HTMLElement) => {

View File

@@ -6,9 +6,9 @@ import {
css, css,
cssManager, cssManager,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import { DeesInputBase } from './dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
import { demoFunc } from './dees-input-checkbox.demo.js'; import { demoFunc } from './dees-input-checkbox.demo.js';
import { cssGeistFontFamily } from './00fonts.js'; import { cssGeistFontFamily } from '../00fonts.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -26,10 +26,10 @@ export class DeesInputCheckbox extends DeesInputBase<DeesInputCheckbox> {
@property({ @property({
type: Boolean, type: Boolean,
}) })
public value: boolean = false; accessor value: boolean = false;
@property({ type: Boolean }) @property({ type: Boolean })
public indeterminate: boolean = false; accessor indeterminate: boolean = false;
constructor() { constructor() {

View File

@@ -0,0 +1 @@
export * from '../dees-input-checkbox/dees-input-checkbox.js';

View File

@@ -4,13 +4,13 @@ import {
property, property,
state, state,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import { DeesInputBase } from '../dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
import { demoFunc } from './demo.js'; import { demoFunc } from './demo.js';
import { datepickerStyles } from './styles.js'; import { datepickerStyles } from './styles.js';
import { renderDatepicker } from './template.js'; import { renderDatepicker } from './template.js';
import type { IDateEvent } from './types.js'; import type { IDateEvent } from './types.js';
import '../dees-icon.js'; import '../dees-icon/dees-icon.js';
import '../dees-label.js'; import '../dees-label/dees-label.js';
declare global { declare global {
@@ -24,61 +24,61 @@ export class DeesInputDatepicker extends DeesInputBase<DeesInputDatepicker> {
public static demo = demoFunc; public static demo = demoFunc;
@property({ type: String }) @property({ type: String })
public value: string = ''; accessor value: string = '';
@property({ type: Boolean }) @property({ type: Boolean })
public enableTime: boolean = false; accessor enableTime: boolean = false;
@property({ type: String }) @property({ type: String })
public timeFormat: '24h' | '12h' = '24h'; accessor timeFormat: '24h' | '12h' = '24h';
@property({ type: Number }) @property({ type: Number })
public minuteIncrement: number = 1; accessor minuteIncrement: number = 1;
@property({ type: String }) @property({ type: String })
public dateFormat: string = 'YYYY-MM-DD'; accessor dateFormat: string = 'YYYY-MM-DD';
@property({ type: String }) @property({ type: String })
public minDate: string = ''; accessor minDate: string = '';
@property({ type: String }) @property({ type: String })
public maxDate: string = ''; accessor maxDate: string = '';
@property({ type: Array }) @property({ type: Array })
public disabledDates: string[] = []; accessor disabledDates: string[] = [];
@property({ type: Number }) @property({ type: Number })
public weekStartsOn: 0 | 1 = 1; // Default to Monday accessor weekStartsOn: 0 | 1 = 1; // Default to Monday
@property({ type: String }) @property({ type: String })
public placeholder: string = 'YYYY-MM-DD'; accessor placeholder: string = 'YYYY-MM-DD';
@property({ type: Boolean }) @property({ type: Boolean })
public enableTimezone: boolean = false; accessor enableTimezone: boolean = false;
@property({ type: String }) @property({ type: String })
public timezone: string = Intl.DateTimeFormat().resolvedOptions().timeZone; accessor timezone: string = Intl.DateTimeFormat().resolvedOptions().timeZone;
@property({ type: Array }) @property({ type: Array })
public events: IDateEvent[] = []; accessor events: IDateEvent[] = [];
@state() @state()
public isOpened: boolean = false; accessor isOpened: boolean = false;
@state() @state()
public opensToTop: boolean = false; accessor opensToTop: boolean = false;
@state() @state()
public selectedDate: Date | null = null; accessor selectedDate: Date | null = null;
@state() @state()
public viewDate: Date = new Date(); accessor viewDate: Date = new Date();
@state() @state()
public selectedHour: number = 0; accessor selectedHour: number = 0;
@state() @state()
public selectedMinute: number = 0; accessor selectedMinute: number = 0;
public static styles = datepickerStyles; public static styles = datepickerStyles;

View File

@@ -1,6 +1,6 @@
import { html, css } from '@design.estate/dees-element'; import { html, css } from '@design.estate/dees-element';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
import '../dees-panel.js'; import '../dees-panel/dees-panel.js';
import './component.js'; import './component.js';
import type { DeesInputDatepicker } from './component.js'; import type { DeesInputDatepicker } from './component.js';

View File

@@ -1,5 +1,5 @@
import { css, cssManager } from '@design.estate/dees-element'; import { css, cssManager } from '@design.estate/dees-element';
import { DeesInputBase } from '../dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
export const datepickerStyles = [ export const datepickerStyles = [
...DeesInputBase.baseStyles, ...DeesInputBase.baseStyles,

View File

@@ -1,8 +1,8 @@
import { html, css } from '@design.estate/dees-element'; import { html, css } from '@design.estate/dees-element';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
import './dees-panel.js'; import '../dees-panel/dees-panel.js';
import './dees-form.js'; import '../dees-form/dees-form.js';
import './dees-form-submit.js'; import '../dees-form-submit/dees-form-submit.js';
export const demoFunc = () => html` export const demoFunc = () => html`
<style> <style>

View File

@@ -9,8 +9,8 @@ import {
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import { demoFunc } from './dees-input-dropdown.demo.js'; import { demoFunc } from './dees-input-dropdown.demo.js';
import { DeesInputBase } from './dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
import { cssGeistFontFamily } from './00fonts.js'; import { cssGeistFontFamily } from '../00fonts.js';
declare global { declare global {
interface HTMLElementTagNameMap { interface HTMLElementTagNameMap {
@@ -25,10 +25,10 @@ export class DeesInputDropdown extends DeesInputBase<DeesInputDropdown> {
// INSTANCE // INSTANCE
@property() @property()
public options: { option: string; key: string; payload?: any }[] = []; accessor options: { option: string; key: string; payload?: any }[] = [];
@property() @property()
public selectedOption: { option: string; key: string; payload?: any } = null; accessor selectedOption: { option: string; key: string; payload?: any } = null;
// Add value property for form compatibility // Add value property for form compatibility
public get value() { public get value() {
@@ -42,22 +42,22 @@ export class DeesInputDropdown extends DeesInputBase<DeesInputDropdown> {
@property({ @property({
type: Boolean, type: Boolean,
}) })
public enableSearch: boolean = true; accessor enableSearch: boolean = true;
@state() @state()
public opensToTop: boolean = false; accessor opensToTop: boolean = false;
@state() @state()
private filteredOptions: { option: string; key: string; payload?: any }[] = []; accessor filteredOptions: { option: string; key: string; payload?: any }[] = [];
@state() @state()
private highlightedIndex: number = 0; accessor highlightedIndex: number = 0;
@state() @state()
public isOpened = false; accessor isOpened = false;
@state() @state()
private searchValue: string = ''; accessor searchValue: string = '';
public static styles = [ public static styles = [
...DeesInputBase.baseStyles, ...DeesInputBase.baseStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-input-dropdown/dees-input-dropdown.js';

View File

@@ -1,8 +1,8 @@
import { DeesInputBase } from '../dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
import { demoFunc } from './demo.js'; import { demoFunc } from './demo.js';
import { fileuploadStyles } from './styles.js'; import { fileuploadStyles } from './styles.js';
import '../dees-icon.js'; import '../dees-icon/dees-icon.js';
import '../dees-label.js'; import '../dees-label/dees-label.js';
import { import {
customElement, customElement,
@@ -23,33 +23,33 @@ export class DeesInputFileupload extends DeesInputBase<DeesInputFileupload> {
public static demo = demoFunc; public static demo = demoFunc;
@property({ attribute: false }) @property({ attribute: false })
public value: File[] = []; accessor value: File[] = [];
@state() @state()
public state: 'idle' | 'dragOver' | 'dropped' | 'uploading' | 'completed' = 'idle'; accessor state: 'idle' | 'dragOver' | 'dropped' | 'uploading' | 'completed' = 'idle';
@state() @state()
public isLoading: boolean = false; accessor isLoading: boolean = false;
@property({ type: String }) @property({ type: String })
public buttonText: string = 'Select files'; accessor buttonText: string = 'Select files';
@property({ type: String }) @property({ type: String })
public accept: string = ''; accessor accept: string = '';
@property({ type: Boolean }) @property({ type: Boolean })
public multiple: boolean = true; accessor multiple: boolean = true;
@property({ type: Number }) @property({ type: Number })
public maxSize: number = 0; // 0 means no limit accessor maxSize: number = 0; // 0 means no limit
@property({ type: Number }) @property({ type: Number })
public maxFiles: number = 0; // 0 means no limit accessor maxFiles: number = 0; // 0 means no limit
@property({ type: String, reflect: true }) @property({ type: String, reflect: true })
public validationState: 'valid' | 'invalid' | 'warn' | 'pending' = null; accessor validationState: 'valid' | 'invalid' | 'warn' | 'pending' = null;
public validationMessage: string = ''; accessor validationMessage: string = '';
private previewUrlMap: WeakMap<File, string> = new WeakMap(); private previewUrlMap: WeakMap<File, string> = new WeakMap();
private dropArea: HTMLElement | null = null; private dropArea: HTMLElement | null = null;

View File

@@ -1,6 +1,6 @@
import { css, cssManager, html } from '@design.estate/dees-element'; import { css, cssManager, html } from '@design.estate/dees-element';
import './component.js'; import './component.js';
import '../dees-panel.js'; import '../dees-panel/dees-panel.js';
export const demoFunc = () => html` export const demoFunc = () => html`
<dees-demowrapper> <dees-demowrapper>

View File

@@ -1,5 +1,5 @@
import { css, cssManager } from '@design.estate/dees-element'; import { css, cssManager } from '@design.estate/dees-element';
import { DeesInputBase } from '../dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
export const fileuploadStyles = [ export const fileuploadStyles = [
cssManager.defaultStyles, cssManager.defaultStyles,

View File

@@ -8,7 +8,7 @@ import {
cssManager, cssManager,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import * as domtools from '@design.estate/dees-domtools'; import * as domtools from '@design.estate/dees-domtools';
import { DeesInputBase } from './dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
import * as ibantools from 'ibantools'; import * as ibantools from 'ibantools';
import { demoFunc } from './dees-input-iban.demo.js'; import { demoFunc } from './dees-input-iban.demo.js';
@@ -19,15 +19,15 @@ export class DeesInputIban extends DeesInputBase<DeesInputIban> {
// INSTANCE // INSTANCE
@state() @state()
enteredString: string = ''; accessor enteredString: string = '';
@state() @state()
enteredIbanIsValid: boolean = false; accessor enteredIbanIsValid: boolean = false;
@property({ @property({
type: String, type: String,
}) })
public value = ''; accessor value = '';
public static styles = [ public static styles = [
...DeesInputBase.baseStyles, ...DeesInputBase.baseStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-input-iban/dees-input-iban.js';

View File

@@ -1,9 +1,9 @@
import { html, css } from '@design.estate/dees-element'; import { html, css } from '@design.estate/dees-element';
import '@design.estate/dees-wcctools/demotools'; import '@design.estate/dees-wcctools/demotools';
import './dees-panel.js'; import '../dees-panel/dees-panel.js';
import './dees-form.js'; import '../dees-form/dees-form.js';
import './dees-input-text.js'; import '../dees-input-text/dees-input-text.js';
import './dees-form-submit.js'; import '../dees-form-submit/dees-form-submit.js';
export const demoFunc = () => html` export const demoFunc = () => html`
<dees-demowrapper> <dees-demowrapper>

View File

@@ -7,9 +7,9 @@ import {
state, state,
type TemplateResult, type TemplateResult,
} from '@design.estate/dees-element'; } from '@design.estate/dees-element';
import { DeesInputBase } from './dees-input-base.js'; import { DeesInputBase } from '../dees-input-base/dees-input-base.js';
import './dees-icon.js'; import '../dees-icon/dees-icon.js';
import './dees-button.js'; import '../dees-button/dees-button.js';
import { demoFunc } from './dees-input-list.demo.js'; import { demoFunc } from './dees-input-list.demo.js';
declare global { declare global {
@@ -25,43 +25,43 @@ export class DeesInputList extends DeesInputBase<DeesInputList> {
// INSTANCE // INSTANCE
@property({ type: Array }) @property({ type: Array })
public value: string[] = []; accessor value: string[] = [];
@property({ type: String }) @property({ type: String })
public placeholder: string = 'Add new item...'; accessor placeholder: string = 'Add new item...';
@property({ type: Number }) @property({ type: Number })
public maxItems: number = 0; // 0 means unlimited accessor maxItems: number = 0; // 0 means unlimited
@property({ type: Number }) @property({ type: Number })
public minItems: number = 0; accessor minItems: number = 0;
@property({ type: Boolean }) @property({ type: Boolean })
public allowDuplicates: boolean = false; accessor allowDuplicates: boolean = false;
@property({ type: Boolean }) @property({ type: Boolean })
public sortable: boolean = false; accessor sortable: boolean = false;
@property({ type: Boolean }) @property({ type: Boolean })
public confirmDelete: boolean = false; accessor confirmDelete: boolean = false;
@property({ type: String }) @property({ type: String })
public validationText: string = ''; accessor validationText: string = '';
@state() @state()
private inputValue: string = ''; accessor inputValue: string = '';
@state() @state()
private editingIndex: number = -1; accessor editingIndex: number = -1;
@state() @state()
private editingValue: string = ''; accessor editingValue: string = '';
@state() @state()
private draggedIndex: number = -1; accessor draggedIndex: number = -1;
@state() @state()
private dragOverIndex: number = -1; accessor dragOverIndex: number = -1;
public static styles = [ public static styles = [
...DeesInputBase.baseStyles, ...DeesInputBase.baseStyles,

View File

@@ -0,0 +1 @@
export * from '../dees-input-list/dees-input-list.js';

Some files were not shown because too many files have changed in this diff Show More