@swimlane/ngx-dnd
Advanced tools
Comparing version 8.1.0 to 8.1.1
@@ -5,3 +5,3 @@ (function (global, factory) { | ||
(global = global || self, factory((global.swimlane = global.swimlane || {}, global.swimlane['ngx-dnd'] = {}), global.ng.core, global.ng.common, global.dragulaNamespace)); | ||
}(this, function (exports, core, common, dragulaNamespace) { 'use strict'; | ||
}(this, (function (exports, core, common, dragulaNamespace) { 'use strict'; | ||
@@ -22,3 +22,109 @@ /*! ***************************************************************************** | ||
***************************************************************************** */ | ||
/* global Reflect, Promise */ | ||
var extendStatics = function(d, b) { | ||
extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; | ||
return extendStatics(d, b); | ||
}; | ||
function __extends(d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
} | ||
var __assign = function() { | ||
__assign = Object.assign || function __assign(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
function __rest(s, e) { | ||
var t = {}; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) | ||
t[p] = s[p]; | ||
if (s != null && typeof Object.getOwnPropertySymbols === "function") | ||
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { | ||
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) | ||
t[p[i]] = s[p[i]]; | ||
} | ||
return t; | ||
} | ||
function __decorate(decorators, target, key, desc) { | ||
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; | ||
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); | ||
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; | ||
return c > 3 && r && Object.defineProperty(target, key, r), r; | ||
} | ||
function __param(paramIndex, decorator) { | ||
return function (target, key) { decorator(target, key, paramIndex); } | ||
} | ||
function __metadata(metadataKey, metadataValue) { | ||
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); | ||
} | ||
function __awaiter(thisArg, _arguments, P, generator) { | ||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
} | ||
function __generator(thisArg, body) { | ||
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; | ||
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; | ||
function verb(n) { return function (v) { return step([n, v]); }; } | ||
function step(op) { | ||
if (f) throw new TypeError("Generator is already executing."); | ||
while (_) try { | ||
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; | ||
if (y = 0, t) op = [op[0] & 2, t.value]; | ||
switch (op[0]) { | ||
case 0: case 1: t = op; break; | ||
case 4: _.label++; return { value: op[1], done: false }; | ||
case 5: _.label++; y = op[1]; op = [0]; continue; | ||
case 7: op = _.ops.pop(); _.trys.pop(); continue; | ||
default: | ||
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } | ||
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } | ||
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } | ||
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } | ||
if (t[2]) _.ops.pop(); | ||
_.trys.pop(); continue; | ||
} | ||
op = body.call(thisArg, _); | ||
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } | ||
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; | ||
} | ||
} | ||
function __exportStar(m, exports) { | ||
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; | ||
} | ||
function __values(o) { | ||
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; | ||
if (m) return m.call(o); | ||
if (o && typeof o.length === "number") return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); | ||
} | ||
function __read(o, n) { | ||
@@ -47,8 +153,73 @@ var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
function __spreadArrays() { | ||
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; | ||
for (var r = Array(s), k = 0, i = 0; i < il; i++) | ||
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) | ||
r[k] = a[j]; | ||
return r; | ||
}; | ||
function __await(v) { | ||
return this instanceof __await ? (this.v = v, this) : new __await(v); | ||
} | ||
function __asyncGenerator(thisArg, _arguments, generator) { | ||
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); | ||
var g = generator.apply(thisArg, _arguments || []), i, q = []; | ||
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; | ||
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } | ||
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } | ||
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } | ||
function fulfill(value) { resume("next", value); } | ||
function reject(value) { resume("throw", value); } | ||
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } | ||
} | ||
function __asyncDelegator(o) { | ||
var i, p; | ||
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; | ||
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; } | ||
} | ||
function __asyncValues(o) { | ||
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); | ||
var m = o[Symbol.asyncIterator], i; | ||
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); | ||
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } | ||
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } | ||
} | ||
function __makeTemplateObject(cooked, raw) { | ||
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } | ||
return cooked; | ||
}; | ||
function __importStar(mod) { | ||
if (mod && mod.__esModule) return mod; | ||
var result = {}; | ||
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||
result.default = mod; | ||
return result; | ||
} | ||
function __importDefault(mod) { | ||
return (mod && mod.__esModule) ? mod : { default: mod }; | ||
} | ||
function __classPrivateFieldGet(receiver, privateMap) { | ||
if (!privateMap.has(receiver)) { | ||
throw new TypeError("attempted to get private field on non-instance"); | ||
} | ||
return privateMap.get(receiver); | ||
} | ||
function __classPrivateFieldSet(receiver, privateMap, value) { | ||
if (!privateMap.has(receiver)) { | ||
throw new TypeError("attempted to set private field on non-instance"); | ||
} | ||
privateMap.set(receiver, value); | ||
return value; | ||
} | ||
// see https://github.com/dherges/ng-packagr/issues/217 | ||
/** @type {?} */ | ||
var dragula = dragulaNamespace; | ||
@@ -68,25 +239,8 @@ /** | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.register = /** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
function (droppable) { | ||
DrakeStoreService.prototype.register = function (droppable) { | ||
this.droppableMap.set(droppable.container, droppable); | ||
this.drake.containers.push(droppable.container); | ||
}; | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.remove = /** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
function (droppable) { | ||
DrakeStoreService.prototype.remove = function (droppable) { | ||
this.droppableMap.delete(droppable.container); | ||
/** @type {?} */ | ||
var idx = this.drake.containers.indexOf(droppable.container); | ||
@@ -97,45 +251,15 @@ if (idx > -1) { | ||
}; | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.registerDraggable = /** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
function (draggable) { | ||
DrakeStoreService.prototype.registerDraggable = function (draggable) { | ||
this.draggableMap.set(draggable.element, draggable); | ||
}; | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.removeDraggable = /** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
function (draggable) { | ||
DrakeStoreService.prototype.removeDraggable = function (draggable) { | ||
this.draggableMap.delete(draggable.element); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.createDrakeOptions = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DrakeStoreService.prototype.createDrakeOptions = function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var accepts = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @return {?} | ||
*/ | ||
function (el, target /*, source: any, sibling: any */) { | ||
var accepts = function (el, target /*, source: any, sibling: any */) { | ||
if (el.contains(target)) { | ||
return false; | ||
} | ||
/** @type {?} */ | ||
var elementComponent = _this.draggableMap.get(el); | ||
/** @type {?} */ | ||
var targetComponent = _this.droppableMap.get(target); | ||
@@ -146,11 +270,4 @@ if (elementComponent && targetComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
var copy = (/** | ||
* @param {?} _ | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (_, source) { | ||
/** @type {?} */ | ||
}; | ||
var copy = function (_, source) { | ||
var sourceComponent = _this.droppableMap.get(source); | ||
@@ -161,13 +278,4 @@ if (sourceComponent) { | ||
return false; | ||
}); | ||
/** @type {?} */ | ||
var moves = (/** | ||
* @param {?=} el | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
function (el, source, handle, sibling) { | ||
/** @type {?} */ | ||
}; | ||
var moves = function (el, source, handle, sibling) { | ||
var elementComponent = _this.draggableMap.get(el); | ||
@@ -178,35 +286,14 @@ if (elementComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
var direction = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, target, source) { | ||
/** @type {?} */ | ||
}; | ||
var direction = function (el, target, source) { | ||
var targetComponent = _this.droppableMap.get(target); | ||
return targetComponent.direction || 'vertical'; | ||
}); | ||
}; | ||
return { accepts: accepts, copy: copy, moves: moves, revertOnSpill: true, direction: direction }; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.registerEvents = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DrakeStoreService.prototype.registerEvents = function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var dragElm; | ||
/** @type {?} */ | ||
var draggedItem; | ||
this.drake.on('drag', (/** | ||
* @param {?} el | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, source) { | ||
this.drake.on('drag', function (el, source) { | ||
draggedItem = undefined; | ||
@@ -218,3 +305,2 @@ dragElm = el; | ||
if (_this.draggableMap.has(el)) { | ||
/** @type {?} */ | ||
var elementComponent = _this.draggableMap.get(el); | ||
@@ -230,3 +316,2 @@ draggedItem = elementComponent.model; | ||
if (_this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
@@ -242,11 +327,4 @@ _this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill; | ||
} | ||
})); | ||
this.drake.on('drop', (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, target, source) { | ||
/** @type {?} */ | ||
}); | ||
this.drake.on('drop', function (el, target, source) { | ||
var targetComponent = _this.droppableMap.get(target); | ||
@@ -257,5 +335,3 @@ if (!targetComponent) { | ||
} | ||
/** @type {?} */ | ||
var dropElmModel = draggedItem; | ||
/** @type {?} */ | ||
var dropIndex = Array.prototype.indexOf.call(target.children, el); | ||
@@ -267,12 +343,7 @@ if (dropIndex < 0) { | ||
} | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
if (sourceComponent) { | ||
/** @type {?} */ | ||
var sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
var targetModel = targetComponent.model; | ||
/** @type {?} */ | ||
var hasDragModel = !!(sourceModel && draggedItem); | ||
/** @type {?} */ | ||
var dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -285,5 +356,3 @@ if (hasDragModel && dragIndex < 0) { | ||
if (targetModel) { | ||
/** @type {?} */ | ||
var reorder = dragIndex > -1 && sourceModel && target === source; | ||
/** @type {?} */ | ||
var copy = !sourceModel || dragElm !== el; | ||
@@ -318,16 +387,7 @@ if (reorder) { | ||
}); | ||
})); | ||
this.drake.on('remove', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('remove', function (el, container, source) { | ||
if (_this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
/** @type {?} */ | ||
var sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
var dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -349,12 +409,5 @@ if (dragIndex > -1) { | ||
} | ||
})); | ||
this.drake.on('cancel', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('cancel', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -369,12 +422,5 @@ containerComponent.cancel.emit({ | ||
} | ||
})); | ||
this.drake.on('over', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('over', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -389,12 +435,5 @@ containerComponent.over.emit({ | ||
} | ||
})); | ||
this.drake.on('out', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('out', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -409,22 +448,13 @@ containerComponent.out.emit({ | ||
} | ||
})); | ||
}); | ||
}; | ||
DrakeStoreService.decorators = [ | ||
{ type: core.Injectable, args: [{ providedIn: 'root' },] } | ||
]; | ||
/** @nocollapse */ | ||
DrakeStoreService.ctorParameters = function () { return []; }; | ||
/** @nocollapse */ DrakeStoreService.ngInjectableDef = core.ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService.ɵprov = core["ɵɵdefineInjectable"]({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService = __decorate([ | ||
core.Injectable({ providedIn: 'root' }), | ||
__metadata("design:paramtypes", []) | ||
], DrakeStoreService); | ||
return DrakeStoreService; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var i = 10000; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -454,6 +484,3 @@ return i++; | ||
Object.defineProperty(DroppableDirective.prototype, "container", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.el.nativeElement; | ||
@@ -465,13 +492,6 @@ }, | ||
Object.defineProperty(DroppableDirective.prototype, "dropZone", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZone || this.ngxDroppable || this.defaultZone; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZone = val; | ||
@@ -482,46 +502,18 @@ }, | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngOnInit = function () { | ||
this.defaultZone = "@@DefaultDropZone-" + getNextId() + "@@"; | ||
this.drakesService.register(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngAfterViewInit = function () { | ||
var _this = this; | ||
this.over.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.over.subscribe(function () { | ||
_this.renderer.addClass(_this.container, 'gu-over'); | ||
})); | ||
this.out.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
}); | ||
this.out.subscribe(function () { | ||
_this.renderer.removeClass(_this.container, 'gu-over'); | ||
})); | ||
}); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngOnDestroy = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngOnDestroy = function () { | ||
this.drakesService.remove(this); | ||
}; | ||
DroppableDirective.decorators = [ | ||
{ type: core.Directive, args: [{ selector: '[ngxDroppable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
DroppableDirective.ctorParameters = function () { return [ | ||
@@ -532,16 +524,55 @@ { type: core.ElementRef }, | ||
]; }; | ||
DroppableDirective.propDecorators = { | ||
model: [{ type: core.Input }], | ||
copy: [{ type: core.Input }], | ||
removeOnSpill: [{ type: core.Input }], | ||
ngxDroppable: [{ type: core.Input }], | ||
direction: [{ type: core.Input }], | ||
drop: [{ type: core.Output }], | ||
drag: [{ type: core.Output }], | ||
over: [{ type: core.Output }], | ||
out: [{ type: core.Output }], | ||
remove: [{ type: core.Output }], | ||
cancel: [{ type: core.Output }], | ||
dropZone: [{ type: core.Input }] | ||
}; | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "copy", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "ngxDroppable", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "direction", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DroppableDirective.prototype, "drop", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DroppableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DroppableDirective.prototype, "over", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DroppableDirective.prototype, "out", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DroppableDirective.prototype, "remove", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DroppableDirective.prototype, "cancel", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", String), | ||
__metadata("design:paramtypes", [String]) | ||
], DroppableDirective.prototype, "dropZone", null); | ||
DroppableDirective = __decorate([ | ||
core.Directive({ selector: '[ngxDroppable]' }), | ||
__metadata("design:paramtypes", [core.ElementRef, core.Renderer2, DrakeStoreService]) | ||
], DroppableDirective); | ||
return DroppableDirective; | ||
@@ -551,6 +582,2 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Adds properties and events to draggable elements | ||
@@ -567,26 +594,18 @@ * | ||
/* | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
this.handles = []; | ||
this.drag = new core.EventEmitter(); | ||
this.dragDelay = 200; // milliseconds | ||
// milliseconds | ||
this.dragDelayed = true; | ||
} | ||
Object.defineProperty(DraggableDirective.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this.ngxDraggable || this._parentDropzones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -598,6 +617,3 @@ }, | ||
Object.defineProperty(DraggableDirective.prototype, "hasHandle", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return !!this.handles.length; | ||
@@ -609,6 +625,3 @@ }, | ||
Object.defineProperty(DraggableDirective.prototype, "element", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.el.nativeElement; | ||
@@ -620,14 +633,3 @@ }, | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onMove = | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
function (e) { | ||
DraggableDirective.prototype.onMove = function (e) { | ||
if (!this._moves || this.dragDelayed) { | ||
@@ -638,47 +640,20 @@ e.stopPropagation(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onDown = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.onDown = function () { | ||
var _this = this; | ||
if (this._moves) { | ||
this.touchTimeout = setTimeout((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.touchTimeout = setTimeout(function () { | ||
_this.dragDelayed = false; | ||
}), this.dragDelay); | ||
}, this.dragDelay); | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onUp = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.onUp = function () { | ||
if (this._moves) { | ||
clearTimeout((/** @type {?} */ (this.touchTimeout))); | ||
clearTimeout(this.touchTimeout); | ||
this.dragDelayed = true; | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngOnInit = function () { | ||
this.update(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.update = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.update = function () { | ||
this._parentDropzones = [this.droppableDirective.dropZone]; | ||
@@ -688,31 +663,9 @@ this.drakesService.registerDraggable(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngOnDestroy = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngOnDestroy = function () { | ||
this.drakesService.removeDraggable(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.updateElements = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
DraggableDirective.prototype.updateElements = function () { | ||
var nativeElement = this.el.nativeElement; | ||
/** @type {?} */ | ||
var handles = nativeElement.querySelectorAll('[ngxdraghandle]'); | ||
this.handles = Array.from(handles).filter((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
function (h) { return findFirstDraggableParent(h) === nativeElement; })); | ||
/** | ||
* @param {?} c | ||
* @return {?} | ||
*/ | ||
this.handles = Array.from(handles).filter(function (h) { return findFirstDraggableParent(h) === nativeElement; }); | ||
function findFirstDraggableParent(c) { | ||
@@ -727,15 +680,3 @@ while (c.parentNode) { | ||
}; | ||
/** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.canMove = /** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
function (source, handle, sibling) { | ||
DraggableDirective.prototype.canMove = function (source, handle, sibling) { | ||
if (typeof this._moves === 'boolean') | ||
@@ -747,27 +688,6 @@ return this._moves; | ||
}; | ||
/** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.moves = /** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
function (source, handle, sibling) { | ||
DraggableDirective.prototype.moves = function (source, handle, sibling) { | ||
if (!this.canMove(source, handle, sibling)) | ||
return false; | ||
return this.hasHandle ? this.handles.some((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
function (h) { return handelFor(handle, h); })) : true; | ||
/** | ||
* @param {?} c | ||
* @param {?} p | ||
* @return {?} | ||
*/ | ||
return this.hasHandle ? this.handles.some(function (h) { return handelFor(handle, h); }) : true; | ||
function handelFor(c, p) { | ||
@@ -781,15 +701,5 @@ if (c === p) | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngDoCheck = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngDoCheck = function () { | ||
this.updateElements(); | ||
}; | ||
DraggableDirective.decorators = [ | ||
{ type: core.Directive, args: [{ selector: '[ngxDraggable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
DraggableDirective.ctorParameters = function () { return [ | ||
@@ -800,12 +710,47 @@ { type: core.ElementRef }, | ||
]; }; | ||
DraggableDirective.propDecorators = { | ||
ngxDraggable: [{ type: core.Input }], | ||
model: [{ type: core.Input }], | ||
dropZones: [{ type: core.Input }], | ||
_moves: [{ type: core.Input, args: ['moves',] }], | ||
drag: [{ type: core.Output }], | ||
onMove: [{ type: core.HostListener, args: ['touchmove', ['$event'],] }], | ||
onDown: [{ type: core.HostListener, args: ['touchstart',] }], | ||
onUp: [{ type: core.HostListener, args: ['touchend',] }] | ||
}; | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Array) | ||
], DraggableDirective.prototype, "ngxDraggable", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], DraggableDirective.prototype, "dropZones", null); | ||
__decorate([ | ||
core.Input('moves'), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "_moves", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], DraggableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
core.HostListener('touchmove', ['$event']), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", [Event]), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onMove", null); | ||
__decorate([ | ||
core.HostListener('touchstart'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onDown", null); | ||
__decorate([ | ||
core.HostListener('touchend'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onUp", null); | ||
DraggableDirective = __decorate([ | ||
core.Directive({ selector: '[ngxDraggable]' }), | ||
__metadata("design:paramtypes", [core.ElementRef, | ||
DrakeStoreService, | ||
DroppableDirective]) | ||
], DraggableDirective); | ||
return DraggableDirective; | ||
@@ -815,6 +760,2 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Adds properties and events to drag handle elements | ||
@@ -827,17 +768,9 @@ * | ||
} | ||
DragHandleDirective.decorators = [ | ||
{ type: core.Directive, args: [{ selector: '[ngxDragHandle]' },] } | ||
]; | ||
DragHandleDirective = __decorate([ | ||
core.Directive({ selector: '[ngxDragHandle]' }) | ||
], DragHandleDirective); | ||
return DragHandleDirective; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var i$1 = 0; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId$1() { | ||
@@ -864,13 +797,6 @@ return i$1++; | ||
Object.defineProperty(ContainerComponent.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this._defaultZones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -884,10 +810,3 @@ }, | ||
// @Input() dragulaOptions: any; | ||
set: | ||
// @Input() classes: any = {}; | ||
// @Input() dragulaOptions: any; | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
function (template) { | ||
set: function (template) { | ||
this.template = template; | ||
@@ -899,7 +818,3 @@ }, | ||
Object.defineProperty(ContainerComponent.prototype, "templateChild", { | ||
set: /** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
function (template) { | ||
set: function (template) { | ||
this.template = template; | ||
@@ -910,76 +825,89 @@ }, | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
ContainerComponent.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ContainerComponent.prototype.ngOnInit = function () { | ||
this._defaultZones = [this.dropZone]; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ContainerComponent.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ContainerComponent.prototype.ngAfterViewInit = function () { | ||
var _this = this; | ||
this.droppable.drag.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.drag.emit(v); })); | ||
this.droppable.drop.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.drop.emit(v); })); | ||
this.droppable.over.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.over.emit(v); })); | ||
this.droppable.out.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.out.emit(v); })); | ||
this.droppable.remove.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.remove.emit(v); })); | ||
this.droppable.cancel.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.cancel.emit(v); })); | ||
this.droppable.drag.subscribe(function (v) { return _this.drag.emit(v); }); | ||
this.droppable.drop.subscribe(function (v) { return _this.drop.emit(v); }); | ||
this.droppable.over.subscribe(function (v) { return _this.over.emit(v); }); | ||
this.droppable.out.subscribe(function (v) { return _this.out.emit(v); }); | ||
this.droppable.remove.subscribe(function (v) { return _this.remove.emit(v); }); | ||
this.droppable.cancel.subscribe(function (v) { return _this.cancel.emit(v); }); | ||
}; | ||
ContainerComponent.decorators = [ | ||
{ type: core.Component, args: [{ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: core.ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}] } | ||
]; | ||
ContainerComponent.propDecorators = { | ||
model: [{ type: core.Input }], | ||
copy: [{ type: core.Input }], | ||
removeOnSpill: [{ type: core.Input }], | ||
droppableItemClass: [{ type: core.Input }], | ||
dropZone: [{ type: core.Input }], | ||
dropZones: [{ type: core.Input }], | ||
moves: [{ type: core.Input }], | ||
templateInput: [{ type: core.Input, args: ['template',] }], | ||
templateChild: [{ type: core.ContentChild, args: [core.TemplateRef, { static: true },] }], | ||
droppable: [{ type: core.ViewChild, args: [DroppableDirective, { static: true },] }], | ||
drop: [{ type: core.Output }], | ||
drag: [{ type: core.Output }], | ||
over: [{ type: core.Output }], | ||
out: [{ type: core.Output }], | ||
remove: [{ type: core.Output }], | ||
cancel: [{ type: core.Output }] | ||
}; | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "model", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "copy", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppableItemClass", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "dropZone", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ContainerComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Function) | ||
], ContainerComponent.prototype, "moves", void 0); | ||
__decorate([ | ||
core.Input('template'), | ||
__metadata("design:type", core.TemplateRef), | ||
__metadata("design:paramtypes", [core.TemplateRef]) | ||
], ContainerComponent.prototype, "templateInput", null); | ||
__decorate([ | ||
core.ContentChild(core.TemplateRef, { static: true }), | ||
__metadata("design:type", core.TemplateRef), | ||
__metadata("design:paramtypes", [core.TemplateRef]) | ||
], ContainerComponent.prototype, "templateChild", null); | ||
__decorate([ | ||
core.ViewChild(DroppableDirective, { static: true }), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppable", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], ContainerComponent.prototype, "drop", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], ContainerComponent.prototype, "drag", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], ContainerComponent.prototype, "over", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], ContainerComponent.prototype, "out", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], ContainerComponent.prototype, "remove", void 0); | ||
__decorate([ | ||
core.Output(), | ||
__metadata("design:type", core.EventEmitter) | ||
], ContainerComponent.prototype, "cancel", void 0); | ||
ContainerComponent = __decorate([ | ||
core.Component({ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: core.ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}) | ||
], ContainerComponent); | ||
return ContainerComponent; | ||
@@ -989,6 +917,2 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Component that allows nested ngxDroppable and ngxDraggables | ||
@@ -1008,13 +932,6 @@ * Should only be use inside a ngx-dnd-container | ||
Object.defineProperty(ItemComponent.prototype, "dropZone", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZone || this.container.dropZone; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZone = val; | ||
@@ -1026,13 +943,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this.container.dropZones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -1044,13 +954,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "droppableItemClass", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._droppableItemClass || this.container.droppableItemClass; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._droppableItemClass = val; | ||
@@ -1062,13 +965,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "removeOnSpill", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return typeof this._removeOnSpill === 'boolean' ? this._removeOnSpill : this.container.removeOnSpill; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._removeOnSpill = val; | ||
@@ -1080,13 +976,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "copy", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return typeof this._copy === 'boolean' ? this._copy : this.container.copy; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._copy = val; | ||
@@ -1098,6 +987,3 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "hasHandle", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.draggableDirective.hasHandle; | ||
@@ -1109,6 +995,3 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "moveDisabled", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return !this.draggableDirective.canMove(); | ||
@@ -1120,9 +1003,4 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "classString", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
get: function () { | ||
var itemClass = typeof this.droppableItemClass === 'function' ? this.droppableItemClass(this.model) : this.droppableItemClass; | ||
/** @type {?} */ | ||
var classes = ['ngx-dnd-item', itemClass || '']; | ||
@@ -1141,6 +1019,3 @@ if (this.moveDisabled) { | ||
Object.defineProperty(ItemComponent.prototype, "type", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
if (Array.isArray(this.model)) { | ||
@@ -1154,9 +1029,3 @@ return 'array'; | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
ItemComponent.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ItemComponent.prototype.ngOnInit = function () { | ||
this.data = { | ||
@@ -1169,11 +1038,2 @@ model: this.model, | ||
}; | ||
ItemComponent.decorators = [ | ||
{ type: core.Component, args: [{ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: core.ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}] } | ||
]; | ||
/** @nocollapse */ | ||
ItemComponent.ctorParameters = function () { return [ | ||
@@ -1183,21 +1043,49 @@ { type: ContainerComponent }, | ||
]; }; | ||
ItemComponent.propDecorators = { | ||
model: [{ type: core.Input }], | ||
dropZone: [{ type: core.Input }], | ||
dropZones: [{ type: core.Input }], | ||
droppableItemClass: [{ type: core.Input }], | ||
removeOnSpill: [{ type: core.Input }], | ||
copy: [{ type: core.Input }], | ||
classString: [{ type: core.HostBinding, args: ['class',] }] | ||
}; | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object) | ||
], ItemComponent.prototype, "model", void 0); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZone", null); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "droppableItemClass", null); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "removeOnSpill", null); | ||
__decorate([ | ||
core.Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "copy", null); | ||
__decorate([ | ||
core.HostBinding('class'), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", []) | ||
], ItemComponent.prototype, "classString", null); | ||
ItemComponent = __decorate([ | ||
core.Component({ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: core.ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}), | ||
__metadata("design:paramtypes", [ContainerComponent, DraggableDirective]) | ||
], ItemComponent); | ||
return ItemComponent; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var components = [ContainerComponent, ItemComponent]; | ||
/** @type {?} */ | ||
var directives = [DraggableDirective, DroppableDirective, DragHandleDirective]; | ||
@@ -1207,21 +1095,17 @@ var NgxDnDModule = /** @class */ (function () { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxDnDModule.forRoot = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
NgxDnDModule_1 = NgxDnDModule; | ||
NgxDnDModule.forRoot = function () { | ||
return { | ||
ngModule: NgxDnDModule, | ||
ngModule: NgxDnDModule_1, | ||
providers: [DrakeStoreService] | ||
}; | ||
}; | ||
NgxDnDModule.decorators = [ | ||
{ type: core.NgModule, args: [{ | ||
imports: [common.CommonModule], | ||
declarations: __spread(components, directives), | ||
exports: __spread(components, directives) | ||
},] } | ||
]; | ||
var NgxDnDModule_1; | ||
NgxDnDModule = NgxDnDModule_1 = __decorate([ | ||
core.NgModule({ | ||
imports: [common.CommonModule], | ||
declarations: __spread(components, directives), | ||
exports: __spread(components, directives) | ||
}) | ||
], NgxDnDModule); | ||
return NgxDnDModule; | ||
@@ -1240,3 +1124,3 @@ }()); | ||
})); | ||
}))); | ||
//# sourceMappingURL=swimlane-ngx-dnd.umd.js.map |
@@ -1,2 +0,16 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@swimlane/dragula")):"function"==typeof define&&define.amd?define("@swimlane/ngx-dnd",["exports","@angular/core","@angular/common","@swimlane/dragula"],t):t(((e=e||self).swimlane=e.swimlane||{},e.swimlane["ngx-dnd"]={}),e.ng.core,e.ng.common,e.dragulaNamespace)}(this,function(e,t,n,o){"use strict";function r(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var o,r,i=n.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(o=i.next()).done;)a.push(o.value)}catch(p){r={error:p}}finally{try{o&&!o.done&&(n=i["return"])&&n.call(i)}finally{if(r)throw r.error}}return a}function i(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(r(arguments[t]));return e}var a=o,p=function(){function e(){this.droppableMap=new WeakMap,this.draggableMap=new WeakMap,this.dragulaOptions=this.createDrakeOptions(),this.drake=a([],this.dragulaOptions),this.registerEvents()}return e.prototype.register=function(e){this.droppableMap.set(e.container,e),this.drake.containers.push(e.container)},e.prototype.remove=function(e){this.droppableMap["delete"](e.container);var t=this.drake.containers.indexOf(e.container);t>-1&&this.drake.containers.splice(t,1)},e.prototype.registerDraggable=function(e){this.draggableMap.set(e.element,e)},e.prototype.removeDraggable=function(e){this.draggableMap["delete"](e.element)},e.prototype.createDrakeOptions=function(){var e=this;return{accepts:function(t,n){if(t.contains(n))return!1;var o=e.draggableMap.get(t),r=e.droppableMap.get(n);return!o||!r||o.dropZones.includes(r.dropZone)},copy:function(t,n){var o=e.droppableMap.get(n);return!!o&&o.copy},moves:function(t,n,o,r){var i=e.draggableMap.get(t);return!i||i.moves(n,o,r)},revertOnSpill:!0,direction:function(t,n,o){return e.droppableMap.get(n).direction||"vertical"}}},e.prototype.registerEvents=function(){var e,t,n=this;this.drake.on("drag",function(o,r){if(t=undefined,e=o,o&&r){if(n.draggableMap.has(o)){var i=n.draggableMap.get(o);t=i.model,i.drag.emit({type:"drag",el:o,source:r,value:t})}if(n.droppableMap.has(r)){var a=n.droppableMap.get(r);n.dragulaOptions.removeOnSpill=a.removeOnSpill,a.drag.emit({type:"drag",el:o,source:r,sourceComponent:a,value:t})}}}),this.drake.on("drop",function(o,r,i){var a=n.droppableMap.get(r);if(a){var p=t,s=Array.prototype.indexOf.call(r.children,o);if(s<0)n.drake.cancel(!0);else{var l=n.droppableMap.get(i);if(l){var d=l.model,c=a.model,u=!(!d||!t),g=u?d.indexOf(t):-1;if(u&&g<0)return void n.drake.cancel(!0);if(c){var m=!d||e!==o;g>-1&&d&&r===i?d.splice(s,0,d.splice(g,1)[0]):(o.parentNode===r&&r.removeChild(o),m?p=JSON.parse(JSON.stringify(p)):(o.parentNode!==i&&n.drake.cancel(!0),d.splice(g,1)),c.splice(s,0,p))}}a.drop.emit({type:"drop",el:o,source:i,value:p,dropIndex:s})}}}),this.drake.on("remove",function(e,o,r){if(n.droppableMap.has(r)){var i=n.droppableMap.get(r),a=i.model,p=t&&a?a.indexOf(t):-1;p>-1&&(e.parentNode!==r&&r.appendChild(e),a.splice(p,1)),i.remove.emit({type:"remove",el:e,container:o,source:r,value:t})}}),this.drake.on("cancel",function(e,o,r){n.droppableMap.has(o)&&n.droppableMap.get(o).cancel.emit({type:"cancel",el:e,container:o,source:r,value:t})}),this.drake.on("over",function(e,o,r){n.droppableMap.has(o)&&n.droppableMap.get(o).over.emit({type:"over",el:e,container:o,source:r,value:t})}),this.drake.on("out",function(e,o,r){n.droppableMap.has(o)&&n.droppableMap.get(o).out.emit({type:"out",el:e,container:o,source:r,value:t})})},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e},token:e,providedIn:"root"}),e}(),s=1e4;var l=function(){function e(e,n,o){this.el=e,this.renderer=n,this.drakesService=o,this.copy=!1,this.removeOnSpill=!1,this.direction="vertical",this.drop=new t.EventEmitter,this.drag=new t.EventEmitter,this.over=new t.EventEmitter,this.out=new t.EventEmitter,this.remove=new t.EventEmitter,this.cancel=new t.EventEmitter}return Object.defineProperty(e.prototype,"container",{get:function(){return this.el.nativeElement},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dropZone",{get:function(){return this._dropZone||this.ngxDroppable||this.defaultZone},set:function(e){this._dropZone=e},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.defaultZone="@@DefaultDropZone-"+s+++"@@",this.drakesService.register(this)},e.prototype.ngAfterViewInit=function(){var e=this;this.over.subscribe(function(){e.renderer.addClass(e.container,"gu-over")}),this.out.subscribe(function(){e.renderer.removeClass(e.container,"gu-over")})},e.prototype.ngOnDestroy=function(){this.drakesService.remove(this)},e.decorators=[{type:t.Directive,args:[{selector:"[ngxDroppable]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2},{type:p}]},e.propDecorators={model:[{type:t.Input}],copy:[{type:t.Input}],removeOnSpill:[{type:t.Input}],ngxDroppable:[{type:t.Input}],direction:[{type:t.Input}],drop:[{type:t.Output}],drag:[{type:t.Output}],over:[{type:t.Output}],out:[{type:t.Output}],remove:[{type:t.Output}],cancel:[{type:t.Output}],dropZone:[{type:t.Input}]},e}(),d=function(){function e(e,n,o){this.el=e,this.drakesService=n,this.droppableDirective=o,this._moves=!0,this.handles=[],this.drag=new t.EventEmitter,this.dragDelay=200,this.dragDelayed=!0}return Object.defineProperty(e.prototype,"dropZones",{get:function(){return this._dropZones||this.ngxDraggable||this._parentDropzones},set:function(e){this._dropZones=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasHandle",{get:function(){return!!this.handles.length},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"element",{get:function(){return this.el.nativeElement},enumerable:!0,configurable:!0}),e.prototype.onMove=function(e){this._moves&&!this.dragDelayed||(e.stopPropagation(),clearTimeout(this.touchTimeout))},e.prototype.onDown=function(){var e=this;this._moves&&(this.touchTimeout=setTimeout(function(){e.dragDelayed=!1},this.dragDelay))},e.prototype.onUp=function(){this._moves&&(clearTimeout(this.touchTimeout),this.dragDelayed=!0)},e.prototype.ngOnInit=function(){this.update()},e.prototype.update=function(){this._parentDropzones=[this.droppableDirective.dropZone],this.drakesService.registerDraggable(this),this.updateElements()},e.prototype.ngOnDestroy=function(){this.drakesService.removeDraggable(this)},e.prototype.updateElements=function(){var e=this.el.nativeElement,t=e.querySelectorAll("[ngxdraghandle]");this.handles=Array.from(t).filter(function(t){return function(e){for(;e.parentNode;)if((e=e.parentNode).hasAttribute&&e.hasAttribute("ngxdraggable"))return e}(t)===e})},e.prototype.canMove=function(e,t,n){return"boolean"==typeof this._moves?this._moves:"function"!=typeof this._moves||this._moves(this.model,e,t,n)},e.prototype.moves=function(e,t,n){return!!this.canMove(e,t,n)&&(!this.hasHandle||this.handles.some(function(e){return function(e,t){if(e===t)return!0;for(;(e=e.parentNode)&&e!==t;);return!!e}(t,e)}))},e.prototype.ngDoCheck=function(){this.updateElements()},e.decorators=[{type:t.Directive,args:[{selector:"[ngxDraggable]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:p},{type:l}]},e.propDecorators={ngxDraggable:[{type:t.Input}],model:[{type:t.Input}],dropZones:[{type:t.Input}],_moves:[{type:t.Input,args:["moves"]}],drag:[{type:t.Output}],onMove:[{type:t.HostListener,args:["touchmove",["$event"]]}],onDown:[{type:t.HostListener,args:["touchstart"]}],onUp:[{type:t.HostListener,args:["touchend"]}]},e}(),c=function(){function e(){}return e.decorators=[{type:t.Directive,args:[{selector:"[ngxDragHandle]"}]}],e}(),u=0;var g=function(){function e(){this.copy=!1,this.removeOnSpill=!1,this.dropZone="@@DefaultDropZone-"+u+++"@@",this.drop=new t.EventEmitter,this.drag=new t.EventEmitter,this.over=new t.EventEmitter,this.out=new t.EventEmitter,this.remove=new t.EventEmitter,this.cancel=new t.EventEmitter}return Object.defineProperty(e.prototype,"dropZones",{get:function(){return this._dropZones||this._defaultZones},set:function(e){this._dropZones=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"templateInput",{set:function(e){this.template=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"templateChild",{set:function(e){this.template=e},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this._defaultZones=[this.dropZone]},e.prototype.ngAfterViewInit=function(){var e=this;this.droppable.drag.subscribe(function(t){return e.drag.emit(t)}),this.droppable.drop.subscribe(function(t){return e.drop.emit(t)}),this.droppable.over.subscribe(function(t){return e.over.emit(t)}),this.droppable.out.subscribe(function(t){return e.out.emit(t)}),this.droppable.remove.subscribe(function(t){return e.remove.emit(t)}),this.droppable.cancel.subscribe(function(t){return e.cancel.emit(t)})},e.decorators=[{type:t.Component,args:[{selector:"ngx-dnd-container",template:'<div\n ngxDroppable\n [dropZone]="dropZone"\n [model]="model"\n [copy]="copy"\n [ngClass]="{ \'gu-empty\': !model?.length }"\n [removeOnSpill]="removeOnSpill"\n class=\'ngx-dnd-container\'>\n <ng-container *ngIf="model">\n <ng-container *ngFor="let item of model">\n <ngx-dnd-item\n ngxDraggable\n [model]="item"\n [dropZone]="dropZone"\n [dropZones]="dropZones"\n [copy]="copy"\n [moves]="moves"\n [removeOnSpill]="removeOnSpill"\n [droppableItemClass]="droppableItemClass">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf="!model"></ng-content>\n</div>\n',encapsulation:t.ViewEncapsulation.None,styles:['.ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:" ";display:block;height:0;clear:both}']}]}],e.propDecorators={model:[{type:t.Input}],copy:[{type:t.Input}],removeOnSpill:[{type:t.Input}],droppableItemClass:[{type:t.Input}],dropZone:[{type:t.Input}],dropZones:[{type:t.Input}],moves:[{type:t.Input}],templateInput:[{type:t.Input,args:["template"]}],templateChild:[{type:t.ContentChild,args:[t.TemplateRef,{"static":!0}]}],droppable:[{type:t.ViewChild,args:[l,{"static":!0}]}],drop:[{type:t.Output}],drag:[{type:t.Output}],over:[{type:t.Output}],out:[{type:t.Output}],remove:[{type:t.Output}],cancel:[{type:t.Output}]},e}(),m=function(){function e(e,t){this.container=e,this.draggableDirective=t,this._copy=!1,this._removeOnSpill=!1}return Object.defineProperty(e.prototype,"dropZone",{get:function(){return this._dropZone||this.container.dropZone},set:function(e){this._dropZone=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dropZones",{get:function(){return this._dropZones||this.container.dropZones},set:function(e){this._dropZones=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"droppableItemClass",{get:function(){return this._droppableItemClass||this.container.droppableItemClass},set:function(e){this._droppableItemClass=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"removeOnSpill",{get:function(){return"boolean"==typeof this._removeOnSpill?this._removeOnSpill:this.container.removeOnSpill},set:function(e){this._removeOnSpill=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"copy",{get:function(){return"boolean"==typeof this._copy?this._copy:this.container.copy},set:function(e){this._copy=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasHandle",{get:function(){return this.draggableDirective.hasHandle},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"moveDisabled",{get:function(){return!this.draggableDirective.canMove()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"classString",{get:function(){var e=["ngx-dnd-item",("function"==typeof this.droppableItemClass?this.droppableItemClass(this.model):this.droppableItemClass)||""];return this.moveDisabled&&e.push("move-disabled"),this.hasHandle&&e.push("has-handle"),e.join(" ")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"type",{get:function(){return Array.isArray(this.model)?"array":typeof this.model},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.data={model:this.model,type:this.type,dropZone:this.dropZone,template:this.container.template}},e.decorators=[{type:t.Component,args:[{selector:"ngx-dnd-item",template:'<ng-container [ngSwitch]="type">\n\n <ng-container *ngSwitchCase="\'array\'">\n <ngx-dnd-container\n [model]="model"\n [template]="container.template"\n [dropZone]="dropZone"\n [dropZones]="dropZones"\n [removeOnSpill]="removeOnSpill"\n [droppableItemClass]="droppableItemClass"\n [copy]="copy">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase="\'object\'">\n <ng-template\n *ngIf="container.template"\n [ngTemplateOutlet]="container.template"\n [ngTemplateOutletContext]="data">\n </ng-template>\n <ng-container *ngIf="!container.template">\n <div\n class="ngx-dnd-content">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf="model.children"\n [model]="model.children"\n [template]="container.template"\n [dropZone]="dropZone"\n [dropZones]="dropZones"\n [removeOnSpill]="removeOnSpill"\n [droppableItemClass]="droppableItemClass"\n [copy]="copy">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase="\'undefined\'">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf="container.template"\n [ngTemplateOutlet]="container.template"\n [ngTemplateOutletContext]="data">\n </ng-template>\n <div\n *ngIf="!container.template"\n class="ngx-dnd-content">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n',encapsulation:t.ViewEncapsulation.None,styles:[".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"]}]}],e.ctorParameters=function(){return[{type:g},{type:d}]},e.propDecorators={model:[{type:t.Input}],dropZone:[{type:t.Input}],dropZones:[{type:t.Input}],droppableItemClass:[{type:t.Input}],removeOnSpill:[{type:t.Input}],copy:[{type:t.Input}],classString:[{type:t.HostBinding,args:["class"]}]},e}(),h=[g,m],f=[d,l,c],y=function(){function e(){}return e.forRoot=function(){return{ngModule:e,providers:[p]}},e.decorators=[{type:t.NgModule,args:[{imports:[n.CommonModule],declarations:i(h,f),exports:i(h,f)}]}],e}();e.ContainerComponent=g,e.DragHandleDirective=c,e.DraggableDirective=d,e.DrakeStoreService=p,e.DroppableDirective=l,e.ItemComponent=m,e.NgxDnDModule=y,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@swimlane/dragula")):"function"==typeof define&&define.amd?define("@swimlane/ngx-dnd",["exports","@angular/core","@angular/common","@swimlane/dragula"],t):t(((e=e||self).swimlane=e.swimlane||{},e.swimlane["ngx-dnd"]={}),e.ng.core,e.ng.common,e.dragulaNamespace)}(this,(function(e,t,n,o){"use strict"; | ||
/*! ***************************************************************************** | ||
Copyright (c) Microsoft Corporation. All rights reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); you may not use | ||
this file except in compliance with the License. You may obtain a copy of the | ||
License at http://www.apache.org/licenses/LICENSE-2.0 | ||
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED | ||
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, | ||
MERCHANTABLITY OR NON-INFRINGEMENT. | ||
See the Apache Version 2.0 License for specific language governing permissions | ||
and limitations under the License. | ||
***************************************************************************** */function r(e,t,n,o){var r,i=arguments.length,p=i<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)p=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(p=(i<3?r(p):i>3?r(t,n,p):r(t,n))||p);return i>3&&p&&Object.defineProperty(t,n,p),p}function i(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function p(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var o,r,i=n.call(e),p=[];try{for(;(void 0===t||t-- >0)&&!(o=i.next()).done;)p.push(o.value)}catch(e){r={error:e}}finally{try{o&&!o.done&&(n=i.return)&&n.call(i)}finally{if(r)throw r.error}}return p}function a(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(p(arguments[t]));return e}var s=o,d=function(){function e(){this.droppableMap=new WeakMap,this.draggableMap=new WeakMap,this.dragulaOptions=this.createDrakeOptions(),this.drake=s([],this.dragulaOptions),this.registerEvents()}return e.prototype.register=function(e){this.droppableMap.set(e.container,e),this.drake.containers.push(e.container)},e.prototype.remove=function(e){this.droppableMap.delete(e.container);var t=this.drake.containers.indexOf(e.container);t>-1&&this.drake.containers.splice(t,1)},e.prototype.registerDraggable=function(e){this.draggableMap.set(e.element,e)},e.prototype.removeDraggable=function(e){this.draggableMap.delete(e.element)},e.prototype.createDrakeOptions=function(){var e=this;return{accepts:function(t,n){if(t.contains(n))return!1;var o=e.draggableMap.get(t),r=e.droppableMap.get(n);return!o||!r||o.dropZones.includes(r.dropZone)},copy:function(t,n){var o=e.droppableMap.get(n);return!!o&&o.copy},moves:function(t,n,o,r){var i=e.draggableMap.get(t);return!i||i.moves(n,o,r)},revertOnSpill:!0,direction:function(t,n,o){return e.droppableMap.get(n).direction||"vertical"}}},e.prototype.registerEvents=function(){var e,t,n=this;this.drake.on("drag",(function(o,r){if(t=void 0,e=o,o&&r){if(n.draggableMap.has(o)){var i=n.draggableMap.get(o);t=i.model,i.drag.emit({type:"drag",el:o,source:r,value:t})}if(n.droppableMap.has(r)){var p=n.droppableMap.get(r);n.dragulaOptions.removeOnSpill=p.removeOnSpill,p.drag.emit({type:"drag",el:o,source:r,sourceComponent:p,value:t})}}})),this.drake.on("drop",(function(o,r,i){var p=n.droppableMap.get(r);if(p){var a=t,s=Array.prototype.indexOf.call(r.children,o);if(s<0)n.drake.cancel(!0);else{var d=n.droppableMap.get(i);if(d){var l=d.model,c=p.model,u=!(!l||!t),g=u?l.indexOf(t):-1;if(u&&g<0)return void n.drake.cancel(!0);if(c){var m=!l||e!==o;g>-1&&l&&r===i?l.splice(s,0,l.splice(g,1)[0]):(o.parentNode===r&&r.removeChild(o),m?a=JSON.parse(JSON.stringify(a)):(o.parentNode!==i&&n.drake.cancel(!0),l.splice(g,1)),c.splice(s,0,a))}}p.drop.emit({type:"drop",el:o,source:i,value:a,dropIndex:s})}}})),this.drake.on("remove",(function(e,o,r){if(n.droppableMap.has(r)){var i=n.droppableMap.get(r),p=i.model,a=t&&p?p.indexOf(t):-1;a>-1&&(e.parentNode!==r&&r.appendChild(e),p.splice(a,1)),i.remove.emit({type:"remove",el:e,container:o,source:r,value:t})}})),this.drake.on("cancel",(function(e,o,r){n.droppableMap.has(o)&&n.droppableMap.get(o).cancel.emit({type:"cancel",el:e,container:o,source:r,value:t})})),this.drake.on("over",(function(e,o,r){n.droppableMap.has(o)&&n.droppableMap.get(o).over.emit({type:"over",el:e,container:o,source:r,value:t})})),this.drake.on("out",(function(e,o,r){n.droppableMap.has(o)&&n.droppableMap.get(o).out.emit({type:"out",el:e,container:o,source:r,value:t})}))},e.ɵprov=t["ɵɵdefineInjectable"]({factory:function(){return new e},token:e,providedIn:"root"}),e=r([t.Injectable({providedIn:"root"}),i("design:paramtypes",[])],e)}(),l=1e4;var c=function(){function e(e,n,o){this.el=e,this.renderer=n,this.drakesService=o,this.copy=!1,this.removeOnSpill=!1,this.direction="vertical",this.drop=new t.EventEmitter,this.drag=new t.EventEmitter,this.over=new t.EventEmitter,this.out=new t.EventEmitter,this.remove=new t.EventEmitter,this.cancel=new t.EventEmitter}return Object.defineProperty(e.prototype,"container",{get:function(){return this.el.nativeElement},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dropZone",{get:function(){return this._dropZone||this.ngxDroppable||this.defaultZone},set:function(e){this._dropZone=e},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.defaultZone="@@DefaultDropZone-"+l+++"@@",this.drakesService.register(this)},e.prototype.ngAfterViewInit=function(){var e=this;this.over.subscribe((function(){e.renderer.addClass(e.container,"gu-over")})),this.out.subscribe((function(){e.renderer.removeClass(e.container,"gu-over")}))},e.prototype.ngOnDestroy=function(){this.drakesService.remove(this)},e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2},{type:d}]},r([t.Input(),i("design:type",Object)],e.prototype,"model",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"copy",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"removeOnSpill",void 0),r([t.Input(),i("design:type",String)],e.prototype,"ngxDroppable",void 0),r([t.Input(),i("design:type",String)],e.prototype,"direction",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"drop",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"drag",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"over",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"out",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"remove",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"cancel",void 0),r([t.Input(),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"dropZone",null),e=r([t.Directive({selector:"[ngxDroppable]"}),i("design:paramtypes",[t.ElementRef,t.Renderer2,d])],e)}(),u=function(){function e(e,n,o){this.el=e,this.drakesService=n,this.droppableDirective=o,this._moves=!0,this.handles=[],this.drag=new t.EventEmitter,this.dragDelay=200,this.dragDelayed=!0}return Object.defineProperty(e.prototype,"dropZones",{get:function(){return this._dropZones||this.ngxDraggable||this._parentDropzones},set:function(e){this._dropZones=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasHandle",{get:function(){return!!this.handles.length},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"element",{get:function(){return this.el.nativeElement},enumerable:!0,configurable:!0}),e.prototype.onMove=function(e){this._moves&&!this.dragDelayed||(e.stopPropagation(),clearTimeout(this.touchTimeout))},e.prototype.onDown=function(){var e=this;this._moves&&(this.touchTimeout=setTimeout((function(){e.dragDelayed=!1}),this.dragDelay))},e.prototype.onUp=function(){this._moves&&(clearTimeout(this.touchTimeout),this.dragDelayed=!0)},e.prototype.ngOnInit=function(){this.update()},e.prototype.update=function(){this._parentDropzones=[this.droppableDirective.dropZone],this.drakesService.registerDraggable(this),this.updateElements()},e.prototype.ngOnDestroy=function(){this.drakesService.removeDraggable(this)},e.prototype.updateElements=function(){var e=this.el.nativeElement,t=e.querySelectorAll("[ngxdraghandle]");this.handles=Array.from(t).filter((function(t){return function(e){for(;e.parentNode;)if((e=e.parentNode).hasAttribute&&e.hasAttribute("ngxdraggable"))return e}(t)===e}))},e.prototype.canMove=function(e,t,n){return"boolean"==typeof this._moves?this._moves:"function"!=typeof this._moves||this._moves(this.model,e,t,n)},e.prototype.moves=function(e,t,n){return!!this.canMove(e,t,n)&&(!this.hasHandle||this.handles.some((function(e){return function(e,t){if(e===t)return!0;for(;(e=e.parentNode)&&e!==t;);return!!e}(t,e)})))},e.prototype.ngDoCheck=function(){this.updateElements()},e.ctorParameters=function(){return[{type:t.ElementRef},{type:d},{type:c}]},r([t.Input(),i("design:type",Array)],e.prototype,"ngxDraggable",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"model",void 0),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"dropZones",null),r([t.Input("moves"),i("design:type",Object)],e.prototype,"_moves",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"drag",void 0),r([t.HostListener("touchmove",["$event"]),i("design:type",Function),i("design:paramtypes",[Event]),i("design:returntype",void 0)],e.prototype,"onMove",null),r([t.HostListener("touchstart"),i("design:type",Function),i("design:paramtypes",[]),i("design:returntype",void 0)],e.prototype,"onDown",null),r([t.HostListener("touchend"),i("design:type",Function),i("design:paramtypes",[]),i("design:returntype",void 0)],e.prototype,"onUp",null),e=r([t.Directive({selector:"[ngxDraggable]"}),i("design:paramtypes",[t.ElementRef,d,c])],e)}(),g=function(){function e(){}return e=r([t.Directive({selector:"[ngxDragHandle]"})],e)}(),m=0;var y=function(){function e(){this.copy=!1,this.removeOnSpill=!1,this.dropZone="@@DefaultDropZone-"+m+++"@@",this.drop=new t.EventEmitter,this.drag=new t.EventEmitter,this.over=new t.EventEmitter,this.out=new t.EventEmitter,this.remove=new t.EventEmitter,this.cancel=new t.EventEmitter}return Object.defineProperty(e.prototype,"dropZones",{get:function(){return this._dropZones||this._defaultZones},set:function(e){this._dropZones=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"templateInput",{set:function(e){this.template=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"templateChild",{set:function(e){this.template=e},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this._defaultZones=[this.dropZone]},e.prototype.ngAfterViewInit=function(){var e=this;this.droppable.drag.subscribe((function(t){return e.drag.emit(t)})),this.droppable.drop.subscribe((function(t){return e.drop.emit(t)})),this.droppable.over.subscribe((function(t){return e.over.emit(t)})),this.droppable.out.subscribe((function(t){return e.out.emit(t)})),this.droppable.remove.subscribe((function(t){return e.remove.emit(t)})),this.droppable.cancel.subscribe((function(t){return e.cancel.emit(t)}))},r([t.Input(),i("design:type",Object)],e.prototype,"model",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"copy",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"removeOnSpill",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"droppableItemClass",void 0),r([t.Input(),i("design:type",Object)],e.prototype,"dropZone",void 0),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"dropZones",null),r([t.Input(),i("design:type",Function)],e.prototype,"moves",void 0),r([t.Input("template"),i("design:type",t.TemplateRef),i("design:paramtypes",[t.TemplateRef])],e.prototype,"templateInput",null),r([t.ContentChild(t.TemplateRef,{static:!0}),i("design:type",t.TemplateRef),i("design:paramtypes",[t.TemplateRef])],e.prototype,"templateChild",null),r([t.ViewChild(c,{static:!0}),i("design:type",Object)],e.prototype,"droppable",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"drop",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"drag",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"over",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"out",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"remove",void 0),r([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"cancel",void 0),e=r([t.Component({selector:"ngx-dnd-container",template:'<div\n ngxDroppable\n [dropZone]="dropZone"\n [model]="model"\n [copy]="copy"\n [ngClass]="{ \'gu-empty\': !model?.length }"\n [removeOnSpill]="removeOnSpill"\n class=\'ngx-dnd-container\'>\n <ng-container *ngIf="model">\n <ng-container *ngFor="let item of model">\n <ngx-dnd-item\n ngxDraggable\n [model]="item"\n [dropZone]="dropZone"\n [dropZones]="dropZones"\n [copy]="copy"\n [moves]="moves"\n [removeOnSpill]="removeOnSpill"\n [droppableItemClass]="droppableItemClass">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf="!model"></ng-content>\n</div>\n',encapsulation:t.ViewEncapsulation.None,styles:['.ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:" ";display:block;height:0;clear:both}']})],e)}(),h=function(){function e(e,t){this.container=e,this.draggableDirective=t,this._copy=!1,this._removeOnSpill=!1}return Object.defineProperty(e.prototype,"dropZone",{get:function(){return this._dropZone||this.container.dropZone},set:function(e){this._dropZone=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dropZones",{get:function(){return this._dropZones||this.container.dropZones},set:function(e){this._dropZones=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"droppableItemClass",{get:function(){return this._droppableItemClass||this.container.droppableItemClass},set:function(e){this._droppableItemClass=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"removeOnSpill",{get:function(){return"boolean"==typeof this._removeOnSpill?this._removeOnSpill:this.container.removeOnSpill},set:function(e){this._removeOnSpill=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"copy",{get:function(){return"boolean"==typeof this._copy?this._copy:this.container.copy},set:function(e){this._copy=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"hasHandle",{get:function(){return this.draggableDirective.hasHandle},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"moveDisabled",{get:function(){return!this.draggableDirective.canMove()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"classString",{get:function(){var e=["ngx-dnd-item",("function"==typeof this.droppableItemClass?this.droppableItemClass(this.model):this.droppableItemClass)||""];return this.moveDisabled&&e.push("move-disabled"),this.hasHandle&&e.push("has-handle"),e.join(" ")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"type",{get:function(){return Array.isArray(this.model)?"array":typeof this.model},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.data={model:this.model,type:this.type,dropZone:this.dropZone,template:this.container.template}},e.ctorParameters=function(){return[{type:y},{type:u}]},r([t.Input(),i("design:type",Object)],e.prototype,"model",void 0),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"dropZone",null),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"dropZones",null),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"droppableItemClass",null),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"removeOnSpill",null),r([t.Input(),i("design:type",Object),i("design:paramtypes",[Object])],e.prototype,"copy",null),r([t.HostBinding("class"),i("design:type",Object),i("design:paramtypes",[])],e.prototype,"classString",null),e=r([t.Component({selector:"ngx-dnd-item",template:'<ng-container [ngSwitch]="type">\n\n <ng-container *ngSwitchCase="\'array\'">\n <ngx-dnd-container\n [model]="model"\n [template]="container.template"\n [dropZone]="dropZone"\n [dropZones]="dropZones"\n [removeOnSpill]="removeOnSpill"\n [droppableItemClass]="droppableItemClass"\n [copy]="copy">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase="\'object\'">\n <ng-template\n *ngIf="container.template"\n [ngTemplateOutlet]="container.template"\n [ngTemplateOutletContext]="data">\n </ng-template>\n <ng-container *ngIf="!container.template">\n <div\n class="ngx-dnd-content">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf="model.children"\n [model]="model.children"\n [template]="container.template"\n [dropZone]="dropZone"\n [dropZones]="dropZones"\n [removeOnSpill]="removeOnSpill"\n [droppableItemClass]="droppableItemClass"\n [copy]="copy">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase="\'undefined\'">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf="container.template"\n [ngTemplateOutlet]="container.template"\n [ngTemplateOutletContext]="data">\n </ng-template>\n <div\n *ngIf="!container.template"\n class="ngx-dnd-content">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n',encapsulation:t.ViewEncapsulation.None,styles:[".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"]}),i("design:paramtypes",[y,u])],e)}(),f=[y,h],v=[u,c,g],b=function(){function e(){}var o;return o=e,e.forRoot=function(){return{ngModule:o,providers:[d]}},e=o=r([t.NgModule({imports:[n.CommonModule],declarations:a(f,v),exports:a(f,v)})],e)}();e.ContainerComponent=y,e.DragHandleDirective=g,e.DraggableDirective=u,e.DrakeStoreService=d,e.DroppableDirective=c,e.ItemComponent=h,e.NgxDnDModule=b,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=swimlane-ngx-dnd.umd.min.js.map |
# CHANGELOG | ||
## HEAD (Unreleased) | ||
_(none)_ | ||
-------------------- | ||
--- | ||
## 8.1.1 (2020-04-14) | ||
- Update deps | ||
## 8.1.0 (2019-09-09) | ||
* Compat with Angular Ivy | ||
- Compat with Angular Ivy | ||
## 8.0.0 (2019-06-11) | ||
* Angular version 8 | ||
- Angular version 8 | ||
## 7.0.0 (2019-04-18) | ||
* Breaking: use `NgxDnDModule.forRoot()` in your module imports. | ||
* Add `direction` as an option on `ngx-dnd-container`. | ||
* Bump `@swimlnae/dragula` to support `direction`. | ||
* Make `@swimlane/dragula` and `@type/dragula` a dep of `@swimlane/ngx-dnd` | ||
- Breaking: use `NgxDnDModule.forRoot()` in your module imports. | ||
- Add `direction` as an option on `ngx-dnd-container`. | ||
- Bump `@swimlnae/dragula` to support `direction`. | ||
- Make `@swimlane/dragula` and `@type/dragula` a dep of `@swimlane/ngx-dnd` | ||
## 6.0.0 (2018-10-29) | ||
* Angular version 7 | ||
- Angular version 7 | ||
## 5.1.0 (2018-09-10) | ||
* Provide service in root | ||
- Provide service in root | ||
## 5.0.6 (2018-06-20) | ||
_(none)_ | ||
## 5.0.5 (2018-06-20) | ||
* Add support files to published resources (again, really) | ||
- Add support files to published resources (again, really) | ||
## 5.0.5 (2018-06-20) | ||
* Add support files to published resources (again) | ||
- Add support files to published resources (again) | ||
## 5.0.4 (2018-06-20) | ||
* Add support files to published resources | ||
- Add support files to published resources | ||
## 5.0.3 (2018-06-20) | ||
* Publish for metadata | ||
- Publish for metadata | ||
## 5.0.2 (2018-06-20) | ||
* Release latest version | ||
- Release latest version | ||
## 5.0.1 (2018-06-19) | ||
* Fix: re-added CSS fields to release | ||
* Chore: now including SCSS files in release | ||
- Fix: re-added CSS fields to release | ||
- Chore: now including SCSS files in release | ||
## 5.0.0 (2018-06-18) | ||
* Chore: Port to Angular CLI 6 | ||
- Chore: Port to Angular CLI 6 | ||
## 4.0.2 (2018-05-23) | ||
@@ -61,7 +79,7 @@ | ||
* Add Angular v6.0 support | ||
- Add Angular v6.0 support | ||
## 3.2.0 (2018-04-03) | ||
* Fixed AOT issue | ||
- Fixed AOT issue | ||
@@ -74,9 +92,9 @@ ## 3.1.2 (2018-01-19) | ||
* Fix dragging between containers | ||
* Updated README to state importing styles | ||
* Bumped ngx-ui for ng 5.0 support in the demo | ||
- Fix dragging between containers | ||
- Updated README to state importing styles | ||
- Bumped ngx-ui for ng 5.0 support in the demo | ||
## 3.1.0 (2017-11-2) | ||
* Support for Angular 5 | ||
- Support for Angular 5 | ||
@@ -89,21 +107,21 @@ ## 3.0.0 (2017-08-15) | ||
* Support strings as droppableItemClass | ||
* Improved component reactivity | ||
* Feature: add moves input to ngxDraggable and ContainerComponent | ||
- Support strings as droppableItemClass | ||
- Improved component reactivity | ||
- Feature: add moves input to ngxDraggable and ContainerComponent | ||
## 2.1.2 (2017-05-26) | ||
* bugfix: removed browser animation module from NgxDnDModule | ||
- bugfix: removed browser animation module from NgxDnDModule | ||
## 2.1.1 (2017-05-23) | ||
* Fix: emit drop event with copied item instead of source | ||
- Fix: emit drop event with copied item instead of source | ||
## 2.1.0 (2017-05-16) | ||
* Feature: drag handles | ||
- Feature: drag handles | ||
## 2.0.2 (2017-05-11) | ||
* Bugfix: Angular throws errors during digest | ||
- Bugfix: Angular throws errors during digest | ||
@@ -116,4 +134,4 @@ ## 2.0.1 (2017-04-17) | ||
* build typescript types | ||
* upgrade for angular ~4.0 | ||
- build typescript types | ||
- upgrade for angular ~4.0 | ||
@@ -126,6 +144,6 @@ ## 1.0.2 (2017-04-17) | ||
* Fix build process | ||
- Fix build process | ||
## 1.0.0 (2017-03-12) | ||
* My first release | ||
- My first release |
@@ -1,12 +0,5 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Component, Input, Output, ViewEncapsulation, ContentChild, TemplateRef, ViewChild, EventEmitter } from '@angular/core'; | ||
import { DroppableDirective } from '../../directives/ngx-droppable.directive'; | ||
/** @type {?} */ | ||
let i = 0; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -20,3 +13,3 @@ return i++; | ||
*/ | ||
export class ContainerComponent { | ||
let ContainerComponent = class ContainerComponent { | ||
constructor() { | ||
@@ -33,12 +26,5 @@ this.copy = false; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZones() { | ||
return this._dropZones || this._defaultZones; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZones(val) { | ||
@@ -49,118 +35,96 @@ this._dropZones = val; | ||
// @Input() dragulaOptions: any; | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
set templateInput(template) { | ||
this.template = template; | ||
} | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
set templateChild(template) { | ||
this.template = template; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
this._defaultZones = [this.dropZone]; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngAfterViewInit() { | ||
this.droppable.drag.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.drag.emit(v))); | ||
this.droppable.drop.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.drop.emit(v))); | ||
this.droppable.over.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.over.emit(v))); | ||
this.droppable.out.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.out.emit(v))); | ||
this.droppable.remove.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.remove.emit(v))); | ||
this.droppable.cancel.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.cancel.emit(v))); | ||
this.droppable.drag.subscribe((v) => this.drag.emit(v)); | ||
this.droppable.drop.subscribe((v) => this.drop.emit(v)); | ||
this.droppable.over.subscribe((v) => this.over.emit(v)); | ||
this.droppable.out.subscribe((v) => this.out.emit(v)); | ||
this.droppable.remove.subscribe((v) => this.remove.emit(v)); | ||
this.droppable.cancel.subscribe((v) => this.cancel.emit(v)); | ||
} | ||
} | ||
ContainerComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}] } | ||
]; | ||
ContainerComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
moves: [{ type: Input }], | ||
templateInput: [{ type: Input, args: ['template',] }], | ||
templateChild: [{ type: ContentChild, args: [TemplateRef, { static: true },] }], | ||
droppable: [{ type: ViewChild, args: [DroppableDirective, { static: true },] }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }] | ||
}; | ||
if (false) { | ||
/** @type {?} */ | ||
ContainerComponent.prototype.model; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.copy; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.removeOnSpill; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.droppableItemClass; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.dropZone; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.moves; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.template; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.droppable; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.drop; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.drag; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.over; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.out; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.remove; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.cancel; | ||
/** @type {?} */ | ||
ContainerComponent.prototype._dropZones; | ||
/** @type {?} */ | ||
ContainerComponent.prototype._defaultZones; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2NvbXBvbmVudHMvY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFDTCxTQUFTLEVBR1QsS0FBSyxFQUNMLE1BQU0sRUFDTixpQkFBaUIsRUFDakIsWUFBWSxFQUNaLFdBQVcsRUFDWCxTQUFTLEVBQ1QsWUFBWSxFQUNiLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOztJQUUxRSxDQUFDLEdBQUcsQ0FBQzs7OztBQUNULFNBQVMsU0FBUztJQUNoQixPQUFPLENBQUMsRUFBRSxDQUFDO0FBQ2IsQ0FBQzs7Ozs7O0FBYUQsTUFBTSxPQUFPLGtCQUFrQjtJQU4vQjtRQVFXLFNBQUksR0FBRyxLQUFLLENBQUM7UUFDYixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUd0QixhQUFRLEdBQUcscUJBQXFCLFNBQVMsRUFBRSxJQUFJLENBQUM7UUE4Qi9DLFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFFBQUcsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVqRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFcEQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBaUJoRSxDQUFDOzs7O0lBdkRDLElBQ0ksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQy9DLENBQUM7Ozs7O0lBQ0QsSUFBSSxTQUFTLENBQUMsR0FBRztRQUNmLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxDQUFDO0lBQ3hCLENBQUM7Ozs7Ozs7SUFPRCxJQUNJLGFBQWEsQ0FBQyxRQUEwQjtRQUMxQyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUMzQixDQUFDOzs7OztJQUVELElBQ0ksYUFBYSxDQUFDLFFBQTBCO1FBQzFDLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0lBQzNCLENBQUM7Ozs7SUFzQkQsUUFBUTtRQUNOLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDdkMsQ0FBQzs7OztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTOzs7O1FBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFDLENBQUM7UUFDN0QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUzs7OztRQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBQyxDQUFDO1FBQzdELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVM7Ozs7UUFBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxTQUFTOzs7O1FBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFDLENBQUM7UUFDM0QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUzs7OztRQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBQyxDQUFDO1FBQ2pFLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFNBQVM7Ozs7UUFBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUMsQ0FBQztJQUNuRSxDQUFDOzs7WUFwRUYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxtQkFBbUI7Z0JBQzdCLDhyQkFBeUM7Z0JBRXpDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJOzthQUN0Qzs7O29CQUVFLEtBQUs7bUJBQ0wsS0FBSzs0QkFDTCxLQUFLO2lDQUNMLEtBQUs7dUJBRUwsS0FBSzt3QkFFTCxLQUFLO29CQVFMLEtBQUs7NEJBS0wsS0FBSyxTQUFDLFVBQVU7NEJBS2hCLFlBQVksU0FBQyxXQUFXLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO3dCQU8xQyxTQUFTLFNBQUMsa0JBQWtCLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO21CQUc5QyxNQUFNO21CQUVOLE1BQU07bUJBRU4sTUFBTTtrQkFFTixNQUFNO3FCQUVOLE1BQU07cUJBRU4sTUFBTTs7OztJQTdDUCxtQ0FBb0I7O0lBQ3BCLGtDQUFzQjs7SUFDdEIsMkNBQStCOztJQUMvQixnREFBd0Q7O0lBRXhELHNDQUF5RDs7SUFVekQsbUNBQWdGOztJQWVoRixzQ0FBMkI7O0lBRTNCLHVDQUNlOztJQUVmLGtDQUE0RDs7SUFFNUQsa0NBQTREOztJQUU1RCxrQ0FBNEQ7O0lBRTVELGlDQUEyRDs7SUFFM0Qsb0NBQThEOztJQUU5RCxvQ0FBOEQ7O0lBRTlELHdDQUFxQjs7SUFDckIsMkNBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBPbkluaXQsXG4gIEFmdGVyVmlld0luaXQsXG4gIElucHV0LFxuICBPdXRwdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxuICBDb250ZW50Q2hpbGQsXG4gIFRlbXBsYXRlUmVmLFxuICBWaWV3Q2hpbGQsXG4gIEV2ZW50RW1pdHRlclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRHJvcHBhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9uZ3gtZHJvcHBhYmxlLmRpcmVjdGl2ZSc7XG5cbmxldCBpID0gMDtcbmZ1bmN0aW9uIGdldE5leHRJZCgpIHtcbiAgcmV0dXJuIGkrKztcbn1cblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCBhbGxvd3MgbmVzdGVkIG5neERyb3BwYWJsZSBhbmQgbmd4RHJhZ2dhYmxlc1xuICpcbiAqIEBleHBvcnRcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWRuZC1jb250YWluZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgQ29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0IHtcbiAgQElucHV0KCkgbW9kZWw6IGFueTtcbiAgQElucHV0KCkgY29weSA9IGZhbHNlO1xuICBASW5wdXQoKSByZW1vdmVPblNwaWxsID0gZmFsc2U7XG4gIEBJbnB1dCgpIGRyb3BwYWJsZUl0ZW1DbGFzczogc3RyaW5nIHwgKChvOiBhbnkpID0+IGFueSk7XG5cbiAgQElucHV0KCkgZHJvcFpvbmUgPSBgQEBEZWZhdWx0RHJvcFpvbmUtJHtnZXROZXh0SWQoKX1AQGA7XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3Bab25lcygpIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmVzIHx8IHRoaXMuX2RlZmF1bHRab25lcztcbiAgfVxuICBzZXQgZHJvcFpvbmVzKHZhbCkge1xuICAgIHRoaXMuX2Ryb3Bab25lcyA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpIG1vdmVzOiAobW9kZWw6IGFueSwgc291cmNlOiBhbnksIGhhbmRsZTogYW55LCBzaWJsaW5nOiBhbnkpID0+IGJvb2xlYW47XG5cbiAgLy8gQElucHV0KCkgY2xhc3NlczogYW55ID0ge307XG4gIC8vIEBJbnB1dCgpIGRyYWd1bGFPcHRpb25zOiBhbnk7XG5cbiAgQElucHV0KCd0ZW1wbGF0ZScpXG4gIHNldCB0ZW1wbGF0ZUlucHV0KHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgdGhpcy50ZW1wbGF0ZSA9IHRlbXBsYXRlO1xuICB9XG5cbiAgQENvbnRlbnRDaGlsZChUZW1wbGF0ZVJlZiwgeyBzdGF0aWM6IHRydWUgfSlcbiAgc2V0IHRlbXBsYXRlQ2hpbGQodGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4pIHtcbiAgICB0aGlzLnRlbXBsYXRlID0gdGVtcGxhdGU7XG4gIH1cblxuICB0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcblxuICBAVmlld0NoaWxkKERyb3BwYWJsZURpcmVjdGl2ZSwgeyBzdGF0aWM6IHRydWUgfSlcbiAgZHJvcHBhYmxlOiBhbnk7XG5cbiAgQE91dHB1dCgpIGRyb3A6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIGRyYWc6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG92ZXI6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG91dDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgcmVtb3ZlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBjYW5jZWw6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgX2Ryb3Bab25lczogc3RyaW5nW107XG4gIF9kZWZhdWx0Wm9uZXM6IHN0cmluZ1tdO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuX2RlZmF1bHRab25lcyA9IFt0aGlzLmRyb3Bab25lXTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICB0aGlzLmRyb3BwYWJsZS5kcmFnLnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLmRyYWcuZW1pdCh2KSk7XG4gICAgdGhpcy5kcm9wcGFibGUuZHJvcC5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5kcm9wLmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLm92ZXIuc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMub3Zlci5lbWl0KHYpKTtcbiAgICB0aGlzLmRyb3BwYWJsZS5vdXQuc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMub3V0LmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLnJlbW92ZS5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5yZW1vdmUuZW1pdCh2KSk7XG4gICAgdGhpcy5kcm9wcGFibGUuY2FuY2VsLnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLmNhbmNlbC5lbWl0KHYpKTtcbiAgfVxufVxuIl19 | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppableItemClass", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "dropZone", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ContainerComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Function) | ||
], ContainerComponent.prototype, "moves", void 0); | ||
__decorate([ | ||
Input('template'), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateInput", null); | ||
__decorate([ | ||
ContentChild(TemplateRef, { static: true }), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateChild", null); | ||
__decorate([ | ||
ViewChild(DroppableDirective, { static: true }), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppable", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "cancel", void 0); | ||
ContainerComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}) | ||
], ContainerComponent); | ||
export { ContainerComponent }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2NvbXBvbmVudHMvY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxTQUFTLEVBR1QsS0FBSyxFQUNMLE1BQU0sRUFDTixpQkFBaUIsRUFDakIsWUFBWSxFQUNaLFdBQVcsRUFDWCxTQUFTLEVBQ1QsWUFBWSxFQUNiLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRTlFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUNWLFNBQVMsU0FBUztJQUNoQixPQUFPLENBQUMsRUFBRSxDQUFDO0FBQ2IsQ0FBQztBQUVEOzs7O0dBSUc7QUFPSCxJQUFhLGtCQUFrQixHQUEvQixNQUFhLGtCQUFrQjtJQUEvQjtRQUVXLFNBQUksR0FBRyxLQUFLLENBQUM7UUFDYixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUd0QixhQUFRLEdBQUcscUJBQXFCLFNBQVMsRUFBRSxJQUFJLENBQUM7UUE4Qi9DLFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFFBQUcsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVqRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFcEQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBaUJoRSxDQUFDO0lBdERDLElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQy9DLENBQUM7SUFDRCxJQUFJLFNBQVMsQ0FBQyxHQUFHO1FBQ2Ys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dEMsQ0FBQztHQUNXLGtCQUFrQixDQStEOUI7U0EvRFksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBPbkluaXQsXG4gIEFmdGVyVmlld0luaXQsXG4gIElucHV0LFxuICBPdXRwdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxuICBDb250ZW50Q2hpbGQsXG4gIFRlbXBsYXRlUmVmLFxuICBWaWV3Q2hpbGQsXG4gIEV2ZW50RW1pdHRlclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRHJvcHBhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9uZ3gtZHJvcHBhYmxlLmRpcmVjdGl2ZSc7XG5cbmxldCBpID0gMDtcbmZ1bmN0aW9uIGdldE5leHRJZCgpIHtcbiAgcmV0dXJuIGkrKztcbn1cblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCBhbGxvd3MgbmVzdGVkIG5neERyb3BwYWJsZSBhbmQgbmd4RHJhZ2dhYmxlc1xuICpcbiAqIEBleHBvcnRcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWRuZC1jb250YWluZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgQ29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0IHtcbiAgQElucHV0KCkgbW9kZWw6IGFueTtcbiAgQElucHV0KCkgY29weSA9IGZhbHNlO1xuICBASW5wdXQoKSByZW1vdmVPblNwaWxsID0gZmFsc2U7XG4gIEBJbnB1dCgpIGRyb3BwYWJsZUl0ZW1DbGFzczogc3RyaW5nIHwgKChvOiBhbnkpID0+IGFueSk7XG5cbiAgQElucHV0KCkgZHJvcFpvbmUgPSBgQEBEZWZhdWx0RHJvcFpvbmUtJHtnZXROZXh0SWQoKX1AQGA7XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3Bab25lcygpIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmVzIHx8IHRoaXMuX2RlZmF1bHRab25lcztcbiAgfVxuICBzZXQgZHJvcFpvbmVzKHZhbCkge1xuICAgIHRoaXMuX2Ryb3Bab25lcyA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpIG1vdmVzOiAobW9kZWw6IGFueSwgc291cmNlOiBhbnksIGhhbmRsZTogYW55LCBzaWJsaW5nOiBhbnkpID0+IGJvb2xlYW47XG5cbiAgLy8gQElucHV0KCkgY2xhc3NlczogYW55ID0ge307XG4gIC8vIEBJbnB1dCgpIGRyYWd1bGFPcHRpb25zOiBhbnk7XG5cbiAgQElucHV0KCd0ZW1wbGF0ZScpXG4gIHNldCB0ZW1wbGF0ZUlucHV0KHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgdGhpcy50ZW1wbGF0ZSA9IHRlbXBsYXRlO1xuICB9XG5cbiAgQENvbnRlbnRDaGlsZChUZW1wbGF0ZVJlZiwgeyBzdGF0aWM6IHRydWUgfSlcbiAgc2V0IHRlbXBsYXRlQ2hpbGQodGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4pIHtcbiAgICB0aGlzLnRlbXBsYXRlID0gdGVtcGxhdGU7XG4gIH1cblxuICB0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcblxuICBAVmlld0NoaWxkKERyb3BwYWJsZURpcmVjdGl2ZSwgeyBzdGF0aWM6IHRydWUgfSlcbiAgZHJvcHBhYmxlOiBhbnk7XG5cbiAgQE91dHB1dCgpIGRyb3A6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIGRyYWc6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG92ZXI6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG91dDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgcmVtb3ZlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBjYW5jZWw6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgX2Ryb3Bab25lczogc3RyaW5nW107XG4gIF9kZWZhdWx0Wm9uZXM6IHN0cmluZ1tdO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuX2RlZmF1bHRab25lcyA9IFt0aGlzLmRyb3Bab25lXTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICB0aGlzLmRyb3BwYWJsZS5kcmFnLnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLmRyYWcuZW1pdCh2KSk7XG4gICAgdGhpcy5kcm9wcGFibGUuZHJvcC5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5kcm9wLmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLm92ZXIuc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMub3Zlci5lbWl0KHYpKTtcbiAgICB0aGlzLmRyb3BwYWJsZS5vdXQuc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMub3V0LmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLnJlbW92ZS5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5yZW1vdmUuZW1pdCh2KSk7XG4gICAgdGhpcy5kcm9wcGFibGUuY2FuY2VsLnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLmNhbmNlbC5lbWl0KHYpKTtcbiAgfVxufVxuIl19 |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Component, Input, ViewEncapsulation, HostBinding } from '@angular/core'; | ||
@@ -15,7 +12,3 @@ import { ContainerComponent } from '../container/container.component'; | ||
*/ | ||
export class ItemComponent { | ||
/** | ||
* @param {?} container | ||
* @param {?} draggableDirective | ||
*/ | ||
let ItemComponent = class ItemComponent { | ||
constructor(container, draggableDirective) { | ||
@@ -27,86 +20,40 @@ this.container = container; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZone() { | ||
return this._dropZone || this.container.dropZone; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZone(val) { | ||
this._dropZone = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZones() { | ||
return this._dropZones || this.container.dropZones; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZones(val) { | ||
this._dropZones = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get droppableItemClass() { | ||
return this._droppableItemClass || this.container.droppableItemClass; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set droppableItemClass(val) { | ||
this._droppableItemClass = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get removeOnSpill() { | ||
return typeof this._removeOnSpill === 'boolean' ? this._removeOnSpill : this.container.removeOnSpill; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set removeOnSpill(val) { | ||
this._removeOnSpill = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get copy() { | ||
return typeof this._copy === 'boolean' ? this._copy : this.container.copy; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set copy(val) { | ||
this._copy = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get hasHandle() { | ||
return this.draggableDirective.hasHandle; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get moveDisabled() { | ||
return !this.draggableDirective.canMove(); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get classString() { | ||
/** @type {?} */ | ||
const itemClass = typeof this.droppableItemClass === 'function' ? this.droppableItemClass(this.model) : this.droppableItemClass; | ||
/** @type {?} */ | ||
const classes = ['ngx-dnd-item', itemClass || '']; | ||
@@ -121,5 +68,2 @@ if (this.moveDisabled) { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get type() { | ||
@@ -131,5 +75,2 @@ if (Array.isArray(this.model)) { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
@@ -143,12 +84,3 @@ this.data = { | ||
} | ||
} | ||
ItemComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}] } | ||
]; | ||
/** @nocollapse */ | ||
}; | ||
ItemComponent.ctorParameters = () => [ | ||
@@ -158,31 +90,46 @@ { type: ContainerComponent }, | ||
]; | ||
ItemComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
classString: [{ type: HostBinding, args: ['class',] }] | ||
}; | ||
if (false) { | ||
/** @type {?} */ | ||
ItemComponent.prototype.model; | ||
/** @type {?} */ | ||
ItemComponent.prototype._copy; | ||
/** @type {?} */ | ||
ItemComponent.prototype._dropZone; | ||
/** @type {?} */ | ||
ItemComponent.prototype._dropZones; | ||
/** @type {?} */ | ||
ItemComponent.prototype._droppableItemClass; | ||
/** @type {?} */ | ||
ItemComponent.prototype._removeOnSpill; | ||
/** @type {?} */ | ||
ItemComponent.prototype.data; | ||
/** @type {?} */ | ||
ItemComponent.prototype.container; | ||
/** @type {?} */ | ||
ItemComponent.prototype.draggableDirective; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2l0ZW0vaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQzs7Ozs7Ozs7QUFlOUUsTUFBTSxPQUFPLGFBQWE7Ozs7O0lBZ0Z4QixZQUFtQixTQUE2QixFQUFTLGtCQUFzQztRQUE1RSxjQUFTLEdBQVQsU0FBUyxDQUFvQjtRQUFTLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFyQy9GLFVBQUssR0FBRyxLQUFLLENBQUM7UUFJZCxtQkFBYyxHQUFHLEtBQUssQ0FBQztJQWlDMkUsQ0FBQzs7OztJQTdFbkcsSUFDSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0lBQ25ELENBQUM7Ozs7O0lBQ0QsSUFBSSxRQUFRLENBQUMsR0FBRztRQUNkLElBQUksQ0FBQyxTQUFTLEdBQUcsR0FBRyxDQUFDO0lBQ3ZCLENBQUM7Ozs7SUFFRCxJQUNJLFNBQVM7UUFDWCxPQUFPLElBQUksQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUM7SUFDckQsQ0FBQzs7Ozs7SUFDRCxJQUFJLFNBQVMsQ0FBQyxHQUFHO1FBQ2YsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7SUFDeEIsQ0FBQzs7OztJQUVELElBQ0ksa0JBQWtCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixJQUFJLElBQUksQ0FBQyxT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b3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uLCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuLi9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmFnZ2FibGVEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzL25neC1kcmFnZ2FibGUuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCBhbGxvd3MgbmVzdGVkIG5neERyb3BwYWJsZSBhbmQgbmd4RHJhZ2dhYmxlc1xuICogU2hvdWxkIG9ubHkgYmUgdXNlIGluc2lkZSBhIG5neC1kbmQtY29udGFpbmVyXG4gKiBPdXRzaWRlIGEgbmd4LWRuZC1jb250YWluZXIgdXNlIG5neERyb3BwYWJsZVxuICpcbiAqIEBleHBvcnRcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWRuZC1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2l0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9pdGVtLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgSXRlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3Bab25lKCkge1xuICAgIHJldHVybiB0aGlzLl9kcm9wWm9uZSB8fCB0aGlzLmNvbnRhaW5lci5kcm9wWm9uZTtcbiAgfVxuICBzZXQgZHJvcFpvbmUodmFsKSB7XG4gICAgdGhpcy5fZHJvcFpvbmUgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgZHJvcFpvbmVzKCkge1xuICAgIHJldHVybiB0aGlzLl9kcm9wWm9uZXMgfHwgdGhpcy5jb250YWluZXIuZHJvcFpvbmVzO1xuICB9XG4gIHNldCBkcm9wWm9uZXModmFsKSB7XG4gICAgdGhpcy5fZHJvcFpvbmVzID0gdmFsO1xuICB9XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3BwYWJsZUl0ZW1DbGFzcygpIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcHBhYmxlSXRlbUNsYXNzIHx8IHRoaXMuY29udGFpbmVyLmRyb3BwYWJsZUl0ZW1DbGFzcztcbiAgfVxuICBzZXQgZHJvcHBhYmxlSXRlbUNsYXNzKHZhbCkge1xuICAgIHRoaXMuX2Ryb3BwYWJsZUl0ZW1DbGFzcyA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCByZW1vdmVPblNwaWxsKCkge1xuICAgIHJldHVybiB0eXBlb2YgdGhpcy5fcmVtb3ZlT25TcGlsbCA9PT0gJ2Jvb2xlYW4nID8gdGhpcy5fcmVtb3ZlT25TcGlsbCA6IHRoaXMuY29udGFpbmVyLnJlbW92ZU9uU3BpbGw7XG4gIH1cbiAgc2V0IHJlbW92ZU9uU3BpbGwodmFsKSB7XG4gICAgdGhpcy5fcmVtb3ZlT25TcGlsbCA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCBjb3B5KCkge1xuICAgIHJldHVybiB0eXBlb2YgdGhpcy5fY29weSA9PT0gJ2Jvb2xlYW4nID8gdGhpcy5fY29weSA6IHRoaXMuY29udGFpbmVyLmNvcHk7XG4gIH1cbiAgc2V0IGNvcHkodmFsKSB7XG4gICAgdGhpcy5fY29weSA9IHZhbDtcbiAgfVxuXG4gIF9jb3B5ID0gZmFsc2U7XG4gIF9kcm9wWm9uZTogYW55O1xuICBfZHJvcFpvbmVzOiBhbnk7XG4gIF9kcm9wcGFibGVJdGVtQ2xhc3M6IGFueTtcbiAgX3JlbW92ZU9uU3BpbGwgPSBmYWxzZTtcbiAgZGF0YTogYW55O1xuXG4gIGdldCBoYXNIYW5kbGUoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuZHJhZ2dhYmxlRGlyZWN0aXZlLmhhc0hhbmRsZTtcbiAgfVxuXG4gIGdldCBtb3ZlRGlzYWJsZWQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICF0aGlzLmRyYWdnYWJsZURpcmVjdGl2ZS5jYW5Nb3ZlKCk7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgZ2V0IGNsYXNzU3RyaW5nKCkge1xuICAgIGNvbnN0IGl0ZW1DbGFzcyA9XG4gICAgICB0eXBlb2YgdGhpcy5kcm9wcGFibGVJdGVtQ2xhc3MgPT09ICdmdW5jdGlvbicgPyB0aGlzLmRyb3BwYWJsZUl0ZW1DbGFzcyh0aGlzLm1vZGVsKSA6IHRoaXMuZHJvcHBhYmxlSXRlbUNsYXNzO1xuXG4gICAgY29uc3QgY2xhc3NlcyA9IFsnbmd4LWRuZC1pdGVtJywgaXRlbUNsYXNzIHx8ICcnXTtcbiAgICBpZiAodGhpcy5tb3ZlRGlzYWJsZWQpIHtcbiAgICAgIGNsYXNzZXMucHVzaCgnbW92ZS1kaXNhYmxlZCcpO1xuICAgIH1cbiAgICBpZiAodGhpcy5oYXNIYW5kbGUpIHtcbiAgICAgIGNsYXNzZXMucHVzaCgnaGFzLWhhbmRsZScpO1xuICAgIH1cbiAgICByZXR1cm4gY2xhc3Nlcy5qb2luKCcgJyk7XG4gIH1cblxuICBnZXQgdHlwZSgpIHtcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh0aGlzLm1vZGVsKSkge1xuICAgICAgcmV0dXJuICdhcnJheSc7XG4gICAgfVxuICAgIHJldHVybiB0eXBlb2YgdGhpcy5tb2RlbDtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBjb250YWluZXI6IENvbnRhaW5lckNvbXBvbmVudCwgcHVibGljIGRyYWdnYWJsZURpcmVjdGl2ZTogRHJhZ2dhYmxlRGlyZWN0aXZlKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuZGF0YSA9IHtcbiAgICAgIG1vZGVsOiB0aGlzLm1vZGVsLFxuICAgICAgdHlwZTogdGhpcy50eXBlLFxuICAgICAgZHJvcFpvbmU6IHRoaXMuZHJvcFpvbmUsXG4gICAgICB0ZW1wbGF0ZTogdGhpcy5jb250YWluZXIudGVtcGxhdGVcbiAgICB9O1xuICB9XG59XG4iXX0= | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ItemComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZone", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "droppableItemClass", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "removeOnSpill", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "copy", null); | ||
__decorate([ | ||
HostBinding('class'), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", []) | ||
], ItemComponent.prototype, "classString", null); | ||
ItemComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}), | ||
__metadata("design:paramtypes", [ContainerComponent, DraggableDirective]) | ||
], ItemComponent); | ||
export { ItemComponent }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2l0ZW0vaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUU5RTs7Ozs7O0dBTUc7QUFPSCxJQUFhLGFBQWEsR0FBMUIsTUFBYSxhQUFhO0lBZ0Z4QixZQUFtQixTQUE2QixFQUFTLGtCQUFzQztRQUE1RSxjQUFTLEdBQVQsU0FBUyxDQUFvQjtRQUFTLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFyQy9GLFVBQUssR0FBRyxLQUFLLENBQUM7UUFJZCxtQkFBYyxHQUFHLEtBQUssQ0FBQztJQWlDMkUsQ0FBQztJQTVFbkcsSUFBSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0lBQ25ELENBQUM7SUFDRCxJQUFJLFFBQVEsQ0FBQyxHQUFHO1FBQ2QsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLENBQUM7SUFDdkIsQ0FBQztJQUdELElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztJQUNyRCxDQUFDO0lBQ0QsSUFBSSxTQUFTLENBQUMsR0FBRztRQUNmLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxDQUFDO0lBQ3hCLENBQUM7SUFHRCxJQUFJLGtCQUFrQjtRQUNwQixPQUFPLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxJQUFJLENBQUMsU0FBUyxD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a0JBQWtCLEVBQTZCLGtCQUFrQjtHQWhGcEYsYUFBYSxDQTBGekI7U0ExRlksYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb24sIEhvc3RCaW5kaW5nIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IENvbnRhaW5lckNvbXBvbmVudCB9IGZyb20gJy4uL2NvbnRhaW5lci9jb250YWluZXIuY29tcG9uZW50JztcbmltcG9ydCB7IERyYWdnYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvbmd4LWRyYWdnYWJsZS5kaXJlY3RpdmUnO1xuXG4vKipcbiAqIENvbXBvbmVudCB0aGF0IGFsbG93cyBuZXN0ZWQgbmd4RHJvcHBhYmxlIGFuZCBuZ3hEcmFnZ2FibGVzXG4gKiBTaG91bGQgb25seSBiZSB1c2UgaW5zaWRlIGEgbmd4LWRuZC1jb250YWluZXJcbiAqIE91dHNpZGUgYSBuZ3gtZG5kLWNvbnRhaW5lciB1c2Ugbmd4RHJvcHBhYmxlXG4gKlxuICogQGV4cG9ydFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ3gtZG5kLWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJy4vaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2l0ZW0uY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxufSlcbmV4cG9ydCBjbGFzcyBJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgbW9kZWw6IGFueTtcblxuICBASW5wdXQoKVxuICBnZXQgZHJvcFpvbmUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2Ryb3Bab25lIHx8IHRoaXMuY29udGFpbmVyLmRyb3Bab25lO1xuICB9XG4gIHNldCBkcm9wWm9uZSh2YWwpIHtcbiAgICB0aGlzLl9kcm9wWm9uZSA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCBkcm9wWm9uZXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2Ryb3Bab25lcyB8fCB0aGlzLmNvbnRhaW5lci5kcm9wWm9uZXM7XG4gIH1cbiAgc2V0IGRyb3Bab25lcyh2YWwpIHtcbiAgICB0aGlzLl9kcm9wWm9uZXMgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgZHJvcHBhYmxlSXRlbUNsYXNzKCkge1xuICAgIHJldHVybiB0aGlzLl9kcm9wcGFibGVJdGVtQ2xhc3MgfHwgdGhpcy5jb250YWluZXIuZHJvcHBhYmxlSXRlbUNsYXNzO1xuICB9XG4gIHNldCBkcm9wcGFibGVJdGVtQ2xhc3ModmFsKSB7XG4gICAgdGhpcy5fZHJvcHBhYmxlSXRlbUNsYXNzID0gdmFsO1xuICB9XG5cbiAgQElucHV0KClcbiAgZ2V0IHJlbW92ZU9uU3BpbGwoKSB7XG4gICAgcmV0dXJuIHR5cGVvZiB0aGlzLl9yZW1vdmVPblNwaWxsID09PSAnYm9vbGVhbicgPyB0aGlzLl9yZW1vdmVPblNwaWxsIDogdGhpcy5jb250YWluZXIucmVtb3ZlT25TcGlsbDtcbiAgfVxuICBzZXQgcmVtb3ZlT25TcGlsbCh2YWwpIHtcbiAgICB0aGlzLl9yZW1vdmVPblNwaWxsID0gdmFsO1xuICB9XG5cbiAgQElucHV0KClcbiAgZ2V0IGNvcHkoKSB7XG4gICAgcmV0dXJuIHR5cGVvZiB0aGlzLl9jb3B5ID09PSAnYm9vbGVhbicgPyB0aGlzLl9jb3B5IDogdGhpcy5jb250YWluZXIuY29weTtcbiAgfVxuICBzZXQgY29weSh2YWwpIHtcbiAgICB0aGlzLl9jb3B5ID0gdmFsO1xuICB9XG5cbiAgX2NvcHkgPSBmYWxzZTtcbiAgX2Ryb3Bab25lOiBhbnk7XG4gIF9kcm9wWm9uZXM6IGFueTtcbiAgX2Ryb3BwYWJsZUl0ZW1DbGFzczogYW55O1xuICBfcmVtb3ZlT25TcGlsbCA9IGZhbHNlO1xuICBkYXRhOiBhbnk7XG5cbiAgZ2V0IGhhc0hhbmRsZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5kcmFnZ2FibGVEaXJlY3RpdmUuaGFzSGFuZGxlO1xuICB9XG5cbiAgZ2V0IG1vdmVEaXNhYmxlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gIXRoaXMuZHJhZ2dhYmxlRGlyZWN0aXZlLmNhbk1vdmUoKTtcbiAgfVxuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBnZXQgY2xhc3NTdHJpbmcoKSB7XG4gICAgY29uc3QgaXRlbUNsYXNzID1cbiAgICAgIHR5cGVvZiB0aGlzLmRyb3BwYWJsZUl0ZW1DbGFzcyA9PT0gJ2Z1bmN0aW9uJyA/IHRoaXMuZHJvcHBhYmxlSXRlbUNsYXNzKHRoaXMubW9kZWwpIDogdGhpcy5kcm9wcGFibGVJdGVtQ2xhc3M7XG5cbiAgICBjb25zdCBjbGFzc2VzID0gWyduZ3gtZG5kLWl0ZW0nLCBpdGVtQ2xhc3MgfHwgJyddO1xuICAgIGlmICh0aGlzLm1vdmVEaXNhYmxlZCkge1xuICAgICAgY2xhc3Nlcy5wdXNoKCdtb3ZlLWRpc2FibGVkJyk7XG4gICAgfVxuICAgIGlmICh0aGlzLmhhc0hhbmRsZSkge1xuICAgICAgY2xhc3Nlcy5wdXNoKCdoYXMtaGFuZGxlJyk7XG4gICAgfVxuICAgIHJldHVybiBjbGFzc2VzLmpvaW4oJyAnKTtcbiAgfVxuXG4gIGdldCB0eXBlKCkge1xuICAgIGlmIChBcnJheS5pc0FycmF5KHRoaXMubW9kZWwpKSB7XG4gICAgICByZXR1cm4gJ2FycmF5JztcbiAgICB9XG4gICAgcmV0dXJuIHR5cGVvZiB0aGlzLm1vZGVsO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHVibGljIGNvbnRhaW5lcjogQ29udGFpbmVyQ29tcG9uZW50LCBwdWJsaWMgZHJhZ2dhYmxlRGlyZWN0aXZlOiBEcmFnZ2FibGVEaXJlY3RpdmUpIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5kYXRhID0ge1xuICAgICAgbW9kZWw6IHRoaXMubW9kZWwsXG4gICAgICB0eXBlOiB0aGlzLnR5cGUsXG4gICAgICBkcm9wWm9uZTogdGhpcy5kcm9wWm9uZSxcbiAgICAgIHRlbXBsYXRlOiB0aGlzLmNvbnRhaW5lci50ZW1wbGF0ZVxuICAgIH07XG4gIH1cbn1cbiJdfQ== |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate } from "tslib"; | ||
import { Directive } from '@angular/core'; | ||
@@ -11,7 +8,8 @@ /** | ||
*/ | ||
export class DragHandleDirective { | ||
} | ||
DragHandleDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDragHandle]' },] } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2RpcmVjdGl2ZXMvbmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBUTFDLE1BQU0sT0FBTyxtQkFBbUI7OztZQUQvQixTQUFTLFNBQUMsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBBZGRzIHByb3BlcnRpZXMgYW5kIGV2ZW50cyB0byBkcmFnIGhhbmRsZSBlbGVtZW50c1xuICpcbiAqIEBleHBvcnRcbiAqL1xuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW25neERyYWdIYW5kbGVdJyB9KVxuZXhwb3J0IGNsYXNzIERyYWdIYW5kbGVEaXJlY3RpdmUge31cbiJdfQ== | ||
let DragHandleDirective = class DragHandleDirective { | ||
}; | ||
DragHandleDirective = __decorate([ | ||
Directive({ selector: '[ngxDragHandle]' }) | ||
], DragHandleDirective); | ||
export { DragHandleDirective }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2RpcmVjdGl2ZXMvbmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQzs7OztHQUlHO0FBRUgsSUFBYSxtQkFBbUIsR0FBaEMsTUFBYSxtQkFBbUI7Q0FBRyxDQUFBO0FBQXRCLG1CQUFtQjtJQUQvQixTQUFTLENBQUMsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQztHQUM5QixtQkFBbUIsQ0FBRztTQUF0QixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBBZGRzIHByb3BlcnRpZXMgYW5kIGV2ZW50cyB0byBkcmFnIGhhbmRsZSBlbGVtZW50c1xuICpcbiAqIEBleHBvcnRcbiAqL1xuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW25neERyYWdIYW5kbGVdJyB9KVxuZXhwb3J0IGNsYXNzIERyYWdIYW5kbGVEaXJlY3RpdmUge31cbiJdfQ== |
@@ -1,6 +0,3 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { Directive, ElementRef, HostListener, Input, Output, EventEmitter } from '@angular/core'; | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Directive, ElementRef, HostListener, Input, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core'; | ||
import { DroppableDirective } from './ngx-droppable.directive'; | ||
@@ -13,8 +10,3 @@ import { DrakeStoreService } from '../services/drake-store.service'; | ||
*/ | ||
export class DraggableDirective { | ||
/** | ||
* @param {?} el | ||
* @param {?} drakesService | ||
* @param {?} droppableDirective | ||
*/ | ||
let DraggableDirective = class DraggableDirective { | ||
constructor(el, drakesService, droppableDirective) { | ||
@@ -26,36 +18,22 @@ this.el = el; | ||
/* | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
this.handles = []; | ||
this.drag = new EventEmitter(); | ||
this.dragDelay = 200; // milliseconds | ||
// milliseconds | ||
this.dragDelayed = true; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZones() { | ||
return this._dropZones || this.ngxDraggable || this._parentDropzones; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZones(val) { | ||
this._dropZones = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get hasHandle() { | ||
return !!this.handles.length; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get element() { | ||
@@ -65,6 +43,2 @@ return this.el.nativeElement; | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
onMove(e) { | ||
@@ -76,33 +50,18 @@ if (!this._moves || this.dragDelayed) { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
onDown() { | ||
if (this._moves) { | ||
this.touchTimeout = setTimeout((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.touchTimeout = setTimeout(() => { | ||
this.dragDelayed = false; | ||
}), this.dragDelay); | ||
}, this.dragDelay); | ||
} | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
onUp() { | ||
if (this._moves) { | ||
clearTimeout((/** @type {?} */ (this.touchTimeout))); | ||
clearTimeout(this.touchTimeout); | ||
this.dragDelayed = true; | ||
} | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
this.update(); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
update() { | ||
@@ -113,25 +72,9 @@ this._parentDropzones = [this.droppableDirective.dropZone]; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnDestroy() { | ||
this.drakesService.removeDraggable(this); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
updateElements() { | ||
/** @type {?} */ | ||
const nativeElement = this.el.nativeElement; | ||
/** @type {?} */ | ||
const handles = nativeElement.querySelectorAll('[ngxdraghandle]'); | ||
this.handles = Array.from(handles).filter((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
(h) => findFirstDraggableParent(h) === nativeElement)); | ||
/** | ||
* @param {?} c | ||
* @return {?} | ||
*/ | ||
this.handles = Array.from(handles).filter((h) => findFirstDraggableParent(h) === nativeElement); | ||
function findFirstDraggableParent(c) { | ||
@@ -146,8 +89,2 @@ while (c.parentNode) { | ||
} | ||
/** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
canMove(source, handle, sibling) { | ||
@@ -160,21 +97,6 @@ if (typeof this._moves === 'boolean') | ||
} | ||
/** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
moves(source, handle, sibling) { | ||
if (!this.canMove(source, handle, sibling)) | ||
return false; | ||
return this.hasHandle ? this.handles.some((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
h => handelFor(handle, h))) : true; | ||
/** | ||
* @param {?} c | ||
* @param {?} p | ||
* @return {?} | ||
*/ | ||
return this.hasHandle ? this.handles.some(h => handelFor(handle, h)) : true; | ||
function handelFor(c, p) { | ||
@@ -188,13 +110,6 @@ if (c === p) | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngDoCheck() { | ||
this.updateElements(); | ||
} | ||
} | ||
DraggableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDraggable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
}; | ||
DraggableDirective.ctorParameters = () => [ | ||
@@ -205,49 +120,48 @@ { type: ElementRef }, | ||
]; | ||
DraggableDirective.propDecorators = { | ||
ngxDraggable: [{ type: Input }], | ||
model: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
_moves: [{ type: Input, args: ['moves',] }], | ||
drag: [{ type: Output }], | ||
onMove: [{ type: HostListener, args: ['touchmove', ['$event'],] }], | ||
onDown: [{ type: HostListener, args: ['touchstart',] }], | ||
onUp: [{ type: HostListener, args: ['touchend',] }] | ||
}; | ||
if (false) { | ||
/** @type {?} */ | ||
DraggableDirective.prototype.ngxDraggable; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.model; | ||
/** @type {?} */ | ||
DraggableDirective.prototype._moves; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.handles; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.drag; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.dragDelay; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.dragDelayed; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.touchTimeout; | ||
/** @type {?} */ | ||
DraggableDirective.prototype._dropZones; | ||
/** @type {?} */ | ||
DraggableDirective.prototype._parentDropzones; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DraggableDirective.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DraggableDirective.prototype.drakesService; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DraggableDirective.prototype.droppableDirective; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-draggable.directive.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/directives/ngx-draggable.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAqB,MAAM,eAAe,CAAC;AAEpH,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;;;;;;AAQpE,MAAM,OAAO,kBAAkB;;;;;;IA0C7B,YACU,EAAc,EACd,aAAgC,EAChC,kBAAsC;QAFtC,OAAE,GAAF,EAAE,CAAY;QACd,kBAAa,GAAb,aAAa,CAAmB;QAChC,uBAAkB,GAAlB,kBAAkB,CAAoB;QAjChC,WAAM,GAAwC,IAAI,CAAC;;;;;;;;QAUnE,YAAO,GAAU,EAAE,CAAC;QAMV,SAAI,GAAsB,IAAI,YAAY,EAAO,CAAC;QAE5D,cAAS,GAAW,GAAG,CAAC,CAAC,eAAe;;QACxC,gBAAW,GAAY,IAAI,CAAC;IAezB,CAAC;;;;IA1CJ,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,gBAAgB,CAAC;IACvE,CAAC;;;;;IACD,IAAI,SAAS,CAAC,GAAQ;QACpB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;IACxB,CAAC;;;;IAcD,IAAI,SAAS;QACX,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;IAC/B,CAAC;;;;IASD,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;IAC/B,CAAC;;;;;;IAaD,MAAM,CAAC,CAAQ;QACb,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE;YACpC,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACjC;IACH,CAAC;;;;IAGD,MAAM;QACJ,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,YAAY,GAAG,UAAU;;;YAAC,GAAG,EAAE;gBAClC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YAC3B,CAAC,GAAE,IAAI,CAAC,SAAS,CAAC,CAAC;SACpB;IACH,CAAC;;;;IAGD,IAAI;QACF,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,YAAY,CAAC,mBAAQ,IAAI,CAAC,YAAY,EAAA,CAAC,CAAC;YACxC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SACzB;IACH,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IAED,MAAM;QACJ,IAAI,CAAC,gBAAgB,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAC3D,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC;;;;IAED,cAAc;;cACN,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa;;cACrC,OAAO,GAAa,aAAa,CAAC,gBAAgB,CAAC,iBAAiB,CAAC;QAC3E,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM;;;;QAAC,CAAC,CAAM,EAAE,EAAE,CAAC,wBAAwB,CAAC,CAAC,CAAC,KAAK,aAAa,EAAC,CAAC;;;;;QAErG,SAAS,wBAAwB,CAAC,CAAM;YACtC,OAAO,CAAC,CAAC,UAAU,EAAE;gBACnB,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC;gBACjB,IAAI,CAAC,CAAC,YAAY,IAAI,CAAC,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE;oBACpD,OAAO,CAAC,CAAC;iBACV;aACF;QACH,CAAC;IACH,CAAC;;;;;;;IAED,OAAO,CAAC,MAAY,EAAE,MAAY,EAAE,OAAa;QAC/C,IAAI,OAAO,IAAI,CAAC,MAAM,KAAK,SAAS;YAAE,OAAO,IAAI,CAAC,MAAM,CAAC;QACzD,IAAI,OAAO,IAAI,CAAC,MAAM,KAAK,UAAU;YAAE,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QAC/F,OAAO,IAAI,CAAC;IACd,CAAC;;;;;;;IAED,KAAK,CAAC,MAAW,EAAE,MAAW,EAAE,OAAY;QAC1C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC;YAAE,OAAO,KAAK,CAAC;QAEzD,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI;;;;QAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,IAAI,CAAC;;;;;;QAE5E,SAAS,SAAS,CAAC,CAAM,EAAE,CAAM;YAC/B,IAAI,CAAC,KAAK,CAAC;gBAAE,OAAO,IAAI,CAAC;YACzB,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC;gBAAC,CAAC,CAAC,sBAAsB;YAC7D,OAAO,CAAC,CAAC,CAAC,CAAC;QACb,CAAC;IACH,CAAC;;;;IAED,SAAS;QACP,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;;YA5HF,SAAS,SAAC,EAAE,QAAQ,EAAE,gBAAgB,EAAE;;;;YAVrB,UAAU;YAGrB,iBAAiB;YADjB,kBAAkB;;;2BAUxB,KAAK;oBACL,KAAK;wBAEL,KAAK;qBAQL,KAAK,SAAC,OAAO;mBAgBb,MAAM;qBAqBN,YAAY,SAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;qBAQpC,YAAY,SAAC,YAAY;mBASzB,YAAY,SAAC,UAAU;;;;IAjExB,0CAAgC;;IAChC,mCAAoB;;IAUpB,oCAAmE;;IAUnE,qCAAoB;;IAMpB,kCAA4D;;IAE5D,uCAAwB;;IACxB,yCAA4B;;IAE5B,0CAAkB;;IAMlB,wCAAqB;;IACrB,8CAA2B;;;;;IAGzB,gCAAsB;;;;;IACtB,2CAAwC;;;;;IACxC,gDAA8C","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core';\n\nimport { DroppableDirective } from './ngx-droppable.directive';\nimport { DrakeStoreService } from '../services/drake-store.service';\n\n/**\n * Adds properties and events to draggable elements\n *\n * @export\n */\n@Directive({ selector: '[ngxDraggable]' })\nexport class DraggableDirective implements OnInit, OnDestroy {\n  @Input() ngxDraggable: string[];\n  @Input() model: any;\n\n  @Input()\n  get dropZones(): any {\n    return this._dropZones || this.ngxDraggable || this._parentDropzones;\n  }\n  set dropZones(val: any) {\n    this._dropZones = val;\n  }\n\n  @Input('moves') _moves: boolean | ((...args: any[]) => any) = true;\n\n  /*\n  ContentChildren doesn't get children created with NgTemplateOutlet\n  See https://github.com/angular/angular/issues/14842\n  Implemented via updateElements method\n\n  @ContentChildren(DragHandleDirective, {descendants: true})\n  handlesList: QueryList<DragHandleDirective>; */\n\n  handles: any[] = [];\n\n  get hasHandle() {\n    return !!this.handles.length;\n  }\n\n  @Output() drag: EventEmitter<any> = new EventEmitter<any>();\n\n  dragDelay: number = 200; // milliseconds\n  dragDelayed: boolean = true;\n\n  touchTimeout: any;\n\n  get element(): any {\n    return this.el.nativeElement;\n  }\n\n  _dropZones: string[];\n  _parentDropzones: string[];\n\n  constructor(\n    private el: ElementRef,\n    private drakesService: DrakeStoreService,\n    private droppableDirective: DroppableDirective\n  ) {}\n\n  // From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172\n  @HostListener('touchmove', ['$event'])\n  onMove(e: Event) {\n    if (!this._moves || this.dragDelayed) {\n      e.stopPropagation();\n      clearTimeout(this.touchTimeout);\n    }\n  }\n\n  @HostListener('touchstart')\n  onDown() {\n    if (this._moves) {\n      this.touchTimeout = setTimeout(() => {\n        this.dragDelayed = false;\n      }, this.dragDelay);\n    }\n  }\n\n  @HostListener('touchend')\n  onUp() {\n    if (this._moves) {\n      clearTimeout(<number>this.touchTimeout);\n      this.dragDelayed = true;\n    }\n  }\n\n  ngOnInit(): void {\n    this.update();\n  }\n\n  update(): void {\n    this._parentDropzones = [this.droppableDirective.dropZone];\n    this.drakesService.registerDraggable(this);\n    this.updateElements();\n  }\n\n  ngOnDestroy(): void {\n    this.drakesService.removeDraggable(this);\n  }\n\n  updateElements(): void {\n    const nativeElement = this.el.nativeElement;\n    const handles: NodeList = nativeElement.querySelectorAll('[ngxdraghandle]');\n    this.handles = Array.from(handles).filter((h: any) => findFirstDraggableParent(h) === nativeElement);\n\n    function findFirstDraggableParent(c: any) {\n      while (c.parentNode) {\n        c = c.parentNode;\n        if (c.hasAttribute && c.hasAttribute('ngxdraggable')) {\n          return c;\n        }\n      }\n    }\n  }\n\n  canMove(source?: any, handle?: any, sibling?: any): boolean {\n    if (typeof this._moves === 'boolean') return this._moves;\n    if (typeof this._moves === 'function') return this._moves(this.model, source, handle, sibling);\n    return true;\n  }\n\n  moves(source: any, handle: any, sibling: any): boolean {\n    if (!this.canMove(source, handle, sibling)) return false;\n\n    return this.hasHandle ? this.handles.some(h => handelFor(handle, h)) : true;\n\n    function handelFor(c: any, p: any) {\n      if (c === p) return true;\n      while ((c = c.parentNode) && c !== p); // tslint:disable-line\n      return !!c;\n    }\n  }\n\n  ngDoCheck(): void {\n    this.updateElements();\n  }\n}\n"]} | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Array) | ||
], DraggableDirective.prototype, "ngxDraggable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], DraggableDirective.prototype, "dropZones", null); | ||
__decorate([ | ||
Input('moves'), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "_moves", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DraggableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
HostListener('touchmove', ['$event']), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", [Event]), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onMove", null); | ||
__decorate([ | ||
HostListener('touchstart'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onDown", null); | ||
__decorate([ | ||
HostListener('touchend'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onUp", null); | ||
DraggableDirective = __decorate([ | ||
Directive({ selector: '[ngxDraggable]' }), | ||
__metadata("design:paramtypes", [ElementRef, | ||
DrakeStoreService, | ||
DroppableDirective]) | ||
], DraggableDirective); | ||
export { DraggableDirective }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-draggable.directive.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/directives/ngx-draggable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core';\n\nimport { DroppableDirective } from './ngx-droppable.directive';\nimport { DrakeStoreService } from '../services/drake-store.service';\n\n/**\n * Adds properties and events to draggable elements\n *\n * @export\n */\n@Directive({ selector: '[ngxDraggable]' })\nexport class DraggableDirective implements OnInit, OnDestroy {\n  @Input() ngxDraggable: string[];\n  @Input() model: any;\n\n  @Input()\n  get dropZones(): any {\n    return this._dropZones || this.ngxDraggable || this._parentDropzones;\n  }\n  set dropZones(val: any) {\n    this._dropZones = val;\n  }\n\n  @Input('moves') _moves: boolean | ((...args: any[]) => any) = true;\n\n  /*\n  ContentChildren doesn't get children created with NgTemplateOutlet\n  See https://github.com/angular/angular/issues/14842\n  Implemented via updateElements method\n\n  @ContentChildren(DragHandleDirective, {descendants: true})\n  handlesList: QueryList<DragHandleDirective>; */\n\n  handles: any[] = [];\n\n  get hasHandle() {\n    return !!this.handles.length;\n  }\n\n  @Output() drag: EventEmitter<any> = new EventEmitter<any>();\n\n  dragDelay: number = 200; // milliseconds\n  dragDelayed: boolean = true;\n\n  touchTimeout: any;\n\n  get element(): any {\n    return this.el.nativeElement;\n  }\n\n  _dropZones: string[];\n  _parentDropzones: string[];\n\n  constructor(\n    private el: ElementRef,\n    private drakesService: DrakeStoreService,\n    private droppableDirective: DroppableDirective\n  ) {}\n\n  // From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172\n  @HostListener('touchmove', ['$event'])\n  onMove(e: Event) {\n    if (!this._moves || this.dragDelayed) {\n      e.stopPropagation();\n      clearTimeout(this.touchTimeout);\n    }\n  }\n\n  @HostListener('touchstart')\n  onDown() {\n    if (this._moves) {\n      this.touchTimeout = setTimeout(() => {\n        this.dragDelayed = false;\n      }, this.dragDelay);\n    }\n  }\n\n  @HostListener('touchend')\n  onUp() {\n    if (this._moves) {\n      clearTimeout(<number>this.touchTimeout);\n      this.dragDelayed = true;\n    }\n  }\n\n  ngOnInit(): void {\n    this.update();\n  }\n\n  update(): void {\n    this._parentDropzones = [this.droppableDirective.dropZone];\n    this.drakesService.registerDraggable(this);\n    this.updateElements();\n  }\n\n  ngOnDestroy(): void {\n    this.drakesService.removeDraggable(this);\n  }\n\n  updateElements(): void {\n    const nativeElement = this.el.nativeElement;\n    const handles: NodeList = nativeElement.querySelectorAll('[ngxdraghandle]');\n    this.handles = Array.from(handles).filter((h: any) => findFirstDraggableParent(h) === nativeElement);\n\n    function findFirstDraggableParent(c: any) {\n      while (c.parentNode) {\n        c = c.parentNode;\n        if (c.hasAttribute && c.hasAttribute('ngxdraggable')) {\n          return c;\n        }\n      }\n    }\n  }\n\n  canMove(source?: any, handle?: any, sibling?: any): boolean {\n    if (typeof this._moves === 'boolean') return this._moves;\n    if (typeof this._moves === 'function') return this._moves(this.model, source, handle, sibling);\n    return true;\n  }\n\n  moves(source: any, handle: any, sibling: any): boolean {\n    if (!this.canMove(source, handle, sibling)) return false;\n\n    return this.hasHandle ? this.handles.some(h => handelFor(handle, h)) : true;\n\n    function handelFor(c: any, p: any) {\n      if (c === p) return true;\n      while ((c = c.parentNode) && c !== p); // tslint:disable-line\n      return !!c;\n    }\n  }\n\n  ngDoCheck(): void {\n    this.updateElements();\n  }\n}\n"]} |
@@ -1,12 +0,5 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { Directive, Input, Output, ElementRef, EventEmitter, Renderer2 } from '@angular/core'; | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Directive, Input, Output, OnInit, OnDestroy, AfterViewInit, ElementRef, EventEmitter, Renderer2 } from '@angular/core'; | ||
import { DrakeStoreService } from '../services/drake-store.service'; | ||
/** @type {?} */ | ||
let i = 10000; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -20,8 +13,3 @@ return i++; | ||
*/ | ||
export class DroppableDirective { | ||
/** | ||
* @param {?} el | ||
* @param {?} renderer | ||
* @param {?} drakesService | ||
*/ | ||
let DroppableDirective = class DroppableDirective { | ||
constructor(el, renderer, drakesService) { | ||
@@ -41,24 +29,11 @@ this.el = el; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get container() { | ||
return this.el.nativeElement; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZone() { | ||
return this._dropZone || this.ngxDroppable || this.defaultZone; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZone(val) { | ||
this._dropZone = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
@@ -68,30 +43,14 @@ this.defaultZone = `@@DefaultDropZone-${getNextId()}@@`; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngAfterViewInit() { | ||
this.over.subscribe((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.over.subscribe(() => { | ||
this.renderer.addClass(this.container, 'gu-over'); | ||
})); | ||
this.out.subscribe((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
}); | ||
this.out.subscribe(() => { | ||
this.renderer.removeClass(this.container, 'gu-over'); | ||
})); | ||
}); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnDestroy() { | ||
this.drakesService.remove(this); | ||
} | ||
} | ||
DroppableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDroppable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
}; | ||
DroppableDirective.ctorParameters = () => [ | ||
@@ -102,59 +61,56 @@ { type: ElementRef }, | ||
]; | ||
DroppableDirective.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
ngxDroppable: [{ type: Input }], | ||
direction: [{ type: Input }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }], | ||
dropZone: [{ type: Input }] | ||
}; | ||
if (false) { | ||
/** @type {?} */ | ||
DroppableDirective.prototype.model; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.copy; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.removeOnSpill; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.ngxDroppable; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.direction; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.drop; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.drag; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.over; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.out; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.remove; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.cancel; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.defaultZone; | ||
/** @type {?} */ | ||
DroppableDirective.prototype._dropZone; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DroppableDirective.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DroppableDirective.prototype.renderer; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DroppableDirective.prototype.drakesService; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyb3BwYWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULEtBQUssRUFDTCxNQUFNLEVBSU4sVUFBVSxFQUNWLFlBQVksRUFDWixTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7O0lBRWhFLENBQUMsR0FBRyxLQUFLOzs7O0FBQ2IsU0FBUyxTQUFTO0lBQ2hCLE9BQU8sQ0FBQyxFQUFFLENBQUM7QUFDYixDQUFDOzs7Ozs7QUFRRCxNQUFNLE9BQU8sa0JBQWtCOzs7Ozs7SUFrQzdCLFlBQW9CLEVBQWMsRUFBVSxRQUFtQixFQUFVLGFBQWdDO1FBQXJGLE9BQUUsR0FBRixFQUFFLENBQVk7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQVUsa0JBQWEsR0FBYixhQUFhLENBQW1CO1FBaENoRyxTQUFJLEdBQUcsS0FBSyxDQUFDO1FBQ2Isa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFFdEIsY0FBUyxHQUF3QyxVQUFVLENBQUM7UUFFM0QsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsUUFBRyxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWpELFdBQU0sR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVwRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7SUFpQjhDLENBQUM7Ozs7SUFmN0csSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztJQUMvQixDQUFDOzs7O0lBRUQsSUFDSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUNqRSxDQUFDOzs7OztJQUNELElBQUksUUFBUSxDQUFDLEdBQVc7UUFDdEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLENBQUM7SUFDdkIsQ0FBQzs7OztJQU9ELFFBQVE7UUFDTixJQUFJLENBQUMsV0FBVyxHQUFHLHFCQUFxQixTQUFTLEVBQUUsSUFBSSxDQUFDO1FBQ3hELElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3BDLENBQUM7Ozs7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTOzs7UUFBQyxHQUFHLEVBQUU7WUFDdkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNwRCxDQUFDLEVBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUzs7O1FBQUMsR0FBRyxFQUFFO1lBQ3RCLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDdkQsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOzs7O0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2xDLENBQUM7OztZQXJERixTQUFTLFNBQUMsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUU7Ozs7WUFqQnZDLFVBQVU7WUFFVixTQUFTO1lBR0YsaUJBQWlCOzs7b0JBY3ZCLEtBQUs7bUJBQ0wsS0FBSzs0QkFDTCxLQUFLOzJCQUNMLEtBQUs7d0JBQ0wsS0FBSzttQkFFTCxNQUFNO21CQUVOLE1BQU07bUJBRU4sTUFBTTtrQkFFTixNQUFNO3FCQUVOLE1BQU07cUJBRU4sTUFBTTt1QkFNTixLQUFLOzs7O0lBdEJOLG1DQUFvQjs7SUFDcEIsa0NBQXNCOztJQUN0QiwyQ0FBK0I7O0lBQy9CLDBDQUE4Qjs7SUFDOUIsdUNBQXFFOztJQUVyRSxrQ0FBNEQ7O0lBRTVELGtDQUE0RDs7SUFFNUQsa0NBQTREOztJQUU1RCxpQ0FBMkQ7O0lBRTNELG9DQUE4RDs7SUFFOUQsb0NBQThEOztJQWM5RCx5Q0FBb0I7O0lBQ3BCLHVDQUFrQjs7Ozs7SUFFTixnQ0FBc0I7Ozs7O0lBQUUsc0NBQTJCOzs7OztJQUFFLDJDQUF3QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgT25Jbml0LFxuICBPbkRlc3Ryb3ksXG4gIEFmdGVyVmlld0luaXQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgUmVuZGVyZXIyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2RyYWtlLXN0b3JlLnNlcnZpY2UnO1xuXG5sZXQgaSA9IDEwMDAwO1xuZnVuY3Rpb24gZ2V0TmV4dElkKCkge1xuICByZXR1cm4gaSsrO1xufVxuXG4vKipcbiAqIE1ha2VzIHRoZSBjb250YWluZXIgZHJvcHBhYmxlIGFuZCBjaGlsZHJlbiBkcmFnZ2FibGUuXG4gKlxuICogQGV4cG9ydFxuICovXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbbmd4RHJvcHBhYmxlXScgfSlcbmV4cG9ydCBjbGFzcyBEcm9wcGFibGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG4gIEBJbnB1dCgpIGNvcHkgPSBmYWxzZTtcbiAgQElucHV0KCkgcmVtb3ZlT25TcGlsbCA9IGZhbHNlO1xuICBASW5wdXQoKSBuZ3hEcm9wcGFibGU6IHN0cmluZztcbiAgQElucHV0KCkgZGlyZWN0aW9uOiAndmVydGljYWwnIHwgJ2hvcml6b250YWwnIHwgJ21peGVkJyA9ICd2ZXJ0aWNhbCc7XG5cbiAgQE91dHB1dCgpIGRyb3A6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIGRyYWc6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG92ZXI6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG91dDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgcmVtb3ZlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBjYW5jZWw6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgZ2V0IGNvbnRhaW5lcigpOiBhbnkge1xuICAgIHJldHVybiB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQ7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgZHJvcFpvbmUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmUgfHwgdGhpcy5uZ3hEcm9wcGFibGUgfHwgdGhpcy5kZWZhdWx0Wm9uZTtcbiAgfVxuICBzZXQgZHJvcFpvbmUodmFsOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9kcm9wWm9uZSA9IHZhbDtcbiAgfVxuXG4gIGRlZmF1bHRab25lOiBzdHJpbmc7XG4gIF9kcm9wWm9uZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHJpdmF0ZSBkcmFrZXNTZXJ2aWNlOiBEcmFrZVN0b3JlU2VydmljZSkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmRlZmF1bHRab25lID0gYEBARGVmYXVsdERyb3Bab25lLSR7Z2V0TmV4dElkKCl9QEBgO1xuICAgIHRoaXMuZHJha2VzU2VydmljZS5yZWdpc3Rlcih0aGlzKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXIuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5jb250YWluZXIsICdndS1vdmVyJyk7XG4gICAgfSk7XG4gICAgdGhpcy5vdXQuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVuZGVyZXIucmVtb3ZlQ2xhc3ModGhpcy5jb250YWluZXIsICdndS1vdmVyJyk7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmRyYWtlc1NlcnZpY2UucmVtb3ZlKHRoaXMpO1xuICB9XG59XG4iXX0= | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "ngxDroppable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "direction", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "cancel", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String), | ||
__metadata("design:paramtypes", [String]) | ||
], DroppableDirective.prototype, "dropZone", null); | ||
DroppableDirective = __decorate([ | ||
Directive({ selector: '[ngxDroppable]' }), | ||
__metadata("design:paramtypes", [ElementRef, Renderer2, DrakeStoreService]) | ||
], DroppableDirective); | ||
export { DroppableDirective }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyb3BwYWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULEtBQUssRUFDTCxNQUFNLEVBQ04sTUFBTSxFQUNOLFNBQVMsRUFDVCxhQUFhLEVBQ2IsVUFBVSxFQUNWLFlBQVksRUFDWixTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFcEUsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDO0FBQ2QsU0FBUyxTQUFTO0lBQ2hCLE9BQU8sQ0FBQyxFQUFFLENBQUM7QUFDYixDQUFDO0FBRUQ7Ozs7R0FJRztBQUVILElBQWEsa0JBQWtCLEdBQS9CLE1BQWEsa0JBQWtCO0lBa0M3QixZQUFvQixFQUFjLEVBQVUsUUFBbUIsRUFBVSxhQUFnQztRQUFyRixPQUFFLEdBQUYsRUFBRSxDQUFZO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUFVLGtCQUFhLEdBQWIsYUFBYSxDQUFtQjtRQWhDaEcsU0FBSSxHQUFHLEtBQUssQ0FBQztRQUNiLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBRXRCLGNBQVMsR0FBd0MsVUFBVSxDQUFDO1FBRTNELFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFFBQUcsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVqRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFcEQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBaUI4QyxDQUFDO0lBZjdHLElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUM7SUFDL0IsQ0FBQztJQUdELElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDakUsQ0FBQztJQUNELElBQUksUUFBUSxDQUFDLEdBQVc7UUFDdEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLENBQUM7SUFDdkIsQ0FBQztJQU9ELFFBQVE7UUFDTixJQUFJLENBQUMsV0FBVyxHQUFHLHFCQUFxQixTQUFTLEVBQUUsSUFBSSxDQUFDO1FBQ3hELElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEQsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN2RCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQztDQUNGLENBQUE7O1lBbkJ5QixVQUFVO1lBQW9CLFNBQVM7WUFBeUIsaUJBQWlCOztBQWpDaEc7SUFBUixLQUFLLEVBQUU7O2lEQUFZO0FBQ1g7SUFBUixLQUFLLEVBQUU7O2dEQUFjO0FBQ2I7SUFBUixLQUFLLEVBQUU7O3lEQUF1QjtBQUN0QjtJQUFSLEtBQUssRUFBRTs7d0RBQXNCO0FBQ3JCO0lBQVIsS0FBSyxFQUFFOztxREFBNkQ7QUFFM0Q7SUFBVCxNQUFNLEVBQUU7OEJBQU8sWUFBWTtnREFBZ0M7QUFFbEQ7SUFBVCxNQUFNLEVBQUU7OEJBQU8sWUFBWTtnREFBZ0M7QUFFbEQ7SUFBVCxNQUFNLEVBQUU7OEJBQU8sWUFBWTtnREFBZ0M7QUFFbEQ7SUFBVCxNQUFNLEVBQUU7OEJBQU0sWUFBWTsrQ0FBZ0M7QUFFakQ7SUFBVCxNQUFNLEVBQUU7OEJBQVMsWUFBWTtrREFBZ0M7QUFFcEQ7SUFBVCxNQUFNLEVBQUU7OEJBQVMsWUFBWTtrREFBZ0M7QUFPOUQ7SUFEQyxLQUFLLEVBQUU7OztrREFHUDtBQTFCVSxrQkFBa0I7SUFEOUIsU0FBUyxDQUFDLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLENBQUM7cUNBbUNoQixVQUFVLEVBQW9CLFNBQVMsRUFBeUIsaUJBQWlCO0dBbEM5RixrQkFBa0IsQ0FxRDlCO1NBckRZLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgT25Jbml0LFxuICBPbkRlc3Ryb3ksXG4gIEFmdGVyVmlld0luaXQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgUmVuZGVyZXIyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2RyYWtlLXN0b3JlLnNlcnZpY2UnO1xuXG5sZXQgaSA9IDEwMDAwO1xuZnVuY3Rpb24gZ2V0TmV4dElkKCkge1xuICByZXR1cm4gaSsrO1xufVxuXG4vKipcbiAqIE1ha2VzIHRoZSBjb250YWluZXIgZHJvcHBhYmxlIGFuZCBjaGlsZHJlbiBkcmFnZ2FibGUuXG4gKlxuICogQGV4cG9ydFxuICovXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbbmd4RHJvcHBhYmxlXScgfSlcbmV4cG9ydCBjbGFzcyBEcm9wcGFibGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG4gIEBJbnB1dCgpIGNvcHkgPSBmYWxzZTtcbiAgQElucHV0KCkgcmVtb3ZlT25TcGlsbCA9IGZhbHNlO1xuICBASW5wdXQoKSBuZ3hEcm9wcGFibGU6IHN0cmluZztcbiAgQElucHV0KCkgZGlyZWN0aW9uOiAndmVydGljYWwnIHwgJ2hvcml6b250YWwnIHwgJ21peGVkJyA9ICd2ZXJ0aWNhbCc7XG5cbiAgQE91dHB1dCgpIGRyb3A6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIGRyYWc6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG92ZXI6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG91dDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgcmVtb3ZlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBjYW5jZWw6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgZ2V0IGNvbnRhaW5lcigpOiBhbnkge1xuICAgIHJldHVybiB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQ7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgZHJvcFpvbmUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmUgfHwgdGhpcy5uZ3hEcm9wcGFibGUgfHwgdGhpcy5kZWZhdWx0Wm9uZTtcbiAgfVxuICBzZXQgZHJvcFpvbmUodmFsOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9kcm9wWm9uZSA9IHZhbDtcbiAgfVxuXG4gIGRlZmF1bHRab25lOiBzdHJpbmc7XG4gIF9kcm9wWm9uZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHJpdmF0ZSBkcmFrZXNTZXJ2aWNlOiBEcmFrZVN0b3JlU2VydmljZSkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmRlZmF1bHRab25lID0gYEBARGVmYXVsdERyb3Bab25lLSR7Z2V0TmV4dElkKCl9QEBgO1xuICAgIHRoaXMuZHJha2VzU2VydmljZS5yZWdpc3Rlcih0aGlzKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXIuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5jb250YWluZXIsICdndS1vdmVyJyk7XG4gICAgfSk7XG4gICAgdGhpcy5vdXQuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVuZGVyZXIucmVtb3ZlQ2xhc3ModGhpcy5jb250YWluZXIsICdndS1vdmVyJyk7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmRyYWtlc1NlcnZpY2UucmVtb3ZlKHRoaXMpO1xuICB9XG59XG4iXX0= |
@@ -1,5 +0,3 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var NgxDnDModule_1; | ||
import { __decorate } from "tslib"; | ||
import { NgModule } from '@angular/core'; | ||
@@ -13,24 +11,20 @@ import { CommonModule } from '@angular/common'; | ||
import { DrakeStoreService } from './services/drake-store.service'; | ||
/** @type {?} */ | ||
const components = [ContainerComponent, ItemComponent]; | ||
/** @type {?} */ | ||
const directives = [DraggableDirective, DroppableDirective, DragHandleDirective]; | ||
export class NgxDnDModule { | ||
/** | ||
* @return {?} | ||
*/ | ||
let NgxDnDModule = NgxDnDModule_1 = class NgxDnDModule { | ||
static forRoot() { | ||
return { | ||
ngModule: NgxDnDModule, | ||
ngModule: NgxDnDModule_1, | ||
providers: [DrakeStoreService] | ||
}; | ||
} | ||
} | ||
NgxDnDModule.decorators = [ | ||
{ type: NgModule, args: [{ | ||
imports: [CommonModule], | ||
declarations: [...components, ...directives], | ||
exports: [...components, ...directives] | ||
},] } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRuZC5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtZG5kLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDMUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDaEYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDOztNQUc3RCxVQUFVLEdBQUcsQ0FBQyxrQkFBa0IsRUFBRSxhQUFhLENBQUM7O01BQ2hELFVBQVUsR0FBRyxDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLG1CQUFtQixDQUFDO0FBT2hGLE1BQU0sT0FBTyxZQUFZOzs7O0lBQ3ZCLE1BQU0sQ0FBQyxPQUFPO1FBQ2QsT0FBTztZQUNMLFFBQVEsRUFBRSxZQUFZO1lBQ3RCLFNBQVMsRUFBRSxDQUFFLGlCQUFpQixDQUFFO1NBQ2pDLENBQUM7SUFDSixDQUFDOzs7WUFYQSxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2dCQUN2QixZQUFZLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxHQUFHLFVBQVUsQ0FBQztnQkFDNUMsT0FBTyxFQUFFLENBQUMsR0FBRyxVQUFVLEVBQUUsR0FBRyxVQUFVLENBQUM7YUFDeEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgRHJhZ2dhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL25neC1kcmFnZ2FibGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyb3BwYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9uZ3gtZHJvcHBhYmxlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEcmFnSGFuZGxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL25neC1kcmFnLWhhbmRsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2NvbnRhaW5lci9jb250YWluZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvaXRlbS9pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZHJha2Utc3RvcmUuc2VydmljZSc7XG5pbXBvcnQgeyBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXIvc3JjL2NvcmUnO1xuXG5jb25zdCBjb21wb25lbnRzID0gW0NvbnRhaW5lckNvbXBvbmVudCwgSXRlbUNvbXBvbmVudF07XG5jb25zdCBkaXJlY3RpdmVzID0gW0RyYWdnYWJsZURpcmVjdGl2ZSwgRHJvcHBhYmxlRGlyZWN0aXZlLCBEcmFnSGFuZGxlRGlyZWN0aXZlXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogWy4uLmNvbXBvbmVudHMsIC4uLmRpcmVjdGl2ZXNdLFxuICBleHBvcnRzOiBbLi4uY29tcG9uZW50cywgLi4uZGlyZWN0aXZlc11cbn0pXG5leHBvcnQgY2xhc3MgTmd4RG5ETW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gIHJldHVybiB7XG4gICAgbmdNb2R1bGU6IE5neERuRE1vZHVsZSxcbiAgICBwcm92aWRlcnM6IFsgRHJha2VTdG9yZVNlcnZpY2UgXVxuICB9O1xufX1cbiJdfQ== | ||
}; | ||
NgxDnDModule = NgxDnDModule_1 = __decorate([ | ||
NgModule({ | ||
imports: [CommonModule], | ||
declarations: [...components, ...directives], | ||
exports: [...components, ...directives] | ||
}) | ||
], NgxDnDModule); | ||
export { NgxDnDModule }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRuZC5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtZG5kLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUduRSxNQUFNLFVBQVUsR0FBRyxDQUFDLGtCQUFrQixFQUFFLGFBQWEsQ0FBQyxDQUFDO0FBQ3ZELE1BQU0sVUFBVSxHQUFHLENBQUMsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsbUJBQW1CLENBQUMsQ0FBQztBQU9qRixJQUFhLFlBQVksb0JBQXpCLE1BQWEsWUFBWTtJQUN2QixNQUFNLENBQUMsT0FBTztRQUNaLE9BQU87WUFDTCxRQUFRLEVBQUUsY0FBWTtZQUN0QixTQUFTLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztTQUMvQixDQUFDO0lBQ0osQ0FBQztDQUNGLENBQUE7QUFQWSxZQUFZO0lBTHhCLFFBQVEsQ0FBQztRQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztRQUN2QixZQUFZLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxHQUFHLFVBQVUsQ0FBQztRQUM1QyxPQUFPLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxHQUFHLFVBQVUsQ0FBQztLQUN4QyxDQUFDO0dBQ1csWUFBWSxDQU94QjtTQVBZLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgRHJhZ2dhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL25neC1kcmFnZ2FibGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyb3BwYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9uZ3gtZHJvcHBhYmxlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEcmFnSGFuZGxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL25neC1kcmFnLWhhbmRsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2NvbnRhaW5lci9jb250YWluZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvaXRlbS9pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZHJha2Utc3RvcmUuc2VydmljZSc7XG5pbXBvcnQgeyBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXIvc3JjL2NvcmUnO1xuXG5jb25zdCBjb21wb25lbnRzID0gW0NvbnRhaW5lckNvbXBvbmVudCwgSXRlbUNvbXBvbmVudF07XG5jb25zdCBkaXJlY3RpdmVzID0gW0RyYWdnYWJsZURpcmVjdGl2ZSwgRHJvcHBhYmxlRGlyZWN0aXZlLCBEcmFnSGFuZGxlRGlyZWN0aXZlXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogWy4uLmNvbXBvbmVudHMsIC4uLmRpcmVjdGl2ZXNdLFxuICBleHBvcnRzOiBbLi4uY29tcG9uZW50cywgLi4uZGlyZWN0aXZlc11cbn0pXG5leHBvcnQgY2xhc3MgTmd4RG5ETW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBOZ3hEbkRNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtEcmFrZVN0b3JlU2VydmljZV1cbiAgICB9O1xuICB9XG59XG4iXX0= |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Injectable } from '@angular/core'; | ||
@@ -9,3 +6,2 @@ import * as dragulaNamespace from '@swimlane/dragula'; | ||
// see https://github.com/dherges/ng-packagr/issues/217 | ||
/** @type {?} */ | ||
const dragula = dragulaNamespace; | ||
@@ -17,3 +13,3 @@ /** | ||
*/ | ||
export class DrakeStoreService { | ||
let DrakeStoreService = class DrakeStoreService { | ||
constructor() { | ||
@@ -26,6 +22,2 @@ this.droppableMap = new WeakMap(); | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
register(droppable) { | ||
@@ -35,9 +27,4 @@ this.droppableMap.set(droppable.container, droppable); | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
remove(droppable) { | ||
this.droppableMap.delete(droppable.container); | ||
/** @type {?} */ | ||
const idx = this.drake.containers.indexOf(droppable.container); | ||
@@ -48,33 +35,14 @@ if (idx > -1) { | ||
} | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
registerDraggable(draggable) { | ||
this.draggableMap.set(draggable.element, draggable); | ||
} | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
removeDraggable(draggable) { | ||
this.draggableMap.delete(draggable.element); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
createDrakeOptions() { | ||
/** @type {?} */ | ||
const accepts = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @return {?} | ||
*/ | ||
(el, target /*, source: any, sibling: any */) => { | ||
const accepts = (el, target /*, source: any, sibling: any */) => { | ||
if (el.contains(target)) { | ||
return false; | ||
} | ||
/** @type {?} */ | ||
const elementComponent = this.draggableMap.get(el); | ||
/** @type {?} */ | ||
const targetComponent = this.droppableMap.get(target); | ||
@@ -85,11 +53,4 @@ if (elementComponent && targetComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
const copy = (/** | ||
* @param {?} _ | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(_, source) => { | ||
/** @type {?} */ | ||
}; | ||
const copy = (_, source) => { | ||
const sourceComponent = this.droppableMap.get(source); | ||
@@ -100,13 +61,4 @@ if (sourceComponent) { | ||
return false; | ||
}); | ||
/** @type {?} */ | ||
const moves = (/** | ||
* @param {?=} el | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
(el, source, handle, sibling) => { | ||
/** @type {?} */ | ||
}; | ||
const moves = (el, source, handle, sibling) => { | ||
const elementComponent = this.draggableMap.get(el); | ||
@@ -117,31 +69,13 @@ if (elementComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
const direction = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, target, source) => { | ||
/** @type {?} */ | ||
}; | ||
const direction = (el, target, source) => { | ||
const targetComponent = this.droppableMap.get(target); | ||
return targetComponent.direction || 'vertical'; | ||
}); | ||
}; | ||
return { accepts, copy, moves, revertOnSpill: true, direction }; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
registerEvents() { | ||
/** @type {?} */ | ||
let dragElm; | ||
/** @type {?} */ | ||
let draggedItem; | ||
this.drake.on('drag', (/** | ||
* @param {?} el | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, source) => { | ||
this.drake.on('drag', (el, source) => { | ||
draggedItem = undefined; | ||
@@ -153,3 +87,2 @@ dragElm = el; | ||
if (this.draggableMap.has(el)) { | ||
/** @type {?} */ | ||
const elementComponent = this.draggableMap.get(el); | ||
@@ -165,3 +98,2 @@ draggedItem = elementComponent.model; | ||
if (this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
const sourceComponent = this.droppableMap.get(source); | ||
@@ -177,11 +109,4 @@ this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill; | ||
} | ||
})); | ||
this.drake.on('drop', (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, target, source) => { | ||
/** @type {?} */ | ||
}); | ||
this.drake.on('drop', (el, target, source) => { | ||
const targetComponent = this.droppableMap.get(target); | ||
@@ -192,5 +117,3 @@ if (!targetComponent) { | ||
} | ||
/** @type {?} */ | ||
let dropElmModel = draggedItem; | ||
/** @type {?} */ | ||
const dropIndex = Array.prototype.indexOf.call(target.children, el); | ||
@@ -202,12 +125,7 @@ if (dropIndex < 0) { | ||
} | ||
/** @type {?} */ | ||
const sourceComponent = this.droppableMap.get(source); | ||
if (sourceComponent) { | ||
/** @type {?} */ | ||
const sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
const targetModel = targetComponent.model; | ||
/** @type {?} */ | ||
const hasDragModel = !!(sourceModel && draggedItem); | ||
/** @type {?} */ | ||
const dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -220,5 +138,3 @@ if (hasDragModel && dragIndex < 0) { | ||
if (targetModel) { | ||
/** @type {?} */ | ||
const reorder = dragIndex > -1 && sourceModel && target === source; | ||
/** @type {?} */ | ||
const copy = !sourceModel || dragElm !== el; | ||
@@ -253,16 +169,7 @@ if (reorder) { | ||
}); | ||
})); | ||
this.drake.on('remove', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('remove', (el, container, source) => { | ||
if (this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
const sourceComponent = this.droppableMap.get(source); | ||
/** @type {?} */ | ||
const sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
const dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -284,12 +191,5 @@ if (dragIndex > -1) { | ||
} | ||
})); | ||
this.drake.on('cancel', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('cancel', (el, container, source) => { | ||
if (this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
const containerComponent = this.droppableMap.get(container); | ||
@@ -304,12 +204,5 @@ containerComponent.cancel.emit({ | ||
} | ||
})); | ||
this.drake.on('over', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('over', (el, container, source) => { | ||
if (this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
const containerComponent = this.droppableMap.get(container); | ||
@@ -324,12 +217,5 @@ containerComponent.over.emit({ | ||
} | ||
})); | ||
this.drake.on('out', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('out', (el, container, source) => { | ||
if (this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
const containerComponent = this.droppableMap.get(container); | ||
@@ -344,33 +230,11 @@ containerComponent.out.emit({ | ||
} | ||
})); | ||
}); | ||
} | ||
} | ||
DrakeStoreService.decorators = [ | ||
{ type: Injectable, args: [{ providedIn: 'root' },] } | ||
]; | ||
/** @nocollapse */ | ||
DrakeStoreService.ctorParameters = () => []; | ||
/** @nocollapse */ DrakeStoreService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
if (false) { | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.droppableMap; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.draggableMap; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.dragulaOptions; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.drake; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drake-store.service.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/services/drake-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport * as dragulaNamespace from '@swimlane/dragula';\nimport { DroppableDirective } from '../directives/ngx-droppable.directive';\nimport { DraggableDirective } from '../directives/ngx-draggable.directive';\n\n// see https://github.com/dherges/ng-packagr/issues/217\nconst dragula = dragulaNamespace;\n\n/**\n * Central service that handles all events\n *\n * @export\n */\n@Injectable({ providedIn: 'root' })\nexport class DrakeStoreService {\n  private droppableMap = new WeakMap<any, DroppableDirective>();\n  private draggableMap = new WeakMap<any, DraggableDirective>();\n  private dragulaOptions: dragulaNamespace.DragulaOptions;\n  private drake: dragulaNamespace.Drake;\n\n  constructor() {\n    this.dragulaOptions = this.createDrakeOptions();\n    this.drake = dragula([], this.dragulaOptions);\n    this.registerEvents();    \n  }\n\n  register(droppable: DroppableDirective) {\n    this.droppableMap.set(droppable.container, droppable);\n    this.drake.containers.push(droppable.container);\n  }\n\n  remove(droppable: DroppableDirective) {\n    this.droppableMap.delete(droppable.container);\n    const idx = this.drake.containers.indexOf(droppable.container);\n    if (idx > -1) {\n      this.drake.containers.splice(idx, 1);\n    }\n  }\n\n  registerDraggable(draggable: DraggableDirective) {\n    this.draggableMap.set(draggable.element, draggable);\n  }\n\n  removeDraggable(draggable: DraggableDirective) {\n    this.draggableMap.delete(draggable.element);\n  }\n\n  createDrakeOptions(): dragulaNamespace.DragulaOptions {\n    const accepts = (el: any, target: any /*, source: any, sibling: any */) => {\n      if (el.contains(target)) {\n        return false;\n      }\n      const elementComponent = this.draggableMap.get(el);\n      const targetComponent = this.droppableMap.get(target);\n      if (elementComponent && targetComponent) {\n        return elementComponent.dropZones.includes(targetComponent.dropZone);\n      }\n      return true;\n    };\n\n    const copy = (_: any, source: any) => {\n      const sourceComponent = this.droppableMap.get(source);\n      if (sourceComponent) {\n        return sourceComponent.copy;\n      }\n      return false;\n    };\n\n    const moves = (el?: any, source?: any, handle?: any, sibling?: any) => {\n      const elementComponent = this.draggableMap.get(el);\n      if (elementComponent) {\n        return elementComponent.moves(source, handle, sibling);\n      }\n      return true;\n    };\n\n    const direction: any = (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n      return targetComponent.direction || 'vertical';\n    };\n\n    return { accepts, copy, moves, revertOnSpill: true, direction };\n  }\n\n  registerEvents(): void {\n    let dragElm: any;\n    let draggedItem: any;\n\n    this.drake.on('drag', (el: any, source: any) => {\n      draggedItem = undefined;\n      dragElm = el;\n\n      if (!el || !source) {\n        return;\n      }\n\n      if (this.draggableMap.has(el)) {\n        const elementComponent = this.draggableMap.get(el);\n        draggedItem = elementComponent.model;\n\n        elementComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          value: draggedItem\n        });\n      }\n\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill;\n\n        sourceComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          sourceComponent,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('drop', (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n\n      if (!targetComponent) {\n        // not a target, abort\n        return;\n      }\n\n      let dropElmModel = draggedItem;\n      const dropIndex = Array.prototype.indexOf.call(target.children, el);\n\n      if (dropIndex < 0) {\n        // dropIndex is bad... cancel\n        this.drake.cancel(true);\n        return;\n      }\n\n      const sourceComponent = this.droppableMap.get(source);\n\n      if (sourceComponent) {\n        const sourceModel = sourceComponent.model;\n        const targetModel = targetComponent.model;\n\n        const hasDragModel = !!(sourceModel && draggedItem);\n        const dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1;\n        if (hasDragModel && dragIndex < 0) {\n          // dragIndex is bad... cancel\n          this.drake.cancel(true);\n          return;\n        }\n\n        if (targetModel) {\n          const reorder = dragIndex > -1 && sourceModel && target === source;\n          const copy = !sourceModel || dragElm !== el;\n          if (reorder) {\n            sourceModel.splice(dropIndex, 0, sourceModel.splice(dragIndex, 1)[0]);\n          } else {\n            if (el.parentNode === target) {\n              target.removeChild(el);\n            }\n\n            if (copy) {\n              dropElmModel = JSON.parse(JSON.stringify(dropElmModel));\n            } else {\n              if (el.parentNode !== source) {\n                // add element back, let angular remove it\n                this.drake.cancel(true);\n              }\n              sourceModel.splice(dragIndex, 1);\n            }\n            targetModel.splice(dropIndex, 0, dropElmModel);\n          }\n        }\n      }\n\n      targetComponent.drop.emit({\n        type: 'drop',\n        el,\n        source,\n        value: dropElmModel,\n        dropIndex\n      });\n    });\n\n    this.drake.on('remove', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        const sourceModel = sourceComponent.model;\n\n        const dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1;\n\n        if (dragIndex > -1) {\n          if (el.parentNode !== source) {\n            // add element back, let angular remove it\n            source.appendChild(el);\n          }\n          sourceModel.splice(dragIndex, 1);\n        }\n\n        sourceComponent.remove.emit({\n          type: 'remove',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('cancel', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.cancel.emit({\n          type: 'cancel',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('over', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.over.emit({\n          type: 'over',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('out', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.out.emit({\n          type: 'out',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n  }\n}\n"]} | ||
}; | ||
DrakeStoreService.ɵprov = i0.ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService = __decorate([ | ||
Injectable({ providedIn: 'root' }), | ||
__metadata("design:paramtypes", []) | ||
], DrakeStoreService); | ||
export { DrakeStoreService }; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drake-store.service.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/services/drake-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport * as dragulaNamespace from '@swimlane/dragula';\nimport { DroppableDirective } from '../directives/ngx-droppable.directive';\nimport { DraggableDirective } from '../directives/ngx-draggable.directive';\n\n// see https://github.com/dherges/ng-packagr/issues/217\nconst dragula = dragulaNamespace;\n\n/**\n * Central service that handles all events\n *\n * @export\n */\n@Injectable({ providedIn: 'root' })\nexport class DrakeStoreService {\n  private droppableMap = new WeakMap<any, DroppableDirective>();\n  private draggableMap = new WeakMap<any, DraggableDirective>();\n  private dragulaOptions: dragulaNamespace.DragulaOptions;\n  private drake: dragulaNamespace.Drake;\n\n  constructor() {\n    this.dragulaOptions = this.createDrakeOptions();\n    this.drake = dragula([], this.dragulaOptions);\n    this.registerEvents();\n  }\n\n  register(droppable: DroppableDirective) {\n    this.droppableMap.set(droppable.container, droppable);\n    this.drake.containers.push(droppable.container);\n  }\n\n  remove(droppable: DroppableDirective) {\n    this.droppableMap.delete(droppable.container);\n    const idx = this.drake.containers.indexOf(droppable.container);\n    if (idx > -1) {\n      this.drake.containers.splice(idx, 1);\n    }\n  }\n\n  registerDraggable(draggable: DraggableDirective) {\n    this.draggableMap.set(draggable.element, draggable);\n  }\n\n  removeDraggable(draggable: DraggableDirective) {\n    this.draggableMap.delete(draggable.element);\n  }\n\n  createDrakeOptions(): dragulaNamespace.DragulaOptions {\n    const accepts = (el: any, target: any /*, source: any, sibling: any */) => {\n      if (el.contains(target)) {\n        return false;\n      }\n      const elementComponent = this.draggableMap.get(el);\n      const targetComponent = this.droppableMap.get(target);\n      if (elementComponent && targetComponent) {\n        return elementComponent.dropZones.includes(targetComponent.dropZone);\n      }\n      return true;\n    };\n\n    const copy = (_: any, source: any) => {\n      const sourceComponent = this.droppableMap.get(source);\n      if (sourceComponent) {\n        return sourceComponent.copy;\n      }\n      return false;\n    };\n\n    const moves = (el?: any, source?: any, handle?: any, sibling?: any) => {\n      const elementComponent = this.draggableMap.get(el);\n      if (elementComponent) {\n        return elementComponent.moves(source, handle, sibling);\n      }\n      return true;\n    };\n\n    const direction: any = (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n      return targetComponent.direction || 'vertical';\n    };\n\n    return { accepts, copy, moves, revertOnSpill: true, direction };\n  }\n\n  registerEvents(): void {\n    let dragElm: any;\n    let draggedItem: any;\n\n    this.drake.on('drag', (el: any, source: any) => {\n      draggedItem = undefined;\n      dragElm = el;\n\n      if (!el || !source) {\n        return;\n      }\n\n      if (this.draggableMap.has(el)) {\n        const elementComponent = this.draggableMap.get(el);\n        draggedItem = elementComponent.model;\n\n        elementComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          value: draggedItem\n        });\n      }\n\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill;\n\n        sourceComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          sourceComponent,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('drop', (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n\n      if (!targetComponent) {\n        // not a target, abort\n        return;\n      }\n\n      let dropElmModel = draggedItem;\n      const dropIndex = Array.prototype.indexOf.call(target.children, el);\n\n      if (dropIndex < 0) {\n        // dropIndex is bad... cancel\n        this.drake.cancel(true);\n        return;\n      }\n\n      const sourceComponent = this.droppableMap.get(source);\n\n      if (sourceComponent) {\n        const sourceModel = sourceComponent.model;\n        const targetModel = targetComponent.model;\n\n        const hasDragModel = !!(sourceModel && draggedItem);\n        const dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1;\n        if (hasDragModel && dragIndex < 0) {\n          // dragIndex is bad... cancel\n          this.drake.cancel(true);\n          return;\n        }\n\n        if (targetModel) {\n          const reorder = dragIndex > -1 && sourceModel && target === source;\n          const copy = !sourceModel || dragElm !== el;\n          if (reorder) {\n            sourceModel.splice(dropIndex, 0, sourceModel.splice(dragIndex, 1)[0]);\n          } else {\n            if (el.parentNode === target) {\n              target.removeChild(el);\n            }\n\n            if (copy) {\n              dropElmModel = JSON.parse(JSON.stringify(dropElmModel));\n            } else {\n              if (el.parentNode !== source) {\n                // add element back, let angular remove it\n                this.drake.cancel(true);\n              }\n              sourceModel.splice(dragIndex, 1);\n            }\n            targetModel.splice(dropIndex, 0, dropElmModel);\n          }\n        }\n      }\n\n      targetComponent.drop.emit({\n        type: 'drop',\n        el,\n        source,\n        value: dropElmModel,\n        dropIndex\n      });\n    });\n\n    this.drake.on('remove', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        const sourceModel = sourceComponent.model;\n\n        const dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1;\n\n        if (dragIndex > -1) {\n          if (el.parentNode !== source) {\n            // add element back, let angular remove it\n            source.appendChild(el);\n          }\n          sourceModel.splice(dragIndex, 1);\n        }\n\n        sourceComponent.remove.emit({\n          type: 'remove',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('cancel', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.cancel.emit({\n          type: 'cancel',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('over', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.over.emit({\n          type: 'over',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('out', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.out.emit({\n          type: 'out',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n  }\n}\n"]} |
@@ -1,6 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { NgxDnDModule } from './lib/ngx-dnd.module'; | ||
export * from './lib/ngx-dnd.module'; | ||
export { DraggableDirective } from './lib/directives/ngx-draggable.directive'; | ||
@@ -12,2 +8,2 @@ export { DroppableDirective } from './lib/directives/ngx-droppable.directive'; | ||
export { DrakeStoreService } from './lib/services/drake-store.service'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsicHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsNkJBQWMsc0JBQXNCLENBQUM7QUFDckMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDOUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDOUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDakYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbmd4LWRuZC5tb2R1bGUnO1xuZXhwb3J0IHsgRHJhZ2dhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9uZ3gtZHJhZ2dhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBEcm9wcGFibGVEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCB7IERyYWdIYW5kbGVEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL25neC1kcmFnLWhhbmRsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgSXRlbUNvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvaXRlbS9pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2NvbnRhaW5lci9jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IERyYWtlU3RvcmVTZXJ2aWNlIH0gZnJvbSAnLi9saWIvc2VydmljZXMvZHJha2Utc3RvcmUuc2VydmljZSc7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsicHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUNwRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL25neC1kbmQubW9kdWxlJztcbmV4cG9ydCB7IERyYWdnYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvbmd4LWRyYWdnYWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgRHJvcHBhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9uZ3gtZHJvcHBhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBEcmFnSGFuZGxlRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9uZ3gtZHJhZy1oYW5kbGUuZGlyZWN0aXZlJztcbmV4cG9ydCB7IEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2l0ZW0vaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4vbGliL3NlcnZpY2VzL2RyYWtlLXN0b3JlLnNlcnZpY2UnO1xuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
export { DraggableDirective, DroppableDirective, DragHandleDirective, ItemComponent, ContainerComponent, DrakeStoreService, NgxDnDModule } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpbWxhbmUtbmd4LWRuZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsic3dpbWxhbmUtbmd4LWRuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsZ0pBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19 | ||
export * from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpbWxhbmUtbmd4LWRuZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsic3dpbWxhbmUtbmd4LWRuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19 |
@@ -1,12 +0,5 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Component, Input, Output, ViewEncapsulation, ContentChild, TemplateRef, ViewChild, EventEmitter } from '@angular/core'; | ||
import { DroppableDirective } from '../../directives/ngx-droppable.directive'; | ||
/** @type {?} */ | ||
var i = 0; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -33,13 +26,6 @@ return i++; | ||
Object.defineProperty(ContainerComponent.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this._defaultZones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -53,10 +39,3 @@ }, | ||
// @Input() dragulaOptions: any; | ||
set: | ||
// @Input() classes: any = {}; | ||
// @Input() dragulaOptions: any; | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
function (template) { | ||
set: function (template) { | ||
this.template = template; | ||
@@ -68,7 +47,3 @@ }, | ||
Object.defineProperty(ContainerComponent.prototype, "templateChild", { | ||
set: /** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
function (template) { | ||
set: function (template) { | ||
this.template = template; | ||
@@ -79,113 +54,92 @@ }, | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
ContainerComponent.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ContainerComponent.prototype.ngOnInit = function () { | ||
this._defaultZones = [this.dropZone]; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ContainerComponent.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ContainerComponent.prototype.ngAfterViewInit = function () { | ||
var _this = this; | ||
this.droppable.drag.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.drag.emit(v); })); | ||
this.droppable.drop.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.drop.emit(v); })); | ||
this.droppable.over.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.over.emit(v); })); | ||
this.droppable.out.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.out.emit(v); })); | ||
this.droppable.remove.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.remove.emit(v); })); | ||
this.droppable.cancel.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.cancel.emit(v); })); | ||
this.droppable.drag.subscribe(function (v) { return _this.drag.emit(v); }); | ||
this.droppable.drop.subscribe(function (v) { return _this.drop.emit(v); }); | ||
this.droppable.over.subscribe(function (v) { return _this.over.emit(v); }); | ||
this.droppable.out.subscribe(function (v) { return _this.out.emit(v); }); | ||
this.droppable.remove.subscribe(function (v) { return _this.remove.emit(v); }); | ||
this.droppable.cancel.subscribe(function (v) { return _this.cancel.emit(v); }); | ||
}; | ||
ContainerComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}] } | ||
]; | ||
ContainerComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
moves: [{ type: Input }], | ||
templateInput: [{ type: Input, args: ['template',] }], | ||
templateChild: [{ type: ContentChild, args: [TemplateRef, { static: true },] }], | ||
droppable: [{ type: ViewChild, args: [DroppableDirective, { static: true },] }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppableItemClass", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "dropZone", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ContainerComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Function) | ||
], ContainerComponent.prototype, "moves", void 0); | ||
__decorate([ | ||
Input('template'), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateInput", null); | ||
__decorate([ | ||
ContentChild(TemplateRef, { static: true }), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateChild", null); | ||
__decorate([ | ||
ViewChild(DroppableDirective, { static: true }), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppable", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "cancel", void 0); | ||
ContainerComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}) | ||
], ContainerComponent); | ||
return ContainerComponent; | ||
}()); | ||
export { ContainerComponent }; | ||
if (false) { | ||
/** @type {?} */ | ||
ContainerComponent.prototype.model; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.copy; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.removeOnSpill; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.droppableItemClass; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.dropZone; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.moves; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.template; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.droppable; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.drop; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.drag; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.over; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.out; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.remove; | ||
/** @type {?} */ | ||
ContainerComponent.prototype.cancel; | ||
/** @type {?} */ | ||
ContainerComponent.prototype._dropZones; | ||
/** @type {?} */ | ||
ContainerComponent.prototype._defaultZones; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2NvbXBvbmVudHMvY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFDTCxTQUFTLEVBR1QsS0FBSyxFQUNMLE1BQU0sRUFDTixpQkFBaUIsRUFDakIsWUFBWSxFQUNaLFdBQVcsRUFDWCxTQUFTLEVBQ1QsWUFBWSxFQUNiLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOztJQUUxRSxDQUFDLEdBQUcsQ0FBQzs7OztBQUNULFNBQVMsU0FBUztJQUNoQixPQUFPLENBQUMsRUFBRSxDQUFDO0FBQ2IsQ0FBQzs7Ozs7O0FBT0Q7SUFBQTtRQVFXLFNBQUksR0FBRyxLQUFLLENBQUM7UUFDYixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUd0QixhQUFRLEdBQUcsdUJBQXFCLFNBQVMsRUFBRSxPQUFJLENBQUM7UUE4Qi9DLFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFFBQUcsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVqRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFcEQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBaUJoRSxDQUFDO0lBdkRDLHNCQUNJLHlDQUFTOzs7O1FBRGI7WUFFRSxPQUFPLElBQUksQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUMvQyxDQUFDOzs7OztRQUNELFVBQWMsR0FBRztZQUNmLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxDQUFDO1FBQ3hCLENB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cG9ydCB7XG4gIENvbXBvbmVudCxcbiAgT25Jbml0LFxuICBBZnRlclZpZXdJbml0LFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbiAgQ29udGVudENoaWxkLFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NoaWxkLFxuICBFdmVudEVtaXR0ZXJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IERyb3BwYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvbmd4LWRyb3BwYWJsZS5kaXJlY3RpdmUnO1xuXG5sZXQgaSA9IDA7XG5mdW5jdGlvbiBnZXROZXh0SWQoKSB7XG4gIHJldHVybiBpKys7XG59XG5cbi8qKlxuICogQ29tcG9uZW50IHRoYXQgYWxsb3dzIG5lc3RlZCBuZ3hEcm9wcGFibGUgYW5kIG5neERyYWdnYWJsZXNcbiAqXG4gKiBAZXhwb3J0XG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25neC1kbmQtY29udGFpbmVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NvbnRhaW5lci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NvbnRhaW5lci5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIENvbnRhaW5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG4gIEBJbnB1dCgpIGNvcHkgPSBmYWxzZTtcbiAgQElucHV0KCkgcmVtb3ZlT25TcGlsbCA9IGZhbHNlO1xuICBASW5wdXQoKSBkcm9wcGFibGVJdGVtQ2xhc3M6IHN0cmluZyB8ICgobzogYW55KSA9PiBhbnkpO1xuXG4gIEBJbnB1dCgpIGRyb3Bab25lID0gYEBARGVmYXVsdERyb3Bab25lLSR7Z2V0TmV4dElkKCl9QEBgO1xuXG4gIEBJbnB1dCgpXG4gIGdldCBkcm9wWm9uZXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2Ryb3Bab25lcyB8fCB0aGlzLl9kZWZhdWx0Wm9uZXM7XG4gIH1cbiAgc2V0IGRyb3Bab25lcyh2YWwpIHtcbiAgICB0aGlzLl9kcm9wWm9uZXMgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKSBtb3ZlczogKG1vZGVsOiBhbnksIHNvdXJjZTogYW55LCBoYW5kbGU6IGFueSwgc2libGluZzogYW55KSA9PiBib29sZWFuO1xuXG4gIC8vIEBJbnB1dCgpIGNsYXNzZXM6IGFueSA9IHt9O1xuICAvLyBASW5wdXQoKSBkcmFndWxhT3B0aW9uczogYW55O1xuXG4gIEBJbnB1dCgndGVtcGxhdGUnKVxuICBzZXQgdGVtcGxhdGVJbnB1dCh0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55Pikge1xuICAgIHRoaXMudGVtcGxhdGUgPSB0ZW1wbGF0ZTtcbiAgfVxuXG4gIEBDb250ZW50Q2hpbGQoVGVtcGxhdGVSZWYsIHsgc3RhdGljOiB0cnVlIH0pXG4gIHNldCB0ZW1wbGF0ZUNoaWxkKHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgdGhpcy50ZW1wbGF0ZSA9IHRlbXBsYXRlO1xuICB9XG5cbiAgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgQFZpZXdDaGlsZChEcm9wcGFibGVEaXJlY3RpdmUsIHsgc3RhdGljOiB0cnVlIH0pXG4gIGRyb3BwYWJsZTogYW55O1xuXG4gIEBPdXRwdXQoKSBkcm9wOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBkcmFnOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBvdmVyOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBvdXQ6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIHJlbW92ZTogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgY2FuY2VsOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIF9kcm9wWm9uZXM6IHN0cmluZ1tdO1xuICBfZGVmYXVsdFpvbmVzOiBzdHJpbmdbXTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLl9kZWZhdWx0Wm9uZXMgPSBbdGhpcy5kcm9wWm9uZV07XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5kcm9wcGFibGUuZHJhZy5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5kcmFnLmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLmRyb3Auc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMuZHJvcC5lbWl0KHYpKTtcbiAgICB0aGlzLmRyb3BwYWJsZS5vdmVyLnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLm92ZXIuZW1pdCh2KSk7XG4gICAgdGhpcy5kcm9wcGFibGUub3V0LnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLm91dC5lbWl0KHYpKTtcbiAgICB0aGlzLmRyb3BwYWJsZS5yZW1vdmUuc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMucmVtb3ZlLmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLmNhbmNlbC5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5jYW5jZWwuZW1pdCh2KSk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2NvbXBvbmVudHMvY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxTQUFTLEVBR1QsS0FBSyxFQUNMLE1BQU0sRUFDTixpQkFBaUIsRUFDakIsWUFBWSxFQUNaLFdBQVcsRUFDWCxTQUFTLEVBQ1QsWUFBWSxFQUNiLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRTlFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUNWLFNBQVMsU0FBUztJQUNoQixPQUFPLENBQUMsRUFBRSxDQUFDO0FBQ2IsQ0FBQztBQUVEOzs7O0dBSUc7QUFPSDtJQUFBO1FBRVcsU0FBSSxHQUFHLEtBQUssQ0FBQztRQUNiLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBR3RCLGFBQVEsR0FBRyx1QkFBcUIsU0FBUyxFQUFFLE9BQUksQ0FBQztRQThCL0MsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsUUFBRyxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWpELFdBQU0sR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVwRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7SUFpQmhFLENBQUM7SUF0REMsc0JBQUkseUNBQVM7YUFBYjtZQUNFLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDO1FBQy9DLENBQUM7YUFDRCxVQUFjLEdBQUc7WUFDZixJQUFJLENBQUMsVUFBVSxHQUFHLEdBQUcsQ0FBQztRQUN4QixDQUFDOzs7T0FIQTtJQVdELHNCQUFJLDZDQUFhO1FBSmpCLDhCQUE4QjtRQUM5QixnQ0FBZ0M7YUFHaEMsVUFBa0IsUUFBMEI7WUFDMUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7UUFDM0IsQ0FBQzs7O09BQUE7SUFHRCxzQkFBSSw2Q0FBYTthQUFqQixVQUFrQixRQUEwQjtZQUMxQyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUMzQixDQUFDOzs7T0FBQTtJQXNCRCxxQ0FBUSxHQUFSO1FBQ0UsSUFBSSxDQUFDLGFBQWEsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsNENBQWUsR0FBZjtRQUFBLGlCQU9DO1FBTkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQUMsQ0FBTSxJQUFLLE9BQUEsS0FBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQWpCLENBQWlCLENBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBQyxDQUFNLElBQUssT0FBQSxLQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBakIsQ0FBaUIsQ0FBQyxDQUFDO1FBQzdELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFDLENBQU0sSUFBSyxPQUFBLEtBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFqQixDQUFpQixDQUFDLENBQUM7UUFDN0QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLFVBQUMsQ0FBTSxJQUFLLE9BQUEsS0FBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQWhCLENBQWdCLENBQUMsQ0FBQztRQUMzRCxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsVUFBQyxDQUFNLElBQUssT0FBQSxLQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBbkIsQ0FBbUIsQ0FBQyxDQUFDO1FBQ2pFLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxVQUFDLENBQU0sSUFBSyxPQUFBLEtBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFuQixDQUFtQixDQUFDLENBQUM7SUFDbkUsQ0FBQztJQTdEUTtRQUFSLEtBQUssRUFBRTs7cURBQVk7SUFDWDtRQUFSLEtBQUssRUFBRTs7b0RBQWM7SUFDYjtRQUFSLEtBQUssRUFBRTs7NkRBQXVCO0lBQ3RCO1FBQVIsS0FBSyxFQUFFOztrRUFBZ0Q7SUFFL0M7UUFBUixLQUFLLEVBQUU7O3dEQUFpRDtJQUd6RDtRQURDLEtBQUssRUFBRTs7O3VEQUdQO0lBS1E7UUFBUixLQUFLLEVBQUU7O3FEQUF3RTtJQU1oRjtRQURDLEtBQUssQ0FBQyxVQUFVLENBQUM7a0NBQ1UsV0FBVzt5Q0FBWCxXQUFXOzJEQUV0QztJQUdEO1FBREMsWUFBWSxDQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQztrQ0FDaEIsV0FBVzt5Q0FBWCxXQUFXOzJEQUV0QztJQUtEO1FBREMsU0FBUyxDQUFDLGtCQUFrQixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDOzt5REFDakM7SUFFTDtRQUFULE1BQU0sRUFBRTtrQ0FBTyxZQUFZO29EQUFnQztJQUVsRDtRQUFULE1BQU0sRUFBRTtrQ0FBTyxZQUFZO29EQUFnQztJQUVsRDtRQUFULE1BQU0sRUFBRTtrQ0FBTyxZQUFZO29EQUFnQztJQUVsRDtRQUFULE1BQU0sRUFBRTtrQ0FBTSxZQUFZO21EQUFnQztJQUVqRDtRQUFULE1BQU0sRUFBRTtrQ0FBUyxZQUFZO3NEQUFnQztJQUVwRDtRQUFULE1BQU0sRUFBRTtrQ0FBUyxZQUFZO3NEQUFnQztJQTlDbkQsa0JBQWtCO1FBTjlCLFNBQVMsQ0FBQztZQUNULFFBQVEsRUFBRSxtQkFBbUI7WUFDN0IsOHJCQUF5QztZQUV6QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTs7U0FDdEMsQ0FBQztPQUNXLGtCQUFrQixDQStEOUI7SUFBRCx5QkFBQztDQUFBLEFBL0RELElBK0RDO1NBL0RZLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgT25Jbml0LFxuICBBZnRlclZpZXdJbml0LFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbiAgQ29udGVudENoaWxkLFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NoaWxkLFxuICBFdmVudEVtaXR0ZXJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IERyb3BwYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvbmd4LWRyb3BwYWJsZS5kaXJlY3RpdmUnO1xuXG5sZXQgaSA9IDA7XG5mdW5jdGlvbiBnZXROZXh0SWQoKSB7XG4gIHJldHVybiBpKys7XG59XG5cbi8qKlxuICogQ29tcG9uZW50IHRoYXQgYWxsb3dzIG5lc3RlZCBuZ3hEcm9wcGFibGUgYW5kIG5neERyYWdnYWJsZXNcbiAqXG4gKiBAZXhwb3J0XG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25neC1kbmQtY29udGFpbmVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NvbnRhaW5lci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NvbnRhaW5lci5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIENvbnRhaW5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG4gIEBJbnB1dCgpIGNvcHkgPSBmYWxzZTtcbiAgQElucHV0KCkgcmVtb3ZlT25TcGlsbCA9IGZhbHNlO1xuICBASW5wdXQoKSBkcm9wcGFibGVJdGVtQ2xhc3M6IHN0cmluZyB8ICgobzogYW55KSA9PiBhbnkpO1xuXG4gIEBJbnB1dCgpIGRyb3Bab25lID0gYEBARGVmYXVsdERyb3Bab25lLSR7Z2V0TmV4dElkKCl9QEBgO1xuXG4gIEBJbnB1dCgpXG4gIGdldCBkcm9wWm9uZXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2Ryb3Bab25lcyB8fCB0aGlzLl9kZWZhdWx0Wm9uZXM7XG4gIH1cbiAgc2V0IGRyb3Bab25lcyh2YWwpIHtcbiAgICB0aGlzLl9kcm9wWm9uZXMgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKSBtb3ZlczogKG1vZGVsOiBhbnksIHNvdXJjZTogYW55LCBoYW5kbGU6IGFueSwgc2libGluZzogYW55KSA9PiBib29sZWFuO1xuXG4gIC8vIEBJbnB1dCgpIGNsYXNzZXM6IGFueSA9IHt9O1xuICAvLyBASW5wdXQoKSBkcmFndWxhT3B0aW9uczogYW55O1xuXG4gIEBJbnB1dCgndGVtcGxhdGUnKVxuICBzZXQgdGVtcGxhdGVJbnB1dCh0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55Pikge1xuICAgIHRoaXMudGVtcGxhdGUgPSB0ZW1wbGF0ZTtcbiAgfVxuXG4gIEBDb250ZW50Q2hpbGQoVGVtcGxhdGVSZWYsIHsgc3RhdGljOiB0cnVlIH0pXG4gIHNldCB0ZW1wbGF0ZUNoaWxkKHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgdGhpcy50ZW1wbGF0ZSA9IHRlbXBsYXRlO1xuICB9XG5cbiAgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgQFZpZXdDaGlsZChEcm9wcGFibGVEaXJlY3RpdmUsIHsgc3RhdGljOiB0cnVlIH0pXG4gIGRyb3BwYWJsZTogYW55O1xuXG4gIEBPdXRwdXQoKSBkcm9wOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBkcmFnOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBvdmVyOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBvdXQ6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIHJlbW92ZTogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgY2FuY2VsOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIF9kcm9wWm9uZXM6IHN0cmluZ1tdO1xuICBfZGVmYXVsdFpvbmVzOiBzdHJpbmdbXTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLl9kZWZhdWx0Wm9uZXMgPSBbdGhpcy5kcm9wWm9uZV07XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5kcm9wcGFibGUuZHJhZy5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5kcmFnLmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLmRyb3Auc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMuZHJvcC5lbWl0KHYpKTtcbiAgICB0aGlzLmRyb3BwYWJsZS5vdmVyLnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLm92ZXIuZW1pdCh2KSk7XG4gICAgdGhpcy5kcm9wcGFibGUub3V0LnN1YnNjcmliZSgodjogYW55KSA9PiB0aGlzLm91dC5lbWl0KHYpKTtcbiAgICB0aGlzLmRyb3BwYWJsZS5yZW1vdmUuc3Vic2NyaWJlKCh2OiBhbnkpID0+IHRoaXMucmVtb3ZlLmVtaXQodikpO1xuICAgIHRoaXMuZHJvcHBhYmxlLmNhbmNlbC5zdWJzY3JpYmUoKHY6IGFueSkgPT4gdGhpcy5jYW5jZWwuZW1pdCh2KSk7XG4gIH1cbn1cbiJdfQ== |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Component, Input, ViewEncapsulation, HostBinding } from '@angular/core'; | ||
@@ -23,13 +20,6 @@ import { ContainerComponent } from '../container/container.component'; | ||
Object.defineProperty(ItemComponent.prototype, "dropZone", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZone || this.container.dropZone; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZone = val; | ||
@@ -41,13 +31,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this.container.dropZones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -59,13 +42,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "droppableItemClass", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._droppableItemClass || this.container.droppableItemClass; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._droppableItemClass = val; | ||
@@ -77,13 +53,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "removeOnSpill", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return typeof this._removeOnSpill === 'boolean' ? this._removeOnSpill : this.container.removeOnSpill; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._removeOnSpill = val; | ||
@@ -95,13 +64,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "copy", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return typeof this._copy === 'boolean' ? this._copy : this.container.copy; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._copy = val; | ||
@@ -113,6 +75,3 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "hasHandle", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.draggableDirective.hasHandle; | ||
@@ -124,6 +83,3 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "moveDisabled", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return !this.draggableDirective.canMove(); | ||
@@ -135,9 +91,4 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "classString", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
get: function () { | ||
var itemClass = typeof this.droppableItemClass === 'function' ? this.droppableItemClass(this.model) : this.droppableItemClass; | ||
/** @type {?} */ | ||
var classes = ['ngx-dnd-item', itemClass || '']; | ||
@@ -156,6 +107,3 @@ if (this.moveDisabled) { | ||
Object.defineProperty(ItemComponent.prototype, "type", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
if (Array.isArray(this.model)) { | ||
@@ -169,9 +117,3 @@ return 'array'; | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
ItemComponent.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ItemComponent.prototype.ngOnInit = function () { | ||
this.data = { | ||
@@ -184,11 +126,2 @@ model: this.model, | ||
}; | ||
ItemComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}] } | ||
]; | ||
/** @nocollapse */ | ||
ItemComponent.ctorParameters = function () { return [ | ||
@@ -198,34 +131,48 @@ { type: ContainerComponent }, | ||
]; }; | ||
ItemComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
classString: [{ type: HostBinding, args: ['class',] }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ItemComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZone", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "droppableItemClass", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "removeOnSpill", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "copy", null); | ||
__decorate([ | ||
HostBinding('class'), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", []) | ||
], ItemComponent.prototype, "classString", null); | ||
ItemComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}), | ||
__metadata("design:paramtypes", [ContainerComponent, DraggableDirective]) | ||
], ItemComponent); | ||
return ItemComponent; | ||
}()); | ||
export { ItemComponent }; | ||
if (false) { | ||
/** @type {?} */ | ||
ItemComponent.prototype.model; | ||
/** @type {?} */ | ||
ItemComponent.prototype._copy; | ||
/** @type {?} */ | ||
ItemComponent.prototype._dropZone; | ||
/** @type {?} */ | ||
ItemComponent.prototype._dropZones; | ||
/** @type {?} */ | ||
ItemComponent.prototype._droppableItemClass; | ||
/** @type {?} */ | ||
ItemComponent.prototype._removeOnSpill; | ||
/** @type {?} */ | ||
ItemComponent.prototype.data; | ||
/** @type {?} */ | ||
ItemComponent.prototype.container; | ||
/** @type {?} */ | ||
ItemComponent.prototype.draggableDirective; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2l0ZW0vaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQzs7Ozs7Ozs7QUFTOUU7SUFzRkUsdUJBQW1CLFNBQTZCLEVBQVMsa0JBQXNDO1FBQTVFLGNBQVMsR0FBVCxTQUFTLENBQW9CO1FBQVMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFvQjtRQXJDL0YsVUFBSyxHQUFHLEtBQUssQ0FBQztRQUlkLG1CQUFjLEdBQUcsS0FBSyxDQUFDO0lBaUMyRSxDQUFDO0lBN0VuRyxzQkFDSSxtQ0FBUTs7OztRQURaO1lBRUUsT0FBTyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO1FBQ25ELENBQUM7Ozs7O1FBQ0QsVUFBYSxHQUFHO1lBQ2QsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLENBQUM7UUFDdkIsQ0FBQzs7O09BSEE7SUFLRCxzQkFDSSxvQ0FBUzs7OztRQURiO1lBRUUsT0FBTyxJQUFJLENBQUMsVUFBVSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDO1FBQ3JELENBQUM7Ozs7O1FBQ0QsVUFBYyxHQUFHO1lBQ2YsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7UUFDeEIsQ0FBQzs7O09BSEE7SUFLRCxzQkFDSSw2Q0FBa0I7Ozs7UUFEdEI7WUFFRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxJQUFJLENBQUMsU0FBUyxD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QW9COztJQTBDcEIsOEJBQWM7O0lBQ2Qsa0NBQWU7O0lBQ2YsbUNBQWdCOztJQUNoQiw0Q0FBeUI7O0lBQ3pCLHVDQUF1Qjs7SUFDdkIsNkJBQVU7O0lBZ0NFLGtDQUFvQzs7SUFBRSwyQ0FBNkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uLCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuLi9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmFnZ2FibGVEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzL25neC1kcmFnZ2FibGUuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCBhbGxvd3MgbmVzdGVkIG5neERyb3BwYWJsZSBhbmQgbmd4RHJhZ2dhYmxlc1xuICogU2hvdWxkIG9ubHkgYmUgdXNlIGluc2lkZSBhIG5neC1kbmQtY29udGFpbmVyXG4gKiBPdXRzaWRlIGEgbmd4LWRuZC1jb250YWluZXIgdXNlIG5neERyb3BwYWJsZVxuICpcbiAqIEBleHBvcnRcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbmd4LWRuZC1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2l0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9pdGVtLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgSXRlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3Bab25lKCkge1xuICAgIHJldHVybiB0aGlzLl9kcm9wWm9uZSB8fCB0aGlzLmNvbnRhaW5lci5kcm9wWm9uZTtcbiAgfVxuICBzZXQgZHJvcFpvbmUodmFsKSB7XG4gICAgdGhpcy5fZHJvcFpvbmUgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgZHJvcFpvbmVzKCkge1xuICAgIHJldHVybiB0aGlzLl9kcm9wWm9uZXMgfHwgdGhpcy5jb250YWluZXIuZHJvcFpvbmVzO1xuICB9XG4gIHNldCBkcm9wWm9uZXModmFsKSB7XG4gICAgdGhpcy5fZHJvcFpvbmVzID0gdmFsO1xuICB9XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3BwYWJsZUl0ZW1DbGFzcygpIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcHBhYmxlSXRlbUNsYXNzIHx8IHRoaXMuY29udGFpbmVyLmRyb3BwYWJsZUl0ZW1DbGFzcztcbiAgfVxuICBzZXQgZHJvcHBhYmxlSXRlbUNsYXNzKHZhbCkge1xuICAgIHRoaXMuX2Ryb3BwYWJsZUl0ZW1DbGFzcyA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCByZW1vdmVPblNwaWxsKCkge1xuICAgIHJldHVybiB0eXBlb2YgdGhpcy5fcmVtb3ZlT25TcGlsbCA9PT0gJ2Jvb2xlYW4nID8gdGhpcy5fcmVtb3ZlT25TcGlsbCA6IHRoaXMuY29udGFpbmVyLnJlbW92ZU9uU3BpbGw7XG4gIH1cbiAgc2V0IHJlbW92ZU9uU3BpbGwodmFsKSB7XG4gICAgdGhpcy5fcmVtb3ZlT25TcGlsbCA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCBjb3B5KCkge1xuICAgIHJldHVybiB0eXBlb2YgdGhpcy5fY29weSA9PT0gJ2Jvb2xlYW4nID8gdGhpcy5fY29weSA6IHRoaXMuY29udGFpbmVyLmNvcHk7XG4gIH1cbiAgc2V0IGNvcHkodmFsKSB7XG4gICAgdGhpcy5fY29weSA9IHZhbDtcbiAgfVxuXG4gIF9jb3B5ID0gZmFsc2U7XG4gIF9kcm9wWm9uZTogYW55O1xuICBfZHJvcFpvbmVzOiBhbnk7XG4gIF9kcm9wcGFibGVJdGVtQ2xhc3M6IGFueTtcbiAgX3JlbW92ZU9uU3BpbGwgPSBmYWxzZTtcbiAgZGF0YTogYW55O1xuXG4gIGdldCBoYXNIYW5kbGUoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuZHJhZ2dhYmxlRGlyZWN0aXZlLmhhc0hhbmRsZTtcbiAgfVxuXG4gIGdldCBtb3ZlRGlzYWJsZWQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICF0aGlzLmRyYWdnYWJsZURpcmVjdGl2ZS5jYW5Nb3ZlKCk7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgZ2V0IGNsYXNzU3RyaW5nKCkge1xuICAgIGNvbnN0IGl0ZW1DbGFzcyA9XG4gICAgICB0eXBlb2YgdGhpcy5kcm9wcGFibGVJdGVtQ2xhc3MgPT09ICdmdW5jdGlvbicgPyB0aGlzLmRyb3BwYWJsZUl0ZW1DbGFzcyh0aGlzLm1vZGVsKSA6IHRoaXMuZHJvcHBhYmxlSXRlbUNsYXNzO1xuXG4gICAgY29uc3QgY2xhc3NlcyA9IFsnbmd4LWRuZC1pdGVtJywgaXRlbUNsYXNzIHx8ICcnXTtcbiAgICBpZiAodGhpcy5tb3ZlRGlzYWJsZWQpIHtcbiAgICAgIGNsYXNzZXMucHVzaCgnbW92ZS1kaXNhYmxlZCcpO1xuICAgIH1cbiAgICBpZiAodGhpcy5oYXNIYW5kbGUpIHtcbiAgICAgIGNsYXNzZXMucHVzaCgnaGFzLWhhbmRsZScpO1xuICAgIH1cbiAgICByZXR1cm4gY2xhc3Nlcy5qb2luKCcgJyk7XG4gIH1cblxuICBnZXQgdHlwZSgpIHtcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh0aGlzLm1vZGVsKSkge1xuICAgICAgcmV0dXJuICdhcnJheSc7XG4gICAgfVxuICAgIHJldHVybiB0eXBlb2YgdGhpcy5tb2RlbDtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBjb250YWluZXI6IENvbnRhaW5lckNvbXBvbmVudCwgcHVibGljIGRyYWdnYWJsZURpcmVjdGl2ZTogRHJhZ2dhYmxlRGlyZWN0aXZlKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuZGF0YSA9IHtcbiAgICAgIG1vZGVsOiB0aGlzLm1vZGVsLFxuICAgICAgdHlwZTogdGhpcy50eXBlLFxuICAgICAgZHJvcFpvbmU6IHRoaXMuZHJvcFpvbmUsXG4gICAgICB0ZW1wbGF0ZTogdGhpcy5jb250YWluZXIudGVtcGxhdGVcbiAgICB9O1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2l0ZW0vaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUU5RTs7Ozs7O0dBTUc7QUFPSDtJQWdGRSx1QkFBbUIsU0FBNkIsRUFBUyxrQkFBc0M7UUFBNUUsY0FBUyxHQUFULFNBQVMsQ0FBb0I7UUFBUyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW9CO1FBckMvRixVQUFLLEdBQUcsS0FBSyxDQUFDO1FBSWQsbUJBQWMsR0FBRyxLQUFLLENBQUM7SUFpQzJFLENBQUM7SUE1RW5HLHNCQUFJLG1DQUFRO2FBQVo7WUFDRSxPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7UUFDbkQsQ0FBQzthQUNELFVBQWEsR0FBRztZQUNkLElBQUksQ0FBQyxTQUFTLEdBQUcsR0FBRyxDQUFDO1FBQ3ZCLENBQUM7OztPQUhBO0lBTUQsc0JBQUksb0NBQVM7YUFBYjtZQUNFLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztRQUNyRCxDQUFDO2FBQ0QsVUFBYyxHQUFHO1lBQ2YsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7UUFDeEIsQ0FBQzs7O09BSEE7SUFNRCxzQkFBSSw2Q0FBa0I7YUFBdEI7WUFDRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLGtCQUFrQixD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QUVwQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTs7U0FDdEMsQ0FBQzt5Q0FpRjhCLGtCQUFrQixFQUE2QixrQkFBa0I7T0FoRnBGLGFBQWEsQ0EwRnpCO0lBQUQsb0JBQUM7Q0FBQSxBQTFGRCxJQTBGQztTQTFGWSxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiwgSG9zdEJpbmRpbmcgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi4vY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJhZ2dhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9uZ3gtZHJhZ2dhYmxlLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICogQ29tcG9uZW50IHRoYXQgYWxsb3dzIG5lc3RlZCBuZ3hEcm9wcGFibGUgYW5kIG5neERyYWdnYWJsZXNcbiAqIFNob3VsZCBvbmx5IGJlIHVzZSBpbnNpZGUgYSBuZ3gtZG5kLWNvbnRhaW5lclxuICogT3V0c2lkZSBhIG5neC1kbmQtY29udGFpbmVyIHVzZSBuZ3hEcm9wcGFibGVcbiAqXG4gKiBAZXhwb3J0XG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25neC1kbmQtaXRlbScsXG4gIHRlbXBsYXRlVXJsOiAnLi9pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaXRlbS5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIEl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBtb2RlbDogYW55O1xuXG4gIEBJbnB1dCgpXG4gIGdldCBkcm9wWm9uZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmUgfHwgdGhpcy5jb250YWluZXIuZHJvcFpvbmU7XG4gIH1cbiAgc2V0IGRyb3Bab25lKHZhbCkge1xuICAgIHRoaXMuX2Ryb3Bab25lID0gdmFsO1xuICB9XG5cbiAgQElucHV0KClcbiAgZ2V0IGRyb3Bab25lcygpIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmVzIHx8IHRoaXMuY29udGFpbmVyLmRyb3Bab25lcztcbiAgfVxuICBzZXQgZHJvcFpvbmVzKHZhbCkge1xuICAgIHRoaXMuX2Ryb3Bab25lcyA9IHZhbDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCBkcm9wcGFibGVJdGVtQ2xhc3MoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2Ryb3BwYWJsZUl0ZW1DbGFzcyB8fCB0aGlzLmNvbnRhaW5lci5kcm9wcGFibGVJdGVtQ2xhc3M7XG4gIH1cbiAgc2V0IGRyb3BwYWJsZUl0ZW1DbGFzcyh2YWwpIHtcbiAgICB0aGlzLl9kcm9wcGFibGVJdGVtQ2xhc3MgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgcmVtb3ZlT25TcGlsbCgpIHtcbiAgICByZXR1cm4gdHlwZW9mIHRoaXMuX3JlbW92ZU9uU3BpbGwgPT09ICdib29sZWFuJyA/IHRoaXMuX3JlbW92ZU9uU3BpbGwgOiB0aGlzLmNvbnRhaW5lci5yZW1vdmVPblNwaWxsO1xuICB9XG4gIHNldCByZW1vdmVPblNwaWxsKHZhbCkge1xuICAgIHRoaXMuX3JlbW92ZU9uU3BpbGwgPSB2YWw7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgY29weSgpIHtcbiAgICByZXR1cm4gdHlwZW9mIHRoaXMuX2NvcHkgPT09ICdib29sZWFuJyA/IHRoaXMuX2NvcHkgOiB0aGlzLmNvbnRhaW5lci5jb3B5O1xuICB9XG4gIHNldCBjb3B5KHZhbCkge1xuICAgIHRoaXMuX2NvcHkgPSB2YWw7XG4gIH1cblxuICBfY29weSA9IGZhbHNlO1xuICBfZHJvcFpvbmU6IGFueTtcbiAgX2Ryb3Bab25lczogYW55O1xuICBfZHJvcHBhYmxlSXRlbUNsYXNzOiBhbnk7XG4gIF9yZW1vdmVPblNwaWxsID0gZmFsc2U7XG4gIGRhdGE6IGFueTtcblxuICBnZXQgaGFzSGFuZGxlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmRyYWdnYWJsZURpcmVjdGl2ZS5oYXNIYW5kbGU7XG4gIH1cblxuICBnZXQgbW92ZURpc2FibGVkKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiAhdGhpcy5kcmFnZ2FibGVEaXJlY3RpdmUuY2FuTW92ZSgpO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIGdldCBjbGFzc1N0cmluZygpIHtcbiAgICBjb25zdCBpdGVtQ2xhc3MgPVxuICAgICAgdHlwZW9mIHRoaXMuZHJvcHBhYmxlSXRlbUNsYXNzID09PSAnZnVuY3Rpb24nID8gdGhpcy5kcm9wcGFibGVJdGVtQ2xhc3ModGhpcy5tb2RlbCkgOiB0aGlzLmRyb3BwYWJsZUl0ZW1DbGFzcztcblxuICAgIGNvbnN0IGNsYXNzZXMgPSBbJ25neC1kbmQtaXRlbScsIGl0ZW1DbGFzcyB8fCAnJ107XG4gICAgaWYgKHRoaXMubW92ZURpc2FibGVkKSB7XG4gICAgICBjbGFzc2VzLnB1c2goJ21vdmUtZGlzYWJsZWQnKTtcbiAgICB9XG4gICAgaWYgKHRoaXMuaGFzSGFuZGxlKSB7XG4gICAgICBjbGFzc2VzLnB1c2goJ2hhcy1oYW5kbGUnKTtcbiAgICB9XG4gICAgcmV0dXJuIGNsYXNzZXMuam9pbignICcpO1xuICB9XG5cbiAgZ2V0IHR5cGUoKSB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy5tb2RlbCkpIHtcbiAgICAgIHJldHVybiAnYXJyYXknO1xuICAgIH1cbiAgICByZXR1cm4gdHlwZW9mIHRoaXMubW9kZWw7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgY29udGFpbmVyOiBDb250YWluZXJDb21wb25lbnQsIHB1YmxpYyBkcmFnZ2FibGVEaXJlY3RpdmU6IERyYWdnYWJsZURpcmVjdGl2ZSkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmRhdGEgPSB7XG4gICAgICBtb2RlbDogdGhpcy5tb2RlbCxcbiAgICAgIHR5cGU6IHRoaXMudHlwZSxcbiAgICAgIGRyb3Bab25lOiB0aGlzLmRyb3Bab25lLFxuICAgICAgdGVtcGxhdGU6IHRoaXMuY29udGFpbmVyLnRlbXBsYXRlXG4gICAgfTtcbiAgfVxufVxuIl19 |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate } from "tslib"; | ||
import { Directive } from '@angular/core'; | ||
@@ -14,8 +11,8 @@ /** | ||
} | ||
DragHandleDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDragHandle]' },] } | ||
]; | ||
DragHandleDirective = __decorate([ | ||
Directive({ selector: '[ngxDragHandle]' }) | ||
], DragHandleDirective); | ||
return DragHandleDirective; | ||
}()); | ||
export { DragHandleDirective }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2RpcmVjdGl2ZXMvbmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBTzFDO0lBQUE7SUFDa0MsQ0FBQzs7Z0JBRGxDLFNBQVMsU0FBQyxFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRTs7SUFDUiwwQkFBQztDQUFBLEFBRG5DLElBQ21DO1NBQXRCLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEFkZHMgcHJvcGVydGllcyBhbmQgZXZlbnRzIHRvIGRyYWcgaGFuZGxlIGVsZW1lbnRzXG4gKlxuICogQGV4cG9ydFxuICovXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbbmd4RHJhZ0hhbmRsZV0nIH0pXG5leHBvcnQgY2xhc3MgRHJhZ0hhbmRsZURpcmVjdGl2ZSB7fVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsibGliL2RpcmVjdGl2ZXMvbmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQzs7OztHQUlHO0FBRUg7SUFBQTtJQUFrQyxDQUFDO0lBQXRCLG1CQUFtQjtRQUQvQixTQUFTLENBQUMsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQztPQUM5QixtQkFBbUIsQ0FBRztJQUFELDBCQUFDO0NBQUEsQUFBbkMsSUFBbUM7U0FBdEIsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQWRkcyBwcm9wZXJ0aWVzIGFuZCBldmVudHMgdG8gZHJhZyBoYW5kbGUgZWxlbWVudHNcbiAqXG4gKiBAZXhwb3J0XG4gKi9cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1tuZ3hEcmFnSGFuZGxlXScgfSlcbmV4cG9ydCBjbGFzcyBEcmFnSGFuZGxlRGlyZWN0aXZlIHt9XG4iXX0= |
@@ -1,6 +0,3 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { Directive, ElementRef, HostListener, Input, Output, EventEmitter } from '@angular/core'; | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Directive, ElementRef, HostListener, Input, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core'; | ||
import { DroppableDirective } from './ngx-droppable.directive'; | ||
@@ -20,26 +17,18 @@ import { DrakeStoreService } from '../services/drake-store.service'; | ||
/* | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
this.handles = []; | ||
this.drag = new EventEmitter(); | ||
this.dragDelay = 200; // milliseconds | ||
// milliseconds | ||
this.dragDelayed = true; | ||
} | ||
Object.defineProperty(DraggableDirective.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this.ngxDraggable || this._parentDropzones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -51,6 +40,3 @@ }, | ||
Object.defineProperty(DraggableDirective.prototype, "hasHandle", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return !!this.handles.length; | ||
@@ -62,6 +48,3 @@ }, | ||
Object.defineProperty(DraggableDirective.prototype, "element", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.el.nativeElement; | ||
@@ -73,14 +56,3 @@ }, | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onMove = | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
function (e) { | ||
DraggableDirective.prototype.onMove = function (e) { | ||
if (!this._moves || this.dragDelayed) { | ||
@@ -91,47 +63,20 @@ e.stopPropagation(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onDown = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.onDown = function () { | ||
var _this = this; | ||
if (this._moves) { | ||
this.touchTimeout = setTimeout((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.touchTimeout = setTimeout(function () { | ||
_this.dragDelayed = false; | ||
}), this.dragDelay); | ||
}, this.dragDelay); | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onUp = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.onUp = function () { | ||
if (this._moves) { | ||
clearTimeout((/** @type {?} */ (this.touchTimeout))); | ||
clearTimeout(this.touchTimeout); | ||
this.dragDelayed = true; | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngOnInit = function () { | ||
this.update(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.update = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.update = function () { | ||
this._parentDropzones = [this.droppableDirective.dropZone]; | ||
@@ -141,31 +86,9 @@ this.drakesService.registerDraggable(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngOnDestroy = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngOnDestroy = function () { | ||
this.drakesService.removeDraggable(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.updateElements = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
DraggableDirective.prototype.updateElements = function () { | ||
var nativeElement = this.el.nativeElement; | ||
/** @type {?} */ | ||
var handles = nativeElement.querySelectorAll('[ngxdraghandle]'); | ||
this.handles = Array.from(handles).filter((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
function (h) { return findFirstDraggableParent(h) === nativeElement; })); | ||
/** | ||
* @param {?} c | ||
* @return {?} | ||
*/ | ||
this.handles = Array.from(handles).filter(function (h) { return findFirstDraggableParent(h) === nativeElement; }); | ||
function findFirstDraggableParent(c) { | ||
@@ -180,15 +103,3 @@ while (c.parentNode) { | ||
}; | ||
/** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.canMove = /** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
function (source, handle, sibling) { | ||
DraggableDirective.prototype.canMove = function (source, handle, sibling) { | ||
if (typeof this._moves === 'boolean') | ||
@@ -200,27 +111,6 @@ return this._moves; | ||
}; | ||
/** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.moves = /** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
function (source, handle, sibling) { | ||
DraggableDirective.prototype.moves = function (source, handle, sibling) { | ||
if (!this.canMove(source, handle, sibling)) | ||
return false; | ||
return this.hasHandle ? this.handles.some((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
function (h) { return handelFor(handle, h); })) : true; | ||
/** | ||
* @param {?} c | ||
* @param {?} p | ||
* @return {?} | ||
*/ | ||
return this.hasHandle ? this.handles.some(function (h) { return handelFor(handle, h); }) : true; | ||
function handelFor(c, p) { | ||
@@ -234,15 +124,5 @@ if (c === p) | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngDoCheck = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngDoCheck = function () { | ||
this.updateElements(); | ||
}; | ||
DraggableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDraggable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
DraggableDirective.ctorParameters = function () { return [ | ||
@@ -253,52 +133,50 @@ { type: ElementRef }, | ||
]; }; | ||
DraggableDirective.propDecorators = { | ||
ngxDraggable: [{ type: Input }], | ||
model: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
_moves: [{ type: Input, args: ['moves',] }], | ||
drag: [{ type: Output }], | ||
onMove: [{ type: HostListener, args: ['touchmove', ['$event'],] }], | ||
onDown: [{ type: HostListener, args: ['touchstart',] }], | ||
onUp: [{ type: HostListener, args: ['touchend',] }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Array) | ||
], DraggableDirective.prototype, "ngxDraggable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], DraggableDirective.prototype, "dropZones", null); | ||
__decorate([ | ||
Input('moves'), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "_moves", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DraggableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
HostListener('touchmove', ['$event']), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", [Event]), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onMove", null); | ||
__decorate([ | ||
HostListener('touchstart'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onDown", null); | ||
__decorate([ | ||
HostListener('touchend'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onUp", null); | ||
DraggableDirective = __decorate([ | ||
Directive({ selector: '[ngxDraggable]' }), | ||
__metadata("design:paramtypes", [ElementRef, | ||
DrakeStoreService, | ||
DroppableDirective]) | ||
], DraggableDirective); | ||
return DraggableDirective; | ||
}()); | ||
export { DraggableDirective }; | ||
if (false) { | ||
/** @type {?} */ | ||
DraggableDirective.prototype.ngxDraggable; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.model; | ||
/** @type {?} */ | ||
DraggableDirective.prototype._moves; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.handles; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.drag; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.dragDelay; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.dragDelayed; | ||
/** @type {?} */ | ||
DraggableDirective.prototype.touchTimeout; | ||
/** @type {?} */ | ||
DraggableDirective.prototype._dropZones; | ||
/** @type {?} */ | ||
DraggableDirective.prototype._parentDropzones; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DraggableDirective.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DraggableDirective.prototype.drakesService; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DraggableDirective.prototype.droppableDirective; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-draggable.directive.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/directives/ngx-draggable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core';\n\nimport { DroppableDirective } from './ngx-droppable.directive';\nimport { DrakeStoreService } from '../services/drake-store.service';\n\n/**\n * Adds properties and events to draggable elements\n *\n * @export\n */\n@Directive({ selector: '[ngxDraggable]' })\nexport class DraggableDirective implements OnInit, OnDestroy {\n  @Input() ngxDraggable: string[];\n  @Input() model: any;\n\n  @Input()\n  get dropZones(): any {\n    return this._dropZones || this.ngxDraggable || this._parentDropzones;\n  }\n  set dropZones(val: any) {\n    this._dropZones = val;\n  }\n\n  @Input('moves') _moves: boolean | ((...args: any[]) => any) = true;\n\n  /*\n  ContentChildren doesn't get children created with NgTemplateOutlet\n  See https://github.com/angular/angular/issues/14842\n  Implemented via updateElements method\n\n  @ContentChildren(DragHandleDirective, {descendants: true})\n  handlesList: QueryList<DragHandleDirective>; */\n\n  handles: any[] = [];\n\n  get hasHandle() {\n    return !!this.handles.length;\n  }\n\n  @Output() drag: EventEmitter<any> = new EventEmitter<any>();\n\n  dragDelay: number = 200; // milliseconds\n  dragDelayed: boolean = true;\n\n  touchTimeout: any;\n\n  get element(): any {\n    return this.el.nativeElement;\n  }\n\n  _dropZones: string[];\n  _parentDropzones: string[];\n\n  constructor(\n    private el: ElementRef,\n    private drakesService: DrakeStoreService,\n    private droppableDirective: DroppableDirective\n  ) {}\n\n  // From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172\n  @HostListener('touchmove', ['$event'])\n  onMove(e: Event) {\n    if (!this._moves || this.dragDelayed) {\n      e.stopPropagation();\n      clearTimeout(this.touchTimeout);\n    }\n  }\n\n  @HostListener('touchstart')\n  onDown() {\n    if (this._moves) {\n      this.touchTimeout = setTimeout(() => {\n        this.dragDelayed = false;\n      }, this.dragDelay);\n    }\n  }\n\n  @HostListener('touchend')\n  onUp() {\n    if (this._moves) {\n      clearTimeout(<number>this.touchTimeout);\n      this.dragDelayed = true;\n    }\n  }\n\n  ngOnInit(): void {\n    this.update();\n  }\n\n  update(): void {\n    this._parentDropzones = [this.droppableDirective.dropZone];\n    this.drakesService.registerDraggable(this);\n    this.updateElements();\n  }\n\n  ngOnDestroy(): void {\n    this.drakesService.removeDraggable(this);\n  }\n\n  updateElements(): void {\n    const nativeElement = this.el.nativeElement;\n    const handles: NodeList = nativeElement.querySelectorAll('[ngxdraghandle]');\n    this.handles = Array.from(handles).filter((h: any) => findFirstDraggableParent(h) === nativeElement);\n\n    function findFirstDraggableParent(c: any) {\n      while (c.parentNode) {\n        c = c.parentNode;\n        if (c.hasAttribute && c.hasAttribute('ngxdraggable')) {\n          return c;\n        }\n      }\n    }\n  }\n\n  canMove(source?: any, handle?: any, sibling?: any): boolean {\n    if (typeof this._moves === 'boolean') return this._moves;\n    if (typeof this._moves === 'function') return this._moves(this.model, source, handle, sibling);\n    return true;\n  }\n\n  moves(source: any, handle: any, sibling: any): boolean {\n    if (!this.canMove(source, handle, sibling)) return false;\n\n    return this.hasHandle ? this.handles.some(h => handelFor(handle, h)) : true;\n\n    function handelFor(c: any, p: any) {\n      if (c === p) return true;\n      while ((c = c.parentNode) && c !== p); // tslint:disable-line\n      return !!c;\n    }\n  }\n\n  ngDoCheck(): void {\n    this.updateElements();\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-draggable.directive.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/directives/ngx-draggable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core';\n\nimport { DroppableDirective } from './ngx-droppable.directive';\nimport { DrakeStoreService } from '../services/drake-store.service';\n\n/**\n * Adds properties and events to draggable elements\n *\n * @export\n */\n@Directive({ selector: '[ngxDraggable]' })\nexport class DraggableDirective implements OnInit, OnDestroy {\n  @Input() ngxDraggable: string[];\n  @Input() model: any;\n\n  @Input()\n  get dropZones(): any {\n    return this._dropZones || this.ngxDraggable || this._parentDropzones;\n  }\n  set dropZones(val: any) {\n    this._dropZones = val;\n  }\n\n  @Input('moves') _moves: boolean | ((...args: any[]) => any) = true;\n\n  /*\n  ContentChildren doesn't get children created with NgTemplateOutlet\n  See https://github.com/angular/angular/issues/14842\n  Implemented via updateElements method\n\n  @ContentChildren(DragHandleDirective, {descendants: true})\n  handlesList: QueryList<DragHandleDirective>; */\n\n  handles: any[] = [];\n\n  get hasHandle() {\n    return !!this.handles.length;\n  }\n\n  @Output() drag: EventEmitter<any> = new EventEmitter<any>();\n\n  dragDelay: number = 200; // milliseconds\n  dragDelayed: boolean = true;\n\n  touchTimeout: any;\n\n  get element(): any {\n    return this.el.nativeElement;\n  }\n\n  _dropZones: string[];\n  _parentDropzones: string[];\n\n  constructor(\n    private el: ElementRef,\n    private drakesService: DrakeStoreService,\n    private droppableDirective: DroppableDirective\n  ) {}\n\n  // From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172\n  @HostListener('touchmove', ['$event'])\n  onMove(e: Event) {\n    if (!this._moves || this.dragDelayed) {\n      e.stopPropagation();\n      clearTimeout(this.touchTimeout);\n    }\n  }\n\n  @HostListener('touchstart')\n  onDown() {\n    if (this._moves) {\n      this.touchTimeout = setTimeout(() => {\n        this.dragDelayed = false;\n      }, this.dragDelay);\n    }\n  }\n\n  @HostListener('touchend')\n  onUp() {\n    if (this._moves) {\n      clearTimeout(<number>this.touchTimeout);\n      this.dragDelayed = true;\n    }\n  }\n\n  ngOnInit(): void {\n    this.update();\n  }\n\n  update(): void {\n    this._parentDropzones = [this.droppableDirective.dropZone];\n    this.drakesService.registerDraggable(this);\n    this.updateElements();\n  }\n\n  ngOnDestroy(): void {\n    this.drakesService.removeDraggable(this);\n  }\n\n  updateElements(): void {\n    const nativeElement = this.el.nativeElement;\n    const handles: NodeList = nativeElement.querySelectorAll('[ngxdraghandle]');\n    this.handles = Array.from(handles).filter((h: any) => findFirstDraggableParent(h) === nativeElement);\n\n    function findFirstDraggableParent(c: any) {\n      while (c.parentNode) {\n        c = c.parentNode;\n        if (c.hasAttribute && c.hasAttribute('ngxdraggable')) {\n          return c;\n        }\n      }\n    }\n  }\n\n  canMove(source?: any, handle?: any, sibling?: any): boolean {\n    if (typeof this._moves === 'boolean') return this._moves;\n    if (typeof this._moves === 'function') return this._moves(this.model, source, handle, sibling);\n    return true;\n  }\n\n  moves(source: any, handle: any, sibling: any): boolean {\n    if (!this.canMove(source, handle, sibling)) return false;\n\n    return this.hasHandle ? this.handles.some(h => handelFor(handle, h)) : true;\n\n    function handelFor(c: any, p: any) {\n      if (c === p) return true;\n      while ((c = c.parentNode) && c !== p); // tslint:disable-line\n      return !!c;\n    }\n  }\n\n  ngDoCheck(): void {\n    this.updateElements();\n  }\n}\n"]} |
@@ -1,12 +0,5 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { Directive, Input, Output, ElementRef, EventEmitter, Renderer2 } from '@angular/core'; | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Directive, Input, Output, OnInit, OnDestroy, AfterViewInit, ElementRef, EventEmitter, Renderer2 } from '@angular/core'; | ||
import { DrakeStoreService } from '../services/drake-store.service'; | ||
/** @type {?} */ | ||
var i = 10000; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -36,6 +29,3 @@ return i++; | ||
Object.defineProperty(DroppableDirective.prototype, "container", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.el.nativeElement; | ||
@@ -47,13 +37,6 @@ }, | ||
Object.defineProperty(DroppableDirective.prototype, "dropZone", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZone || this.ngxDroppable || this.defaultZone; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZone = val; | ||
@@ -64,46 +47,18 @@ }, | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngOnInit = function () { | ||
this.defaultZone = "@@DefaultDropZone-" + getNextId() + "@@"; | ||
this.drakesService.register(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngAfterViewInit = function () { | ||
var _this = this; | ||
this.over.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.over.subscribe(function () { | ||
_this.renderer.addClass(_this.container, 'gu-over'); | ||
})); | ||
this.out.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
}); | ||
this.out.subscribe(function () { | ||
_this.renderer.removeClass(_this.container, 'gu-over'); | ||
})); | ||
}); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngOnDestroy = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngOnDestroy = function () { | ||
this.drakesService.remove(this); | ||
}; | ||
DroppableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDroppable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
DroppableDirective.ctorParameters = function () { return [ | ||
@@ -114,62 +69,58 @@ { type: ElementRef }, | ||
]; }; | ||
DroppableDirective.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
ngxDroppable: [{ type: Input }], | ||
direction: [{ type: Input }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }], | ||
dropZone: [{ type: Input }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "ngxDroppable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "direction", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "cancel", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String), | ||
__metadata("design:paramtypes", [String]) | ||
], DroppableDirective.prototype, "dropZone", null); | ||
DroppableDirective = __decorate([ | ||
Directive({ selector: '[ngxDroppable]' }), | ||
__metadata("design:paramtypes", [ElementRef, Renderer2, DrakeStoreService]) | ||
], DroppableDirective); | ||
return DroppableDirective; | ||
}()); | ||
export { DroppableDirective }; | ||
if (false) { | ||
/** @type {?} */ | ||
DroppableDirective.prototype.model; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.copy; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.removeOnSpill; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.ngxDroppable; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.direction; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.drop; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.drag; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.over; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.out; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.remove; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.cancel; | ||
/** @type {?} */ | ||
DroppableDirective.prototype.defaultZone; | ||
/** @type {?} */ | ||
DroppableDirective.prototype._dropZone; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DroppableDirective.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DroppableDirective.prototype.renderer; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DroppableDirective.prototype.drakesService; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyb3BwYWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULEtBQUssRUFDTCxNQUFNLEVBSU4sVUFBVSxFQUNWLFlBQVksRUFDWixTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7O0lBRWhFLENBQUMsR0FBRyxLQUFLOzs7O0FBQ2IsU0FBUyxTQUFTO0lBQ2hCLE9BQU8sQ0FBQyxFQUFFLENBQUM7QUFDYixDQUFDOzs7Ozs7QUFPRDtJQW1DRSw0QkFBb0IsRUFBYyxFQUFVLFFBQW1CLEVBQVUsYUFBZ0M7UUFBckYsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQUFVLGFBQVEsR0FBUixRQUFRLENBQVc7UUFBVSxrQkFBYSxHQUFiLGFBQWEsQ0FBbUI7UUFoQ2hHLFNBQUksR0FBRyxLQUFLLENBQUM7UUFDYixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUV0QixjQUFTLEdBQXdDLFVBQVUsQ0FBQztRQUUzRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxRQUFHLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFakQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRXBELFdBQU0sR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQWlCOEMsQ0FBQztJQWY3RyxzQkFBSSx5Q0FBUzs7OztRQUFiO1lBQ0UsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUMvQixDQUFDOzs7T0FBQTtJQUVELHNCQUNJLHdDQUFROzs7O1FBRFo7WUFFRSxPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQ2pFLENBQUM7Ozs7O1FBQ0QsVUFBYSxHQUFXO1lBQ3RCLElBQUksQ0FBQyxTQUFTLEdBQUcsR0FBRyxDQUFDO1FBQ3ZCLENBQUM7OztPQUhBOzs7O0lBVUQscUNBQVE7OztJQUFSO1FBQ0UsSUFBSSxDQUFDLFdBQVcsR0FBRyx1QkFBcUIsU0FBUyxFQUFFLE9BQUksQ0FBQztRQUN4RCxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQyxDQUFDOzs7O0lBRUQsNENBQWU7OztJQUFmO1FBQUEsaUJBT0M7UUFOQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVM7OztRQUFDO1lBQ2xCLEtBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLEtBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEQsQ0FBQyxFQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVM7OztRQUFDO1lBQ2pCLEtBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLEtBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDdkQsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOzs7O0lBRUQsd0NBQVc7OztJQUFYO1FBQ0UsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7Z0JBckRGLFNBQVMsU0FBQyxFQUFFLFFBQVEsRUFBRSxnQkFBZ0IsRUFBRTs7OztnQkFqQnZDLFVBQVU7Z0JBRVYsU0FBUztnQkFHRixpQkFBaUI7Ozt3QkFjdkIsS0FBSzt1QkFDTCxLQUFLO2dDQUNMLEtBQUs7K0JBQ0wsS0FBSzs0QkFDTCxLQUFLO3VCQUVMLE1BQU07dUJBRU4sTUFBTTt1QkFFTixNQUFNO3NCQUVOLE1BQU07eUJBRU4sTUFBTTt5QkFFTixNQUFNOzJCQU1OLEtBQUs7O0lBOEJSLHlCQUFDO0NBQUEsQUF0REQsSUFzREM7U0FyRFksa0JBQWtCOzs7SUFDN0IsbUNBQW9COztJQUNwQixrQ0FBc0I7O0lBQ3RCLDJDQUErQjs7SUFDL0IsMENBQThCOztJQUM5Qix1Q0FBcUU7O0lBRXJFLGtDQUE0RDs7SUFFNUQsa0NBQTREOztJQUU1RCxrQ0FBNEQ7O0lBRTVELGlDQUEyRDs7SUFFM0Qsb0NBQThEOztJQUU5RCxvQ0FBOEQ7O0lBYzlELHlDQUFvQjs7SUFDcEIsdUNBQWtCOzs7OztJQUVOLGdDQUFzQjs7Ozs7SUFBRSxzQ0FBMkI7Ozs7O0lBQUUsMkNBQXdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlyZWN0aXZlLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBPbkluaXQsXG4gIE9uRGVzdHJveSxcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBSZW5kZXJlcjJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IERyYWtlU3RvcmVTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZHJha2Utc3RvcmUuc2VydmljZSc7XG5cbmxldCBpID0gMTAwMDA7XG5mdW5jdGlvbiBnZXROZXh0SWQoKSB7XG4gIHJldHVybiBpKys7XG59XG5cbi8qKlxuICogTWFrZXMgdGhlIGNvbnRhaW5lciBkcm9wcGFibGUgYW5kIGNoaWxkcmVuIGRyYWdnYWJsZS5cbiAqXG4gKiBAZXhwb3J0XG4gKi9cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1tuZ3hEcm9wcGFibGVdJyB9KVxuZXhwb3J0IGNsYXNzIERyb3BwYWJsZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95LCBBZnRlclZpZXdJbml0IHtcbiAgQElucHV0KCkgbW9kZWw6IGFueTtcbiAgQElucHV0KCkgY29weSA9IGZhbHNlO1xuICBASW5wdXQoKSByZW1vdmVPblNwaWxsID0gZmFsc2U7XG4gIEBJbnB1dCgpIG5neERyb3BwYWJsZTogc3RyaW5nO1xuICBASW5wdXQoKSBkaXJlY3Rpb246ICd2ZXJ0aWNhbCcgfCAnaG9yaXpvbnRhbCcgfCAnbWl4ZWQnID0gJ3ZlcnRpY2FsJztcblxuICBAT3V0cHV0KCkgZHJvcDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgZHJhZzogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgb3ZlcjogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgb3V0OiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSByZW1vdmU6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIGNhbmNlbDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBnZXQgY29udGFpbmVyKCk6IGFueSB7XG4gICAgcmV0dXJuIHRoaXMuZWwubmF0aXZlRWxlbWVudDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIGdldCBkcm9wWm9uZSgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLl9kcm9wWm9uZSB8fCB0aGlzLm5neERyb3BwYWJsZSB8fCB0aGlzLmRlZmF1bHRab25lO1xuICB9XG4gIHNldCBkcm9wWm9uZSh2YWw6IHN0cmluZykge1xuICAgIHRoaXMuX2Ryb3Bab25lID0gdmFsO1xuICB9XG5cbiAgZGVmYXVsdFpvbmU6IHN0cmluZztcbiAgX2Ryb3Bab25lOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLCBwcml2YXRlIGRyYWtlc1NlcnZpY2U6IERyYWtlU3RvcmVTZXJ2aWNlKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuZGVmYXVsdFpvbmUgPSBgQEBEZWZhdWx0RHJvcFpvbmUtJHtnZXROZXh0SWQoKX1AQGA7XG4gICAgdGhpcy5kcmFrZXNTZXJ2aWNlLnJlZ2lzdGVyKHRoaXMpO1xuICB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMub3Zlci5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyh0aGlzLmNvbnRhaW5lciwgJ2d1LW92ZXInKTtcbiAgICB9KTtcbiAgICB0aGlzLm91dC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5yZW5kZXJlci5yZW1vdmVDbGFzcyh0aGlzLmNvbnRhaW5lciwgJ2d1LW92ZXInKTtcbiAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuZHJha2VzU2VydmljZS5yZW1vdmUodGhpcyk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRyb3BwYWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULEtBQUssRUFDTCxNQUFNLEVBQ04sTUFBTSxFQUNOLFNBQVMsRUFDVCxhQUFhLEVBQ2IsVUFBVSxFQUNWLFlBQVksRUFDWixTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFcEUsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDO0FBQ2QsU0FBUyxTQUFTO0lBQ2hCLE9BQU8sQ0FBQyxFQUFFLENBQUM7QUFDYixDQUFDO0FBRUQ7Ozs7R0FJRztBQUVIO0lBa0NFLDRCQUFvQixFQUFjLEVBQVUsUUFBbUIsRUFBVSxhQUFnQztRQUFyRixPQUFFLEdBQUYsRUFBRSxDQUFZO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUFVLGtCQUFhLEdBQWIsYUFBYSxDQUFtQjtRQWhDaEcsU0FBSSxHQUFHLEtBQUssQ0FBQztRQUNiLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBRXRCLGNBQVMsR0FBd0MsVUFBVSxDQUFDO1FBRTNELFNBQUksR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVsRCxTQUFJLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbEQsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWxELFFBQUcsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUVqRCxXQUFNLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFFcEQsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBaUI4QyxDQUFDO0lBZjdHLHNCQUFJLHlDQUFTO2FBQWI7WUFDRSxPQUFPLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDO1FBQy9CLENBQUM7OztPQUFBO0lBR0Qsc0JBQUksd0NBQVE7YUFBWjtZQUNFLE9BQU8sSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxXQUFXLENBQUM7UUFDakUsQ0FBQzthQUNELFVBQWEsR0FBVztZQUN0QixJQUFJLENBQUMsU0FBUyxHQUFHLEdBQUcsQ0FBQztRQUN2QixDQUFDOzs7T0FIQTtJQVVELHFDQUFRLEdBQVI7UUFDRSxJQUFJLENBQUMsV0FBVyxHQUFHLHVCQUFxQixTQUFTLEVBQUUsT0FBSSxDQUFDO1FBQ3hELElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCw0Q0FBZSxHQUFmO1FBQUEsaUJBT0M7UUFOQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztZQUNsQixLQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxLQUFJLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3BELENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUM7WUFDakIsS0FBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsS0FBSSxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN2RCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCx3Q0FBVyxHQUFYO1FBQ0UsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7Z0JBbEJ1QixVQUFVO2dCQUFvQixTQUFTO2dCQUF5QixpQkFBaUI7O0lBakNoRztRQUFSLEtBQUssRUFBRTs7cURBQVk7SUFDWDtRQUFSLEtBQUssRUFBRTs7b0RBQWM7SUFDYjtRQUFSLEtBQUssRUFBRTs7NkRBQXVCO0lBQ3RCO1FBQVIsS0FBSyxFQUFFOzs0REFBc0I7SUFDckI7UUFBUixLQUFLLEVBQUU7O3lEQUE2RDtJQUUzRDtRQUFULE1BQU0sRUFBRTtrQ0FBTyxZQUFZO29EQUFnQztJQUVsRDtRQUFULE1BQU0sRUFBRTtrQ0FBTyxZQUFZO29EQUFnQztJQUVsRDtRQUFULE1BQU0sRUFBRTtrQ0FBTyxZQUFZO29EQUFnQztJQUVsRDtRQUFULE1BQU0sRUFBRTtrQ0FBTSxZQUFZO21EQUFnQztJQUVqRDtRQUFULE1BQU0sRUFBRTtrQ0FBUyxZQUFZO3NEQUFnQztJQUVwRDtRQUFULE1BQU0sRUFBRTtrQ0FBUyxZQUFZO3NEQUFnQztJQU85RDtRQURDLEtBQUssRUFBRTs7O3NEQUdQO0lBMUJVLGtCQUFrQjtRQUQ5QixTQUFTLENBQUMsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQzt5Q0FtQ2hCLFVBQVUsRUFBb0IsU0FBUyxFQUF5QixpQkFBaUI7T0FsQzlGLGtCQUFrQixDQXFEOUI7SUFBRCx5QkFBQztDQUFBLEFBckRELElBcURDO1NBckRZLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgT25Jbml0LFxuICBPbkRlc3Ryb3ksXG4gIEFmdGVyVmlld0luaXQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgUmVuZGVyZXIyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2RyYWtlLXN0b3JlLnNlcnZpY2UnO1xuXG5sZXQgaSA9IDEwMDAwO1xuZnVuY3Rpb24gZ2V0TmV4dElkKCkge1xuICByZXR1cm4gaSsrO1xufVxuXG4vKipcbiAqIE1ha2VzIHRoZSBjb250YWluZXIgZHJvcHBhYmxlIGFuZCBjaGlsZHJlbiBkcmFnZ2FibGUuXG4gKlxuICogQGV4cG9ydFxuICovXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbbmd4RHJvcHBhYmxlXScgfSlcbmV4cG9ydCBjbGFzcyBEcm9wcGFibGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIG1vZGVsOiBhbnk7XG4gIEBJbnB1dCgpIGNvcHkgPSBmYWxzZTtcbiAgQElucHV0KCkgcmVtb3ZlT25TcGlsbCA9IGZhbHNlO1xuICBASW5wdXQoKSBuZ3hEcm9wcGFibGU6IHN0cmluZztcbiAgQElucHV0KCkgZGlyZWN0aW9uOiAndmVydGljYWwnIHwgJ2hvcml6b250YWwnIHwgJ21peGVkJyA9ICd2ZXJ0aWNhbCc7XG5cbiAgQE91dHB1dCgpIGRyb3A6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIGRyYWc6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG92ZXI6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG91dDogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBAT3V0cHV0KCkgcmVtb3ZlOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIEBPdXRwdXQoKSBjYW5jZWw6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgZ2V0IGNvbnRhaW5lcigpOiBhbnkge1xuICAgIHJldHVybiB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQ7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgZHJvcFpvbmUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fZHJvcFpvbmUgfHwgdGhpcy5uZ3hEcm9wcGFibGUgfHwgdGhpcy5kZWZhdWx0Wm9uZTtcbiAgfVxuICBzZXQgZHJvcFpvbmUodmFsOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9kcm9wWm9uZSA9IHZhbDtcbiAgfVxuXG4gIGRlZmF1bHRab25lOiBzdHJpbmc7XG4gIF9kcm9wWm9uZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHJpdmF0ZSBkcmFrZXNTZXJ2aWNlOiBEcmFrZVN0b3JlU2VydmljZSkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmRlZmF1bHRab25lID0gYEBARGVmYXVsdERyb3Bab25lLSR7Z2V0TmV4dElkKCl9QEBgO1xuICAgIHRoaXMuZHJha2VzU2VydmljZS5yZWdpc3Rlcih0aGlzKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXIuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5jb250YWluZXIsICdndS1vdmVyJyk7XG4gICAgfSk7XG4gICAgdGhpcy5vdXQuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVuZGVyZXIucmVtb3ZlQ2xhc3ModGhpcy5jb250YWluZXIsICdndS1vdmVyJyk7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmRyYWtlc1NlcnZpY2UucmVtb3ZlKHRoaXMpO1xuICB9XG59XG4iXX0= |
@@ -1,6 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import * as tslib_1 from "tslib"; | ||
import { __decorate, __read, __spread } from "tslib"; | ||
import { NgModule } from '@angular/core'; | ||
@@ -14,5 +10,3 @@ import { CommonModule } from '@angular/common'; | ||
import { DrakeStoreService } from './services/drake-store.service'; | ||
/** @type {?} */ | ||
var components = [ContainerComponent, ItemComponent]; | ||
/** @type {?} */ | ||
var directives = [DraggableDirective, DroppableDirective, DragHandleDirective]; | ||
@@ -22,24 +16,20 @@ var NgxDnDModule = /** @class */ (function () { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxDnDModule.forRoot = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
NgxDnDModule_1 = NgxDnDModule; | ||
NgxDnDModule.forRoot = function () { | ||
return { | ||
ngModule: NgxDnDModule, | ||
ngModule: NgxDnDModule_1, | ||
providers: [DrakeStoreService] | ||
}; | ||
}; | ||
NgxDnDModule.decorators = [ | ||
{ type: NgModule, args: [{ | ||
imports: [CommonModule], | ||
declarations: tslib_1.__spread(components, directives), | ||
exports: tslib_1.__spread(components, directives) | ||
},] } | ||
]; | ||
var NgxDnDModule_1; | ||
NgxDnDModule = NgxDnDModule_1 = __decorate([ | ||
NgModule({ | ||
imports: [CommonModule], | ||
declarations: __spread(components, directives), | ||
exports: __spread(components, directives) | ||
}) | ||
], NgxDnDModule); | ||
return NgxDnDModule; | ||
}()); | ||
export { NgxDnDModule }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRuZC5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtZG5kLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7SUFHN0QsVUFBVSxHQUFHLENBQUMsa0JBQWtCLEVBQUUsYUFBYSxDQUFDOztJQUNoRCxVQUFVLEdBQUcsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsQ0FBQztBQUVoRjtJQUFBO0lBV0MsQ0FBQzs7OztJQUxPLG9CQUFPOzs7SUFBZDtRQUNBLE9BQU87WUFDTCxRQUFRLEVBQUUsWUFBWTtZQUN0QixTQUFTLEVBQUUsQ0FBRSxpQkFBaUIsQ0FBRTtTQUNqQyxDQUFDO0lBQ0osQ0FBQzs7Z0JBWEEsUUFBUSxTQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsWUFBWSxtQkFBTSxVQUFVLEVBQUssVUFBVSxDQUFDO29CQUM1QyxPQUFPLG1CQUFNLFVBQVUsRUFBSyxVQUFVLENBQUM7aUJBQ3hDOztJQU9BLG1CQUFDO0NBQUEsQUFYRixJQVdFO1NBTlcsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBEcmFnZ2FibGVEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvbmd4LWRyYWdnYWJsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJvcHBhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyYWdIYW5kbGVEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvbmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSXRlbUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9pdGVtL2l0ZW0uY29tcG9uZW50JztcbmltcG9ydCB7IERyYWtlU3RvcmVTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9kcmFrZS1zdG9yZS5zZXJ2aWNlJztcbmltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb21waWxlci9zcmMvY29yZSc7XG5cbmNvbnN0IGNvbXBvbmVudHMgPSBbQ29udGFpbmVyQ29tcG9uZW50LCBJdGVtQ29tcG9uZW50XTtcbmNvbnN0IGRpcmVjdGl2ZXMgPSBbRHJhZ2dhYmxlRGlyZWN0aXZlLCBEcm9wcGFibGVEaXJlY3RpdmUsIERyYWdIYW5kbGVEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbLi4uY29tcG9uZW50cywgLi4uZGlyZWN0aXZlc10sXG4gIGV4cG9ydHM6IFsuLi5jb21wb25lbnRzLCAuLi5kaXJlY3RpdmVzXVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hEbkRNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzIHtcbiAgcmV0dXJuIHtcbiAgICBuZ01vZHVsZTogTmd4RG5ETW9kdWxlLFxuICAgIHByb3ZpZGVyczogWyBEcmFrZVN0b3JlU2VydmljZSBdXG4gIH07XG59fVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRuZC5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac3dpbWxhbmUvbmd4LWRuZC8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtZG5kLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDMUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDaEYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBR25FLElBQU0sVUFBVSxHQUFHLENBQUMsa0JBQWtCLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFDdkQsSUFBTSxVQUFVLEdBQUcsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0FBT2pGO0lBQUE7SUFPQSxDQUFDO3FCQVBZLFlBQVk7SUFDaEIsb0JBQU8sR0FBZDtRQUNFLE9BQU87WUFDTCxRQUFRLEVBQUUsY0FBWTtZQUN0QixTQUFTLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztTQUMvQixDQUFDO0lBQ0osQ0FBQzs7SUFOVSxZQUFZO1FBTHhCLFFBQVEsQ0FBQztZQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztZQUN2QixZQUFZLFdBQU0sVUFBVSxFQUFLLFVBQVUsQ0FBQztZQUM1QyxPQUFPLFdBQU0sVUFBVSxFQUFLLFVBQVUsQ0FBQztTQUN4QyxDQUFDO09BQ1csWUFBWSxDQU94QjtJQUFELG1CQUFDO0NBQUEsQUFQRCxJQU9DO1NBUFksWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBEcmFnZ2FibGVEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvbmd4LWRyYWdnYWJsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJvcHBhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyYWdIYW5kbGVEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMvbmd4LWRyYWctaGFuZGxlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSXRlbUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9pdGVtL2l0ZW0uY29tcG9uZW50JztcbmltcG9ydCB7IERyYWtlU3RvcmVTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9kcmFrZS1zdG9yZS5zZXJ2aWNlJztcbmltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb21waWxlci9zcmMvY29yZSc7XG5cbmNvbnN0IGNvbXBvbmVudHMgPSBbQ29udGFpbmVyQ29tcG9uZW50LCBJdGVtQ29tcG9uZW50XTtcbmNvbnN0IGRpcmVjdGl2ZXMgPSBbRHJhZ2dhYmxlRGlyZWN0aXZlLCBEcm9wcGFibGVEaXJlY3RpdmUsIERyYWdIYW5kbGVEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbLi4uY29tcG9uZW50cywgLi4uZGlyZWN0aXZlc10sXG4gIGV4cG9ydHM6IFsuLi5jb21wb25lbnRzLCAuLi5kaXJlY3RpdmVzXVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hEbkRNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzIHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IE5neERuRE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW0RyYWtlU3RvcmVTZXJ2aWNlXVxuICAgIH07XG4gIH1cbn1cbiJdfQ== |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
import { __decorate, __metadata } from "tslib"; | ||
import { Injectable } from '@angular/core'; | ||
@@ -9,3 +6,2 @@ import * as dragulaNamespace from '@swimlane/dragula'; | ||
// see https://github.com/dherges/ng-packagr/issues/217 | ||
/** @type {?} */ | ||
var dragula = dragulaNamespace; | ||
@@ -25,25 +21,8 @@ /** | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.register = /** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
function (droppable) { | ||
DrakeStoreService.prototype.register = function (droppable) { | ||
this.droppableMap.set(droppable.container, droppable); | ||
this.drake.containers.push(droppable.container); | ||
}; | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.remove = /** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
function (droppable) { | ||
DrakeStoreService.prototype.remove = function (droppable) { | ||
this.droppableMap.delete(droppable.container); | ||
/** @type {?} */ | ||
var idx = this.drake.containers.indexOf(droppable.container); | ||
@@ -54,45 +33,15 @@ if (idx > -1) { | ||
}; | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.registerDraggable = /** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
function (draggable) { | ||
DrakeStoreService.prototype.registerDraggable = function (draggable) { | ||
this.draggableMap.set(draggable.element, draggable); | ||
}; | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.removeDraggable = /** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
function (draggable) { | ||
DrakeStoreService.prototype.removeDraggable = function (draggable) { | ||
this.draggableMap.delete(draggable.element); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.createDrakeOptions = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DrakeStoreService.prototype.createDrakeOptions = function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var accepts = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @return {?} | ||
*/ | ||
function (el, target /*, source: any, sibling: any */) { | ||
var accepts = function (el, target /*, source: any, sibling: any */) { | ||
if (el.contains(target)) { | ||
return false; | ||
} | ||
/** @type {?} */ | ||
var elementComponent = _this.draggableMap.get(el); | ||
/** @type {?} */ | ||
var targetComponent = _this.droppableMap.get(target); | ||
@@ -103,11 +52,4 @@ if (elementComponent && targetComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
var copy = (/** | ||
* @param {?} _ | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (_, source) { | ||
/** @type {?} */ | ||
}; | ||
var copy = function (_, source) { | ||
var sourceComponent = _this.droppableMap.get(source); | ||
@@ -118,13 +60,4 @@ if (sourceComponent) { | ||
return false; | ||
}); | ||
/** @type {?} */ | ||
var moves = (/** | ||
* @param {?=} el | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
function (el, source, handle, sibling) { | ||
/** @type {?} */ | ||
}; | ||
var moves = function (el, source, handle, sibling) { | ||
var elementComponent = _this.draggableMap.get(el); | ||
@@ -135,35 +68,14 @@ if (elementComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
var direction = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, target, source) { | ||
/** @type {?} */ | ||
}; | ||
var direction = function (el, target, source) { | ||
var targetComponent = _this.droppableMap.get(target); | ||
return targetComponent.direction || 'vertical'; | ||
}); | ||
}; | ||
return { accepts: accepts, copy: copy, moves: moves, revertOnSpill: true, direction: direction }; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.registerEvents = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DrakeStoreService.prototype.registerEvents = function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var dragElm; | ||
/** @type {?} */ | ||
var draggedItem; | ||
this.drake.on('drag', (/** | ||
* @param {?} el | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, source) { | ||
this.drake.on('drag', function (el, source) { | ||
draggedItem = undefined; | ||
@@ -175,3 +87,2 @@ dragElm = el; | ||
if (_this.draggableMap.has(el)) { | ||
/** @type {?} */ | ||
var elementComponent = _this.draggableMap.get(el); | ||
@@ -187,3 +98,2 @@ draggedItem = elementComponent.model; | ||
if (_this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
@@ -199,11 +109,4 @@ _this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill; | ||
} | ||
})); | ||
this.drake.on('drop', (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, target, source) { | ||
/** @type {?} */ | ||
}); | ||
this.drake.on('drop', function (el, target, source) { | ||
var targetComponent = _this.droppableMap.get(target); | ||
@@ -214,5 +117,3 @@ if (!targetComponent) { | ||
} | ||
/** @type {?} */ | ||
var dropElmModel = draggedItem; | ||
/** @type {?} */ | ||
var dropIndex = Array.prototype.indexOf.call(target.children, el); | ||
@@ -224,12 +125,7 @@ if (dropIndex < 0) { | ||
} | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
if (sourceComponent) { | ||
/** @type {?} */ | ||
var sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
var targetModel = targetComponent.model; | ||
/** @type {?} */ | ||
var hasDragModel = !!(sourceModel && draggedItem); | ||
/** @type {?} */ | ||
var dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -242,5 +138,3 @@ if (hasDragModel && dragIndex < 0) { | ||
if (targetModel) { | ||
/** @type {?} */ | ||
var reorder = dragIndex > -1 && sourceModel && target === source; | ||
/** @type {?} */ | ||
var copy = !sourceModel || dragElm !== el; | ||
@@ -275,16 +169,7 @@ if (reorder) { | ||
}); | ||
})); | ||
this.drake.on('remove', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('remove', function (el, container, source) { | ||
if (_this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
/** @type {?} */ | ||
var sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
var dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -306,12 +191,5 @@ if (dragIndex > -1) { | ||
} | ||
})); | ||
this.drake.on('cancel', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('cancel', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -326,12 +204,5 @@ containerComponent.cancel.emit({ | ||
} | ||
})); | ||
this.drake.on('over', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('over', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -346,12 +217,5 @@ containerComponent.over.emit({ | ||
} | ||
})); | ||
this.drake.on('out', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('out', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -366,35 +230,12 @@ containerComponent.out.emit({ | ||
} | ||
})); | ||
}); | ||
}; | ||
DrakeStoreService.decorators = [ | ||
{ type: Injectable, args: [{ providedIn: 'root' },] } | ||
]; | ||
/** @nocollapse */ | ||
DrakeStoreService.ctorParameters = function () { return []; }; | ||
/** @nocollapse */ DrakeStoreService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService.ɵprov = i0.ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService = __decorate([ | ||
Injectable({ providedIn: 'root' }), | ||
__metadata("design:paramtypes", []) | ||
], DrakeStoreService); | ||
return DrakeStoreService; | ||
}()); | ||
export { DrakeStoreService }; | ||
if (false) { | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.droppableMap; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.draggableMap; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.dragulaOptions; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
DrakeStoreService.prototype.drake; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drake-store.service.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/services/drake-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport * as dragulaNamespace from '@swimlane/dragula';\nimport { DroppableDirective } from '../directives/ngx-droppable.directive';\nimport { DraggableDirective } from '../directives/ngx-draggable.directive';\n\n// see https://github.com/dherges/ng-packagr/issues/217\nconst dragula = dragulaNamespace;\n\n/**\n * Central service that handles all events\n *\n * @export\n */\n@Injectable({ providedIn: 'root' })\nexport class DrakeStoreService {\n  private droppableMap = new WeakMap<any, DroppableDirective>();\n  private draggableMap = new WeakMap<any, DraggableDirective>();\n  private dragulaOptions: dragulaNamespace.DragulaOptions;\n  private drake: dragulaNamespace.Drake;\n\n  constructor() {\n    this.dragulaOptions = this.createDrakeOptions();\n    this.drake = dragula([], this.dragulaOptions);\n    this.registerEvents();    \n  }\n\n  register(droppable: DroppableDirective) {\n    this.droppableMap.set(droppable.container, droppable);\n    this.drake.containers.push(droppable.container);\n  }\n\n  remove(droppable: DroppableDirective) {\n    this.droppableMap.delete(droppable.container);\n    const idx = this.drake.containers.indexOf(droppable.container);\n    if (idx > -1) {\n      this.drake.containers.splice(idx, 1);\n    }\n  }\n\n  registerDraggable(draggable: DraggableDirective) {\n    this.draggableMap.set(draggable.element, draggable);\n  }\n\n  removeDraggable(draggable: DraggableDirective) {\n    this.draggableMap.delete(draggable.element);\n  }\n\n  createDrakeOptions(): dragulaNamespace.DragulaOptions {\n    const accepts = (el: any, target: any /*, source: any, sibling: any */) => {\n      if (el.contains(target)) {\n        return false;\n      }\n      const elementComponent = this.draggableMap.get(el);\n      const targetComponent = this.droppableMap.get(target);\n      if (elementComponent && targetComponent) {\n        return elementComponent.dropZones.includes(targetComponent.dropZone);\n      }\n      return true;\n    };\n\n    const copy = (_: any, source: any) => {\n      const sourceComponent = this.droppableMap.get(source);\n      if (sourceComponent) {\n        return sourceComponent.copy;\n      }\n      return false;\n    };\n\n    const moves = (el?: any, source?: any, handle?: any, sibling?: any) => {\n      const elementComponent = this.draggableMap.get(el);\n      if (elementComponent) {\n        return elementComponent.moves(source, handle, sibling);\n      }\n      return true;\n    };\n\n    const direction: any = (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n      return targetComponent.direction || 'vertical';\n    };\n\n    return { accepts, copy, moves, revertOnSpill: true, direction };\n  }\n\n  registerEvents(): void {\n    let dragElm: any;\n    let draggedItem: any;\n\n    this.drake.on('drag', (el: any, source: any) => {\n      draggedItem = undefined;\n      dragElm = el;\n\n      if (!el || !source) {\n        return;\n      }\n\n      if (this.draggableMap.has(el)) {\n        const elementComponent = this.draggableMap.get(el);\n        draggedItem = elementComponent.model;\n\n        elementComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          value: draggedItem\n        });\n      }\n\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill;\n\n        sourceComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          sourceComponent,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('drop', (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n\n      if (!targetComponent) {\n        // not a target, abort\n        return;\n      }\n\n      let dropElmModel = draggedItem;\n      const dropIndex = Array.prototype.indexOf.call(target.children, el);\n\n      if (dropIndex < 0) {\n        // dropIndex is bad... cancel\n        this.drake.cancel(true);\n        return;\n      }\n\n      const sourceComponent = this.droppableMap.get(source);\n\n      if (sourceComponent) {\n        const sourceModel = sourceComponent.model;\n        const targetModel = targetComponent.model;\n\n        const hasDragModel = !!(sourceModel && draggedItem);\n        const dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1;\n        if (hasDragModel && dragIndex < 0) {\n          // dragIndex is bad... cancel\n          this.drake.cancel(true);\n          return;\n        }\n\n        if (targetModel) {\n          const reorder = dragIndex > -1 && sourceModel && target === source;\n          const copy = !sourceModel || dragElm !== el;\n          if (reorder) {\n            sourceModel.splice(dropIndex, 0, sourceModel.splice(dragIndex, 1)[0]);\n          } else {\n            if (el.parentNode === target) {\n              target.removeChild(el);\n            }\n\n            if (copy) {\n              dropElmModel = JSON.parse(JSON.stringify(dropElmModel));\n            } else {\n              if (el.parentNode !== source) {\n                // add element back, let angular remove it\n                this.drake.cancel(true);\n              }\n              sourceModel.splice(dragIndex, 1);\n            }\n            targetModel.splice(dropIndex, 0, dropElmModel);\n          }\n        }\n      }\n\n      targetComponent.drop.emit({\n        type: 'drop',\n        el,\n        source,\n        value: dropElmModel,\n        dropIndex\n      });\n    });\n\n    this.drake.on('remove', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        const sourceModel = sourceComponent.model;\n\n        const dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1;\n\n        if (dragIndex > -1) {\n          if (el.parentNode !== source) {\n            // add element back, let angular remove it\n            source.appendChild(el);\n          }\n          sourceModel.splice(dragIndex, 1);\n        }\n\n        sourceComponent.remove.emit({\n          type: 'remove',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('cancel', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.cancel.emit({\n          type: 'cancel',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('over', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.over.emit({\n          type: 'over',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('out', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.out.emit({\n          type: 'out',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drake-store.service.js","sourceRoot":"ng://@swimlane/ngx-dnd/","sources":["lib/services/drake-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport * as dragulaNamespace from '@swimlane/dragula';\nimport { DroppableDirective } from '../directives/ngx-droppable.directive';\nimport { DraggableDirective } from '../directives/ngx-draggable.directive';\n\n// see https://github.com/dherges/ng-packagr/issues/217\nconst dragula = dragulaNamespace;\n\n/**\n * Central service that handles all events\n *\n * @export\n */\n@Injectable({ providedIn: 'root' })\nexport class DrakeStoreService {\n  private droppableMap = new WeakMap<any, DroppableDirective>();\n  private draggableMap = new WeakMap<any, DraggableDirective>();\n  private dragulaOptions: dragulaNamespace.DragulaOptions;\n  private drake: dragulaNamespace.Drake;\n\n  constructor() {\n    this.dragulaOptions = this.createDrakeOptions();\n    this.drake = dragula([], this.dragulaOptions);\n    this.registerEvents();\n  }\n\n  register(droppable: DroppableDirective) {\n    this.droppableMap.set(droppable.container, droppable);\n    this.drake.containers.push(droppable.container);\n  }\n\n  remove(droppable: DroppableDirective) {\n    this.droppableMap.delete(droppable.container);\n    const idx = this.drake.containers.indexOf(droppable.container);\n    if (idx > -1) {\n      this.drake.containers.splice(idx, 1);\n    }\n  }\n\n  registerDraggable(draggable: DraggableDirective) {\n    this.draggableMap.set(draggable.element, draggable);\n  }\n\n  removeDraggable(draggable: DraggableDirective) {\n    this.draggableMap.delete(draggable.element);\n  }\n\n  createDrakeOptions(): dragulaNamespace.DragulaOptions {\n    const accepts = (el: any, target: any /*, source: any, sibling: any */) => {\n      if (el.contains(target)) {\n        return false;\n      }\n      const elementComponent = this.draggableMap.get(el);\n      const targetComponent = this.droppableMap.get(target);\n      if (elementComponent && targetComponent) {\n        return elementComponent.dropZones.includes(targetComponent.dropZone);\n      }\n      return true;\n    };\n\n    const copy = (_: any, source: any) => {\n      const sourceComponent = this.droppableMap.get(source);\n      if (sourceComponent) {\n        return sourceComponent.copy;\n      }\n      return false;\n    };\n\n    const moves = (el?: any, source?: any, handle?: any, sibling?: any) => {\n      const elementComponent = this.draggableMap.get(el);\n      if (elementComponent) {\n        return elementComponent.moves(source, handle, sibling);\n      }\n      return true;\n    };\n\n    const direction: any = (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n      return targetComponent.direction || 'vertical';\n    };\n\n    return { accepts, copy, moves, revertOnSpill: true, direction };\n  }\n\n  registerEvents(): void {\n    let dragElm: any;\n    let draggedItem: any;\n\n    this.drake.on('drag', (el: any, source: any) => {\n      draggedItem = undefined;\n      dragElm = el;\n\n      if (!el || !source) {\n        return;\n      }\n\n      if (this.draggableMap.has(el)) {\n        const elementComponent = this.draggableMap.get(el);\n        draggedItem = elementComponent.model;\n\n        elementComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          value: draggedItem\n        });\n      }\n\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill;\n\n        sourceComponent.drag.emit({\n          type: 'drag',\n          el,\n          source,\n          sourceComponent,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('drop', (el: any, target: any, source: any) => {\n      const targetComponent = this.droppableMap.get(target);\n\n      if (!targetComponent) {\n        // not a target, abort\n        return;\n      }\n\n      let dropElmModel = draggedItem;\n      const dropIndex = Array.prototype.indexOf.call(target.children, el);\n\n      if (dropIndex < 0) {\n        // dropIndex is bad... cancel\n        this.drake.cancel(true);\n        return;\n      }\n\n      const sourceComponent = this.droppableMap.get(source);\n\n      if (sourceComponent) {\n        const sourceModel = sourceComponent.model;\n        const targetModel = targetComponent.model;\n\n        const hasDragModel = !!(sourceModel && draggedItem);\n        const dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1;\n        if (hasDragModel && dragIndex < 0) {\n          // dragIndex is bad... cancel\n          this.drake.cancel(true);\n          return;\n        }\n\n        if (targetModel) {\n          const reorder = dragIndex > -1 && sourceModel && target === source;\n          const copy = !sourceModel || dragElm !== el;\n          if (reorder) {\n            sourceModel.splice(dropIndex, 0, sourceModel.splice(dragIndex, 1)[0]);\n          } else {\n            if (el.parentNode === target) {\n              target.removeChild(el);\n            }\n\n            if (copy) {\n              dropElmModel = JSON.parse(JSON.stringify(dropElmModel));\n            } else {\n              if (el.parentNode !== source) {\n                // add element back, let angular remove it\n                this.drake.cancel(true);\n              }\n              sourceModel.splice(dragIndex, 1);\n            }\n            targetModel.splice(dropIndex, 0, dropElmModel);\n          }\n        }\n      }\n\n      targetComponent.drop.emit({\n        type: 'drop',\n        el,\n        source,\n        value: dropElmModel,\n        dropIndex\n      });\n    });\n\n    this.drake.on('remove', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(source)) {\n        const sourceComponent = this.droppableMap.get(source);\n        const sourceModel = sourceComponent.model;\n\n        const dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1;\n\n        if (dragIndex > -1) {\n          if (el.parentNode !== source) {\n            // add element back, let angular remove it\n            source.appendChild(el);\n          }\n          sourceModel.splice(dragIndex, 1);\n        }\n\n        sourceComponent.remove.emit({\n          type: 'remove',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('cancel', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.cancel.emit({\n          type: 'cancel',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('over', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.over.emit({\n          type: 'over',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n\n    this.drake.on('out', (el: any, container: any, source: any) => {\n      if (this.droppableMap.has(container)) {\n        const containerComponent = this.droppableMap.get(container);\n        containerComponent.out.emit({\n          type: 'out',\n          el,\n          container,\n          source,\n          value: draggedItem\n        });\n      }\n    });\n  }\n}\n"]} |
@@ -1,6 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { NgxDnDModule } from './lib/ngx-dnd.module'; | ||
export * from './lib/ngx-dnd.module'; | ||
export { DraggableDirective } from './lib/directives/ngx-draggable.directive'; | ||
@@ -12,2 +8,2 @@ export { DroppableDirective } from './lib/directives/ngx-droppable.directive'; | ||
export { DrakeStoreService } from './lib/services/drake-store.service'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsicHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsNkJBQWMsc0JBQXNCLENBQUM7QUFDckMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDOUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDOUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDakYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbmd4LWRuZC5tb2R1bGUnO1xuZXhwb3J0IHsgRHJhZ2dhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9uZ3gtZHJhZ2dhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBEcm9wcGFibGVEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL25neC1kcm9wcGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCB7IERyYWdIYW5kbGVEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL25neC1kcmFnLWhhbmRsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgSXRlbUNvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvaXRlbS9pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDb250YWluZXJDb21wb25lbnQgfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2NvbnRhaW5lci9jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IERyYWtlU3RvcmVTZXJ2aWNlIH0gZnJvbSAnLi9saWIvc2VydmljZXMvZHJha2Utc3RvcmUuc2VydmljZSc7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsicHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUNwRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL25neC1kbmQubW9kdWxlJztcbmV4cG9ydCB7IERyYWdnYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvbmd4LWRyYWdnYWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgRHJvcHBhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9uZ3gtZHJvcHBhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBEcmFnSGFuZGxlRGlyZWN0aXZlIH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9uZ3gtZHJhZy1oYW5kbGUuZGlyZWN0aXZlJztcbmV4cG9ydCB7IEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2l0ZW0vaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBEcmFrZVN0b3JlU2VydmljZSB9IGZyb20gJy4vbGliL3NlcnZpY2VzL2RyYWtlLXN0b3JlLnNlcnZpY2UnO1xuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
export { DraggableDirective, DroppableDirective, DragHandleDirective, ItemComponent, ContainerComponent, DrakeStoreService, NgxDnDModule } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpbWxhbmUtbmd4LWRuZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsic3dpbWxhbmUtbmd4LWRuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsZ0pBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19 | ||
export * from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpbWxhbmUtbmd4LWRuZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bzd2ltbGFuZS9uZ3gtZG5kLyIsInNvdXJjZXMiOlsic3dpbWxhbmUtbmd4LWRuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19 |
@@ -1,11 +0,7 @@ | ||
import { Injectable, ɵɵdefineInjectable, EventEmitter, Directive, ElementRef, Renderer2, Input, Output, HostListener, Component, ViewEncapsulation, ContentChild, TemplateRef, ViewChild, HostBinding, NgModule } from '@angular/core'; | ||
import { __decorate, __metadata } from 'tslib'; | ||
import { ɵɵdefineInjectable, Injectable, EventEmitter, ElementRef, Renderer2, Input, Output, Directive, HostListener, TemplateRef, ContentChild, ViewChild, Component, ViewEncapsulation, HostBinding, NgModule } from '@angular/core'; | ||
import { CommonModule } from '@angular/common'; | ||
import * as dragulaNamespace from '@swimlane/dragula'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
// see https://github.com/dherges/ng-packagr/issues/217 | ||
/** @type {?} */ | ||
const dragula = dragulaNamespace; | ||
@@ -17,3 +13,3 @@ /** | ||
*/ | ||
class DrakeStoreService { | ||
let DrakeStoreService = class DrakeStoreService { | ||
constructor() { | ||
@@ -26,6 +22,2 @@ this.droppableMap = new WeakMap(); | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
register(droppable) { | ||
@@ -35,9 +27,4 @@ this.droppableMap.set(droppable.container, droppable); | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
remove(droppable) { | ||
this.droppableMap.delete(droppable.container); | ||
/** @type {?} */ | ||
const idx = this.drake.containers.indexOf(droppable.container); | ||
@@ -48,33 +35,14 @@ if (idx > -1) { | ||
} | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
registerDraggable(draggable) { | ||
this.draggableMap.set(draggable.element, draggable); | ||
} | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
removeDraggable(draggable) { | ||
this.draggableMap.delete(draggable.element); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
createDrakeOptions() { | ||
/** @type {?} */ | ||
const accepts = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @return {?} | ||
*/ | ||
(el, target /*, source: any, sibling: any */) => { | ||
const accepts = (el, target /*, source: any, sibling: any */) => { | ||
if (el.contains(target)) { | ||
return false; | ||
} | ||
/** @type {?} */ | ||
const elementComponent = this.draggableMap.get(el); | ||
/** @type {?} */ | ||
const targetComponent = this.droppableMap.get(target); | ||
@@ -85,11 +53,4 @@ if (elementComponent && targetComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
const copy = (/** | ||
* @param {?} _ | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(_, source) => { | ||
/** @type {?} */ | ||
}; | ||
const copy = (_, source) => { | ||
const sourceComponent = this.droppableMap.get(source); | ||
@@ -100,13 +61,4 @@ if (sourceComponent) { | ||
return false; | ||
}); | ||
/** @type {?} */ | ||
const moves = (/** | ||
* @param {?=} el | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
(el, source, handle, sibling) => { | ||
/** @type {?} */ | ||
}; | ||
const moves = (el, source, handle, sibling) => { | ||
const elementComponent = this.draggableMap.get(el); | ||
@@ -117,31 +69,13 @@ if (elementComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
const direction = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, target, source) => { | ||
/** @type {?} */ | ||
}; | ||
const direction = (el, target, source) => { | ||
const targetComponent = this.droppableMap.get(target); | ||
return targetComponent.direction || 'vertical'; | ||
}); | ||
}; | ||
return { accepts, copy, moves, revertOnSpill: true, direction }; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
registerEvents() { | ||
/** @type {?} */ | ||
let dragElm; | ||
/** @type {?} */ | ||
let draggedItem; | ||
this.drake.on('drag', (/** | ||
* @param {?} el | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, source) => { | ||
this.drake.on('drag', (el, source) => { | ||
draggedItem = undefined; | ||
@@ -153,3 +87,2 @@ dragElm = el; | ||
if (this.draggableMap.has(el)) { | ||
/** @type {?} */ | ||
const elementComponent = this.draggableMap.get(el); | ||
@@ -165,3 +98,2 @@ draggedItem = elementComponent.model; | ||
if (this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
const sourceComponent = this.droppableMap.get(source); | ||
@@ -177,11 +109,4 @@ this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill; | ||
} | ||
})); | ||
this.drake.on('drop', (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, target, source) => { | ||
/** @type {?} */ | ||
}); | ||
this.drake.on('drop', (el, target, source) => { | ||
const targetComponent = this.droppableMap.get(target); | ||
@@ -192,5 +117,3 @@ if (!targetComponent) { | ||
} | ||
/** @type {?} */ | ||
let dropElmModel = draggedItem; | ||
/** @type {?} */ | ||
const dropIndex = Array.prototype.indexOf.call(target.children, el); | ||
@@ -202,12 +125,7 @@ if (dropIndex < 0) { | ||
} | ||
/** @type {?} */ | ||
const sourceComponent = this.droppableMap.get(source); | ||
if (sourceComponent) { | ||
/** @type {?} */ | ||
const sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
const targetModel = targetComponent.model; | ||
/** @type {?} */ | ||
const hasDragModel = !!(sourceModel && draggedItem); | ||
/** @type {?} */ | ||
const dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -220,5 +138,3 @@ if (hasDragModel && dragIndex < 0) { | ||
if (targetModel) { | ||
/** @type {?} */ | ||
const reorder = dragIndex > -1 && sourceModel && target === source; | ||
/** @type {?} */ | ||
const copy = !sourceModel || dragElm !== el; | ||
@@ -253,16 +169,7 @@ if (reorder) { | ||
}); | ||
})); | ||
this.drake.on('remove', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('remove', (el, container, source) => { | ||
if (this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
const sourceComponent = this.droppableMap.get(source); | ||
/** @type {?} */ | ||
const sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
const dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -284,12 +191,5 @@ if (dragIndex > -1) { | ||
} | ||
})); | ||
this.drake.on('cancel', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('cancel', (el, container, source) => { | ||
if (this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
const containerComponent = this.droppableMap.get(container); | ||
@@ -304,12 +204,5 @@ containerComponent.cancel.emit({ | ||
} | ||
})); | ||
this.drake.on('over', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('over', (el, container, source) => { | ||
if (this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
const containerComponent = this.droppableMap.get(container); | ||
@@ -324,12 +217,5 @@ containerComponent.over.emit({ | ||
} | ||
})); | ||
this.drake.on('out', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
(el, container, source) => { | ||
}); | ||
this.drake.on('out', (el, container, source) => { | ||
if (this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
const containerComponent = this.droppableMap.get(container); | ||
@@ -344,21 +230,12 @@ containerComponent.out.emit({ | ||
} | ||
})); | ||
}); | ||
} | ||
} | ||
DrakeStoreService.decorators = [ | ||
{ type: Injectable, args: [{ providedIn: 'root' },] } | ||
]; | ||
/** @nocollapse */ | ||
DrakeStoreService.ctorParameters = () => []; | ||
/** @nocollapse */ DrakeStoreService.ngInjectableDef = ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
}; | ||
DrakeStoreService.ɵprov = ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService = __decorate([ | ||
Injectable({ providedIn: 'root' }), | ||
__metadata("design:paramtypes", []) | ||
], DrakeStoreService); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
let i = 10000; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -372,8 +249,3 @@ return i++; | ||
*/ | ||
class DroppableDirective { | ||
/** | ||
* @param {?} el | ||
* @param {?} renderer | ||
* @param {?} drakesService | ||
*/ | ||
let DroppableDirective = class DroppableDirective { | ||
constructor(el, renderer, drakesService) { | ||
@@ -393,24 +265,11 @@ this.el = el; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get container() { | ||
return this.el.nativeElement; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZone() { | ||
return this._dropZone || this.ngxDroppable || this.defaultZone; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZone(val) { | ||
this._dropZone = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
@@ -420,30 +279,14 @@ this.defaultZone = `@@DefaultDropZone-${getNextId()}@@`; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngAfterViewInit() { | ||
this.over.subscribe((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.over.subscribe(() => { | ||
this.renderer.addClass(this.container, 'gu-over'); | ||
})); | ||
this.out.subscribe((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
}); | ||
this.out.subscribe(() => { | ||
this.renderer.removeClass(this.container, 'gu-over'); | ||
})); | ||
}); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnDestroy() { | ||
this.drakesService.remove(this); | ||
} | ||
} | ||
DroppableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDroppable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
}; | ||
DroppableDirective.ctorParameters = () => [ | ||
@@ -454,22 +297,57 @@ { type: ElementRef }, | ||
]; | ||
DroppableDirective.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
ngxDroppable: [{ type: Input }], | ||
direction: [{ type: Input }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }], | ||
dropZone: [{ type: Input }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "ngxDroppable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "direction", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "cancel", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String), | ||
__metadata("design:paramtypes", [String]) | ||
], DroppableDirective.prototype, "dropZone", null); | ||
DroppableDirective = __decorate([ | ||
Directive({ selector: '[ngxDroppable]' }), | ||
__metadata("design:paramtypes", [ElementRef, Renderer2, DrakeStoreService]) | ||
], DroppableDirective); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Adds properties and events to draggable elements | ||
@@ -479,8 +357,3 @@ * | ||
*/ | ||
class DraggableDirective { | ||
/** | ||
* @param {?} el | ||
* @param {?} drakesService | ||
* @param {?} droppableDirective | ||
*/ | ||
let DraggableDirective = class DraggableDirective { | ||
constructor(el, drakesService, droppableDirective) { | ||
@@ -492,36 +365,22 @@ this.el = el; | ||
/* | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
this.handles = []; | ||
this.drag = new EventEmitter(); | ||
this.dragDelay = 200; // milliseconds | ||
// milliseconds | ||
this.dragDelayed = true; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZones() { | ||
return this._dropZones || this.ngxDraggable || this._parentDropzones; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZones(val) { | ||
this._dropZones = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get hasHandle() { | ||
return !!this.handles.length; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get element() { | ||
@@ -531,6 +390,2 @@ return this.el.nativeElement; | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
onMove(e) { | ||
@@ -542,33 +397,18 @@ if (!this._moves || this.dragDelayed) { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
onDown() { | ||
if (this._moves) { | ||
this.touchTimeout = setTimeout((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.touchTimeout = setTimeout(() => { | ||
this.dragDelayed = false; | ||
}), this.dragDelay); | ||
}, this.dragDelay); | ||
} | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
onUp() { | ||
if (this._moves) { | ||
clearTimeout((/** @type {?} */ (this.touchTimeout))); | ||
clearTimeout(this.touchTimeout); | ||
this.dragDelayed = true; | ||
} | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
this.update(); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
update() { | ||
@@ -579,25 +419,9 @@ this._parentDropzones = [this.droppableDirective.dropZone]; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnDestroy() { | ||
this.drakesService.removeDraggable(this); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
updateElements() { | ||
/** @type {?} */ | ||
const nativeElement = this.el.nativeElement; | ||
/** @type {?} */ | ||
const handles = nativeElement.querySelectorAll('[ngxdraghandle]'); | ||
this.handles = Array.from(handles).filter((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
(h) => findFirstDraggableParent(h) === nativeElement)); | ||
/** | ||
* @param {?} c | ||
* @return {?} | ||
*/ | ||
this.handles = Array.from(handles).filter((h) => findFirstDraggableParent(h) === nativeElement); | ||
function findFirstDraggableParent(c) { | ||
@@ -612,8 +436,2 @@ while (c.parentNode) { | ||
} | ||
/** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
canMove(source, handle, sibling) { | ||
@@ -626,21 +444,6 @@ if (typeof this._moves === 'boolean') | ||
} | ||
/** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
moves(source, handle, sibling) { | ||
if (!this.canMove(source, handle, sibling)) | ||
return false; | ||
return this.hasHandle ? this.handles.some((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
h => handelFor(handle, h))) : true; | ||
/** | ||
* @param {?} c | ||
* @param {?} p | ||
* @return {?} | ||
*/ | ||
return this.hasHandle ? this.handles.some(h => handelFor(handle, h)) : true; | ||
function handelFor(c, p) { | ||
@@ -654,13 +457,6 @@ if (c === p) | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngDoCheck() { | ||
this.updateElements(); | ||
} | ||
} | ||
DraggableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDraggable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
}; | ||
DraggableDirective.ctorParameters = () => [ | ||
@@ -671,18 +467,49 @@ { type: ElementRef }, | ||
]; | ||
DraggableDirective.propDecorators = { | ||
ngxDraggable: [{ type: Input }], | ||
model: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
_moves: [{ type: Input, args: ['moves',] }], | ||
drag: [{ type: Output }], | ||
onMove: [{ type: HostListener, args: ['touchmove', ['$event'],] }], | ||
onDown: [{ type: HostListener, args: ['touchstart',] }], | ||
onUp: [{ type: HostListener, args: ['touchend',] }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Array) | ||
], DraggableDirective.prototype, "ngxDraggable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], DraggableDirective.prototype, "dropZones", null); | ||
__decorate([ | ||
Input('moves'), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "_moves", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DraggableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
HostListener('touchmove', ['$event']), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", [Event]), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onMove", null); | ||
__decorate([ | ||
HostListener('touchstart'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onDown", null); | ||
__decorate([ | ||
HostListener('touchend'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onUp", null); | ||
DraggableDirective = __decorate([ | ||
Directive({ selector: '[ngxDraggable]' }), | ||
__metadata("design:paramtypes", [ElementRef, | ||
DrakeStoreService, | ||
DroppableDirective]) | ||
], DraggableDirective); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Adds properties and events to drag handle elements | ||
@@ -692,17 +519,9 @@ * | ||
*/ | ||
class DragHandleDirective { | ||
} | ||
DragHandleDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDragHandle]' },] } | ||
]; | ||
let DragHandleDirective = class DragHandleDirective { | ||
}; | ||
DragHandleDirective = __decorate([ | ||
Directive({ selector: '[ngxDragHandle]' }) | ||
], DragHandleDirective); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
let i$1 = 0; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId$1() { | ||
@@ -716,3 +535,3 @@ return i$1++; | ||
*/ | ||
class ContainerComponent { | ||
let ContainerComponent = class ContainerComponent { | ||
constructor() { | ||
@@ -729,12 +548,5 @@ this.copy = false; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZones() { | ||
return this._dropZones || this._defaultZones; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZones(val) { | ||
@@ -745,90 +557,97 @@ this._dropZones = val; | ||
// @Input() dragulaOptions: any; | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
set templateInput(template) { | ||
this.template = template; | ||
} | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
set templateChild(template) { | ||
this.template = template; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
this._defaultZones = [this.dropZone]; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngAfterViewInit() { | ||
this.droppable.drag.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.drag.emit(v))); | ||
this.droppable.drop.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.drop.emit(v))); | ||
this.droppable.over.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.over.emit(v))); | ||
this.droppable.out.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.out.emit(v))); | ||
this.droppable.remove.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.remove.emit(v))); | ||
this.droppable.cancel.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
(v) => this.cancel.emit(v))); | ||
this.droppable.drag.subscribe((v) => this.drag.emit(v)); | ||
this.droppable.drop.subscribe((v) => this.drop.emit(v)); | ||
this.droppable.over.subscribe((v) => this.over.emit(v)); | ||
this.droppable.out.subscribe((v) => this.out.emit(v)); | ||
this.droppable.remove.subscribe((v) => this.remove.emit(v)); | ||
this.droppable.cancel.subscribe((v) => this.cancel.emit(v)); | ||
} | ||
} | ||
ContainerComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}] } | ||
]; | ||
ContainerComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
moves: [{ type: Input }], | ||
templateInput: [{ type: Input, args: ['template',] }], | ||
templateChild: [{ type: ContentChild, args: [TemplateRef, { static: true },] }], | ||
droppable: [{ type: ViewChild, args: [DroppableDirective, { static: true },] }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppableItemClass", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "dropZone", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ContainerComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Function) | ||
], ContainerComponent.prototype, "moves", void 0); | ||
__decorate([ | ||
Input('template'), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateInput", null); | ||
__decorate([ | ||
ContentChild(TemplateRef, { static: true }), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateChild", null); | ||
__decorate([ | ||
ViewChild(DroppableDirective, { static: true }), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppable", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "cancel", void 0); | ||
ContainerComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}) | ||
], ContainerComponent); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Component that allows nested ngxDroppable and ngxDraggables | ||
@@ -840,7 +659,3 @@ * Should only be use inside a ngx-dnd-container | ||
*/ | ||
class ItemComponent { | ||
/** | ||
* @param {?} container | ||
* @param {?} draggableDirective | ||
*/ | ||
let ItemComponent = class ItemComponent { | ||
constructor(container, draggableDirective) { | ||
@@ -852,86 +667,40 @@ this.container = container; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZone() { | ||
return this._dropZone || this.container.dropZone; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZone(val) { | ||
this._dropZone = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get dropZones() { | ||
return this._dropZones || this.container.dropZones; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set dropZones(val) { | ||
this._dropZones = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get droppableItemClass() { | ||
return this._droppableItemClass || this.container.droppableItemClass; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set droppableItemClass(val) { | ||
this._droppableItemClass = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get removeOnSpill() { | ||
return typeof this._removeOnSpill === 'boolean' ? this._removeOnSpill : this.container.removeOnSpill; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set removeOnSpill(val) { | ||
this._removeOnSpill = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get copy() { | ||
return typeof this._copy === 'boolean' ? this._copy : this.container.copy; | ||
} | ||
/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
set copy(val) { | ||
this._copy = val; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get hasHandle() { | ||
return this.draggableDirective.hasHandle; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get moveDisabled() { | ||
return !this.draggableDirective.canMove(); | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get classString() { | ||
/** @type {?} */ | ||
const itemClass = typeof this.droppableItemClass === 'function' ? this.droppableItemClass(this.model) : this.droppableItemClass; | ||
/** @type {?} */ | ||
const classes = ['ngx-dnd-item', itemClass || '']; | ||
@@ -946,5 +715,2 @@ if (this.moveDisabled) { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
get type() { | ||
@@ -956,5 +722,2 @@ if (Array.isArray(this.model)) { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
ngOnInit() { | ||
@@ -968,12 +731,3 @@ this.data = { | ||
} | ||
} | ||
ItemComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}] } | ||
]; | ||
/** @nocollapse */ | ||
}; | ||
ItemComponent.ctorParameters = () => [ | ||
@@ -983,50 +737,70 @@ { type: ContainerComponent }, | ||
]; | ||
ItemComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
classString: [{ type: HostBinding, args: ['class',] }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ItemComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZone", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "droppableItemClass", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "removeOnSpill", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "copy", null); | ||
__decorate([ | ||
HostBinding('class'), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", []) | ||
], ItemComponent.prototype, "classString", null); | ||
ItemComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}), | ||
__metadata("design:paramtypes", [ContainerComponent, DraggableDirective]) | ||
], ItemComponent); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var NgxDnDModule_1; | ||
const components = [ContainerComponent, ItemComponent]; | ||
/** @type {?} */ | ||
const directives = [DraggableDirective, DroppableDirective, DragHandleDirective]; | ||
class NgxDnDModule { | ||
/** | ||
* @return {?} | ||
*/ | ||
let NgxDnDModule = NgxDnDModule_1 = class NgxDnDModule { | ||
static forRoot() { | ||
return { | ||
ngModule: NgxDnDModule, | ||
ngModule: NgxDnDModule_1, | ||
providers: [DrakeStoreService] | ||
}; | ||
} | ||
} | ||
NgxDnDModule.decorators = [ | ||
{ type: NgModule, args: [{ | ||
imports: [CommonModule], | ||
declarations: [...components, ...directives], | ||
exports: [...components, ...directives] | ||
},] } | ||
]; | ||
}; | ||
NgxDnDModule = NgxDnDModule_1 = __decorate([ | ||
NgModule({ | ||
imports: [CommonModule], | ||
declarations: [...components, ...directives], | ||
exports: [...components, ...directives] | ||
}) | ||
], NgxDnDModule); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { ContainerComponent, DragHandleDirective, DraggableDirective, DrakeStoreService, DroppableDirective, ItemComponent, NgxDnDModule }; | ||
//# sourceMappingURL=swimlane-ngx-dnd.js.map |
@@ -1,12 +0,7 @@ | ||
import { __spread } from 'tslib'; | ||
import { Injectable, ɵɵdefineInjectable, Directive, ElementRef, Renderer2, Input, Output, EventEmitter, HostListener, Component, ViewEncapsulation, ContentChild, TemplateRef, ViewChild, HostBinding, NgModule } from '@angular/core'; | ||
import { __decorate, __metadata, __spread } from 'tslib'; | ||
import { ɵɵdefineInjectable, Injectable, EventEmitter, ElementRef, Renderer2, Input, Output, Directive, HostListener, TemplateRef, ContentChild, ViewChild, Component, ViewEncapsulation, HostBinding, NgModule } from '@angular/core'; | ||
import { CommonModule } from '@angular/common'; | ||
import * as dragulaNamespace from '@swimlane/dragula'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
// see https://github.com/dherges/ng-packagr/issues/217 | ||
/** @type {?} */ | ||
var dragula = dragulaNamespace; | ||
@@ -26,25 +21,8 @@ /** | ||
} | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.register = /** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
function (droppable) { | ||
DrakeStoreService.prototype.register = function (droppable) { | ||
this.droppableMap.set(droppable.container, droppable); | ||
this.drake.containers.push(droppable.container); | ||
}; | ||
/** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.remove = /** | ||
* @param {?} droppable | ||
* @return {?} | ||
*/ | ||
function (droppable) { | ||
DrakeStoreService.prototype.remove = function (droppable) { | ||
this.droppableMap.delete(droppable.container); | ||
/** @type {?} */ | ||
var idx = this.drake.containers.indexOf(droppable.container); | ||
@@ -55,45 +33,15 @@ if (idx > -1) { | ||
}; | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.registerDraggable = /** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
function (draggable) { | ||
DrakeStoreService.prototype.registerDraggable = function (draggable) { | ||
this.draggableMap.set(draggable.element, draggable); | ||
}; | ||
/** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.removeDraggable = /** | ||
* @param {?} draggable | ||
* @return {?} | ||
*/ | ||
function (draggable) { | ||
DrakeStoreService.prototype.removeDraggable = function (draggable) { | ||
this.draggableMap.delete(draggable.element); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.createDrakeOptions = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DrakeStoreService.prototype.createDrakeOptions = function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var accepts = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @return {?} | ||
*/ | ||
function (el, target /*, source: any, sibling: any */) { | ||
var accepts = function (el, target /*, source: any, sibling: any */) { | ||
if (el.contains(target)) { | ||
return false; | ||
} | ||
/** @type {?} */ | ||
var elementComponent = _this.draggableMap.get(el); | ||
/** @type {?} */ | ||
var targetComponent = _this.droppableMap.get(target); | ||
@@ -104,11 +52,4 @@ if (elementComponent && targetComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
var copy = (/** | ||
* @param {?} _ | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (_, source) { | ||
/** @type {?} */ | ||
}; | ||
var copy = function (_, source) { | ||
var sourceComponent = _this.droppableMap.get(source); | ||
@@ -119,13 +60,4 @@ if (sourceComponent) { | ||
return false; | ||
}); | ||
/** @type {?} */ | ||
var moves = (/** | ||
* @param {?=} el | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
function (el, source, handle, sibling) { | ||
/** @type {?} */ | ||
}; | ||
var moves = function (el, source, handle, sibling) { | ||
var elementComponent = _this.draggableMap.get(el); | ||
@@ -136,35 +68,14 @@ if (elementComponent) { | ||
return true; | ||
}); | ||
/** @type {?} */ | ||
var direction = (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, target, source) { | ||
/** @type {?} */ | ||
}; | ||
var direction = function (el, target, source) { | ||
var targetComponent = _this.droppableMap.get(target); | ||
return targetComponent.direction || 'vertical'; | ||
}); | ||
}; | ||
return { accepts: accepts, copy: copy, moves: moves, revertOnSpill: true, direction: direction }; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DrakeStoreService.prototype.registerEvents = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DrakeStoreService.prototype.registerEvents = function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var dragElm; | ||
/** @type {?} */ | ||
var draggedItem; | ||
this.drake.on('drag', (/** | ||
* @param {?} el | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, source) { | ||
this.drake.on('drag', function (el, source) { | ||
draggedItem = undefined; | ||
@@ -176,3 +87,2 @@ dragElm = el; | ||
if (_this.draggableMap.has(el)) { | ||
/** @type {?} */ | ||
var elementComponent = _this.draggableMap.get(el); | ||
@@ -188,3 +98,2 @@ draggedItem = elementComponent.model; | ||
if (_this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
@@ -200,11 +109,4 @@ _this.dragulaOptions.removeOnSpill = sourceComponent.removeOnSpill; | ||
} | ||
})); | ||
this.drake.on('drop', (/** | ||
* @param {?} el | ||
* @param {?} target | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, target, source) { | ||
/** @type {?} */ | ||
}); | ||
this.drake.on('drop', function (el, target, source) { | ||
var targetComponent = _this.droppableMap.get(target); | ||
@@ -215,5 +117,3 @@ if (!targetComponent) { | ||
} | ||
/** @type {?} */ | ||
var dropElmModel = draggedItem; | ||
/** @type {?} */ | ||
var dropIndex = Array.prototype.indexOf.call(target.children, el); | ||
@@ -225,12 +125,7 @@ if (dropIndex < 0) { | ||
} | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
if (sourceComponent) { | ||
/** @type {?} */ | ||
var sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
var targetModel = targetComponent.model; | ||
/** @type {?} */ | ||
var hasDragModel = !!(sourceModel && draggedItem); | ||
/** @type {?} */ | ||
var dragIndex = hasDragModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -243,5 +138,3 @@ if (hasDragModel && dragIndex < 0) { | ||
if (targetModel) { | ||
/** @type {?} */ | ||
var reorder = dragIndex > -1 && sourceModel && target === source; | ||
/** @type {?} */ | ||
var copy = !sourceModel || dragElm !== el; | ||
@@ -276,16 +169,7 @@ if (reorder) { | ||
}); | ||
})); | ||
this.drake.on('remove', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('remove', function (el, container, source) { | ||
if (_this.droppableMap.has(source)) { | ||
/** @type {?} */ | ||
var sourceComponent = _this.droppableMap.get(source); | ||
/** @type {?} */ | ||
var sourceModel = sourceComponent.model; | ||
/** @type {?} */ | ||
var dragIndex = draggedItem && sourceModel ? sourceModel.indexOf(draggedItem) : -1; | ||
@@ -307,12 +191,5 @@ if (dragIndex > -1) { | ||
} | ||
})); | ||
this.drake.on('cancel', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('cancel', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -327,12 +204,5 @@ containerComponent.cancel.emit({ | ||
} | ||
})); | ||
this.drake.on('over', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('over', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -347,12 +217,5 @@ containerComponent.over.emit({ | ||
} | ||
})); | ||
this.drake.on('out', (/** | ||
* @param {?} el | ||
* @param {?} container | ||
* @param {?} source | ||
* @return {?} | ||
*/ | ||
function (el, container, source) { | ||
}); | ||
this.drake.on('out', function (el, container, source) { | ||
if (_this.droppableMap.has(container)) { | ||
/** @type {?} */ | ||
var containerComponent = _this.droppableMap.get(container); | ||
@@ -367,22 +230,13 @@ containerComponent.out.emit({ | ||
} | ||
})); | ||
}); | ||
}; | ||
DrakeStoreService.decorators = [ | ||
{ type: Injectable, args: [{ providedIn: 'root' },] } | ||
]; | ||
/** @nocollapse */ | ||
DrakeStoreService.ctorParameters = function () { return []; }; | ||
/** @nocollapse */ DrakeStoreService.ngInjectableDef = ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService.ɵprov = ɵɵdefineInjectable({ factory: function DrakeStoreService_Factory() { return new DrakeStoreService(); }, token: DrakeStoreService, providedIn: "root" }); | ||
DrakeStoreService = __decorate([ | ||
Injectable({ providedIn: 'root' }), | ||
__metadata("design:paramtypes", []) | ||
], DrakeStoreService); | ||
return DrakeStoreService; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var i = 10000; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId() { | ||
@@ -412,6 +266,3 @@ return i++; | ||
Object.defineProperty(DroppableDirective.prototype, "container", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.el.nativeElement; | ||
@@ -423,13 +274,6 @@ }, | ||
Object.defineProperty(DroppableDirective.prototype, "dropZone", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZone || this.ngxDroppable || this.defaultZone; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZone = val; | ||
@@ -440,46 +284,18 @@ }, | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngOnInit = function () { | ||
this.defaultZone = "@@DefaultDropZone-" + getNextId() + "@@"; | ||
this.drakesService.register(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngAfterViewInit = function () { | ||
var _this = this; | ||
this.over.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.over.subscribe(function () { | ||
_this.renderer.addClass(_this.container, 'gu-over'); | ||
})); | ||
this.out.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
}); | ||
this.out.subscribe(function () { | ||
_this.renderer.removeClass(_this.container, 'gu-over'); | ||
})); | ||
}); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DroppableDirective.prototype.ngOnDestroy = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DroppableDirective.prototype.ngOnDestroy = function () { | ||
this.drakesService.remove(this); | ||
}; | ||
DroppableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDroppable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
DroppableDirective.ctorParameters = function () { return [ | ||
@@ -490,16 +306,55 @@ { type: ElementRef }, | ||
]; }; | ||
DroppableDirective.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
ngxDroppable: [{ type: Input }], | ||
direction: [{ type: Input }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }], | ||
dropZone: [{ type: Input }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DroppableDirective.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "ngxDroppable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String) | ||
], DroppableDirective.prototype, "direction", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DroppableDirective.prototype, "cancel", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", String), | ||
__metadata("design:paramtypes", [String]) | ||
], DroppableDirective.prototype, "dropZone", null); | ||
DroppableDirective = __decorate([ | ||
Directive({ selector: '[ngxDroppable]' }), | ||
__metadata("design:paramtypes", [ElementRef, Renderer2, DrakeStoreService]) | ||
], DroppableDirective); | ||
return DroppableDirective; | ||
@@ -509,6 +364,2 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Adds properties and events to draggable elements | ||
@@ -525,26 +376,18 @@ * | ||
/* | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
ContentChildren doesn't get children created with NgTemplateOutlet | ||
See https://github.com/angular/angular/issues/14842 | ||
Implemented via updateElements method | ||
@ContentChildren(DragHandleDirective, {descendants: true}) | ||
handlesList: QueryList<DragHandleDirective>; */ | ||
this.handles = []; | ||
this.drag = new EventEmitter(); | ||
this.dragDelay = 200; // milliseconds | ||
// milliseconds | ||
this.dragDelayed = true; | ||
} | ||
Object.defineProperty(DraggableDirective.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this.ngxDraggable || this._parentDropzones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -556,6 +399,3 @@ }, | ||
Object.defineProperty(DraggableDirective.prototype, "hasHandle", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return !!this.handles.length; | ||
@@ -567,6 +407,3 @@ }, | ||
Object.defineProperty(DraggableDirective.prototype, "element", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.el.nativeElement; | ||
@@ -578,14 +415,3 @@ }, | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onMove = | ||
// From: https://github.com/bevacqua/dragula/issues/289#issuecomment-277143172 | ||
/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
function (e) { | ||
DraggableDirective.prototype.onMove = function (e) { | ||
if (!this._moves || this.dragDelayed) { | ||
@@ -596,47 +422,20 @@ e.stopPropagation(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onDown = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.onDown = function () { | ||
var _this = this; | ||
if (this._moves) { | ||
this.touchTimeout = setTimeout((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.touchTimeout = setTimeout(function () { | ||
_this.dragDelayed = false; | ||
}), this.dragDelay); | ||
}, this.dragDelay); | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.onUp = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.onUp = function () { | ||
if (this._moves) { | ||
clearTimeout((/** @type {?} */ (this.touchTimeout))); | ||
clearTimeout(this.touchTimeout); | ||
this.dragDelayed = true; | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngOnInit = function () { | ||
this.update(); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.update = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.update = function () { | ||
this._parentDropzones = [this.droppableDirective.dropZone]; | ||
@@ -646,31 +445,9 @@ this.drakesService.registerDraggable(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngOnDestroy = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngOnDestroy = function () { | ||
this.drakesService.removeDraggable(this); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.updateElements = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
DraggableDirective.prototype.updateElements = function () { | ||
var nativeElement = this.el.nativeElement; | ||
/** @type {?} */ | ||
var handles = nativeElement.querySelectorAll('[ngxdraghandle]'); | ||
this.handles = Array.from(handles).filter((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
function (h) { return findFirstDraggableParent(h) === nativeElement; })); | ||
/** | ||
* @param {?} c | ||
* @return {?} | ||
*/ | ||
this.handles = Array.from(handles).filter(function (h) { return findFirstDraggableParent(h) === nativeElement; }); | ||
function findFirstDraggableParent(c) { | ||
@@ -685,15 +462,3 @@ while (c.parentNode) { | ||
}; | ||
/** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.canMove = /** | ||
* @param {?=} source | ||
* @param {?=} handle | ||
* @param {?=} sibling | ||
* @return {?} | ||
*/ | ||
function (source, handle, sibling) { | ||
DraggableDirective.prototype.canMove = function (source, handle, sibling) { | ||
if (typeof this._moves === 'boolean') | ||
@@ -705,27 +470,6 @@ return this._moves; | ||
}; | ||
/** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.moves = /** | ||
* @param {?} source | ||
* @param {?} handle | ||
* @param {?} sibling | ||
* @return {?} | ||
*/ | ||
function (source, handle, sibling) { | ||
DraggableDirective.prototype.moves = function (source, handle, sibling) { | ||
if (!this.canMove(source, handle, sibling)) | ||
return false; | ||
return this.hasHandle ? this.handles.some((/** | ||
* @param {?} h | ||
* @return {?} | ||
*/ | ||
function (h) { return handelFor(handle, h); })) : true; | ||
/** | ||
* @param {?} c | ||
* @param {?} p | ||
* @return {?} | ||
*/ | ||
return this.hasHandle ? this.handles.some(function (h) { return handelFor(handle, h); }) : true; | ||
function handelFor(c, p) { | ||
@@ -739,15 +483,5 @@ if (c === p) | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
DraggableDirective.prototype.ngDoCheck = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
DraggableDirective.prototype.ngDoCheck = function () { | ||
this.updateElements(); | ||
}; | ||
DraggableDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDraggable]' },] } | ||
]; | ||
/** @nocollapse */ | ||
DraggableDirective.ctorParameters = function () { return [ | ||
@@ -758,12 +492,47 @@ { type: ElementRef }, | ||
]; }; | ||
DraggableDirective.propDecorators = { | ||
ngxDraggable: [{ type: Input }], | ||
model: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
_moves: [{ type: Input, args: ['moves',] }], | ||
drag: [{ type: Output }], | ||
onMove: [{ type: HostListener, args: ['touchmove', ['$event'],] }], | ||
onDown: [{ type: HostListener, args: ['touchstart',] }], | ||
onUp: [{ type: HostListener, args: ['touchend',] }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Array) | ||
], DraggableDirective.prototype, "ngxDraggable", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], DraggableDirective.prototype, "dropZones", null); | ||
__decorate([ | ||
Input('moves'), | ||
__metadata("design:type", Object) | ||
], DraggableDirective.prototype, "_moves", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], DraggableDirective.prototype, "drag", void 0); | ||
__decorate([ | ||
HostListener('touchmove', ['$event']), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", [Event]), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onMove", null); | ||
__decorate([ | ||
HostListener('touchstart'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onDown", null); | ||
__decorate([ | ||
HostListener('touchend'), | ||
__metadata("design:type", Function), | ||
__metadata("design:paramtypes", []), | ||
__metadata("design:returntype", void 0) | ||
], DraggableDirective.prototype, "onUp", null); | ||
DraggableDirective = __decorate([ | ||
Directive({ selector: '[ngxDraggable]' }), | ||
__metadata("design:paramtypes", [ElementRef, | ||
DrakeStoreService, | ||
DroppableDirective]) | ||
], DraggableDirective); | ||
return DraggableDirective; | ||
@@ -773,6 +542,2 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Adds properties and events to drag handle elements | ||
@@ -785,17 +550,9 @@ * | ||
} | ||
DragHandleDirective.decorators = [ | ||
{ type: Directive, args: [{ selector: '[ngxDragHandle]' },] } | ||
]; | ||
DragHandleDirective = __decorate([ | ||
Directive({ selector: '[ngxDragHandle]' }) | ||
], DragHandleDirective); | ||
return DragHandleDirective; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var i$1 = 0; | ||
/** | ||
* @return {?} | ||
*/ | ||
function getNextId$1() { | ||
@@ -822,13 +579,6 @@ return i$1++; | ||
Object.defineProperty(ContainerComponent.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this._defaultZones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -842,10 +592,3 @@ }, | ||
// @Input() dragulaOptions: any; | ||
set: | ||
// @Input() classes: any = {}; | ||
// @Input() dragulaOptions: any; | ||
/** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
function (template) { | ||
set: function (template) { | ||
this.template = template; | ||
@@ -857,7 +600,3 @@ }, | ||
Object.defineProperty(ContainerComponent.prototype, "templateChild", { | ||
set: /** | ||
* @param {?} template | ||
* @return {?} | ||
*/ | ||
function (template) { | ||
set: function (template) { | ||
this.template = template; | ||
@@ -868,76 +607,89 @@ }, | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
ContainerComponent.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ContainerComponent.prototype.ngOnInit = function () { | ||
this._defaultZones = [this.dropZone]; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
ContainerComponent.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ContainerComponent.prototype.ngAfterViewInit = function () { | ||
var _this = this; | ||
this.droppable.drag.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.drag.emit(v); })); | ||
this.droppable.drop.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.drop.emit(v); })); | ||
this.droppable.over.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.over.emit(v); })); | ||
this.droppable.out.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.out.emit(v); })); | ||
this.droppable.remove.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.remove.emit(v); })); | ||
this.droppable.cancel.subscribe((/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
function (v) { return _this.cancel.emit(v); })); | ||
this.droppable.drag.subscribe(function (v) { return _this.drag.emit(v); }); | ||
this.droppable.drop.subscribe(function (v) { return _this.drop.emit(v); }); | ||
this.droppable.over.subscribe(function (v) { return _this.over.emit(v); }); | ||
this.droppable.out.subscribe(function (v) { return _this.out.emit(v); }); | ||
this.droppable.remove.subscribe(function (v) { return _this.remove.emit(v); }); | ||
this.droppable.cancel.subscribe(function (v) { return _this.cancel.emit(v); }); | ||
}; | ||
ContainerComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}] } | ||
]; | ||
ContainerComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
moves: [{ type: Input }], | ||
templateInput: [{ type: Input, args: ['template',] }], | ||
templateChild: [{ type: ContentChild, args: [TemplateRef, { static: true },] }], | ||
droppable: [{ type: ViewChild, args: [DroppableDirective, { static: true },] }], | ||
drop: [{ type: Output }], | ||
drag: [{ type: Output }], | ||
over: [{ type: Output }], | ||
out: [{ type: Output }], | ||
remove: [{ type: Output }], | ||
cancel: [{ type: Output }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "copy", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "removeOnSpill", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppableItemClass", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "dropZone", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ContainerComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Function) | ||
], ContainerComponent.prototype, "moves", void 0); | ||
__decorate([ | ||
Input('template'), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateInput", null); | ||
__decorate([ | ||
ContentChild(TemplateRef, { static: true }), | ||
__metadata("design:type", TemplateRef), | ||
__metadata("design:paramtypes", [TemplateRef]) | ||
], ContainerComponent.prototype, "templateChild", null); | ||
__decorate([ | ||
ViewChild(DroppableDirective, { static: true }), | ||
__metadata("design:type", Object) | ||
], ContainerComponent.prototype, "droppable", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drop", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "drag", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "over", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "out", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "remove", void 0); | ||
__decorate([ | ||
Output(), | ||
__metadata("design:type", EventEmitter) | ||
], ContainerComponent.prototype, "cancel", void 0); | ||
ContainerComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-container', | ||
template: "<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"] | ||
}) | ||
], ContainerComponent); | ||
return ContainerComponent; | ||
@@ -947,6 +699,2 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* Component that allows nested ngxDroppable and ngxDraggables | ||
@@ -966,13 +714,6 @@ * Should only be use inside a ngx-dnd-container | ||
Object.defineProperty(ItemComponent.prototype, "dropZone", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZone || this.container.dropZone; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZone = val; | ||
@@ -984,13 +725,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "dropZones", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._dropZones || this.container.dropZones; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._dropZones = val; | ||
@@ -1002,13 +736,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "droppableItemClass", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._droppableItemClass || this.container.droppableItemClass; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._droppableItemClass = val; | ||
@@ -1020,13 +747,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "removeOnSpill", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return typeof this._removeOnSpill === 'boolean' ? this._removeOnSpill : this.container.removeOnSpill; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._removeOnSpill = val; | ||
@@ -1038,13 +758,6 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "copy", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return typeof this._copy === 'boolean' ? this._copy : this.container.copy; | ||
}, | ||
set: /** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
set: function (val) { | ||
this._copy = val; | ||
@@ -1056,6 +769,3 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "hasHandle", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return this.draggableDirective.hasHandle; | ||
@@ -1067,6 +777,3 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "moveDisabled", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
return !this.draggableDirective.canMove(); | ||
@@ -1078,9 +785,4 @@ }, | ||
Object.defineProperty(ItemComponent.prototype, "classString", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
get: function () { | ||
var itemClass = typeof this.droppableItemClass === 'function' ? this.droppableItemClass(this.model) : this.droppableItemClass; | ||
/** @type {?} */ | ||
var classes = ['ngx-dnd-item', itemClass || '']; | ||
@@ -1099,6 +801,3 @@ if (this.moveDisabled) { | ||
Object.defineProperty(ItemComponent.prototype, "type", { | ||
get: /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
get: function () { | ||
if (Array.isArray(this.model)) { | ||
@@ -1112,9 +811,3 @@ return 'array'; | ||
}); | ||
/** | ||
* @return {?} | ||
*/ | ||
ItemComponent.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
ItemComponent.prototype.ngOnInit = function () { | ||
this.data = { | ||
@@ -1127,11 +820,2 @@ model: this.model, | ||
}; | ||
ItemComponent.decorators = [ | ||
{ type: Component, args: [{ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}] } | ||
]; | ||
/** @nocollapse */ | ||
ItemComponent.ctorParameters = function () { return [ | ||
@@ -1141,21 +825,49 @@ { type: ContainerComponent }, | ||
]; }; | ||
ItemComponent.propDecorators = { | ||
model: [{ type: Input }], | ||
dropZone: [{ type: Input }], | ||
dropZones: [{ type: Input }], | ||
droppableItemClass: [{ type: Input }], | ||
removeOnSpill: [{ type: Input }], | ||
copy: [{ type: Input }], | ||
classString: [{ type: HostBinding, args: ['class',] }] | ||
}; | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object) | ||
], ItemComponent.prototype, "model", void 0); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZone", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "dropZones", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "droppableItemClass", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "removeOnSpill", null); | ||
__decorate([ | ||
Input(), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", [Object]) | ||
], ItemComponent.prototype, "copy", null); | ||
__decorate([ | ||
HostBinding('class'), | ||
__metadata("design:type", Object), | ||
__metadata("design:paramtypes", []) | ||
], ItemComponent.prototype, "classString", null); | ||
ItemComponent = __decorate([ | ||
Component({ | ||
selector: 'ngx-dnd-item', | ||
template: "<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n", | ||
encapsulation: ViewEncapsulation.None, | ||
styles: [".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"] | ||
}), | ||
__metadata("design:paramtypes", [ContainerComponent, DraggableDirective]) | ||
], ItemComponent); | ||
return ItemComponent; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var components = [ContainerComponent, ItemComponent]; | ||
/** @type {?} */ | ||
var directives = [DraggableDirective, DroppableDirective, DragHandleDirective]; | ||
@@ -1165,21 +877,17 @@ var NgxDnDModule = /** @class */ (function () { | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxDnDModule.forRoot = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
NgxDnDModule_1 = NgxDnDModule; | ||
NgxDnDModule.forRoot = function () { | ||
return { | ||
ngModule: NgxDnDModule, | ||
ngModule: NgxDnDModule_1, | ||
providers: [DrakeStoreService] | ||
}; | ||
}; | ||
NgxDnDModule.decorators = [ | ||
{ type: NgModule, args: [{ | ||
imports: [CommonModule], | ||
declarations: __spread(components, directives), | ||
exports: __spread(components, directives) | ||
},] } | ||
]; | ||
var NgxDnDModule_1; | ||
NgxDnDModule = NgxDnDModule_1 = __decorate([ | ||
NgModule({ | ||
imports: [CommonModule], | ||
declarations: __spread(components, directives), | ||
exports: __spread(components, directives) | ||
}) | ||
], NgxDnDModule); | ||
return NgxDnDModule; | ||
@@ -1189,12 +897,6 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { ContainerComponent, DragHandleDirective, DraggableDirective, DrakeStoreService, DroppableDirective, ItemComponent, NgxDnDModule }; | ||
//# sourceMappingURL=swimlane-ngx-dnd.js.map |
@@ -13,6 +13,7 @@ import { OnInit, AfterViewInit, TemplateRef, EventEmitter } from '@angular/core'; | ||
dropZone: string; | ||
dropZones: string[]; | ||
get dropZones(): string[]; | ||
set dropZones(val: string[]); | ||
moves: (model: any, source: any, handle: any, sibling: any) => boolean; | ||
templateInput: TemplateRef<any>; | ||
templateChild: TemplateRef<any>; | ||
set templateInput(template: TemplateRef<any>); | ||
set templateChild(template: TemplateRef<any>); | ||
template: TemplateRef<any>; | ||
@@ -19,0 +20,0 @@ droppable: any; |
@@ -15,7 +15,12 @@ import { OnInit } from '@angular/core'; | ||
model: any; | ||
dropZone: any; | ||
dropZones: any; | ||
droppableItemClass: any; | ||
removeOnSpill: boolean; | ||
copy: boolean; | ||
get dropZone(): any; | ||
set dropZone(val: any); | ||
get dropZones(): any; | ||
set dropZones(val: any); | ||
get droppableItemClass(): any; | ||
set droppableItemClass(val: any); | ||
get removeOnSpill(): boolean; | ||
set removeOnSpill(val: boolean); | ||
get copy(): boolean; | ||
set copy(val: boolean); | ||
_copy: boolean; | ||
@@ -27,8 +32,8 @@ _dropZone: any; | ||
data: any; | ||
readonly hasHandle: boolean; | ||
readonly moveDisabled: boolean; | ||
readonly classString: string; | ||
readonly type: "string" | "number" | "bigint" | "boolean" | "symbol" | "undefined" | "object" | "function" | "array"; | ||
get hasHandle(): boolean; | ||
get moveDisabled(): boolean; | ||
get classString(): string; | ||
get type(): "string" | "number" | "bigint" | "boolean" | "symbol" | "undefined" | "object" | "function" | "array"; | ||
constructor(container: ContainerComponent, draggableDirective: DraggableDirective); | ||
ngOnInit(): void; | ||
} |
@@ -15,6 +15,7 @@ import { ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core'; | ||
model: any; | ||
dropZones: any; | ||
get dropZones(): any; | ||
set dropZones(val: any); | ||
_moves: boolean | ((...args: any[]) => any); | ||
handles: any[]; | ||
readonly hasHandle: boolean; | ||
get hasHandle(): boolean; | ||
drag: EventEmitter<any>; | ||
@@ -24,3 +25,3 @@ dragDelay: number; | ||
touchTimeout: any; | ||
readonly element: any; | ||
get element(): any; | ||
_dropZones: string[]; | ||
@@ -27,0 +28,0 @@ _parentDropzones: string[]; |
@@ -23,4 +23,5 @@ import { OnInit, OnDestroy, AfterViewInit, ElementRef, EventEmitter, Renderer2 } from '@angular/core'; | ||
cancel: EventEmitter<any>; | ||
readonly container: any; | ||
dropZone: string; | ||
get container(): any; | ||
get dropZone(): string; | ||
set dropZone(val: string); | ||
defaultZone: string; | ||
@@ -27,0 +28,0 @@ _dropZone: string; |
{ | ||
"name": "@swimlane/ngx-dnd", | ||
"description": "Drag and Drop for Angular2 and beyond!", | ||
"version": "8.1.0", | ||
"version": "8.1.1", | ||
"peerDependencies": { | ||
"@angular/common": "^8.0.0", | ||
"@angular/core": "^8.0.0" | ||
"@angular/core": "^8.0.0", | ||
"tslib": "^1.10.0" | ||
}, | ||
@@ -29,4 +30,3 @@ "repository": { | ||
"@swimlane/dragula": "^3.8.0", | ||
"@types/dragula": "^2.1.34", | ||
"tslib": "^1.9.0" | ||
"@types/dragula": "^2.1.34" | ||
}, | ||
@@ -33,0 +33,0 @@ "main": "bundles/swimlane-ngx-dnd.umd.js", |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"NgxDnDModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":14,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":15,"character":12}],"declarations":[{"__symbolic":"reference","name":"ContainerComponent"},{"__symbolic":"reference","name":"ItemComponent"},{"__symbolic":"reference","name":"DraggableDirective"},{"__symbolic":"reference","name":"DroppableDirective"},{"__symbolic":"reference","name":"DragHandleDirective"}],"exports":[{"__symbolic":"reference","name":"ContainerComponent"},{"__symbolic":"reference","name":"ItemComponent"},{"__symbolic":"reference","name":"DraggableDirective"},{"__symbolic":"reference","name":"DroppableDirective"},{"__symbolic":"reference","name":"DragHandleDirective"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NgxDnDModule"},"providers":[{"__symbolic":"reference","name":"DrakeStoreService"}]}}}},"DraggableDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":10,"character":1},"arguments":[{"selector":"[ngxDraggable]"}]}],"members":{"ngxDraggable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"dropZones":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"_moves":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3},"arguments":["moves"]}]}],"drag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":39,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":54,"character":16},{"__symbolic":"reference","name":"DrakeStoreService"},{"__symbolic":"reference","name":"DroppableDirective"}]}],"onMove":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":60,"character":3},"arguments":["touchmove",["$event"]]}]}],"onDown":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":68,"character":3},"arguments":["touchstart"]}]}],"onUp":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":77,"character":3},"arguments":["touchend"]}]}],"ngOnInit":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"updateElements":[{"__symbolic":"method"}],"canMove":[{"__symbolic":"method"}],"moves":[{"__symbolic":"method"}],"ngDoCheck":[{"__symbolic":"method"}]}},"DroppableDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":24,"character":1},"arguments":[{"selector":"[ngxDroppable]"}]}],"members":{"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"copy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"removeOnSpill":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"ngxDroppable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"direction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"drop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":32,"character":3}}]}],"drag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":34,"character":3}}]}],"over":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":36,"character":3}}]}],"out":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":38,"character":3}}]}],"remove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":40,"character":3}}]}],"cancel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"dropZone":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":59,"character":26},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":59,"character":56},{"__symbolic":"reference","name":"DrakeStoreService"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"DragHandleDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":7,"character":1},"arguments":[{"selector":"[ngxDragHandle]"}]}],"members":{}},"ItemComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":12,"character":1},"arguments":[{"selector":"ngx-dnd-item","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":16,"character":17},"member":"None"},"template":"<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n","styles":[".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"]}]}],"members":{"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"dropZone":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"dropZones":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"droppableItemClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"removeOnSpill":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"copy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"classString":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":76,"character":3},"arguments":["class"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ContainerComponent"},{"__symbolic":"reference","name":"DraggableDirective"}]}],"ngOnInit":[{"__symbolic":"method"}]}},"ContainerComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":25,"character":1},"arguments":[{"selector":"ngx-dnd-container","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":29,"character":17},"member":"None"},"template":"<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n","styles":[".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"]}]}],"members":{"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"copy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"removeOnSpill":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":34,"character":3}}]}],"droppableItemClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"dropZone":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"dropZones":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"moves":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"templateInput":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3},"arguments":["template"]}]}],"templateChild":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChild","line":57,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"TemplateRef","line":57,"character":16},{"static":true}]}]}],"droppable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":64,"character":3},"arguments":[{"__symbolic":"reference","name":"DroppableDirective"},{"static":true}]}]}],"drop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"drag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"over":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"out":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":73,"character":3}}]}],"remove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":75,"character":3}}]}],"cancel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":77,"character":3}}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}]}},"DrakeStoreService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":14,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"register":[{"__symbolic":"method"}],"remove":[{"__symbolic":"method"}],"registerDraggable":[{"__symbolic":"method"}],"removeDraggable":[{"__symbolic":"method"}],"createDrakeOptions":[{"__symbolic":"method"}],"registerEvents":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}}},"origins":{"NgxDnDModule":"./lib/ngx-dnd.module","DraggableDirective":"./lib/directives/ngx-draggable.directive","DroppableDirective":"./lib/directives/ngx-droppable.directive","DragHandleDirective":"./lib/directives/ngx-drag-handle.directive","ItemComponent":"./lib/components/item/item.component","ContainerComponent":"./lib/components/container/container.component","DrakeStoreService":"./lib/services/drake-store.service"},"importAs":"@swimlane/ngx-dnd"} | ||
{"__symbolic":"module","version":4,"metadata":{"NgxDnDModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":14,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":15,"character":12}],"declarations":[{"__symbolic":"reference","name":"ContainerComponent"},{"__symbolic":"reference","name":"ItemComponent"},{"__symbolic":"reference","name":"DraggableDirective"},{"__symbolic":"reference","name":"DroppableDirective"},{"__symbolic":"reference","name":"DragHandleDirective"}],"exports":[{"__symbolic":"reference","name":"ContainerComponent"},{"__symbolic":"reference","name":"ItemComponent"},{"__symbolic":"reference","name":"DraggableDirective"},{"__symbolic":"reference","name":"DroppableDirective"},{"__symbolic":"reference","name":"DragHandleDirective"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NgxDnDModule"},"providers":[{"__symbolic":"reference","name":"DrakeStoreService"}]}}}},"DraggableDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":10,"character":1},"arguments":[{"selector":"[ngxDraggable]"}]}],"members":{"ngxDraggable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"dropZones":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"_moves":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3},"arguments":["moves"]}]}],"drag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":39,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":54,"character":16},{"__symbolic":"reference","name":"DrakeStoreService"},{"__symbolic":"reference","name":"DroppableDirective"}]}],"onMove":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":60,"character":3},"arguments":["touchmove",["$event"]]}]}],"onDown":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":68,"character":3},"arguments":["touchstart"]}]}],"onUp":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":77,"character":3},"arguments":["touchend"]}]}],"ngOnInit":[{"__symbolic":"method"}],"update":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"updateElements":[{"__symbolic":"method"}],"canMove":[{"__symbolic":"method"}],"moves":[{"__symbolic":"method"}],"ngDoCheck":[{"__symbolic":"method"}]}},"DroppableDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":24,"character":1},"arguments":[{"selector":"[ngxDroppable]"}]}],"members":{"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"copy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"removeOnSpill":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"ngxDroppable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"direction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"drop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":32,"character":3}}]}],"drag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":34,"character":3}}]}],"over":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":36,"character":3}}]}],"out":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":38,"character":3}}]}],"remove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":40,"character":3}}]}],"cancel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"dropZone":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":59,"character":26},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":59,"character":56},{"__symbolic":"reference","name":"DrakeStoreService"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"DragHandleDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":7,"character":1},"arguments":[{"selector":"[ngxDragHandle]"}]}],"members":{}},"ItemComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":12,"character":1},"arguments":[{"selector":"ngx-dnd-item","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":16,"character":17},"member":"None"},"template":"<ng-container [ngSwitch]=\"type\">\n\n <ng-container *ngSwitchCase=\"'array'\">\n <ngx-dnd-container\n [model]=\"model\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'object'\">\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <ng-container *ngIf=\"!container.template\">\n <div\n class=\"ngx-dnd-content\">\n {{model.label}}\n </div>\n <ngx-dnd-container\n *ngIf=\"model.children\"\n [model]=\"model.children\"\n [template]=\"container.template\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\"\n [copy]=\"copy\">\n </ngx-dnd-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'undefined'\">\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-template\n *ngIf=\"container.template\"\n [ngTemplateOutlet]=\"container.template\"\n [ngTemplateOutletContext]=\"data\">\n </ng-template>\n <div\n *ngIf=\"!container.template\"\n class=\"ngx-dnd-content\">\n {{model}}\n </div>\n </ng-container>\n\n</ng-container>\n\n\n\n\n\n\n\n","styles":[".ngx-dnd-box,.ngx-dnd-item{margin:10px;padding:10px;background-color:rgba(0,0,0,.2);transition:opacity .4s ease-in-out;border:1px solid #add8e6;display:block}.ngx-dnd-box.has-handle [ngxDragHandle],.ngx-dnd-box.has-handle [ngxdraghandle],.ngx-dnd-box:not(.has-handle):not(.move-disabled),.ngx-dnd-item.has-handle [ngxDragHandle],.ngx-dnd-item.has-handle [ngxdraghandle],.ngx-dnd-item:not(.has-handle):not(.move-disabled){cursor:move;cursor:grab;cursor:-webkit-grab}.ngx-dnd-box .ngx-dnd-content,.ngx-dnd-item .ngx-dnd-content{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ngx-dnd-box:hover,.ngx-dnd-item:hover{border:1px solid #00f}.ngx-dnd-box{height:40px;width:40px;line-height:20px;text-align:center;float:left}.gu-mirror{position:fixed!important;margin:0!important;z-index:9999!important;opacity:.8}.gu-hide{display:none!important}.gu-unselectable{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important}.gu-transit{opacity:.2}"]}]}],"members":{"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"dropZone":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"dropZones":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"droppableItemClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"removeOnSpill":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":45,"character":3}}]}],"copy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"classString":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":76,"character":3},"arguments":["class"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ContainerComponent"},{"__symbolic":"reference","name":"DraggableDirective"}]}],"ngOnInit":[{"__symbolic":"method"}]}},"ContainerComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":25,"character":1},"arguments":[{"selector":"ngx-dnd-container","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":29,"character":17},"member":"None"},"template":"<div\n ngxDroppable\n [dropZone]=\"dropZone\"\n [model]=\"model\"\n [copy]=\"copy\"\n [ngClass]=\"{ 'gu-empty': !model?.length }\"\n [removeOnSpill]=\"removeOnSpill\"\n class='ngx-dnd-container'>\n <ng-container *ngIf=\"model\">\n <ng-container *ngFor=\"let item of model\">\n <ngx-dnd-item\n ngxDraggable\n [model]=\"item\"\n [dropZone]=\"dropZone\"\n [dropZones]=\"dropZones\"\n [copy]=\"copy\"\n [moves]=\"moves\"\n [removeOnSpill]=\"removeOnSpill\"\n [droppableItemClass]=\"droppableItemClass\">\n </ngx-dnd-item>\n </ng-container>\n </ng-container>\n <ng-content *ngIf=\"!model\"></ng-content>\n</div>\n","styles":[".ngx-dnd-container{background-color:rgba(255,255,255,.2);border:2px solid red;margin:10px;padding:10px}.ngx-dnd-container.gu-empty{border:2px dotted red}.ngx-dnd-container:nth-child(odd){background-color:rgba(0,0,0,.2)}.ngx-dnd-container .ex-moved{background-color:#e74c3c}.ngx-dnd-container .ex-over{background-color:rgba(255,255,255,.3)}.ngx-dnd-container .handle{padding:0 5px;margin-right:5px;background-color:rgba(0,0,0,.4);cursor:move}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.clearfix::after{content:\" \";display:block;height:0;clear:both}"]}]}],"members":{"model":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"copy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"removeOnSpill":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":34,"character":3}}]}],"droppableItemClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"dropZone":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":37,"character":3}}]}],"dropZones":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"moves":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"templateInput":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3},"arguments":["template"]}]}],"templateChild":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChild","line":57,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"TemplateRef","line":57,"character":16},{"static":true}]}]}],"droppable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":64,"character":3},"arguments":[{"__symbolic":"reference","name":"DroppableDirective"},{"static":true}]}]}],"drop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"drag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"over":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"out":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":73,"character":3}}]}],"remove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":75,"character":3}}]}],"cancel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":77,"character":3}}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}]}},"DrakeStoreService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":14,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"register":[{"__symbolic":"method"}],"remove":[{"__symbolic":"method"}],"registerDraggable":[{"__symbolic":"method"}],"removeDraggable":[{"__symbolic":"method"}],"createDrakeOptions":[{"__symbolic":"method"}],"registerEvents":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}}},"origins":{"NgxDnDModule":"./lib/ngx-dnd.module","DraggableDirective":"./lib/directives/ngx-draggable.directive","DroppableDirective":"./lib/directives/ngx-droppable.directive","DragHandleDirective":"./lib/directives/ngx-drag-handle.directive","ItemComponent":"./lib/components/item/item.component","ContainerComponent":"./lib/components/container/container.component","DrakeStoreService":"./lib/services/drake-store.service"},"importAs":"@swimlane/ngx-dnd"} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
533147
4738
1
- Removedtslib@^1.9.0