npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

chop-js

v0.1.0

Published

ChopJS Front-End Framework

Downloads

5

Readme

Chop.JS

A Super Light-Weight JavaScript Framework

Chop.JS Dispenser

Browser support

ChopJS supports most major modern browsers, however, for Internet Explorer, only IE9+ is supported.

Usage

Put the following code at the bottom of body tag:

<script src="chop.js" ch-main="js/main.js"></script>
  • The ch-main attribute indicates the entry point/script of the web page.

ChopJS Modules

See module page

APIs - HTML attributes

ch-init

Initializes data sources. E.g. ch-init="list = []; msg = {from: 'a', to: 'b'}"

ch-use

Loads Chop.js modules. E.g.: ch-use="event; string; local/module"

ch-view

Sets chop.js view.

ch-keypress, ch-keydown, ch-click, ch-dbclick, ch-change, ch-mouseover, ch-mouseenter, ch-mouseout, ch-mouseleave, ch-mousemove, ch-mouseup, ch-mousedown, ch-mousewheel, ch-drag, ch-dragstart, ch-dragend, ch-dragover, ch-dragenter, ch-drop

Adds event listener. Use $$event for event parameter. To access "data source", use {{sourceName}}. Filter can also be used in data-source expression, e.g. {{users | filter: superUserFilter}}.

ch-source

Defines/adds data sources.

To use inline data source, the DOM element then has to have an ID. E.g.:

<div id="inline-div" ch-source>This is a inline {{data}} source.</div>

ch-inline

Turns the enclosed HTML element into an inline chop.js template, and renders the template according the value chop.js expression.

Each ch-inline element has to have an id.

APIs - $ch

$ch.find(query [, context])

Returns an HTML element in the form of a chop.js element object. If no elements found, returns undefined.

context could be an HTML element. E.g. $ch.find('#btn', $ch.find('#context').el).

$ch.findAll(query [, context])

Returns an chop.js element array that contains all the found elements. If no elements found, returns an emptry array.

context could be an HTML element. E.g. $ch.findAll('.btn', $ch.find('#context').el).

$ch.chopEl(DOMElement)

Converts a DOM element into Chop.js element object, and returns the Chop.js element object.

DOMElement can be either a DOM element or an element string.

$ch.element(args)

Alias function to $ch.chopEl.

$ch.source(source, data)

If only source provided, returns the value of source. Otherwise, sets the value of source to data.

$ch.view(param)

Creates and returns a chop.js view object. If no param provided, returns false.

param should at least contains an html property, which can be either a value or a function with return value. The html represents the HTML of the chop.js view.

To manually render a view, call render().

$ch.template(template, data)

Returns a processed string against the template. If no data provided, returns the content of template.

Use type='text/template' to define a template in script elements. Use {{something}} to indicate the place to be processed.

data should be in the form of an object.

$ch.http(url, param)

Performs an AJAX request.

url: the target URL of the AJAX call.

The object param contains:

  • method: HTTP verb (get, post, put, delete)
  • header: HTTP request headers to be set in the form of an object (e.g. {'header1': 'value1', 'header2': 'value2'})
  • async: asynchronous, default: true (true or false)
  • responseType: the response type of the AJAX request
  • data: data to be sent in the form of an object
  • done: the callback function for async AJAX
  • cache: indicates if the AJAX request should be cached. Default false

If async is false, returns the returned AJAX object.

$ch.jsonp(url, callback)

Performs a JSONP request.

url should be in the format of: http://example.com/data.json?jsonp={callback}.

callback is a function and takes a data parameter refers to the loaded JSON.

$ch.define(name[, require], function)

Defines a chop.js module.

  • name: the name of the module. Has to be same with filename, but without extension name (i.e. .js)
  • require: [optional] the modules to be synchronously required.
  • function: the function of the module. The return value will be stored in $ch.module.module_name.

Each customized module HAS TO BE packed in a module folder.

$ch.module(module)

Returns the returned data of module.

$ch.use(module, useLoader[, callback])

Uses/loads a chop.js module, and returns the returned value of module.

  • module: chop.js module name. If multiple modules, then in the form of an array. If a particular version is needed, Use @ to indicate. e.g. $ch.require(['[email protected]', 'layout']).

For details on module versions, see jsDelivr and search for modules by adding chopjs- before modules' names. E.g. to search event, type chopjs-event.

  • useLoader: [Optional] either true or false to define if to use Chop.js online module loader. Default: true.

  • callback: if callback presented, load module asynchronously and then fire callback. The parameters to callback are the returned value of each module.

$ch.readFile(src[, callback])

Reads and returns the content of local file src. If callback presented, read the file asynchronously and fire callback after loading.

$ch.each(obj, callback)

Iterates obj call callback. Parameters to callback:

  • for array: currentItem, index, obj
  • for object: key, value, index, obj

$ch.filter(obj, expression)

Filters and returns the array in obj according to expression.

expression is a function which takes a parameter representing obj and returns either true or false.

$ch.deserialize(formStr)

Returns an object deserialized from formStr.

APIs - chop.js element

css(style, value)

Sets CSS style. If no parameters, returns CSS text.

html(html)

Sets inner HTML into html. If no html provided, returns inner HTML.

content(html)

Sets text content to html. If no html presented, returns text content.

append(html)

Appends html.

prepend(html)

Prepends html.

appendChild(HTMLElement)

Appends HTMLElement as child.

prependChild(HTMLElement)

Prepends HTMLElement as child.

scrollTop(value)

If no value presented, set the element's scrollTop to value. Otherwise, returns current scrollTop.

scrollLeft(value)

If no value presented, set the element's scrollLeft to value. Otherwise, returns current scrollLeft.

offset()

Returns the offset properties of the element in the form of:

{
    left: offsetLeft,
    top: offsetTop,
    width: offsetWidth,
    height: offsetHeight,
    parent: offsetParent
}

get(property)

Returns property value of the element.

set(property, value)

Sets property of the element to value.

addClass(class)

Adds class.

removeClass(class)

Removes class.

toggleClass(class)

Toggles class.

submit()

Submits the form element, otherwise returns false.

animate(style, options[, callback])

Performs animation style (in the form of an object) according to options.

options can either be the form of {duration: duration, easing: easing}, or just duration in ms.

If callback presented, fire callback when animation is finished.

val(value)

Sets value to value. If no value provided, returns value.

attr(key, value)

Sets attribute key to value. If no parameters, returns all attributes.

hasAttr(key)

Checks if the element has attribute key.

removeAttr(key)

Removes attribute key.

inline(data)

Renders the inline-tempalte element with object data.

serialize()

Serializes a form element.

show()

Shows the element.

hide()

Hides the element.

on(event, callback)

Registers callback to event.

detach(event, callback)

Detaches the subscription of callback on event.

delegate(event, callback, query)

Adds callback to all query element on event. Multiple query can present.

E.g.:

aViewObject.delegate('click', triggerSomething, 'button', 'div.btn');

// all buttons and btn-class divs in 'aViewObject' will fire 'triggersomething'
on click.

click(callback)

Adds event listener on click. If no callback, trigger click event.

keypress(callback)

Adds event listener on keypress.

keydown(callback)

Adds event listener on keydown.

change(callback)

Adds event listener on change.

Chop.js global variables

  • $ch/$$CHOP -- chop.js main variable.
  • $$CHOPEL -- chop.js html element.
  • $$CHOPVIEW -- chop.js view.