Socket
Book a DemoInstallSign in
Socket

@buschtoens/sparkles-component

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@buschtoens/sparkles-component

Experiment with `@glimmer/component` style APIs in Ember apps via existing public APIs

beta
latest
Source
npmnpm
Version
1.3.0-beta.1
Version published
Weekly downloads
1
Maintainers
1
Weekly downloads
 
Created
Source

sparkles-component

R. Sparkles

Addon used to experiment with @glimmer/component style APIs in Ember apps via existing public APIs.

Installation

ember install sparkles-component

Usage

The sparkles-component API supports most of the @glimmer/component API, including:

  • Lifecycle hooks
    • constructor - will be called when the component is needed, passed the evaluated named arguments for the component
    • didInsertElement - will be called after the component has been rendered the first time, after the whole top-down rendering process is completed
    • didUpdate - will be called after the component has been updated, after the whole top-down rendering process is completed
    • destroy - will be called when the component is no longer needed
  • Tracked properties
    • Support for setting local properties (triggering a rerender of that property)
    • Support for setting up dependent keys to cause a properties getter to be invoked again
    • Support for tracking class fields
  • Decorator Support
    • Support for consuming with Babel 6 (run ember install -S @ember-decorators/babel-transforms@^2.0.0)
    • Support consuming via TypeScript (enable via experimentalDecorators compiler option in tsconfig.json)

Missing features from @glimmer/component:

  • Access to this.bounds within the component. At the moment there is no access available at all to the rendered DOM. The easiest work around for now would be to use an attribute in your template along with document.querySelector.
  • Access to this.debugName within the component. This was largely only present for debugging purposes, but is not possible to access in the Ember APIs at the moment.

Example

Comprehensive example (nearly exactly the same as the the glimmer.js guides):

// app/components/conference-speakers.js (.ts would also work)
import Component, { tracked } from "sparkles-component";

export default class ConferenceSpeakers extends Component {
  @tracked current = 0;
  speakers = ['Tom', 'Yehuda', 'Ed'];

  @tracked('current')
  get currentlySpeaking() {
    return this.speakers[this.current];
  }

  @tracked('current')
  get moreSpeakers() {
    return (this.speakers.length - 1) > this.current;
  }

  next() {
    this.current = this.current + 1;
  }
}
{{!-- app/templates/components/conference-speakers.hbs --}}

<div>
  <p>Speaking: {{this.currentlySpeaking}}</p>
  <ul>
    {{#each this.speakers key="@index" as |speaker|}}
      <li>{{speaker}}</li>
    {{/each}}
  </ul>

  {{#if this.moreSpeakers}}
    <button onclick={{action this.next}}>Next</button>
  {{else}}
    <p>All finished!</p>
  {{/if}}
</div>

Contributing

Installation

  • git clone <repository-url>
  • cd sparkles-component
  • yarn install

Linting

  • yarn lint:js
  • yarn lint:js --fix

Running tests

  • ember test – Runs the test suite on the current Ember version
  • ember test --server – Runs the test suite in "watch mode"
  • ember try:each – Runs the test suite against multiple Ember versions

Running the dummy application

For more information on using ember-cli, visit https://ember-cli.com/.

License

This project is licensed under the MIT License.

Keywords

ember-addon

FAQs

Package last updated on 10 Jan 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts