UI Toolkit
Closed this issue · 3 comments
New component and model interfaces
(available on every component and model)
Lock/Mutex Interface
Useful to prevent race conditions during animations, modal dialogs, loading, etc.
Component events
beforeLock
cancelLock
afterLock
Component methods
component.lock()
method (prevent global route changes, prevent closing of component, stop listening to DOM events, enter lock state)component.unlock()
method (allow global route changes again, allows component to be closed, resumes listening to DOM events, leave lock state)
Timer
- Depends on moment.js
Useful for triggering interval-based updates to the UI; particularly "current time" indicators, or "50 seconds ago" tags on posts/comments/etc. The latter scenario is supported out of the box by adding a computed attribute for every attribute of the model (prefixed with a key) which is a JavaScript date (this computation is recomputed onTimer, and the new attributes are noticed onChange)
So if you have:
myModel.createdAt === new Date()
Then you might have:
myModel._since_createdAt === 'just now
Then, however fast your frequency is set to, you'll see the computed attribute update (which should trigger bindings in your component). The "ago" number will go up.
or myModel._since_createdAt === '45 seconds ago
Model options
timer.frequency
- How often the timer should run onTimer in seconds (default 1)
Model events
onTimer
(logic to run on top of the default behavior-- note that it won't override the default, just give you other options to time stuff, etc.)
Built-in components
Uses built-in templates which are well documented and may be overridden. Bundled with Foundation framework LESS files.
Utility
Loading Spinner
ui.spin
- Depends on spin.js
spin.js-powered component,ui.spin
can be attached to regions. e.g. in a method in your component:this.someRegion.attach('ui.spin')
Tooltip
ui.tooltip
Meant to be appended to the app region, this tooltip description box will be automatically attached where your mouse is in a sensible way. It's template receives a handful of well documented classes as the tooltip needs to be dynamically repositioned at different areas of the screen, and is fairly simple to extend.
Forms
Datepicker
ui.datepicker
Also includes support for date ranges.
Hour picker
ui.hourpicker
Also includes support for same-day hour ranges.
Select
ui.select
HTML+CSS, friendly custom, mobile-compatible multiple-choice dropdown menu, along w/ associated logic+hacks
Auto-complete
- Depends on
ui.spin
ui.autocomplete
Extendable built-in interface for creating autocomplete fields. Contains logic for automatically fetching data from a collection. Uses whatever collection you pass it.
Data
Search Field
ui.searchable
Extendable built-in interface for creating autocomplete fields. Contains logic for firing global search events, namespaced as you like.
List View
- Depends on
ui.spin
ui.list
Extendable built-in interface for creating dynamic lists with empty, error,and loading states. Uses whatever collection you pass it.
Tree View
- Depends on
ui.spin
ui.tree
Extendable built-in interface for creating nested-depth hierarchies (like filesystem, grouped lists, etc.). Contains logic for automatically fetching data from a collection and then rendering it up to n levels deep. Also contains logic for error, empty, and loading state on a holistic and per-group basis. Uses whatever collection you pass it-- assumes that all but the leaf-level models will have an attribute calledchildren
(configurable).
Progress Bar
ui.progressbar
name says it all
D3 Context
ui.d3
Built-in component used for embedding a d3 context. Accepts a backbone model, collection, or both, and has all the expected hooks for data bindings
@ghernandez345 got any ideas here?
there look good. I would also consider a modal window.
Closing this, since it's not part of the core.