Initial commit
This commit is contained in:
253
node_modules/gridstack/doc/CHANGES.md
generated
vendored
Normal file
253
node_modules/gridstack/doc/CHANGES.md
generated
vendored
Normal file
@@ -0,0 +1,253 @@
|
||||
Change log
|
||||
==========================
|
||||
|
||||
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
|
||||
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
|
||||
**Table of Contents** *generated with [DocToc](http://doctoc.herokuapp.com/)*
|
||||
|
||||
- [v0.6.4-dev (upcoming changes)](#v064-dev-upcoming-changes)
|
||||
- [v0.6.4 (2020-02-17)](#v064-2020-02-17)
|
||||
- [v0.6.3 (2020-02-05)](#v063-2020-02-05)
|
||||
- [v0.6.2 (2020-02-03)](#v062-2020-02-03)
|
||||
- [v0.6.1 (2020-02-02)](#v061-2020-02-02)
|
||||
- [v0.6.0 (2019-12-24)](#v060-2019-12-24)
|
||||
- [v0.5.5 (2019-11-27)](#v055-2019-11-27)
|
||||
- [v0.5.4 (2019-11-26)](#v054-2019-11-26)
|
||||
- [v0.5.3 (2019-11-20)](#v053-2019-11-20)
|
||||
- [v0.5.2 (2019-11-13)](#v052-2019-11-13)
|
||||
- [v0.5.1 (2019-11-07)](#v051-2019-11-07)
|
||||
- [v0.5.0 (2019-11-06)](#v050-2019-11-06)
|
||||
- [v0.4.0 (2018-05-11)](#v040-2018-05-11)
|
||||
- [v0.3.0 (2017-04-21)](#v030-2017-04-21)
|
||||
- [v0.2.6 (2016-08-17)](#v026-2016-08-17)
|
||||
- [v0.2.5 (2016-03-02)](#v025-2016-03-02)
|
||||
- [v0.2.4 (2016-02-15)](#v024-2016-02-15)
|
||||
- [v0.2.3 (2015-06-23)](#v023-2015-06-23)
|
||||
- [v0.2.2 (2014-12-23)](#v022-2014-12-23)
|
||||
- [v0.2.1 (2014-12-09)](#v021-2014-12-09)
|
||||
- [v0.2.0 (2014-11-30)](#v020-2014-11-30)
|
||||
- [v0.1.0 (2014-11-18)](#v010-2014-11-18)
|
||||
|
||||
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
|
||||
|
||||
## v0.6.4-dev (upcoming changes)
|
||||
|
||||
- TBD
|
||||
|
||||
## v0.6.4 (2020-02-17)
|
||||
|
||||
- fix [#540](https://github.com/gridstack/gridstack.js/issues/540) WebComponent support: CSS file now insert before grid instead of 'head'
|
||||
- fix [#1143](https://github.com/gridstack/gridstack.js/issues/1143) nested grids with different `acceptWidgets` class
|
||||
- fix [#1142](https://github.com/gridstack/gridstack.js/issues/1142) add/remove widget will also trigger change events when it should.
|
||||
- optimized `change` callback to save original x,y,w,h values and only call those that changed [1148](https://github.com/gridstack/gridstack.js/pull/1148)
|
||||
- delete `bower` since [dead](https://snyk.io/blog/bower-is-dead) for a while now
|
||||
|
||||
## v0.6.3 (2020-02-05)
|
||||
|
||||
- fix [#1132](https://github.com/gridstack/gridstack.js/issues/1132) oneColumnMode missing CSS to do layout
|
||||
- del `oneColumnModeClass` / `.grid-stack-one-column-mode` and associated code. If you depended on this, use class `.grid-stack-1` instead since it is 1 column layout anyway [1134](https://github.com/gridstack/gridstack.js/pull/1134)
|
||||
|
||||
## v0.6.2 (2020-02-03)
|
||||
|
||||
- add `oneColumnModeDomSort` true|false to let you specify a custom layout (use dom order instead of x,y) for oneColumnMode `setColumn(1)` [#713](https://github.com/gridstack/gridstack.js/issues/713)
|
||||
- fix oneColumnMode to only restore if we auto went to it as window sizes up [#1125](https://github.com/gridstack/gridstack.js/pull/1125)
|
||||
- editing in 1 column (or few columns) does a better job updating higher layout (track before and after and move items accordingly).
|
||||
Tracking item swap would be even better still. [#1127](https://github.com/gridstack/gridstack.js/pull/1127)
|
||||
|
||||
## v0.6.1 (2020-02-02)
|
||||
|
||||
- fix [#37](https://github.com/gridstack/gridstack.js/issues/37) oneColumnMode (<768px by default) now simply calls `setColumn(1)` and remembers prev columns (so we can restore). This gives
|
||||
us full resize/re-order of items capabilities rather than a locked CSS only layout (see prev rev changes). [#1120](https://github.com/gridstack/gridstack.js/pull/1120)
|
||||
- fix [responsive.html](https://gridstackjs.com/demo/responsive.html) demo [#1121](https://github.com/gridstack/gridstack.js/pull/1121)
|
||||
|
||||
## v0.6.0 (2019-12-24)
|
||||
|
||||
- add `float(val)` to set/get the grid float mode, which will relayout [#1088](https://github.com/gridstack/gridstack.js/pull/1088)
|
||||
- add `compact()` to reclaim any empty space and relayout grid items [#1101](https://github.com/gridstack/gridstack.js/pull/1101)
|
||||
- add `options.dragOut` to let user drag nested grid items out of a parent or not (default false)
|
||||
and jQuery UI `draggable.containment` can now be specified in options. You can now drag&drop between 2 nested grids [#1105](https://github.com/gridstack/gridstack.js/pull/1105)
|
||||
- add `%` as a valid unit for height [#1093](https://github.com/gridstack/gridstack.js/pull/1093). thank you
|
||||
[@trevisanweb](https://github.com/trevisanweb) [@aureality](https://github.com/aureality)
|
||||
[@ZoolWay](https://github.com/ZoolWay)
|
||||
- fix callbacks to get either `added, removed, change` or combination if adding a node require also to change its (x,y) for example.
|
||||
Also you can now call `batchUpdate()` before calling a bunch of `addWidget()` and get a single event callback (more efficient).
|
||||
[#1096](https://github.com/gridstack/gridstack.js/pull/1096)
|
||||
- `removeAll()` is now much faster (no relayout) and calls `removed` event just once with a list [#1097](https://github.com/gridstack/gridstack.js/pull/1097)
|
||||
- `setColumn()` complete re-write and is no longer "Experimental". We now do a reasonable job at sizing/position the widgets (especially 1 column) and
|
||||
also now cache each column layout so you can go back to say 12 column and not loose original layout. [#1098](https://github.com/gridstack/gridstack.js/pull/1098)
|
||||
- fix `addWidget(el)` (no data) would not render item at correct location, and overlap item at (0,0) [#1098](https://github.com/gridstack/gridstack.js/pull/1098)
|
||||
- you can now pre-define size of dragable elements from a sidebar using standard `data-gs-width` and `data-gs-height` - fix
|
||||
[#413](https://github.com/gridstack/gridstack.js/issues/413), [#914](https://github.com/gridstack/gridstack.js/issues/914), [#918](https://github.com/gridstack/gridstack.js/issues/918),
|
||||
[#922](https://github.com/gridstack/gridstack.js/issues/922), [#933](https://github.com/gridstack/gridstack.js/issues/933)
|
||||
thanks [@ermcgrat](https://github.com/ermcgrat) and others for pointing out code issue.
|
||||
|
||||
## v0.5.5 (2019-11-27)
|
||||
|
||||
- min files include rev number/license [#1075](https://github.com/gridstack/gridstack.js/pull/1075)
|
||||
- npm package fix to exclude more temporary content [#1078](https://github.com/gridstack/gridstack.js/pull/1078)
|
||||
- removed `jquery-ui/*` requirements from AMD packing in `gridstack.jQueryUI.js` as it was causing App compile missing errors now that we include a subset of jquery-ui
|
||||
|
||||
## v0.5.4 (2019-11-26)
|
||||
|
||||
- fix for griditems with x=0 placement wrong order (introduced by [#1017](https://github.com/gridstack/gridstack.js/issues/10510174)) ([#1054](https://github.com/gridstack/gridstack.js/issues/1054)).
|
||||
- fix `cellHeight(val)` not working due to style change (introduced by [#937](https://github.com/gridstack/gridstack.js/issues/937)) ([#1068](https://github.com/gridstack/gridstack.js/issues/1068)).
|
||||
- add `gridstack-poly.js` for IE and older browsers, removed `core-js` lib from samples (<1k vs 85k), and all IE8 mentions ([#1061](https://github.com/gridstack/gridstack.js/pull/1061)).
|
||||
- add `jquery-ui.js` (and min.js) as minimal subset we need (55k vs 248k), which is now part of `gridstack.all.js`. Include individual parts if you need your own lib instead of all.js
|
||||
([#1064](https://github.com/gridstack/gridstack.js/pull/1064)).
|
||||
- changed jquery dependency to lowest we can use (>=1.8) ([#629](https://github.com/gridstack/gridstack.js/issues/629)).
|
||||
- add advance demo from web site ([#1073](https://github.com/gridstack/gridstack.js/pull/1073)).
|
||||
|
||||
## v0.5.3 (2019-11-20)
|
||||
|
||||
- grid options `width` is now `column`, `height` now `maxRow`, and `setGridWidth()` now `setColumn()` to match what they are. Old names are still supported (console warnings). Various fixes for custom # of column and re-wrote entire doc section ([#1053](https://github.com/gridstack/gridstack.js/issues/1053)).
|
||||
- fix widgets not animating when `animate: true` is used. on every move, styles were recreated-fix should slightly improve gridstack.js speed ([#937](https://github.com/gridstack/gridstack.js/issues/937)).
|
||||
- fix moving widgets when having multiple grids. jquery-ui workaround ([#1043](https://github.com/gridstack/gridstack.js/issues/1043)).
|
||||
- switch to eslint ([#763](https://github.com/gridstack/gridstack.js/issues/763)) thanks [@rwstoneback](https://github.com/rwstoneback).
|
||||
- fix null values `addWidget()` options ([#1042](https://github.com/gridstack/gridstack.js/issues/1042)).
|
||||
|
||||
## v0.5.2 (2019-11-13)
|
||||
|
||||
- fix undefined `x,y` position messes up grid ([#1017](https://github.com/gridstack/gridstack.js/issues/1017)).
|
||||
- changed code to 2 spaces.
|
||||
- fix minHeight during `onStartMoving()` ([#999](https://github.com/gridstack/gridstack.js/issues/999)).
|
||||
- add `gridstack.d.ts` TypeScript definition file now included - no need to include `@types/gridstack`, easier to update ([#1036](https://github.com/gridstack/gridstack.js/pull/1036)).
|
||||
- add `addWidget(el, options)` to pass object so you don't have to spell 10 params. ([#907](https://github.com/gridstack/gridstack.js/issues/907)).
|
||||
|
||||
## v0.5.1 (2019-11-07)
|
||||
|
||||
- reduced npm package size from 672k to 324k (drop demo, src and extra files)
|
||||
|
||||
## v0.5.0 (2019-11-06)
|
||||
|
||||
- emit `dropped` event when a widget is dropped from one grid into another ([#823](https://github.com/gridstack/gridstack.js/issues/823)).
|
||||
- don't throw error if no bounding scroll element is found ([#891](https://github.com/gridstack/gridstack.js/issues/891)).
|
||||
- don't push locked widgets even if they are at the top of the grid ([#882](https://github.com/gridstack/gridstack.js/issues/882)).
|
||||
- RequireJS and CommonJS now export on the `exports` module fix ([#643](https://github.com/gridstack/gridstack.js/issues/643)).
|
||||
- automatically scroll page when widget is moving beyond viewport ([#827](https://github.com/gridstack/gridstack.js/issues/827)).
|
||||
- removed lodash dependencies ([#693](https://github.com/gridstack/gridstack.js/issues/693)).
|
||||
- don't overwrite globals jQuery when in a modular environment ([#974](https://github.com/gridstack/gridstack.js/pull/974)).
|
||||
- removed z-index from `.grid-stack-item-content` causing child modal dialog clipping ([#984](https://github.com/gridstack/gridstack.js/pull/984)).
|
||||
- convert project to use yarn ([#983](https://github.com/gridstack/gridstack.js/pull/983)).
|
||||
|
||||
## v0.4.0 (2018-05-11)
|
||||
|
||||
- widgets can have their own resize handles. Use `data-gs-resize-handles` element attribute to use. For example, `data-gs-resize-handles="e,w"` will make the particular widget only resize west and east. ([#494](https://github.com/gridstack/gridstack.js/issues/494)).
|
||||
- enable sidebar items to be duplicated properly. Pass `helper: 'clone'` in `draggable` options. ([#661](https://github.com/gridstack/gridstack.js/issues/661), [#396](https://github.com/gridstack/gridstack.js/issues/396), [#499](https://github.com/gridstack/gridstack.js/issues/499)).
|
||||
- fix `staticGrid` grid option ([#743](https://github.com/gridstack/gridstack.js/issues/743))
|
||||
- preserve inline styles when moving/cloning items (thanks [@silverwind](https://github.com/silverwind))
|
||||
- fix bug causing heights not to get set ([#744](https://github.com/gridstack/gridstack.js/issues/744))
|
||||
- allow grid to have min-height, fixes ([#628](https://github.com/gridstack/gridstack.js/issues/628)) thanks [@adumesny](https://github.com/adumesny)
|
||||
- widget x and y are now ints (thanks [@DonnchaC](https://github.com/donnchac))
|
||||
- allow all droppable options (thanks [@vigor-vlad](https://github.com/vigor-vlad))
|
||||
- properly track mouse position in `getCellFromPixel` (thanks [@aletorrado](https://github.com/aletorrado))
|
||||
- remove instance of `!important` (thanks [@krilllind](https://github.com/krilllind))
|
||||
- scroll when moving widget up or down out of viewport ([#827](https://github.com/gridstack/gridstack.js/issues/827))
|
||||
|
||||
## v0.3.0 (2017-04-21)
|
||||
|
||||
- remove placeholder when dragging widget below grid (already worked when dragging left, above, and to the right of grid).
|
||||
- prevent extra checks for removing widget when dragging off grid.
|
||||
- trigger `added` when a widget is added via dropping from one grid to another.
|
||||
- trigger `removed` when a widget is removed via dropping from one grid to another.
|
||||
- trigger `removed` when a widget is removed via dropping on a removable zone ([#607](https://github.com/gridstack/gridstack.js/issues/607) and [#550](https://github.com/gridstack/gridstack.js/issues/550)).
|
||||
- trigger custom event for `resizestop` called `gsresizestop` ([#577](https://github.com/gridstack/gridstack.js/issues/577) and [#398](https://github.com/gridstack/gridstack.js/issues/398)).
|
||||
- prevent dragging/resizing in `oneColumnMode` ([#593](https://github.com/gridstack/gridstack.js/issues/593)).
|
||||
- add `oneColumnModeClass` option to grid.
|
||||
- remove 768px CSS styles, moved to grid-stack-one-column-mode class.
|
||||
- add max-width override on grid-stck-one-column-mode ([#462](https://github.com/gridstack/gridstack.js/issues/462)).
|
||||
- add internal function`isNodeChangedPosition`, minor optimization to move/drag.
|
||||
- drag'n'drop plugin system. Move jQuery UI dependencies to separate plugin file.
|
||||
|
||||
## v0.2.6 (2016-08-17)
|
||||
|
||||
- update requirements to the latest versions of jQuery (v3.1.0+) and jquery-ui (v1.12.0+).
|
||||
- fix jQuery `size()` ([#486](https://github.com/gridstack/gridstack.js/issues/486)).
|
||||
- update `destroy([detachGrid])` call ([#422](https://github.com/gridstack/gridstack.js/issues/422)).
|
||||
- don't mutate options when calling `draggable` and `resizable`. ([#505](https://github.com/gridstack/gridstack.js/issues/505)).
|
||||
- update _notify to allow detach ([#411](https://github.com/gridstack/gridstack.js/issues/411)).
|
||||
- fix code that checks for jquery-ui ([#481](https://github.com/gridstack/gridstack.js/issues/481)).
|
||||
- fix `cellWidth` calculation on empty grid
|
||||
|
||||
## v0.2.5 (2016-03-02)
|
||||
|
||||
- update names to respect js naming convention.
|
||||
- `cellHeight` and `verticalMargin` can now be string (e.g. '3em', '20px') (Thanks to @jlowcs).
|
||||
- add `maxWidth`/`maxHeight` methods.
|
||||
- add `enableMove`/`enableResize` methods.
|
||||
- fix window resize issue [#331](https://github.com/gridstack/gridstack.js/issues/331)).
|
||||
- add options `disableDrag` and `disableResize`.
|
||||
- fix `batchUpdate`/`commit` (Thank to @radiolips)
|
||||
- remove dependency of FontAwesome
|
||||
- RTL support
|
||||
- `'auto'` value for `cellHeight` option
|
||||
- fix `setStatic` method
|
||||
- add `setAnimation` method to API
|
||||
- add `setColumn` method ([#227](https://github.com/gridstack/gridstack.js/issues/227))
|
||||
- add `removable`/`removeTimeout` *(experimental)*
|
||||
- add `detachGrid` parameter to `destroy` method ([#216](https://github.com/gridstack/gridstack.js/issues/216)) (thanks @jhpedemonte)
|
||||
- add `useOffset` parameter to `getCellFromPixel` method ([#237](https://github.com/gridstack/gridstack.js/issues/237))
|
||||
- add `minWidth`, `maxWidth`, `minHeight`, `maxHeight`, `id` parameters to `addWidget` ([#188](https://github.com/gridstack/gridstack.js/issues/188))
|
||||
- add `added` and `removed` events for when a widget is added or removed, respectively. ([#54](https://github.com/gridstack/gridstack.js/issues/54))
|
||||
- add `acceptWidgets` parameter. Widgets can now be draggable between grids or from outside *(experimental)*
|
||||
|
||||
## v0.2.4 (2016-02-15)
|
||||
|
||||
- fix closure compiler/linter warnings
|
||||
- add `staticGrid` option.
|
||||
- add `minWidth`/`minHeight` methods (Thanks to @cvillemure)
|
||||
- add `destroy` method (Thanks to @zspitzer)
|
||||
- add `placeholderText` option (Thanks to @slauyama)
|
||||
- add `handleClass` option.
|
||||
- add `makeWidget` method.
|
||||
- lodash v 4.x support (Thanks to @andrewr88)
|
||||
|
||||
## v0.2.3 (2015-06-23)
|
||||
|
||||
- gridstack-extra.css
|
||||
- add support of lodash.js
|
||||
- add `isAreaEmpty` method
|
||||
- nested grids
|
||||
- add `batchUpdate`/`commit` methods
|
||||
- add `update` method
|
||||
- allow to override `resizable`/`draggable` options
|
||||
- add `disable`/`enable` methods
|
||||
- add `getCellFromPixel` (thanks to @juchi)
|
||||
- AMD support
|
||||
- fix nodes sorting
|
||||
- improved touch devices support
|
||||
- add `alwaysShowResizeHandle` option
|
||||
- minor fixes and improvements
|
||||
|
||||
## v0.2.2 (2014-12-23)
|
||||
|
||||
- fix grid initialization
|
||||
- add `cellHeight`/`cellWidth` API methods
|
||||
- fix boolean attributes ([#31](https://github.com/gridstack/gridstack.js/issues/31))
|
||||
|
||||
## v0.2.1 (2014-12-09)
|
||||
|
||||
- add widgets locking ([#19](https://github.com/gridstack/gridstack.js/issues/19))
|
||||
- add `willItFit` API method
|
||||
- fix auto-positioning ([#20](https://github.com/gridstack/gridstack.js/issues/20))
|
||||
- add animation (thanks to @ishields)
|
||||
- fix `y` coordinate calculation when dragging ([#18](https://github.com/gridstack/gridstack.js/issues/18))
|
||||
- fix `removeWidget` ([#16](https://github.com/gridstack/gridstack.js/issues/16))
|
||||
- minor fixes
|
||||
|
||||
|
||||
## v0.2.0 (2014-11-30)
|
||||
|
||||
- add `height` option
|
||||
- auto-generate css rules (widgets `height` and `top`)
|
||||
- add `GridStackUI.Utils.sort` utility function
|
||||
- add `removeAll` API method
|
||||
- add `resize` and `move` API methods
|
||||
- add `resizable` and `movable` API methods
|
||||
- add `data-gs-no-move` attribute
|
||||
- add `float` option
|
||||
- fix default css rule for inner content
|
||||
- minor fixes
|
||||
|
||||
## v0.1.0 (2014-11-18)
|
||||
|
||||
Very first version.
|
||||
514
node_modules/gridstack/doc/README.md
generated
vendored
Normal file
514
node_modules/gridstack/doc/README.md
generated
vendored
Normal file
@@ -0,0 +1,514 @@
|
||||
gridstack.js API
|
||||
================
|
||||
|
||||
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
|
||||
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
|
||||
**Table of Contents** *generated with [DocToc](http://doctoc.herokuapp.com/)*
|
||||
|
||||
- [Options](#options)
|
||||
- [Grid attributes](#grid-attributes)
|
||||
- [Item attributes](#item-attributes)
|
||||
- [Events](#events)
|
||||
- [added(event, items)](#addedevent-items)
|
||||
- [change(event, items)](#changeevent-items)
|
||||
- [disable(event)](#disableevent)
|
||||
- [dragstart(event, ui)](#dragstartevent-ui)
|
||||
- [dragstop(event, ui)](#dragstopevent-ui)
|
||||
- [dropped(event, previousWidget, newWidget)](#droppedevent-previouswidget-newwidget)
|
||||
- [enable(event)](#enableevent)
|
||||
- [removed(event, items)](#removedevent-items)
|
||||
- [resizestart(event, ui)](#resizestartevent-ui)
|
||||
- [gsresizestop(event, ui)](#gsresizestopevent-ui)
|
||||
- [API](#api)
|
||||
- [addWidget(el, [options])](#addwidgetel-options)
|
||||
- [addWidget(el, [x, y, width, height, autoPosition, minWidth, maxWidth, minHeight, maxHeight, id])](#addwidgetel-x-y-width-height-autoposition-minwidth-maxwidth-minheight-maxheight-id)
|
||||
- [batchUpdate()](#batchupdate)
|
||||
- [compact()](#compact)
|
||||
- [cellHeight()](#cellheight)
|
||||
- [cellHeight(val, noUpdate)](#cellheightval-noupdate)
|
||||
- [cellWidth()](#cellwidth)
|
||||
- [commit()](#commit)
|
||||
- [destroy([detachGrid])](#destroydetachgrid)
|
||||
- [disable()](#disable)
|
||||
- [enable()](#enable)
|
||||
- [enableMove(doEnable, includeNewWidgets)](#enablemovedoenable-includenewwidgets)
|
||||
- [enableResize(doEnable, includeNewWidgets)](#enableresizedoenable-includenewwidgets)
|
||||
- [float(val?)](#floatval)
|
||||
- [getCellFromPixel(position[, useOffset])](#getcellfrompixelposition-useoffset)
|
||||
- [isAreaEmpty(x, y, width, height)](#isareaemptyx-y-width-height)
|
||||
- [locked(el, val)](#lockedel-val)
|
||||
- [makeWidget(el)](#makewidgetel)
|
||||
- [maxHeight(el, val)](#maxheightel-val)
|
||||
- [minHeight(el, val)](#minheightel-val)
|
||||
- [maxWidth(el, val)](#maxwidthel-val)
|
||||
- [minWidth(el, val)](#minwidthel-val)
|
||||
- [movable(el, val)](#movableel-val)
|
||||
- [move(el, x, y)](#moveel-x-y)
|
||||
- [removeWidget(el[, detachNode])](#removewidgetel-detachnode)
|
||||
- [removeAll([detachNode])](#removealldetachnode)
|
||||
- [resize(el, width, height)](#resizeel-width-height)
|
||||
- [resizable(el, val)](#resizableel-val)
|
||||
- [setAnimation(doAnimate)](#setanimationdoanimate)
|
||||
- [setColumn(column, doNotPropagate)](#setcolumncolumn-donotpropagate)
|
||||
- [setStatic(staticValue)](#setstaticstaticvalue)
|
||||
- [update(el, x, y, width, height)](#updateel-x-y-width-height)
|
||||
- [verticalMargin()](#verticalmargin)
|
||||
- [verticalMargin(value, noUpdate)](#verticalmarginvalue-noupdate)
|
||||
- [willItFit(x, y, width, height, autoPosition)](#willitfitx-y-width-height-autoposition)
|
||||
- [Utils](#utils)
|
||||
- [GridStackUI.Utils.sort(nodes[, dir[, width]])](#gridstackuiutilssortnodes-dir-width)
|
||||
|
||||
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
|
||||
|
||||
## Options
|
||||
|
||||
- `acceptWidgets` - accept widgets dragged from other grids or from outside (default: `false`). Can be:
|
||||
* `true` (uses `'.grid-stack-item'` class filter) or `false`
|
||||
* string for explicit class name
|
||||
* function (i: number, element: Element) returning a boolean. See [example](http://gridstack.github.io/gridstack.js/demo/two.html)
|
||||
- `alwaysShowResizeHandle` - if `true` the resizing handles are shown even if the user is not hovering over the widget
|
||||
(default: `false`)
|
||||
- `animate` - turns animation on (default: `false`)
|
||||
- `auto` - if `false` gridstack will not initialize existing items (default: `true`)
|
||||
- `cellHeight` - one cell height (default: `60`). Can be:
|
||||
* an integer (px)
|
||||
* a string (ex: '100px', '10em', '10rem', '10%')
|
||||
* 0 or null, in which case the library will not generate styles for rows. Everything must be defined in CSS files.
|
||||
* `'auto'` - height will be calculated to match cell width (initial square grid).
|
||||
- `column` - number of columns (default: `12`) which can change on the fly with `setColumn()` as well. See [example](http://gridstackjs.com/demo/column.html)
|
||||
- `ddPlugin` - class that implement drag'n'drop functionallity for gridstack. If `false` grid will be static. (default: `null` - first available plugin will be used)
|
||||
- `disableDrag` - disallows dragging of widgets (default: `false`).
|
||||
- `disableOneColumnMode` - disables the onColumnMode when the window width is less than minWidth (default: 'false')
|
||||
- `disableResize` - disallows resizing of widgets (default: `false`).
|
||||
- `draggable` - allows to override jQuery UI draggable options. (default: `{handle: '.grid-stack-item-content', scroll: false, appendTo: 'body', containment: null}`)
|
||||
- `dragOut` to let user drag nested grid items out of a parent or not (default false) See [example](http://gridstackjs.com/demo/nested.html)
|
||||
- `float` - enable floating widgets (default: `false`) See [example](http://gridstackjs.com/demo/float.html)
|
||||
- `handle` - draggable handle selector (default: `'.grid-stack-item-content'`)
|
||||
- `handleClass` - draggable handle class (e.g. `'grid-stack-item-content'`). If set `handle` is ignored (default: `null`)
|
||||
- `itemClass` - widget class (default: `'grid-stack-item'`)
|
||||
- `maxRow` - maximum rows amount. Default is `0` which means no maximum rows
|
||||
- `minWidth` - minimal width. If window width is less than or equal to, grid will be shown in one-column mode (default: `768`)
|
||||
- `oneColumnModeDomSort` - set to `true` if you want oneColumnMode to use the DOM order and ignore x,y from normal multi column layouts during sorting. This enables you to have custom 1 column layout that differ from the rest. (default?: `false`)
|
||||
- `placeholderClass` - class for placeholder (default: `'grid-stack-placeholder'`)
|
||||
- `placeholderText` - placeholder default content (default: `''`)
|
||||
- `resizable` - allows to override jQuery UI resizable options. (default: `{autoHide: true, handles: 'se'}`)
|
||||
- `removable` - if `true` widgets could be removed by dragging outside of the grid. It could also be a jQuery selector string, in this case widgets will be removed by dropping them there (default: `false`) See [example](http://gridstackjs.com/demo/two.html)
|
||||
- `removeTimeout` - time in milliseconds before widget is being removed while dragging outside of the grid. (default: `2000`)
|
||||
- `rtl` - if `true` turns grid to RTL. Possible values are `true`, `false`, `'auto'` (default: `'auto'`) See [example](http://gridstackjs.com/demo/rtl.html)
|
||||
- `staticGrid` - makes grid static (default `false`). If true widgets are not movable/resizable. You don't even need jQueryUI draggable/resizable. A CSS class `grid-stack-static` is also added to the container.
|
||||
- `verticalMargin` - vertical gap size (default: `20`). Can be:
|
||||
* an integer (px)
|
||||
* a string (ex: '2em', '20px', '2rem')
|
||||
|
||||
## Grid attributes
|
||||
|
||||
- `data-gs-animate` - turns animation on
|
||||
- `data-gs-column` - amount of columns. Setting non-default value must be supported by equivalent change in CSS, [see docs here](https://github.com/gridstack/gridstack.js#change-grid-columns).
|
||||
- `data-gs-max-row` - maximum rows amount. Default is `0` which means no maximum rows.
|
||||
- `data-gs-current-height` - current rows amount. Set by the library only. Can be used by the CSS rules.
|
||||
|
||||
## Item attributes
|
||||
|
||||
- `data-gs-x`, `data-gs-y` - (number) element position in row/column. Note: if one is missing this will `autoPosition` the item
|
||||
- `data-gs-width`, `data-gs-height` - (number) element size in row/column
|
||||
- `data-gs-id`- (number | string) good for quick identification (for example in change event)
|
||||
- `data-gs-max-width`, `data-gs-min-width`, `data-gs-max-height`, `data-gs-min-height` - element constraints in row/column
|
||||
- `data-gs-no-resize` - disable element resizing
|
||||
- `data-gs-no-move` - disable element moving
|
||||
- `data-gs-auto-position` - tells to ignore `data-gs-x` and `data-gs-y` attributes and to place element to the first available position. Having either one missing will also do that.
|
||||
- `data-gs-locked` - the widget will be locked. It means another widget wouldn't be able to move it during dragging or resizing.
|
||||
The widget can still be dragged or resized. You need to add `data-gs-no-resize` and `data-gs-no-move` attributes
|
||||
to completely lock the widget.
|
||||
- `data-gs-resize-handles` - sets resize handles for a specific widget.
|
||||
|
||||
## Events
|
||||
|
||||
### added(event, items)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('added', function(event, items) {
|
||||
for (var i = 0; i < items.length; i++) {
|
||||
console.log('item added');
|
||||
console.log(items[i]);
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### change(event, items)
|
||||
|
||||
Occurs when adding/removing widgets or existing widgets change their position/size
|
||||
|
||||
```javascript
|
||||
var serializeWidgetMap = function(items) {
|
||||
console.log(items);
|
||||
};
|
||||
|
||||
$('.grid-stack').on('change', function(event, items) {
|
||||
serializeWidgetMap(items);
|
||||
});
|
||||
```
|
||||
|
||||
### disable(event)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('disable', function(event) {
|
||||
var grid = event.target;
|
||||
});
|
||||
```
|
||||
|
||||
### dragstart(event, ui)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('dragstart', function(event, ui) {
|
||||
var grid = this;
|
||||
var element = event.target;
|
||||
});
|
||||
```
|
||||
|
||||
### dragstop(event, ui)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('dragstop', function(event, ui) {
|
||||
var grid = this;
|
||||
var element = event.target;
|
||||
});
|
||||
```
|
||||
|
||||
### dropped(event, previousWidget, newWidget)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('dropped', function(event, previousWidget, newWidget) {
|
||||
console.log('Removed widget that was dragged out of grid:', previousWidget);
|
||||
console.log('Added widget in dropped grid:', newWidget);
|
||||
});
|
||||
```
|
||||
|
||||
### enable(event)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('enable', function(event) {
|
||||
var grid = event.target;
|
||||
});
|
||||
```
|
||||
|
||||
### removed(event, items)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('removed', function(event, items) {
|
||||
for (var i = 0; i < items.length; i++) {
|
||||
console.log('item removed');
|
||||
console.log(items[i]);
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
### resizestart(event, ui)
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('resizestart', function(event, ui) {
|
||||
var grid = this;
|
||||
var element = event.target;
|
||||
});
|
||||
```
|
||||
|
||||
### gsresizestop(event, ui)
|
||||
**Note**: this is a custom event name that is guaranteed to be called
|
||||
**after** the jqueryui resizestop event where we update `data-gs-width` and `data-gs-height`.
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').on('gsresizestop', function(event, elem) {
|
||||
var newHeight = $(elem).attr('data-gs-height');
|
||||
});
|
||||
```
|
||||
|
||||
## API
|
||||
|
||||
### addWidget(el, [options])
|
||||
|
||||
Creates new widget and returns it. Options is an object containing the fields x,y,width,height,etc... described below.
|
||||
|
||||
### addWidget(el, [x, y, width, height, autoPosition, minWidth, maxWidth, minHeight, maxHeight, id])
|
||||
|
||||
Creates new widget and returns it.
|
||||
|
||||
Parameters:
|
||||
|
||||
- `el` - widget to add
|
||||
- `x`, `y`, `width`, `height` - widget position/dimensions (optional)
|
||||
- `autoPosition` - if `true` then `x`, `y` parameters will be ignored and widget will be places on the first available
|
||||
position (optional)
|
||||
- `minWidth` minimum width allowed during resize/creation (optional)
|
||||
- `maxWidth` maximum width allowed during resize/creation (optional)
|
||||
- `minHeight` minimum height allowed during resize/creation (optional)
|
||||
- `maxHeight` maximum height allowed during resize/creation (optional)
|
||||
- `id` value for `data-gs-id` (optional)
|
||||
|
||||
Widget will be always placed even if result height is more than actual grid height. You need to use `willItFit` method
|
||||
before calling `addWidget` for additional check.
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').gridstack();
|
||||
var grid = $('.grid-stack').data('gridstack');
|
||||
grid.addWidget(el, 0, 0, 3, 2, true);
|
||||
```
|
||||
|
||||
### batchUpdate()
|
||||
|
||||
starts batch updates. You will see no changes until `commit()` method is called.
|
||||
|
||||
### compact()
|
||||
|
||||
relayout grid items to reclaim any empty space.
|
||||
|
||||
### cellHeight()
|
||||
|
||||
Gets current cell height.
|
||||
|
||||
### cellHeight(val, noUpdate)
|
||||
|
||||
Update current cell height. This method rebuilds an internal CSS stylesheet (unless optional noUpdate=true). Note: You can expect performance issues if
|
||||
call this method too often.
|
||||
|
||||
```javascript
|
||||
grid.cellHeight(grid.cellWidth() * 1.2);
|
||||
```
|
||||
|
||||
### cellWidth()
|
||||
|
||||
Gets current cell width.
|
||||
|
||||
### commit()
|
||||
|
||||
Ends batch updates. Updates DOM nodes. You must call it after `batchUpdate()`.
|
||||
|
||||
### destroy([detachGrid])
|
||||
|
||||
Destroys a grid instance.
|
||||
|
||||
Parameters:
|
||||
|
||||
- `detachGrid` - if `false` nodes and grid will not be removed from the DOM (Optional. Default `true`).
|
||||
|
||||
### disable()
|
||||
|
||||
Disables widgets moving/resizing. This is a shortcut for:
|
||||
|
||||
```javascript
|
||||
grid.movable('.grid-stack-item', false);
|
||||
grid.resizable('.grid-stack-item', false);
|
||||
```
|
||||
|
||||
### enable()
|
||||
|
||||
Enables widgets moving/resizing. This is a shortcut for:
|
||||
|
||||
```javascript
|
||||
grid.movable('.grid-stack-item', true);
|
||||
grid.resizable('.grid-stack-item', true);
|
||||
```
|
||||
|
||||
### enableMove(doEnable, includeNewWidgets)
|
||||
|
||||
Enables/disables widget moving. `includeNewWidgets` will force new widgets to be draggable as per `doEnable`'s value by changing the `disableDrag` grid option. This is a shortcut for:
|
||||
|
||||
```javascript
|
||||
grid.movable(this.container.children('.' + this.opts.itemClass), doEnable);
|
||||
```
|
||||
|
||||
### enableResize(doEnable, includeNewWidgets)
|
||||
|
||||
Enables/disables widget resizing. `includeNewWidgets` will force new widgets to be resizable as per `doEnable`'s value by changing the `disableResize` grid option. This is a shortcut for:
|
||||
|
||||
```javascript
|
||||
grid.resizable(this.container.children('.' + this.opts.itemClass), doEnable);
|
||||
```
|
||||
|
||||
### float(val?)
|
||||
|
||||
set/get floating widgets (default: `false`)
|
||||
|
||||
- `val` - boolean to set true/false, else get the current value
|
||||
|
||||
### getCellFromPixel(position[, useOffset])
|
||||
|
||||
Get the position of the cell under a pixel on screen.
|
||||
|
||||
Parameters :
|
||||
|
||||
- `position` - the position of the pixel to resolve in absolute coordinates, as an object with `top` and `left` properties
|
||||
- `useOffset` - if `true`, value will be based on offset vs position (Optional. Default `false`). Useful when grid is within `position: relative` element.
|
||||
|
||||
Returns an object with properties `x` and `y` i.e. the column and row in the grid.
|
||||
|
||||
### isAreaEmpty(x, y, width, height)
|
||||
|
||||
Checks if specified area is empty.
|
||||
|
||||
### locked(el, val)
|
||||
|
||||
Locks/unlocks widget.
|
||||
|
||||
- `el` - widget to modify.
|
||||
- `val` - if `true` widget will be locked.
|
||||
|
||||
### makeWidget(el)
|
||||
|
||||
If you add elements to your gridstack container by hand, you have to tell gridstack afterwards to make them widgets. If you want gridstack to add the elements for you, use `addWidget` instead.
|
||||
Makes the given element a widget and returns it.
|
||||
|
||||
Parameters:
|
||||
|
||||
- `el` - element to convert to a widget
|
||||
|
||||
```javascript
|
||||
$('.grid-stack').gridstack();
|
||||
|
||||
$('.grid-stack').append('<div id="gsi-1" data-gs-x="0" data-gs-y="0" data-gs-width="3" data-gs-height="2" data-gs-auto-position="true"></div>')
|
||||
var grid = $('.grid-stack').data('gridstack');
|
||||
grid.makeWidget('gsi-1');
|
||||
```
|
||||
|
||||
### maxHeight(el, val)
|
||||
|
||||
Set the `maxHeight` for a widget.
|
||||
|
||||
- `el` - widget to modify.
|
||||
- `val` - A numeric value of the number of rows
|
||||
|
||||
### minHeight(el, val)
|
||||
|
||||
Set the `minHeight` for a widget.
|
||||
|
||||
- `el` - widget to modify.
|
||||
- `val` - A numeric value of the number of rows
|
||||
|
||||
### maxWidth(el, val)
|
||||
|
||||
Set the `maxWidth` for a widget.
|
||||
|
||||
- `el` - widget to modify.
|
||||
- `val` - A numeric value of the number of columns
|
||||
|
||||
### minWidth(el, val)
|
||||
|
||||
Set the `minWidth` for a widget.
|
||||
|
||||
- `el` - widget to modify.
|
||||
- `val` - A numeric value of the number of columns
|
||||
|
||||
### movable(el, val)
|
||||
|
||||
Enables/Disables moving.
|
||||
|
||||
- `el` - widget to modify
|
||||
- `val` - if `true` widget will be draggable.
|
||||
|
||||
### move(el, x, y)
|
||||
|
||||
Changes widget position
|
||||
|
||||
Parameters:
|
||||
|
||||
- `el` - widget to move
|
||||
- `x`, `y` - new position. If value is `null` or `undefined` it will be ignored.
|
||||
|
||||
### removeWidget(el[, detachNode])
|
||||
|
||||
Removes widget from the grid.
|
||||
|
||||
Parameters:
|
||||
|
||||
- `el` - widget to remove.
|
||||
- `detachNode` - if `false` node won't be removed from the DOM (Optional. Default `true`).
|
||||
|
||||
### removeAll([detachNode])
|
||||
|
||||
Removes all widgets from the grid.
|
||||
|
||||
Parameters:
|
||||
|
||||
- `detachNode` - if `false` nodes won't be removed from the DOM (Optional. Default `true`).
|
||||
|
||||
### resize(el, width, height)
|
||||
|
||||
Changes widget size
|
||||
|
||||
Parameters:
|
||||
|
||||
- `el` - widget to resize
|
||||
- `width`, `height` - new dimensions. If value is `null` or `undefined` it will be ignored.
|
||||
|
||||
### resizable(el, val)
|
||||
|
||||
Enables/Disables resizing.
|
||||
|
||||
- `el` - widget to modify
|
||||
- `val` - if `true` widget will be resizable.
|
||||
|
||||
### setAnimation(doAnimate)
|
||||
|
||||
Toggle the grid animation state. Toggles the `grid-stack-animate` class.
|
||||
|
||||
- `doAnimate` - if `true` the grid will animate.
|
||||
|
||||
### setColumn(column, doNotPropagate)
|
||||
|
||||
Modify number of columns in the grid. Will update existing widgets to conform to new number of columns,
|
||||
as well as cache the original layout so you can revert back to previous positions without loss.
|
||||
Requires `gridstack-extra.css` or `gridstack-extra.min.css` for [1-11],
|
||||
else you will need to generate correct CSS (see https://github.com/gridstack/gridstack.js#change-grid-columns)
|
||||
|
||||
- `column` - Integer > 0 (default 12).
|
||||
- `doNotPropagate` - if true existing widgets will not be updated.
|
||||
|
||||
### setStatic(staticValue)
|
||||
|
||||
Toggle the grid static state. Also toggle the `grid-stack-static` class.
|
||||
|
||||
- `staticValue` - if `true` the grid becomes static.
|
||||
|
||||
### update(el, x, y, width, height)
|
||||
|
||||
Parameters:
|
||||
|
||||
- `el` - widget to move
|
||||
- `x`, `y` - new position. If value is `null` or `undefined` it will be ignored.
|
||||
- `width`, `height` - new dimensions. If value is `null` or `undefined` it will be ignored.
|
||||
|
||||
Updates widget position/size.
|
||||
|
||||
### verticalMargin()
|
||||
|
||||
returns current vertical margin value.
|
||||
|
||||
### verticalMargin(value, noUpdate)
|
||||
|
||||
Parameters:
|
||||
|
||||
- `value` - new vertical margin value.
|
||||
- `noUpdate` - if true, styles will not be updated.
|
||||
|
||||
### willItFit(x, y, width, height, autoPosition)
|
||||
|
||||
Returns `true` if the `height` of the grid will be less the vertical constraint. Always returns `true` if grid doesn't
|
||||
have `height` constraint.
|
||||
|
||||
```javascript
|
||||
if (grid.willItFit(newNode.x, newNode.y, newNode.width, newNode.height, true)) {
|
||||
grid.addWidget(newNode.el, newNode.x, newNode.y, newNode.width, newNode.height, true);
|
||||
}
|
||||
else {
|
||||
alert('Not enough free space to place the widget');
|
||||
}
|
||||
```
|
||||
|
||||
|
||||
## Utils
|
||||
|
||||
### GridStackUI.Utils.sort(nodes[, dir[, width]])
|
||||
|
||||
Sorts array of nodes
|
||||
|
||||
- `nodes` - array to sort
|
||||
- `dir` - `1` for asc, `-1` for desc (optional)
|
||||
- `width` - width of the grid. If `undefined` the width will be calculated automatically (optional).
|
||||
Reference in New Issue
Block a user