Sha256: 87b1e9d965824bda40a15745a8b724faea317ee104b0c7be679d452772c155ed

Contents?: true

Size: 736 Bytes

Versions: 17

Compression:

Stored size: 736 Bytes

Contents

import { htmlAttributes } from "../html/html-attributes";

export class Button {
  attributes: Record<string, any>;
  children: any[];

  constructor(attributes: Record<string, any> = {}) {
    this.attributes = attributes;
    this.children = [];
  }

  add(child: any): Button {
    this.children.push(child);
    return this;
  }

  get render(): string {
    return `<button ${htmlAttributes(this.attributes)}>${this.children.map(child => child.render).join("")}</button>`;
  }

  add_action(event: string, klass: string, fn: string, options: Record<string, any> = {}): Button {
    this.attributes["data-action"] = `${this.attributes["data-action"] || ""} ${event}->${klass}#${fn}@${options.debounce || 0}`;
    return this;
  }
}

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
clapton-0.0.17 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.16 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.15 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.14 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.13 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.12 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.11 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.10 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.9 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.8 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.7 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.6 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.5 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.4 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.3 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.2 lib/clapton/javascripts/src/components/button.ts
clapton-0.0.1 lib/clapton/javascripts/src/components/button.ts