UNPKG

web-atoms-core

Version:
99 lines 4.97 kB
var __extends = (this && this.__extends) || (function () { 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); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __decorate = (this && this.__decorate) || function (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; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; (function (factory) { if (typeof module === "object" && typeof module.exports === "object") { var v = factory(require, exports); if (v !== undefined) module.exports = v; } else if (typeof define === "function" && define.amd) { define(["require", "exports", "../../core/BindableProperty", "./AtomControl", "./AtomGridView"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var BindableProperty_1 = require("../../core/BindableProperty"); var AtomControl_1 = require("./AtomControl"); var AtomGridView_1 = require("./AtomGridView"); /** * Grid Splitter can only be added inside a Grid */ var AtomGridSplitter = /** @class */ (function (_super) { __extends(AtomGridSplitter, _super); function AtomGridSplitter() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.direction = "vertical"; _this.dragging = false; return _this; } AtomGridSplitter.prototype.create = function () { var _this = this; this.bind(this.element, "styleCursor", [["direction"]], false, function (v) { return v === "vertical" ? "ew-resize" : "ns-resize"; }); this.bind(this.element, "styleBackgroundColor", [["dragging"]], false, function (v) { return v ? "blue" : "lightgray"; }); var style = this.element.style; style.position = "absolute"; style.left = style.top = style.bottom = style.right = "0"; this.bindEvent(this.element, "mousedown", function (e) { e.preventDefault(); _this.dragging = true; var parent = _this.parent; var isVertical = _this.direction === "vertical"; var disposables = []; var rect = { x: e.screenX, y: e.screenY }; var _a = AtomGridView_1.AtomGridView.getCellInfo(_this.element), column = _a.column, row = _a.row; disposables.push(_this.bindEvent(document.body, "mousemove", function (me) { // do drag.... var screenX = me.screenX, screenY = me.screenY; var dx = screenX - rect.x; var dy = screenY - rect.y; if (isVertical) { parent.resize("column", column, dx); } else { parent.resize("row", row, dy); } rect.x = screenX; rect.y = screenY; })); disposables.push(_this.bindEvent(document.body, "mouseup", function (mup) { // stop _this.dragging = false; for (var _i = 0, disposables_1 = disposables; _i < disposables_1.length; _i++) { var iterator = disposables_1[_i]; iterator.dispose(); } })); }); }; __decorate([ BindableProperty_1.BindableProperty, __metadata("design:type", String) ], AtomGridSplitter.prototype, "direction", void 0); __decorate([ BindableProperty_1.BindableProperty, __metadata("design:type", Boolean) ], AtomGridSplitter.prototype, "dragging", void 0); return AtomGridSplitter; }(AtomControl_1.AtomControl)); exports.AtomGridSplitter = AtomGridSplitter; }); //# sourceMappingURL=AtomGridSplitter.js.map