Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/cloudbit-interactive/cuppajs

Standard Vanilla Libraries that work with everything.
https://github.com/cloudbit-interactive/cuppajs

angular component components cuppajs element-collection javascript reactive reactjs stencil svelte utility vanilla web web-components

Last synced: 2 months ago
JSON representation

Standard Vanilla Libraries that work with everything.

Awesome Lists containing this project

README

        

# CuppaJS - Standard libraries that work with everything out there.

A set of libraries to create any kind of javascript projects but regardless to other libraries, it is focus in vanilla javascript giving standard tools to built code and reuse it anywere, not matter the toolset (reactj, angular, vue, svelte).

There are tons of good frameworks and libraries implementations out there to create amazing projects and one of the biggest problems is found solid mature standard resources that works with alls of them, for example: if you are using Angular the way to go is found an Angular Component that solve your needed, but if you need switch or create a new project using other technology base "React", needs to found an alternative that supply your needs in that specific framework.

CuppaComponent.js | CuppaRouter.js | CuppaStorage.js

# Advantages

- Compatible with any other framework or libraries due is just standard code.
- Faster performance thanks to lit-html a simple, modern and fast HTML templeating.
- No pre-compilation process.
- Small size.
- No dependencies.

# Documentation

Doc [https://cuppajs.cloudbit.co/](https://cuppajs.cloudbit.co/)

Git [https://github.com/cloudbit-interactive/cuppajs](https://github.com/cloudbit-interactive/cuppajs)

Npm [https://www.npmjs.com/package/cuppajs](https://www.npmjs.com/package/cuppajs)

WebComponents [https://www.webcomponents.org/element/cuppajs-elements](https://www.webcomponents.org/element/cuppajs-elements)

# Cuppa Component ~5.5kB gzipped
```javascript
// Load or embed the library
import {CuppaComponent, html} from "https://cdn.jsdelivr.net/npm/cuppajs/libs/cuppa.component.min.js";

export default class MyComponent extends CuppaComponent {
count = this.observable("count", 0);
refs = {myDivRef:null};

constructor(){ super(); }

// Standard webComponent to observe attributes
static get observedAttributes() { return ['attr1', 'attr2'] }
attributeChangedCallback(attr, oldVal, newVal) { this[attr] = newVal }

// Invoked when the custom element is first connected to the document's DOM.
mounted() { }

// Invoked when the custom element is disconnected from the document's DOM.
unmounted() { }

// Invoked after render execution
rendered(){ }

render(){
return html`


this.count-- }>+
Count: ${this.count}
this.count++ }>+
`
}
}

// Standard way to defines a new custom element.
customElements.define('my-component', MyComponent);

// Ok, now we can add a instance of our component and see the result
document.body.append(new MyComponent())

```
# Cuppa Router ~2.5kB gzipped
```javascript
// Load or embed the library
import { CuppaRouter } from "https://cdn.jsdelivr.net/npm/cuppajs/libs/cuppa.router.min.js";

const router = new CuppaRouter();
router.addListener(onRouterUpdated);
router.updateLinks();
router.resolve();

function onRouterUpdated(path) {
let content = document.getElementById("content");
content.innerHTML = "";

if(router.match(path, "/")) {
content.innerHTML = "Home Page";
}else if(router.match(path, "works")) {
content.innerHTML = "Works";
}else if(router.match(path, "works/:alias")) {
let data = router.match(path, "works/:alias");
content.innerHTML = `Work Alias: ${data.params.alias}`;
}
}
```
# Cuppa Storage ~2.0kB gzipped
```javascript
// Load or embed the cuppa.component.js library
import {CuppaStorage} from "https://cdn.jsdelivr.net/npm/cuppajs/libs/cuppa.storage.min.js";

// Register a callback that will be automatically updated when value change
// store = null, LOCAL, SESSION, INDEXED_DB
CuppaStorage.getData({name:"user", store:CuppaStorage.LOCAL, defaultValue:null, callback:(data)=>{
console.log(data);
}})

// Set the value in the storage
CuppaStorage.setData({name:"user", data:{name:"Tufik", age:36}, store:CuppaStorage.LOCAL});

// Also is possible ge the value directly.
let value = await CuppaStorage.getData({name:"user", store:CuppaStorage.LOCAL, defaultValue:null});
// CuppaStorage.getDataSync doesn't support store CuppaStorage.INDEXED_DB due IndexedDB is async
let value = CuppaStorage.getDataSync({name:"user", store:CuppaStorage.LOCAL});
```