Skip to content
/ Deco Public

An efficient Web Component framework based on decorator-driven development

License

Notifications You must be signed in to change notification settings

star-ll/Deco

Repository files navigation

Decoco

Introduce

Decoco is an efficient Web Component framework based on decorator-driven development. It provides a new way to build reusable components and simplifies common programming tasks such as event listening and state management through decorators.

Packages

  • packages/core: core module(include decorator api, runtime and reactive api...).
  • packages/renderer: render module(jsx to dom).
  • packages/docs: document module(todo)
  • packages/examples: for test and demo.
  • packages/cli: cli module(dveloping).
  • packages/plugins: plugin module for vite.
  • packages/devtools: browser develop devtools (dveloping).

Start

create a decoco project

npm create decoco@latest

create a web component

import {Component,DecoElement,Event,Prop,Ref,RefType,State,Watch,EventEmitter,} from "@decoco/core";

@Component("hello-world")
export class HelloWorld extends DecoElement {
  @State() count = 0;
  @Prop() message = "Hello World!";
  @Event() emitter!: EventEmitter;
  @Ref() hostElement!: RefType<HTMLDivElement>;

  @Watch(["count"])
  onCountUpdate(value: number, oldValue: number, cleanup: () => void) {
    console.log("count update", value, oldValue);
    cleanup();
  }

  @Computed()
	get computedValue() {
		return this.count + 1;
	}
	set computedValue(value: number) {
		this.count = value - 1;
	}

  componentWillMount(): void {
    console.log(this.hostElement.current);
  }

  componentDidMount(): void {
    console.log(this.hostElement.current);
  }

  shouldComponentUpdate(): boolean {
    return true;
  }
  componentDidUpdate(): void {
    console.log(this.count);
  }

  render() {
    const onClick = () => {
      this.count++;
      this.emitter!.emit("click", this.count);
    };
    return (
      <div ref={this.hostElement}>
        <h1>{this.message}</h1>
        <div>
          <section>count: {this.count}</section>
          <button onClick={onClick}>+1</button>
        </div>
      </div>
    );
  }
}

Document

documents (developing)

Contributing

pnpm install
pnpm run --filter <package, e.g. core> dev

Roadmap

  • Reactive System
  • Render and JSX
  • Scheduler
  • @Component
  • @Prop
  • @State
  • @Event and @Listen
  • @Ref
  • @Watch
  • @Computed
  • lifecycle
  • State Management for redux
  • Hook API
  • performance optimization
  • more...

About

An efficient Web Component framework based on decorator-driven development

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published