From 16ef27febe1e33d6dc4b432224cf009c0978c079 Mon Sep 17 00:00:00 2001 From: "sqrd.max" Date: Sun, 29 Sep 2024 01:07:36 +0300 Subject: [PATCH 1/5] try to implement angular-split --- firebird-ng/package-lock.json | 2113 ++++++++++++++++- firebird-ng/package.json | 3 +- firebird-ng/src/app/app.routes.ts | 4 + .../geometry-tree-window.component.html | 16 +- .../geometry-tree-window.component.scss | 143 +- .../geometry-tree-window.component.ts | 217 +- .../main-display/main-display.component.html | 221 +- .../main-display/main-display.component.scss | 1 - .../main-display/main-display.component.ts | 24 +- .../split-window/split-window.component.html | 1 + .../split-window/split-window.component.scss | 0 .../split-window.component.spec.ts | 23 + .../split-window/split-window.component.ts | 58 + package-lock.json | 77 + package.json | 5 + 15 files changed, 2584 insertions(+), 322 deletions(-) create mode 100644 firebird-ng/src/app/pages/split-window/split-window.component.html create mode 100644 firebird-ng/src/app/pages/split-window/split-window.component.scss create mode 100644 firebird-ng/src/app/pages/split-window/split-window.component.spec.ts create mode 100644 firebird-ng/src/app/pages/split-window/split-window.component.ts create mode 100644 package-lock.json create mode 100644 package.json diff --git a/firebird-ng/package-lock.json b/firebird-ng/package-lock.json index a9d0e95..bf43ac6 100644 --- a/firebird-ng/package-lock.json +++ b/firebird-ng/package-lock.json @@ -20,7 +20,8 @@ "@angular/router": "^17.3.0", "@tweenjs/tween.js": "^23.1.2", "@types/picomatch": "^2.3.3", - "angular-split": "^17.2.0", + "angular-split": "^17.1.1", + "component": "^1.1.0", "jsdom": "^24.0.0", "jsonc-parser": "^3.3.1", "jsrootdi": "^7.6.101", @@ -5419,6 +5420,35 @@ "acorn": "^8" } }, + "node_modules/acorn-node": { + "version": "1.8.2", + "resolved": "https://registry.npmjs.org/acorn-node/-/acorn-node-1.8.2.tgz", + "integrity": "sha512-8mt+fslDufLYntIoPAaIMUe/lrbrehIiwmR3t2k9LljIzoigEPF27eLk2hy8zSGzmR/ogr7zbRKINMo1u0yh5A==", + "dependencies": { + "acorn": "^7.0.0", + "acorn-walk": "^7.0.0", + "xtend": "^4.0.2" + } + }, + "node_modules/acorn-node/node_modules/acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-node/node_modules/acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", + "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", + "engines": { + "node": ">=0.4.0" + } + }, "node_modules/acorn-walk": { "version": "8.3.4", "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.4.tgz", @@ -5461,6 +5491,14 @@ "node": ">=8.9.0" } }, + "node_modules/adm-zip": { + "version": "0.4.16", + "resolved": "https://registry.npmjs.org/adm-zip/-/adm-zip-0.4.16.tgz", + "integrity": "sha512-TFi4HBKSGfIKsK5YCkKaaFG2m4PEDyViZmEwof3MTIgzimHLto6muaHVpbrljdIvIrFZzEq/p4nafOeLcYegrg==", + "engines": { + "node": ">=0.3.0" + } + }, "node_modules/agent-base": { "version": "7.1.1", "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", @@ -5534,6 +5572,46 @@ "ajv": "^8.8.2" } }, + "node_modules/align-text": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", + "integrity": "sha512-GrTZLRpmp6wIC2ztrWW9MjjTgSKccffgFagbNDOX95/dcjEcYZibYTeaOntySQLcdw1ztBoFkviiUvTMbb9MYg==", + "dependencies": { + "kind-of": "^3.0.2", + "longest": "^1.0.1", + "repeat-string": "^1.5.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/align-text/node_modules/kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==", + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/alter": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/alter/-/alter-0.2.0.tgz", + "integrity": "sha512-Wuss6JIZ6h4j2+NgU2t+9mSwS7gBSZJbU4Dg8xETguAD2veJUSuCrvTIiC78QgZE7/zX7h6OnXw2PiiCBirEGw==", + "dependencies": { + "stable": "~0.1.3" + } + }, + "node_modules/amdefine": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", + "integrity": "sha512-S2Hw0TtNkMJhIabBwIojKL9YHO5T0n5eNqWJ7Lrlel/zDbftQpxpapi8tZs3X1HWa+u+QeydGmzzNU0m09+Rcg==", + "engines": { + "node": ">=0.4.2" + } + }, "node_modules/angular-split": { "version": "17.2.0", "resolved": "https://registry.npmjs.org/angular-split/-/angular-split-17.2.0.tgz", @@ -5641,6 +5719,14 @@ "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==", "license": "ISC" }, + "node_modules/archy": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/archy/-/archy-0.0.2.tgz", + "integrity": "sha512-8mMsetjXv4pCPTrMbPPO2cxy9vzJn2jwbd+ug+mf8fEUZG2E78Vo5erJMjrnGuLTKqOLtS5ulFHJSfg1yaCjxA==", + "engines": { + "node": "*" + } + }, "node_modules/are-we-there-yet": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz", @@ -5693,6 +5779,22 @@ "dev": true, "license": "MIT" }, + "node_modules/ast-traverse": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/ast-traverse/-/ast-traverse-0.1.1.tgz", + "integrity": "sha512-CPuE4BWIhJjsNMvFkrzjiBgOl56NJTuBPBkBqyRyfq/nZtx1Z1f5I+qx7G/Zt+FAOS+ABhghkEuWJrfW9Njjog==" + }, + "node_modules/ast-types": { + "version": "0.14.2", + "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.14.2.tgz", + "integrity": "sha512-O0yuUDnZeQDL+ncNGlJ78BiO4jnYI3bvMsD5prT0/nsgijG/LpNBIr63gTjVTNsiGkgQhiyCShTgxt8oXOrklA==", + "dependencies": { + "tslib": "^2.0.1" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/asynckit": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", @@ -5749,6 +5851,35 @@ "postcss": "^8.1.0" } }, + "node_modules/autoprefixer-core": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/autoprefixer-core/-/autoprefixer-core-3.1.2.tgz", + "integrity": "sha512-zXBwCsV9nrVf2evKwUREELXvM0IL7bg9k17EVku57I+nSVKXTyH7IvL4Nqit6wZkrY9b3ca6umNxh9SY5lIsuA==", + "dependencies": { + "caniuse-db": "^1.0.30000006", + "postcss": "~2.2.5" + } + }, + "node_modules/autoprefixer-core/node_modules/postcss": { + "version": "2.2.6", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-2.2.6.tgz", + "integrity": "sha512-8zk4tZ73/ddVQ+Cg2Ca/U4CGT1SAzDYriJDYrRp9ZvNXJPWwYlJaSjHSUJLFKlmuaUjCJvtDnKTwwDpoie55Yw==", + "dependencies": { + "js-base64": "~2.1.5", + "source-map": "~0.1.40" + } + }, + "node_modules/autoprefixer-core/node_modules/source-map": { + "version": "0.1.43", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", + "integrity": "sha512-VtCvB9SIQhk3aF6h+N85EaqIaBFIAfZ9Cu+NJHHVvc8BbEcnvDcFw6sqQ2dQrT6SlOrZq3tIvyD9+EGq/lJryQ==", + "dependencies": { + "amdefine": ">=0.0.4" + }, + "engines": { + "node": ">=0.8.0" + } + }, "node_modules/babel-loader": { "version": "9.1.3", "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-9.1.3.tgz", @@ -5876,6 +6007,14 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "license": "MIT" }, + "node_modules/base62": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/base62/-/base62-0.1.1.tgz", + "integrity": "sha512-QtExujIOq/F672OkHmDi3CdkphOA1kSQ38gv03Ro3cplYQk831dq9GM3Q1oXAxpR5HNJjGjjjT2pHtBGAJu1jw==", + "engines": { + "node": "*" + } + }, "node_modules/base64-arraybuffer": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-1.0.2.tgz", @@ -5985,6 +6124,17 @@ "node": ">= 6" } }, + "node_modules/block-stream": { + "version": "0.0.9", + "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", + "integrity": "sha512-OorbnJVPII4DuUKbjARAe8u8EfqOmkEEaSFIyoQ7OjTHn6kafxWl0wLgoZ2rXaYd7MyLcDaU4TmhfxtwgcccMQ==", + "dependencies": { + "inherits": "~2.0.0" + }, + "engines": { + "node": "0.4 || >=0.5.8" + } + }, "node_modules/body-parser": { "version": "1.20.3", "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", @@ -6068,6 +6218,11 @@ "node": ">=8" } }, + "node_modules/breakable": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/breakable/-/breakable-1.0.0.tgz", + "integrity": "sha512-+ityJqcjhozQNrezzTd2dtH/lkIXmE52HL+FohK2TOLQDl3QURTNkim+2C0xcso4Zehq/HM4Wkumcdz7Ue+XmA==" + }, "node_modules/browserslist": { "version": "4.23.3", "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.3.tgz", @@ -6143,6 +6298,23 @@ "dev": true, "license": "MIT" }, + "node_modules/builder-autoprefixer": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/builder-autoprefixer/-/builder-autoprefixer-1.0.4.tgz", + "integrity": "sha512-4z2QQnrzUiA3WOTk9scxj/EfKX5y7fPbwQa3up3qRw0ve3XztPnkQ4ZyC36L2NHY4zuEwA9tlu0QgAqxRyCfgg==", + "dependencies": { + "autoprefixer-core": "^3.1.1" + } + }, + "node_modules/builder-es6-module-to-cjs": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/builder-es6-module-to-cjs/-/builder-es6-module-to-cjs-1.1.0.tgz", + "integrity": "sha512-HrhpHzBl7xqfADs9OHCsOw9TdE3jiU30rlHaLGZNuELvitfow96BWCO/nO6akval3V6/4ytzH/aMmsE7PtUrrg==", + "dependencies": { + "es6-module-jstransform": "^0.1.2", + "is-module": "^1.0.0" + } + }, "node_modules/bytes": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", @@ -6265,6 +6437,11 @@ "node": ">=6" } }, + "node_modules/caniuse-db": { + "version": "1.0.30001664", + "resolved": "https://registry.npmjs.org/caniuse-db/-/caniuse-db-1.0.30001664.tgz", + "integrity": "sha512-73+YTKw0KMawAD9ziTbZmcTYDATAHZVBD+K23Bnj0rUuEEX75M9F3j/3x5Nwweqz4F+djgIIuD+gltXFM7kTCQ==" + }, "node_modules/caniuse-lite": { "version": "1.0.30001663", "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001663.tgz", @@ -6329,6 +6506,18 @@ "optional": true, "peer": true }, + "node_modules/center-align": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", + "integrity": "sha512-Baz3aNe2gd2LP2qk5U+sDk/m4oSuwSDcBfayTCTBoWpfIGO5XFxPmjILQII4NGiZjD6DoDI6kf7gKaxkf7s3VQ==", + "dependencies": { + "align-text": "^0.1.3", + "lazy-cache": "^1.0.3" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/chalk": { "version": "2.4.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", @@ -6343,6 +6532,16 @@ "node": ">=4" } }, + "node_modules/chanel": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/chanel/-/chanel-2.2.0.tgz", + "integrity": "sha512-lI0+F41XPgIMrTBre4o0/OQUuiFMo2w8pk0ww/wpIOsRwV1s+c1fksEdnxfyK7OrBmYxDaqmTgI4YgXfXZ6UHA==", + "dependencies": { + "co": "*", + "generator-supported": "*", + "to-descriptor": "*" + } + }, "node_modules/chardet": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", @@ -6533,6 +6732,52 @@ "node": ">=6" } }, + "node_modules/co": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/co/-/co-3.1.0.tgz", + "integrity": "sha512-CQsjCRiNObI8AtTsNIBDRMQ4oMR83CzEswHYahClvul7gKk+lDQiOKv+5qh7LQWf5sh6jkZNispz/QlsZxyNgA==" + }, + "node_modules/cogent": { + "version": "0.4.3-fix-redirects", + "resolved": "git+ssh://git@github.com/timaschew/cogent.git#2246bd071392f5053a3a110024fd608a40a593ba", + "dependencies": { + "debug": "*", + "generator-supported": "~0.0.1", + "netrc": "~0.1.3", + "proxy-agent": "^1.1.0", + "raw-body": "^1.1.2", + "statuses": "^1.0.2", + "write-to": "^1.0.0" + }, + "peerDependencies": { + "co": "3" + } + }, + "node_modules/cogent/node_modules/bytes": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", + "integrity": "sha512-/x68VkHLeTl3/Ll8IvxdwzhrT+IyKc52e/oyHhA2RwqPqswSnjVbSddfPRwAsJtbilMAPSRWwAlpxdYsSWOTKQ==" + }, + "node_modules/cogent/node_modules/iconv-lite": { + "version": "0.4.8", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.8.tgz", + "integrity": "sha512-D90rbOiZuEJGtmIBK9wcRpW//ZKLD8bTPOAx5oEsu+O+HhSOstX/HCZFBvNkuyDuiNHunb81cfsqaYzZxcUMYA==", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/cogent/node_modules/raw-body": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-1.3.4.tgz", + "integrity": "sha512-ZC2kBq6BsR0uK441H5SvGH9H+hRpTKVRjvlI6BhLOJrih3oGbGRYdFyyKKESw4/hjzJEr4cZkQgbuU52s63MOQ==", + "dependencies": { + "bytes": "1.0.0", + "iconv-lite": "0.4.8" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/color-convert": { "version": "1.9.3", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", @@ -6580,7 +6825,6 @@ "version": "2.20.3", "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", - "dev": true, "license": "MIT" }, "node_modules/common-path-prefix": { @@ -6590,6 +6834,522 @@ "dev": true, "license": "ISC" }, + "node_modules/commoner": { + "version": "0.10.8", + "resolved": "https://registry.npmjs.org/commoner/-/commoner-0.10.8.tgz", + "integrity": "sha512-3/qHkNMM6o/KGXHITA14y78PcfmXh4+AOCJpSoF73h4VY1JpdGv3CHMS5+JW6SwLhfJt4RhNmLAa7+RRX/62EQ==", + "dependencies": { + "commander": "^2.5.0", + "detective": "^4.3.1", + "glob": "^5.0.15", + "graceful-fs": "^4.1.2", + "iconv-lite": "^0.4.5", + "mkdirp": "^0.5.0", + "private": "^0.1.6", + "q": "^1.1.2", + "recast": "^0.11.17" + }, + "bin": { + "commonize": "bin/commonize" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commoner/node_modules/ast-types": { + "version": "0.9.6", + "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.9.6.tgz", + "integrity": "sha512-qEdtR2UH78yyHX/AUNfXmJTlM48XoFZKBdwi1nzkI1mJL21cmbu0cvjxjpkXJ5NENMq42H+hNs8VLJcqXLerBQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commoner/node_modules/esprima": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", + "integrity": "sha512-AWwVMNxwhN8+NIPQzAQZCm7RkLC4RbM3B1OobMuyp3i+w73X57KCKaVIxaRZb+DYCojq7rspo+fmuQfAboyhFg==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/commoner/node_modules/glob": { + "version": "5.0.15", + "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", + "integrity": "sha512-c9IPMazfRITpmAAKi22dK1VKxGDX9ehhqfABDriL/lzO92xcUKEJPQHrVA/2YHSNFB4iFlykVmWvwo48nr3OxA==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dependencies": { + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "2 || 3", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + } + }, + "node_modules/commoner/node_modules/recast": { + "version": "0.11.23", + "resolved": "https://registry.npmjs.org/recast/-/recast-0.11.23.tgz", + "integrity": "sha512-+nixG+3NugceyR8O1bLU45qs84JgI3+8EauyRZafLgC9XbdAOIVgwV1Pe2da0YzGo62KzWoZwUpVEQf6qNAXWA==", + "dependencies": { + "ast-types": "0.9.6", + "esprima": "~3.1.0", + "private": "~0.1.5", + "source-map": "~0.5.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commoner/node_modules/source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/component": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/component/-/component-1.1.0.tgz", + "integrity": "sha512-3729ISBnksZ0luAajVYcJFzm7lSRtaETgfWJsNkOaS1VL4pgC6T2HmEHEJtyVWvpd2H8KJUdNxe7gKXnAed/iw==", + "dependencies": { + "co": "^3.0.0", + "commander": "^2.2.0", + "component-build": "^1.2.2", + "component-consoler": "^2.0.0", + "component-flatten": "^1.0.1", + "component-ls": "^2.1.0", + "component-outdated2": "^1.0.4", + "component-pin": "^1.0.4", + "component-remotes": "^1.2.0", + "component-resolver": "^1.3.0", + "component-search2": "^1.1.1", + "component-updater": "^1.0.4", + "component-watcher": "^1.0.1", + "debug": "*", + "mkdirp": "~0.3.5", + "rimraf": "^2.2.6", + "semver": "^2.2.1", + "superagent": "~0.17.0", + "tiny-lr-fork": "0.0.5", + "win-fork": "~1.1.1" + }, + "bin": { + "component": "bin/component", + "component-build": "bin/component-build", + "component-crawl": "bin/component-crawl", + "component-duplicates": "bin/component-duplicates", + "component-help": "bin/component-help", + "component-install": "bin/component-install", + "component-link": "bin/component-link", + "component-ls": "bin/component-ls", + "component-outdated": "bin/component-outdated", + "component-pin": "bin/component-pin", + "component-search": "bin/component-search", + "component-update": "bin/component-update", + "component-validate": "bin/component-validate" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/component-build": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/component-build/-/component-build-1.2.2.tgz", + "integrity": "sha512-CpLWNhClvE68T9a3UZnAG3L3LdCiHDZlA0ufErCXUYPil9agI1d2ucejxl3h5hk1dfzzcdhAD8gPq54pxsHcuA==", + "dependencies": { + "builder-autoprefixer": "^1.0.3", + "builder-es6-module-to-cjs": "^1.1.0", + "component-builder": "^1.1.12", + "debug": "*" + } + }, + "node_modules/component-builder": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/component-builder/-/component-builder-1.2.1.tgz", + "integrity": "sha512-iNjEioqOs2PTnIxIn+jRaGdtEAw8ncUPwqSJ4c99A2bAwZnZSHklv1R5QPVqmZYlpYMT3SGSc2zmvmwGK3tgrw==", + "dependencies": { + "requires": "^1.0.0", + "chanel": "^2.0.0", + "co": "^3.1.0", + "component-flatten": "^1.0.1", + "component-manifest": "^1.0.0", + "component-require2": "^1.0.1", + "cp": "^0.1.1", + "debug": "*", + "generator-supported": "~0.0.1", + "graceful-fs": "^2.0.3", + "mkdirp": "^0.3.5", + "syntax-error": "^1.1.1" + } + }, + "node_modules/component-builder/node_modules/graceful-fs": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-2.0.3.tgz", + "integrity": "sha512-hcj/NTUWv+C3MbqrVb9F+aH6lvTwEHJdx2foBxlrVq5h6zE8Bfu4pv4CAAqbDcZrw/9Ak5lsRXlY9Ao8/F0Tuw==", + "deprecated": "please upgrade to graceful-fs 4 for compatibility with current and future versions of Node.js", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/component-builder/node_modules/mkdirp": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.5.tgz", + "integrity": "sha512-8OCq0De/h9ZxseqzCH8Kw/Filf5pF/vMI6+BH7Lu0jXz2pqYCjTAQRolSxRIi+Ax+oCCjlxoJMP0YQ4XlrQNHg==", + "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)" + }, + "node_modules/component-consoler": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/component-consoler/-/component-consoler-2.0.0.tgz", + "integrity": "sha512-gHjeG72lAgPdTssGLc7+wcE5gIEE0cDLElmsiaM1E4/feBW2bvCQlP+0H4rdS4SI6iMrDxjh9/6j32LCmUFRYQ==", + "dependencies": { + "debug": "*" + } + }, + "node_modules/component-downloader": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/component-downloader/-/component-downloader-1.2.0.tgz", + "integrity": "sha512-/diPb5TiaOh6ta1ISfwPnndq4HiKRd0pTzZIitohHyLQfxI8LOFkO0s24+UTBx/Ba11QxvH+uIi60NanSRh/rQ==", + "dependencies": { + "chanel": "^2.0.1", + "co": "^3", + "component-consoler": "^2.0.0", + "component-remotes": "^1.1.1", + "debug": "*", + "decompress": "~0.2.0", + "generator-supported": "~0.0.1", + "graceful-fs": "^2.0.2", + "mkdirp": "~0.3.5", + "rimraf": "^2.2.6", + "semver": "^2.2.0", + "unglob": "~0.1.2", + "write-to": "^1.0.0" + } + }, + "node_modules/component-downloader/node_modules/graceful-fs": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-2.0.3.tgz", + "integrity": "sha512-hcj/NTUWv+C3MbqrVb9F+aH6lvTwEHJdx2foBxlrVq5h6zE8Bfu4pv4CAAqbDcZrw/9Ak5lsRXlY9Ao8/F0Tuw==", + "deprecated": "please upgrade to graceful-fs 4 for compatibility with current and future versions of Node.js", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/component-downloader/node_modules/mkdirp": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.5.tgz", + "integrity": "sha512-8OCq0De/h9ZxseqzCH8Kw/Filf5pF/vMI6+BH7Lu0jXz2pqYCjTAQRolSxRIi+Ax+oCCjlxoJMP0YQ4XlrQNHg==", + "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)" + }, + "node_modules/component-downloader/node_modules/rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/component-downloader/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-flatten": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/component-flatten/-/component-flatten-1.0.1.tgz", + "integrity": "sha512-n0YexLJNbA7uhbBK8j0HBVi8DxzMDDXYQZWdo3Mn2cylllHCw7ZUkL3CMtQ8b2N5VEn6X5veC8bvAmdFCwmGxw==", + "deprecated": "no longer maintained, please use a different package", + "dependencies": { + "semver": "^2.2.1" + } + }, + "node_modules/component-flatten/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-ls": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/component-ls/-/component-ls-2.1.0.tgz", + "integrity": "sha512-DurdOSfT1uMS3k6iWJ2Dm6aIuPPbmHKWoE0E/65m/84c7HCSFzHRJgWXcb4TTkXUsYCtVjaCgANAZauy4krSug==", + "dependencies": { + "archy": "~0.0.2" + } + }, + "node_modules/component-manifest": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/component-manifest/-/component-manifest-1.0.0.tgz", + "integrity": "sha512-4eBUmLhuTzmPccH65MaV/teGWLU4gn7duvdjksw4vpuXdLwK7bjBvGIETfv8Q46c54U2ehKCf/ueBXr4xD3alA==", + "dependencies": { + "debug": "*", + "generator-supported": "~0.0.1", + "graceful-fs": "^2.0.1", + "unglob": "~0.1.1" + } + }, + "node_modules/component-manifest/node_modules/graceful-fs": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-2.0.3.tgz", + "integrity": "sha512-hcj/NTUWv+C3MbqrVb9F+aH6lvTwEHJdx2foBxlrVq5h6zE8Bfu4pv4CAAqbDcZrw/9Ak5lsRXlY9Ao8/F0Tuw==", + "deprecated": "please upgrade to graceful-fs 4 for compatibility with current and future versions of Node.js", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/component-outdated2": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/component-outdated2/-/component-outdated2-1.0.5.tgz", + "integrity": "sha512-dMQ1zia/HarCJa0KPW65QGlPiHQI9Dfuz8idw7YGozO3ZKcUgqYNboXnH2RhSK/rJT/tUhqhUCZ6SJTWV/aFOQ==", + "dependencies": { + "component-consoler": "^2.0.0", + "component-flatten": "^1.0.1", + "component-remotes": "^1.1.5", + "generator-supported": "~0.0.1", + "semver": "^2.2.1" + } + }, + "node_modules/component-outdated2/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-pin": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/component-pin/-/component-pin-1.0.5.tgz", + "integrity": "sha512-TJY8yz7wPEBUNNeFRYWhtXjmOJebQas2Dmd5YDOy8I0wE0Y15QvjwFSADe4mIgW2GZfkJYrd/FVTm7m4TQUcDQ==", + "dependencies": { + "component-consoler": "^2.0.0", + "component-flatten": "^1.0.1", + "component-remotes": "^1.1.5", + "generator-supported": "~0.0.1", + "semver": "^2.2.1" + } + }, + "node_modules/component-pin/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-remotes": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/component-remotes/-/component-remotes-1.2.0.tgz", + "integrity": "sha512-9Z1GzJwQPPTQFp/WNGSmYr4KPGzCyork/CD2WyNAi9tLxW7x5nmXxYBruszNGw+h32DNvVyrMYsAfzLARGXYVQ==", + "dependencies": { + "co": "^3", + "cogent": "git://github.com/timaschew/cogent#fix-redirects", + "component-consoler": "^2.0.0", + "component-validator": "^1.0.0", + "debug": "*", + "generator-supported": "~0.0.1", + "graceful-fs": "^2.0.2", + "semver": "^2.2.1" + } + }, + "node_modules/component-remotes/node_modules/graceful-fs": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-2.0.3.tgz", + "integrity": "sha512-hcj/NTUWv+C3MbqrVb9F+aH6lvTwEHJdx2foBxlrVq5h6zE8Bfu4pv4CAAqbDcZrw/9Ak5lsRXlY9Ao8/F0Tuw==", + "deprecated": "please upgrade to graceful-fs 4 for compatibility with current and future versions of Node.js", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/component-remotes/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-require2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/component-require2/-/component-require2-1.1.1.tgz", + "integrity": "sha512-FvrYPSLZxE85+jtnpyuRD9x6hfRzWWjXS6QyxMlf4ZA3miwqXbdMT+qqlYRZdwxu+POaN6dLZkMxLPqS9KR8lg==" + }, + "node_modules/component-resolver": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/component-resolver/-/component-resolver-1.3.0.tgz", + "integrity": "sha512-jtUNWMcVuCRKUBac+v5qMk0Ka8C9XIZ0CEJMLjg/qRr67JTXlBUbABH1pyH2DlFaST+lgLkpmUsHjymyoUAJuw==", + "dependencies": { + "chanel": "^2.0.2", + "co": "^3", + "component-consoler": "^2.0.0", + "component-downloader": "^1.2.0", + "component-flatten": "^1.0.1", + "component-remotes": "^1.2.0", + "component-validator": "^1.1.1", + "debug": "*", + "generator-supported": "~0.0.1", + "graceful-fs": "^2.0.1", + "semver": "^2.2.1", + "unglob": "~0.1.2" + } + }, + "node_modules/component-resolver/node_modules/graceful-fs": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-2.0.3.tgz", + "integrity": "sha512-hcj/NTUWv+C3MbqrVb9F+aH6lvTwEHJdx2foBxlrVq5h6zE8Bfu4pv4CAAqbDcZrw/9Ak5lsRXlY9Ao8/F0Tuw==", + "deprecated": "please upgrade to graceful-fs 4 for compatibility with current and future versions of Node.js", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/component-resolver/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-search2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/component-search2/-/component-search2-1.1.1.tgz", + "integrity": "sha512-Wz1cL/Y1Mqk83iHhVnHhLjF29MI/FYEW61UcxnTx6wXO07np54dQIpqYx+uKOlYRq7yn2xkj4d89CrdGoscs3Q==", + "dependencies": { + "bytes": "~0.3.0", + "cogent": "~0.4.0", + "component-consoler": "^2.0.0", + "debug": "*", + "event-stream": "^3.1.1", + "generator-supported": "~0.0.1", + "JSONStream": "~0.8.0", + "stream-to-array": "^1.0.0" + } + }, + "node_modules/component-search2/node_modules/bytes": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-0.3.0.tgz", + "integrity": "sha512-koasz05sePZ8FLtyBSyGGlrvr1DYqr+D/MFXkz9afRugTCGKuqw6fjWMMmaCWEKtmWpgOnaGI4qlw/hPyyYX6g==" + }, + "node_modules/component-search2/node_modules/cogent": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/cogent/-/cogent-0.4.3.tgz", + "integrity": "sha512-JJZ+vbNzXN+rcZerJRLyFlZW9voOg5cdgbCjeIpaRCk38AH2ukSUaPZyIOLDKsHaWzsnO0vu2Ikpo/bOtZ7Utw==", + "dependencies": { + "debug": "*", + "generator-supported": "~0.0.1", + "netrc": "~0.1.3", + "proxy-agent": "^1.1.0", + "raw-body": "^1.1.2", + "statuses": "^1.0.2", + "write-to": "^1.0.0" + }, + "peerDependencies": { + "co": "3" + } + }, + "node_modules/component-search2/node_modules/iconv-lite": { + "version": "0.4.8", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.8.tgz", + "integrity": "sha512-D90rbOiZuEJGtmIBK9wcRpW//ZKLD8bTPOAx5oEsu+O+HhSOstX/HCZFBvNkuyDuiNHunb81cfsqaYzZxcUMYA==", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/component-search2/node_modules/raw-body": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-1.3.4.tgz", + "integrity": "sha512-ZC2kBq6BsR0uK441H5SvGH9H+hRpTKVRjvlI6BhLOJrih3oGbGRYdFyyKKESw4/hjzJEr4cZkQgbuU52s63MOQ==", + "dependencies": { + "bytes": "1.0.0", + "iconv-lite": "0.4.8" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/component-search2/node_modules/raw-body/node_modules/bytes": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", + "integrity": "sha512-/x68VkHLeTl3/Ll8IvxdwzhrT+IyKc52e/oyHhA2RwqPqswSnjVbSddfPRwAsJtbilMAPSRWwAlpxdYsSWOTKQ==" + }, + "node_modules/component-updater": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/component-updater/-/component-updater-1.0.5.tgz", + "integrity": "sha512-/aOiq2OGejudfeGPlULF7aKxImSzsjvdWLCl35vfrp1FnJcHi5zGYD1GNw39k5LZKgnitz1CCPalFPRnRV5B9w==", + "dependencies": { + "component-consoler": "^2.0.0", + "component-flatten": "^1.0.1", + "component-remotes": "^1.1.5", + "generator-supported": "~0.0.1", + "semver": "^2.2.1" + } + }, + "node_modules/component-updater/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/component-validator": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/component-validator/-/component-validator-1.1.1.tgz", + "integrity": "sha512-UBLY5SXjPvwAtrPzd8s+QSEQmICbnPkTUIPhLAYMG0y2+UPDp/W7KOkXYG+pAUHraOM1SbmE+kBSwLWudtOVBw==", + "dependencies": { + "component-consoler": "^2.0.0" + } + }, + "node_modules/component-watcher": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/component-watcher/-/component-watcher-1.0.3.tgz", + "integrity": "sha512-cjBgbrbC9LACKVycJB4A9E9VsxmwN55elgxrdYLndeXGL+g0u7O0OAlvDgTbUGvF1IJD16nVfXtFpUecUzrUUQ==", + "dependencies": { + "debug": "*", + "sane": "0" + } + }, + "node_modules/component/node_modules/mkdirp": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.5.tgz", + "integrity": "sha512-8OCq0De/h9ZxseqzCH8Kw/Filf5pF/vMI6+BH7Lu0jXz2pqYCjTAQRolSxRIi+Ax+oCCjlxoJMP0YQ4XlrQNHg==", + "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)" + }, + "node_modules/component/node_modules/rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/component/node_modules/semver": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-2.3.2.tgz", + "integrity": "sha512-abLdIKCosKfpnmhS52NCTjO4RiLspDfsn37prjzGrp9im5DPJOgh82Os92vtwGh6XdQryKI/7SREZnV+aqiXrA==", + "bin": { + "semver": "bin/semver" + } + }, "node_modules/compressible": { "version": "2.0.18", "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", @@ -6772,6 +7532,14 @@ "dev": true, "license": "MIT" }, + "node_modules/cookiejar": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-1.3.0.tgz", + "integrity": "sha512-U+NgxxtwHIokuL04FqKEkqsaWBDtnCQo+wvYjUCtBA56Lcg8vpV3SGtBx+RAmw92SV3VT8PwsYcCFK/cC3Dw+A==", + "engines": { + "node": "*" + } + }, "node_modules/copy-anything": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/copy-anything/-/copy-anything-2.0.6.tgz", @@ -6917,6 +7685,11 @@ "js-yaml": "bin/js-yaml.js" } }, + "node_modules/cp": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/cp/-/cp-0.1.1.tgz", + "integrity": "sha512-ht9oKVsn1lAqV8FdUuSwBUQB8AG2cSyYbPim/mEwj+Dt3d21IRu2H5diDumMpKb77tsIAGM3eU484KvcTrPvHw==" + }, "node_modules/create-require": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", @@ -7163,6 +7936,11 @@ "integrity": "sha512-sCNc1OHobc+Erc1HqiswYgHdVNpSJUlk/Hz8vzOCsER7rl+oF/4+v8GXFUyCgtXpoCX6+bnmg07DedLvBLwYKQ==", "license": "Apache-2.0" }, + "node_modules/data-uri-to-buffer": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-0.0.4.tgz", + "integrity": "sha512-nntmCbCupHk2zFSWe64pTt0LJ2U6Bt3K1MWgwXiEAj9IEaowSXbGLYN7m8xCb4hbpQl8QSCRBkKT9tFRUMkU7A==" + }, "node_modules/data-urls": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-5.0.0.tgz", @@ -7225,6 +8003,28 @@ "integrity": "sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==", "license": "MIT" }, + "node_modules/decompress": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/decompress/-/decompress-0.2.5.tgz", + "integrity": "sha512-uGGydmkEBFHdJe2+d3cVzSS71+Fjd5kSuE3ZtCAqnaAgpl3zficiDW3h3iZ8l6SN9dr/SOpYJ6Xe6mR3LycpdA==", + "dependencies": { + "adm-zip": "^0.4.3", + "ext-name": "^1.0.0", + "get-stdin": "^0.1.0", + "mkdirp": "^0.3.5", + "nopt": "^2.2.0", + "rimraf": "^2.2.2", + "stream-combiner": "^0.0.4", + "tar": "^0.1.18", + "tempfile": "^0.1.2" + }, + "bin": { + "decompress": "cli.js" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/decompress-response": { "version": "4.2.1", "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz", @@ -7237,6 +8037,46 @@ "node": ">=8" } }, + "node_modules/decompress/node_modules/mkdirp": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.5.tgz", + "integrity": "sha512-8OCq0De/h9ZxseqzCH8Kw/Filf5pF/vMI6+BH7Lu0jXz2pqYCjTAQRolSxRIi+Ax+oCCjlxoJMP0YQ4XlrQNHg==", + "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)" + }, + "node_modules/decompress/node_modules/nopt": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-2.2.1.tgz", + "integrity": "sha512-gIOTA/uJuhPwFqp+spY7VQ1satbnGlD+iQVZxI18K6hs8Evq4sX81Ml7BB5byP/LsbR2yBVtmvdEmhi7evJ6Aw==", + "dependencies": { + "abbrev": "1" + }, + "bin": { + "nopt": "bin/nopt.js" + } + }, + "node_modules/decompress/node_modules/rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/decompress/node_modules/tar": { + "version": "0.1.20", + "resolved": "https://registry.npmjs.org/tar/-/tar-0.1.20.tgz", + "integrity": "sha512-RW79YhJI8vSyOcVv0OzOr7DVGkhtFhyz6cufNETPF7dmCJ/kQH+ubpCZkV8Wb7RvQlPuGplQPy0o2ihElzkEZA==", + "deprecated": "This version of tar is no longer supported, and will not receive security updates. Please upgrade asap.", + "dependencies": { + "block-stream": "*", + "fstream": "~0.1.28", + "inherits": "2" + } + }, "node_modules/deep-extend": { "version": "0.6.0", "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", @@ -7246,6 +8086,11 @@ "node": ">=4.0.0" } }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==" + }, "node_modules/default-gateway": { "version": "6.0.3", "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-6.0.3.tgz", @@ -7300,6 +8145,104 @@ "node": ">=8" } }, + "node_modules/defined": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.1.tgz", + "integrity": "sha512-hsBd2qSVCRE+5PmNdHt1uzyrFu5d3RwmFDKzyNZMFq/EwDNJF7Ee5+D5oEKF0hU6LhtoUF1macFvOe4AskQC1Q==", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/defs": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/defs/-/defs-1.1.1.tgz", + "integrity": "sha512-KgGV1vmSa2UPKeDXaWE5FiXjix8BOtYMgiPGpYhd/42wxiC6YGwtscj/zU9gD5/xk4K2iLDpyGhGA5puZxaeMg==", + "dependencies": { + "alter": "~0.2.0", + "ast-traverse": "~0.1.1", + "breakable": "~1.0.0", + "esprima-fb": "~15001.1001.0-dev-harmony-fb", + "simple-fmt": "~0.1.0", + "simple-is": "~0.2.0", + "stringmap": "~0.2.2", + "stringset": "~0.2.1", + "tryor": "~0.1.2", + "yargs": "~3.27.0" + }, + "bin": { + "defs": "build/es5/defs" + } + }, + "node_modules/defs/node_modules/camelcase": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", + "integrity": "sha512-wzLkDa4K/mzI1OSITC+DUyjgIl/ETNHE9QvYgy6J6Jvqyyz4C0Xfd+lQhb19sX2jMpZV4IssUn0VDVmglV+s4g==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/defs/node_modules/cliui": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", + "integrity": "sha512-GIOYRizG+TGoc7Wgc1LiOTLare95R3mzKgoln+Q/lE4ceiYH19gUpl0l0Ffq4lJDEf3FxujMe6IBfOCs7pfqNA==", + "dependencies": { + "center-align": "^0.1.1", + "right-align": "^0.1.1", + "wordwrap": "0.0.2" + } + }, + "node_modules/defs/node_modules/esprima-fb": { + "version": "15001.1001.0-dev-harmony-fb", + "resolved": "https://registry.npmjs.org/esprima-fb/-/esprima-fb-15001.1001.0-dev-harmony-fb.tgz", + "integrity": "sha512-m7OsYzocA8OQ3+9CxmhIv7NPHtyDR2ixaLCO7kLZ+YH+xQ/BpaZmll9EXmc+kBxzWA8BRBXbNEuEQqQ6vfsgDw==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/defs/node_modules/y18n": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.2.tgz", + "integrity": "sha512-uGZHXkHnhF0XeeAPgnKfPv1bgKAYyVvmNL1xlKsPYZPaIHxGti2hHqvOCQv71XMsLxu1QjergkqogUnms5D3YQ==" + }, + "node_modules/defs/node_modules/yargs": { + "version": "3.27.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.27.0.tgz", + "integrity": "sha512-6atYjGACjX/OYWico7LwdBx9eiGlkMnIw6OwqfBb+uJQpaT82tQ7oI+BI6Dvq62qZvSbzGzQCVLQdMd59tR2eA==", + "dependencies": { + "camelcase": "^1.2.1", + "cliui": "^2.1.0", + "decamelize": "^1.0.0", + "os-locale": "^1.4.0", + "window-size": "^0.1.2", + "y18n": "^3.2.0" + } + }, + "node_modules/degenerator": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-1.0.4.tgz", + "integrity": "sha512-EMAC+riLSC64jKfOs1jp8J7M4ZXstUUwTdwFBEv6HOzL/Ae+eAzMKEK0nJnpof2fnw9IOjmE6u6qXFejVyk8AA==", + "dependencies": { + "ast-types": "0.x.x", + "escodegen": "1.x.x", + "esprima": "3.x.x" + } + }, + "node_modules/degenerator/node_modules/esprima": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", + "integrity": "sha512-AWwVMNxwhN8+NIPQzAQZCm7RkLC4RbM3B1OobMuyp3i+w73X57KCKaVIxaRZb+DYCojq7rspo+fmuQfAboyhFg==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", @@ -7352,6 +8295,31 @@ "dev": true, "license": "MIT" }, + "node_modules/detective": { + "version": "4.7.1", + "resolved": "https://registry.npmjs.org/detective/-/detective-4.7.1.tgz", + "integrity": "sha512-H6PmeeUcZloWtdt4DAkFyzFL94arpHr3NOwwmVILFiy+9Qd4JTxxXrzfyGk/lmct2qVGBwTSwSXagqu2BxmWig==", + "dependencies": { + "acorn": "^5.2.1", + "defined": "^1.0.0" + } + }, + "node_modules/detective/node_modules/acorn": { + "version": "5.7.4", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.4.tgz", + "integrity": "sha512-1D++VG7BhrtvQpNbBzovKNc1FLGGEE/oGe7b9xJm/RFHMBeUaUGpluV9RLjZa47YFdPcDAenEYuq9pQPcMdLJg==", + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/dethroy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/dethroy/-/dethroy-1.0.2.tgz", + "integrity": "sha512-oZawVs0uwJqhRBYehJsRpU0l2BhEFNXVOAIhivhjNig8QZ3/eHB2xls37rkCbg3PmSkaX0YbdLmnG83z8ZnPKA==" + }, "node_modules/di": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/di/-/di-0.0.1.tgz", @@ -7498,7 +8466,6 @@ "version": "0.1.2", "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==", - "dev": true, "license": "MIT" }, "node_modules/eastasianwidth": { @@ -7520,6 +8487,11 @@ "integrity": "sha512-VufdJl+rzaKZoYVUijN13QcXVF5dWPZANeFTLNy+OSpHdDL5ynXTF35+60RSBbaQYB1ae723lQXHCrf4pyLsMw==", "license": "ISC" }, + "node_modules/emitter-component": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/emitter-component/-/emitter-component-1.0.0.tgz", + "integrity": "sha512-GZrLdp4Z7OERecoYQYElVVqf6/gcbGUs8nvaE+nmu2dGy453lLgGyPLNX9DdSyojdMqI86fCT9XQqsWJymciEw==" + }, "node_modules/emoji-regex": { "version": "8.0.0", "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", @@ -7746,6 +8718,15 @@ "dev": true, "license": "MIT" }, + "node_modules/es6-module-jstransform": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/es6-module-jstransform/-/es6-module-jstransform-0.1.4.tgz", + "integrity": "sha512-jICJqz4k0qOeGgSJ9fGjvWxnuLsC69qaaLTs3rGtO2ZnARpJ+nAzaXdcj+WPzGUl9KlwtpMD5tWd8l5TRgBfaA==", + "dependencies": { + "esprima-fb": "~3001.1.0-dev-harmony-fb", + "jstransform": "~3.0.0" + } + }, "node_modules/esbuild": { "version": "0.20.1", "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.20.1.tgz", @@ -7824,6 +8805,36 @@ "node": ">=0.8.0" } }, + "node_modules/escodegen": { + "version": "1.14.3", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz", + "integrity": "sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==", + "dependencies": { + "esprima": "^4.0.1", + "estraverse": "^4.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1" + }, + "bin": { + "escodegen": "bin/escodegen.js", + "esgenerate": "bin/esgenerate.js" + }, + "engines": { + "node": ">=4.0" + }, + "optionalDependencies": { + "source-map": "~0.6.1" + } + }, + "node_modules/escodegen/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "optional": true, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/eslint-scope": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", @@ -7842,7 +8853,6 @@ "version": "4.0.1", "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "dev": true, "license": "BSD-2-Clause", "bin": { "esparse": "bin/esparse.js", @@ -7852,6 +8862,18 @@ "node": ">=4" } }, + "node_modules/esprima-fb": { + "version": "3001.1.0-dev-harmony-fb", + "resolved": "https://registry.npmjs.org/esprima-fb/-/esprima-fb-3001.0001.0000-dev-harmony-fb.tgz", + "integrity": "sha512-a3RFiCVBiy8KdO6q/C+8BQiP/sRk8XshBU3QHHDP8tNzjYwR3FKBOImu+PXfVhPoZL0JKtJLBAOWlDMCCFY8SQ==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=0.4.0" + } + }, "node_modules/esrecurse": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", @@ -7879,7 +8901,6 @@ "version": "4.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", - "dev": true, "license": "BSD-2-Clause", "engines": { "node": ">=4.0" @@ -7889,7 +8910,6 @@ "version": "2.0.3", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", - "dev": true, "license": "BSD-2-Clause", "engines": { "node": ">=0.10.0" @@ -7905,6 +8925,29 @@ "node": ">= 0.6" } }, + "node_modules/event-stream": { + "version": "3.3.5", + "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.5.tgz", + "integrity": "sha512-vyibDcu5JL20Me1fP734QBH/kenBGLZap2n0+XXM7mvuUPzJ20Ydqj1aKcIeMdri1p+PU+4yAKugjN8KCVst+g==", + "dependencies": { + "duplexer": "^0.1.1", + "from": "^0.1.7", + "map-stream": "0.0.7", + "pause-stream": "^0.0.11", + "split": "^1.0.1", + "stream-combiner": "^0.2.2", + "through": "^2.3.8" + } + }, + "node_modules/event-stream/node_modules/stream-combiner": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.2.2.tgz", + "integrity": "sha512-6yHMqgLYDzQDcAkL+tjJDC5nSNuNIx0vZtRZeiPh7Saef7VHX9H5Ijn9l2VIol2zaNYlYEX6KyuT/237A58qEQ==", + "dependencies": { + "duplexer": "~0.1.1", + "through": "~2.3.4" + } + }, "node_modules/eventemitter3": { "version": "4.0.7", "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", @@ -8091,11 +9134,36 @@ "node": ">= 0.8" } }, + "node_modules/ext-list": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/ext-list/-/ext-list-0.2.0.tgz", + "integrity": "sha512-5HDeVof2cxke3u+FQ3FhTVf9UZUK/07Y/5SNqOL8AjCEEcqZciaR4gP1ESIVbYxctlkClVLHddm8oPsk+Ndcrw==", + "dependencies": { + "got": "^0.2.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ext-name": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ext-name/-/ext-name-1.0.1.tgz", + "integrity": "sha512-1FkRYVZnrkShQu6UagNtNQuTtHn1n5kGmanUsmEN0iF0+szGUREoDRpXLejAdHMA+fM+sf8S11JUq+RWJALRYw==", + "dependencies": { + "ext-list": "^0.2.0", + "underscore.string": "~2.3.3" + }, + "bin": { + "extname": "cli.js" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/extend": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", - "dev": true, "license": "MIT" }, "node_modules/external-editor": { @@ -8144,6 +9212,11 @@ "dev": true, "license": "MIT" }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==" + }, "node_modules/fastq": { "version": "1.17.1", "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", @@ -8373,6 +9446,15 @@ "node": ">= 6" } }, + "node_modules/formidable": { + "version": "1.0.14", + "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.0.14.tgz", + "integrity": "sha512-aOskFHEfYwkSKSzGui5jhQ+uyLo2NTwpzhndggz2YZHlv0HkAi+zG5ZEBCL3GTvqLyr/FzX9Mvx9DueCmu2HzQ==", + "deprecated": "Please upgrade to latest, formidable@v2 or formidable@v3! Check these notes: https://bit.ly/2ZEqIau", + "engines": { + "node": ">=0.8.0" + } + }, "node_modules/forwarded": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", @@ -8407,6 +9489,11 @@ "node": ">= 0.6" } }, + "node_modules/from": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", + "integrity": "sha512-twe20eF1OxVxp/ML/kq2p1uc6KvFK/+vs8WjEbeKmV2He22MKm7YF2ANIt+EOqhJ5L3K/SuuPhk0hWQDjOM23g==" + }, "node_modules/fs-constants": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", @@ -8468,6 +9555,77 @@ "node": "^8.16.0 || ^10.6.0 || >=11.0.0" } }, + "node_modules/fstream": { + "version": "0.1.31", + "resolved": "https://registry.npmjs.org/fstream/-/fstream-0.1.31.tgz", + "integrity": "sha512-N1pLGEHoDyCoI8uMmPXJXhn238L4nk41iipXCrqs4Ss0ooYSr5sNj2ucMo5AqJVC4OaOa7IztpBhOaaYTGZVuA==", + "deprecated": "This package is no longer supported.", + "dependencies": { + "graceful-fs": "~3.0.2", + "inherits": "~2.0.0", + "mkdirp": "0.5", + "rimraf": "2" + }, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/fstream/node_modules/graceful-fs": { + "version": "3.0.12", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-3.0.12.tgz", + "integrity": "sha512-J55gaCS4iTTJfTXIxSVw3EMQckcqkpdRv3IR7gu6sq0+tbC363Zx6KH/SEwXASK9JRbhyZmVjJEVJIOxYsB3Qg==", + "dependencies": { + "natives": "^1.1.3" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/fstream/node_modules/rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/ftp": { + "version": "0.3.10", + "resolved": "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz", + "integrity": "sha512-faFVML1aBx2UoDStmLwv2Wptt4vw5x03xxX172nhA5Y5HBshW5JweqQ2W4xL4dezQTG8inJsuYcpPHHU3X5OTQ==", + "dependencies": { + "readable-stream": "1.1.x", + "xregexp": "2.0.0" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/ftp/node_modules/isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ==" + }, + "node_modules/ftp/node_modules/readable-stream": { + "version": "1.1.14", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "integrity": "sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ==", + "dependencies": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "0.0.1", + "string_decoder": "~0.10.x" + } + }, + "node_modules/ftp/node_modules/string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==" + }, "node_modules/function-bind": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", @@ -8499,6 +9657,11 @@ "node": ">=10" } }, + "node_modules/generator-supported": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/generator-supported/-/generator-supported-0.0.1.tgz", + "integrity": "sha512-VfNqamgY6cuNhi6GF4NIYs5jtJsPZZtpMJl1lCBko5FNALeZ0WfXeG5WMke3lVwfYI6jH1BLZcXyukP9wtPhfw==" + }, "node_modules/gensync": { "version": "1.0.0-beta.2", "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", @@ -8547,6 +9710,14 @@ "node": ">=8.0.0" } }, + "node_modules/get-stdin": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-0.1.0.tgz", + "integrity": "sha512-/WBu3IaQZxE3bs3BhBmR10ipDY4pjN+U4EZgXULa1eqKA0B/Lka/MVoAqhTVYBkkRlCrEGDOU9itrzIgm9Ksng==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/get-stream": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", @@ -8560,6 +9731,37 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/get-uri": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-0.1.4.tgz", + "integrity": "sha512-xV5cksh/mERjnnDgZe0wKO2VokqUeTe/QaKrhUHhm77eiLXhGrWi5qiz20tF6NKRTcY47YP1OzSRgTHadNY3mQ==", + "dependencies": { + "data-uri-to-buffer": "0", + "debug": "2", + "extend": "3", + "file-uri-to-path": "0", + "ftp": "~0.3.5", + "readable-stream": "2" + } + }, + "node_modules/get-uri/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/get-uri/node_modules/file-uri-to-path": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-0.0.2.tgz", + "integrity": "sha512-jNmalsdk1enTf+tjxrMb3nutLleumh96WWtXJQHU700Jmjyl/CHj33Di5iFECNNfgb9GwlMNKU18tukUPlFXMg==" + }, + "node_modules/get-uri/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + }, "node_modules/github-from-package": { "version": "0.0.0", "resolved": "https://registry.npmjs.org/github-from-package/-/github-from-package-0.0.0.tgz", @@ -8677,6 +9879,25 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/got": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/got/-/got-0.2.0.tgz", + "integrity": "sha512-YTZ1W2+KYNuBSR2icdJIU4EXddb6NsjXcZN/e1ggfkdniQk1mrVaxyyRJL0Mi+HggW3+Ld2vH3dDl/tI2LKmag==", + "dependencies": { + "object-assign": "^0.3.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/got/node_modules/object-assign": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-0.3.1.tgz", + "integrity": "sha512-4gWmwoU6o9UImLLzq+8R+kzWT0ABYdKXuvSp08JpYzhibFvdUirMfE9nE5yYHcG1k9ClcVueR4TolZpRvwg5og==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/graceful-fs": { "version": "4.2.11", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", @@ -9002,7 +10223,6 @@ "version": "0.4.24", "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, "license": "MIT", "dependencies": { "safer-buffer": ">= 2.1.2 < 3" @@ -9232,6 +10452,19 @@ "url": "https://github.com/chalk/chalk?sponsor=1" } }, + "node_modules/invert-kv": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", + "integrity": "sha512-xgs2NH9AE66ucSq4cNG1nhSFghr5l6tdL15Pk+jl46bmmBapgoaY/AacXyaDznAqmGL99TiLSQgO/XazFSKYeQ==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ip": { + "version": "1.1.9", + "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.9.tgz", + "integrity": "sha512-cyRxvOEpNHNtchU3Ln9KC/auJgup87llfQpQ+t5ghoC/UhL16SWzbueiCsdTnWmqAWl7LadfuwhlqmtOaqMHdQ==" + }, "node_modules/ip-address": { "version": "9.0.5", "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-9.0.5.tgz", @@ -9281,6 +10514,11 @@ "node": ">=8" } }, + "node_modules/is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" + }, "node_modules/is-core-module": { "version": "2.15.1", "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", @@ -9361,6 +10599,11 @@ "integrity": "sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ==", "license": "MIT" }, + "node_modules/is-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", + "integrity": "sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g==" + }, "node_modules/is-number": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -9687,6 +10930,11 @@ "jiti": "bin/jiti.js" } }, + "node_modules/js-base64": { + "version": "2.1.9", + "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.1.9.tgz", + "integrity": "sha512-f+5mYh8iF7FlF7zgmj/yqvvYQUHI0kAxGiLjIfNxZzqJ7RQNc4sjgp8crVJw0Kzv2O6aFGZWgMTnO71I9utHSg==" + }, "node_modules/js-tokens": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", @@ -9833,6 +11081,29 @@ ], "license": "MIT" }, + "node_modules/JSONStream": { + "version": "0.8.4", + "resolved": "https://registry.npmjs.org/JSONStream/-/JSONStream-0.8.4.tgz", + "integrity": "sha512-l0NN3IcqrZfZBJp7JWDJIHsnPV7yzJWqsYxQzL8Fwdx1BmEMjLuvtYkv+P9pbvpyfP75/f4MeDZhWNU4is32uA==", + "dependencies": { + "jsonparse": "0.0.5", + "through": ">=2.2.7 <3" + }, + "bin": { + "JSONStream": "index.js" + }, + "engines": { + "node": "*" + } + }, + "node_modules/JSONStream/node_modules/jsonparse": { + "version": "0.0.5", + "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-0.0.5.tgz", + "integrity": "sha512-fw7Q/8gFR8iSekUi9I+HqWIap6mywuoe7hQIg3buTVjuZgALKj4HAmm0X6f+TaL4c9NJbvyFQdaI2ppr5p6dnQ==", + "engines": [ + "node >= 0.2.0" + ] + }, "node_modules/jspdf": { "version": "2.5.2", "resolved": "https://registry.npmjs.org/jspdf/-/jspdf-2.5.2.tgz", @@ -10345,6 +11616,30 @@ "node": ">=12" } }, + "node_modules/jstransform": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/jstransform/-/jstransform-3.0.0.tgz", + "integrity": "sha512-sMwqW0EdQk2A5NjddlcSSLp6t7pIknOrJtxPU3kMN82RJXPGbdC3fcM5VhIsApNKL1hpeH38iSQsJRbgprPQZg==", + "dependencies": { + "base62": "0.1.1", + "esprima-fb": "~3001.1.0-dev-harmony-fb", + "source-map": "0.1.31" + }, + "engines": { + "node": ">=0.8.8" + } + }, + "node_modules/jstransform/node_modules/source-map": { + "version": "0.1.31", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.31.tgz", + "integrity": "sha512-qFALUiKHo35Duky0Ubmb5YKj9b3c6CcgGNGeI60sd6Nn3KaY7h9fclEOcCVk0hwszwYYP6+X2/jpS5hHqqVuig==", + "dependencies": { + "amdefine": ">=0.0.4" + }, + "engines": { + "node": ">=0.8.0" + } + }, "node_modules/jszip": { "version": "3.10.1", "resolved": "https://registry.npmjs.org/jszip/-/jszip-3.10.1.tgz", @@ -10615,6 +11910,25 @@ "shell-quote": "^1.8.1" } }, + "node_modules/lazy-cache": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", + "integrity": "sha512-RE2g0b5VGZsOCFOCgP7omTRYFqydmZkBwl5oNnQ1lDYC57uyO9KqNnNVxT7COSHTxrRCWVcAVOcbjk+tvh/rgQ==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/lcid": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", + "integrity": "sha512-YiGkH6EnGrDGqLMITnGjXtGmNtjoXw9SVUzcaos8RBi7Ps0VBylkq+vOcY9QE5poLasPCR849ucFUkl0UzUyOw==", + "dependencies": { + "invert-kv": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/less": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/less/-/less-4.2.0.tgz", @@ -10714,6 +12028,18 @@ "node": ">=0.10.0" } }, + "node_modules/levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA==", + "dependencies": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/license-webpack-plugin": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/license-webpack-plugin/-/license-webpack-plugin-4.0.2.tgz", @@ -10910,6 +12236,14 @@ "node": ">=8.0" } }, + "node_modules/longest": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", + "integrity": "sha512-k+yt5n3l48JU4k8ftnKG6V7u32wyH2NfKzeMto9F/QRE0amxy/LayxwlvjjkZEIzqR+19IrtFO8p5kB9QaYUFg==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/lru-cache": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", @@ -10995,6 +12329,19 @@ "node": "^14.17.0 || ^16.13.0 || >=18.0.0" } }, + "node_modules/makeerror": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", + "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", + "dependencies": { + "tmpl": "1.0.5" + } + }, + "node_modules/map-stream": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.0.7.tgz", + "integrity": "sha512-C0X0KQmGm3N2ftbTGBhSyuydQ+vV1LC3f3zPvT3RXHXNZrvfPZcoXp/N5DOa8vedX/rTMm2CjTtivFg2STJMRQ==" + }, "node_modules/mathjax": { "version": "3.2.2", "resolved": "https://registry.npmjs.org/mathjax/-/mathjax-3.2.2.tgz", @@ -11394,7 +12741,6 @@ "version": "0.5.6", "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", - "dev": true, "license": "MIT", "dependencies": { "minimist": "^1.2.6" @@ -11480,6 +12826,12 @@ "integrity": "sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg==", "license": "MIT" }, + "node_modules/natives": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/natives/-/natives-1.1.6.tgz", + "integrity": "sha512-6+TDFewD4yxY14ptjKaS63GVdtKiES1pTPyxn9Jb0rBqPMZ7VcCiooEhPNsr+mqHtMGxa/5c/HhcC4uPEUw/nA==", + "deprecated": "This module relies on Node.js's internals and will break at some point. Do not use it, and update to graceful-fs@4.x." + }, "node_modules/needle": { "version": "3.3.1", "resolved": "https://registry.npmjs.org/needle/-/needle-3.3.1.tgz", @@ -11528,6 +12880,19 @@ "dev": true, "license": "MIT" }, + "node_modules/netmask": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/netmask/-/netmask-1.0.6.tgz", + "integrity": "sha512-3DWDqAtIiPSkBXZyYEjwebfK56nrlQfRGt642fu8RPaL+ePu750+HCMHxjJCG3iEHq/0aeMvX6KIzlv7nuhfrA==", + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/netrc": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/netrc/-/netrc-0.1.4.tgz", + "integrity": "sha512-ye8AIYWQcP9MvoM1i0Z2jV0qed31Z8EWXYnyGNkiUAd+Fo8J+7uy90xTV8g/oAbhtjkY7iZbNTizQaXdKUuwpQ==" + }, "node_modules/nice-napi": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/nice-napi/-/nice-napi-1.0.2.tgz", @@ -11775,6 +13140,25 @@ "node": ">=6" } }, + "node_modules/noptify": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/noptify/-/noptify-0.0.3.tgz", + "integrity": "sha512-EZT35r9AuK+hig+iYv4144kwfDEDhlj3zncVHw9b9d86TUYk/67BtBApkfPD1kslAT/8TTD262xdsVbV+iCSTw==", + "dependencies": { + "nopt": "~2.0.0" + } + }, + "node_modules/noptify/node_modules/nopt": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-2.0.0.tgz", + "integrity": "sha512-uVTsuT8Hm3aN3VttY+BPKw4KU9lVpI0F22UAr/I1r6+kugMr3oyhMALkycikLcdfvGRsgzCYN48DYLBFcJEUVg==", + "dependencies": { + "abbrev": "1" + }, + "bin": { + "nopt": "bin/nopt.js" + } + }, "node_modules/normalize-package-data": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-6.0.2.tgz", @@ -12071,6 +13455,22 @@ "opener": "bin/opener-bin.js" } }, + "node_modules/optionator": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", + "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", + "dependencies": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/ora": { "version": "5.4.1", "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz", @@ -12171,6 +13571,17 @@ "node": ">=8" } }, + "node_modules/os-locale": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", + "integrity": "sha512-PRT7ZORmwu2MEFt4/fv3Q+mEfN4zetKxufQrkShY2oGvUms9r8otu5HfdyIFHkYXjO7laNsoVGmM2MANfuTA8g==", + "dependencies": { + "lcid": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/os-tmpdir": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", @@ -12262,6 +13673,60 @@ "node": ">=6" } }, + "node_modules/pac-proxy-agent": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-0.2.0.tgz", + "integrity": "sha512-n7a4CFNSiKfr0Kr2XbJxUEQOab5JMJk3si0SNEjKdKAorg15dW4PZWpKZ+J5rr0S91TbuyLnl37vRS0zU7K4cg==", + "dependencies": { + "agent-base": "~1.0.1", + "debug": "2", + "extend": "~1.2.1", + "get-uri": "~0.1.0", + "pac-resolver": "~1.2.1", + "proxy-agent": "1", + "stream-to-array": "~1.0.0" + } + }, + "node_modules/pac-proxy-agent/node_modules/agent-base": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-1.0.2.tgz", + "integrity": "sha512-IrdRInle5l28T2DjBsOojXniN91mXYkt9piDyPbPEoA/X+f7kjd0qiIb18vZThIZCJdLk2Zq/ukXxZp8NkcFsw==" + }, + "node_modules/pac-proxy-agent/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/pac-proxy-agent/node_modules/extend": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/extend/-/extend-1.2.1.tgz", + "integrity": "sha512-2/JwIYRpMBDSjbQjUUppNSrmc719crhFaWIdT+TRSVA8gE+6HEobQWqJ6VkPt/H8twS7h/0WWs7veh8wmp98Ng==" + }, + "node_modules/pac-proxy-agent/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + }, + "node_modules/pac-resolver": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-1.2.6.tgz", + "integrity": "sha512-hgYjw6snhgn68Rdb2Sgrd/rUKMkZ9EpXiA7G9Gqr9BsC6Bb+l1tAZ11WoYfNYzqamdkXU4m3VOb29H4VHOinyA==", + "dependencies": { + "co": "~3.0.6", + "degenerator": "~1.0.0", + "netmask": "~1.0.4", + "regenerator": "~0.8.13", + "thunkify": "~2.1.1" + } + }, + "node_modules/pac-resolver/node_modules/co": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/co/-/co-3.0.6.tgz", + "integrity": "sha512-Vj29f/AYywpPtHPhN9YqC7yK+p3rfjv7l/mTu5iOtn89a7DdccD4MYQmfU6R9wGdLXwufDIV07+PjXM0taVKvw==" + }, "node_modules/package-json-from-dist": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.0.tgz", @@ -12479,6 +13944,14 @@ "node": ">=8" } }, + "node_modules/pause-stream": { + "version": "0.0.11", + "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", + "integrity": "sha512-e3FBlXLmN/D1S+zHzanP4E/4Z60oFAa3O051qt1pxa7DEJWKAyil6upYVXCWadEnuoqa4Pkc9oUx9zsxYeRv8A==", + "dependencies": { + "through": "~2.3" + } + }, "node_modules/performance-now": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", @@ -12973,6 +14446,22 @@ "simple-concat": "^1.0.0" } }, + "node_modules/prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w==", + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/private": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", + "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", + "engines": { + "node": ">= 0.6" + } + }, "node_modules/proc-log": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-3.0.0.tgz", @@ -13023,16 +14512,109 @@ "node": ">= 0.10" } }, - "node_modules/proxy-addr/node_modules/ipaddr.js": { - "version": "1.9.1", - "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", - "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.10" + "node_modules/proxy-addr/node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/proxy-agent": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-1.1.1.tgz", + "integrity": "sha512-25H5ZU12cl82fjFJmlq8iYy9gHjw4jdNmJQBbdztwcpPl4URsepnlTZUqAXKwrxwtPXg4z6NbrIiB7e3arxVUw==", + "dependencies": { + "http-proxy-agent": "0", + "https-proxy-agent": "0", + "lru-cache": "~2.5.0", + "pac-proxy-agent": "0", + "socks-proxy-agent": "1" + } + }, + "node_modules/proxy-agent/node_modules/agent-base": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-1.0.2.tgz", + "integrity": "sha512-IrdRInle5l28T2DjBsOojXniN91mXYkt9piDyPbPEoA/X+f7kjd0qiIb18vZThIZCJdLk2Zq/ukXxZp8NkcFsw==" + }, + "node_modules/proxy-agent/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/proxy-agent/node_modules/http-proxy-agent": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-0.2.7.tgz", + "integrity": "sha512-9W3grrlsrW2kRGNRbGkBNVFx4voQS1H1TxWR60MVHKQ+rw+kRtA9JXVGQiiDgYsp315Ex5HPk+3it4lBNyk4WA==", + "dependencies": { + "agent-base": "~1.0.1", + "debug": "2", + "extend": "3" + } + }, + "node_modules/proxy-agent/node_modules/https-proxy-agent": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-0.3.6.tgz", + "integrity": "sha512-ZuLafAeUu97abfbpAO9Cwjl3slsx6yZ7apTYBNVtMdoDhlVzUhxXO0qh+Xxqc5FAm7oq747k2jjbICYJdEYShg==", + "dependencies": { + "agent-base": "~1.0.1", + "debug": "2", + "extend": "3" + } + }, + "node_modules/proxy-agent/node_modules/lru-cache": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-2.5.2.tgz", + "integrity": "sha512-wyqfj+623mgqv+bpjTdivSoC/LtY9oOrmKz2Cke0NZcgYW9Kce/qWjd9e5PDYf8wuiKfVeo8VnyOSSyeRiUsLw==" + }, + "node_modules/proxy-agent/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + }, + "node_modules/proxy-agent/node_modules/smart-buffer": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-1.1.15.tgz", + "integrity": "sha512-1+8bxygjTsNfvQe0/0pNBesTOlSHtOeG6b6LYbvsZCCHDKYZ40zcQo6YTnZBWrBSLWOCbrHljLdEmGMYebu7aQ==", + "engines": { + "node": ">= 0.10.15", + "npm": ">= 1.3.5" + } + }, + "node_modules/proxy-agent/node_modules/socks": { + "version": "1.1.10", + "resolved": "https://registry.npmjs.org/socks/-/socks-1.1.10.tgz", + "integrity": "sha512-ArX4vGPULWjKDKgUnW8YzfI2uXW7kzgkJuB0GnFBA/PfT3exrrOk+7Wk2oeb894Qf20u1PWv9LEgrO0Z82qAzA==", + "deprecated": "If using 2.x branch, please upgrade to at least 2.1.6 to avoid a serious bug with socket data flow and an import issue introduced in 2.1.0", + "dependencies": { + "ip": "^1.1.4", + "smart-buffer": "^1.0.13" + }, + "engines": { + "node": ">= 0.10.0", + "npm": ">= 1.3.5" + } + }, + "node_modules/proxy-agent/node_modules/socks-proxy-agent": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-1.0.2.tgz", + "integrity": "sha512-F8xR1C4uplta4XIwHvvpIxhLO8oCWLuC48hSgFpMqps45WqtOZQ4JadJ5YGo0eGMvIp94qV3bX3Tqi2iHGlNvw==", + "dependencies": { + "agent-base": "~1.0.1", + "extend": "~1.2.1", + "socks": "~1.1.5" } }, + "node_modules/proxy-agent/node_modules/socks-proxy-agent/node_modules/extend": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/extend/-/extend-1.2.1.tgz", + "integrity": "sha512-2/JwIYRpMBDSjbQjUUppNSrmc719crhFaWIdT+TRSVA8gE+6HEobQWqJ6VkPt/H8twS7h/0WWs7veh8wmp98Ng==" + }, "node_modules/prr": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", @@ -13064,6 +14646,16 @@ "dev": true, "license": "MIT" }, + "node_modules/q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==", + "deprecated": "You or someone you depend on is using Q, the JavaScript Promise library that gave JavaScript developers strong feelings about promises. They can almost certainly migrate to the native JavaScript promise now. Thank you literally everyone for joining me in this bet against the odds. Be excellent to each other.\n\n(For a CapTP with native promises, see @endo/eventual-send and @endo/captp)", + "engines": { + "node": ">=0.6.0", + "teleport": ">=0.2.0" + } + }, "node_modules/qjobs": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/qjobs/-/qjobs-1.2.0.tgz", @@ -13374,6 +14966,53 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, + "node_modules/recast": { + "version": "0.10.33", + "resolved": "https://registry.npmjs.org/recast/-/recast-0.10.33.tgz", + "integrity": "sha512-RxAVgvgWGzfFYsdc3PB6TM4/cq8HMgBH8PC9r+SkO7j1MeHZvIMxLSVlUhin3sv9wbAy8CMAPXSGSGkWPovyKQ==", + "dependencies": { + "ast-types": "0.8.12", + "esprima-fb": "~15001.1001.0-dev-harmony-fb", + "private": "~0.1.5", + "source-map": "~0.5.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/recast/node_modules/ast-types": { + "version": "0.8.12", + "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.8.12.tgz", + "integrity": "sha512-rWhsoD0aHKpx+aKIP0Sf92bai1HC5iZcB1n/HCnkIMR8Bhx0gYRQySo062Y65ND4oRgcuxpLcPrcco09I1shpg==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/recast/node_modules/esprima-fb": { + "version": "15001.1001.0-dev-harmony-fb", + "resolved": "https://registry.npmjs.org/esprima-fb/-/esprima-fb-15001.1001.0-dev-harmony-fb.tgz", + "integrity": "sha512-m7OsYzocA8OQ3+9CxmhIv7NPHtyDR2ixaLCO7kLZ+YH+xQ/BpaZmll9EXmc+kBxzWA8BRBXbNEuEQqQ6vfsgDw==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/recast/node_modules/source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/reduce-component": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/reduce-component/-/reduce-component-1.0.1.tgz", + "integrity": "sha512-y0wyCcdQul3hI3xHfIs0vg/jSbboQc/YTOAqaxjFG7At+XSexduuOqBVL9SmOLSwa/ldkbzVzdwuk9s2EKTAZg==" + }, "node_modules/reflect-metadata": { "version": "0.2.2", "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.2.2.tgz", @@ -13401,6 +15040,26 @@ "node": ">=4" } }, + "node_modules/regenerator": { + "version": "0.8.46", + "resolved": "https://registry.npmjs.org/regenerator/-/regenerator-0.8.46.tgz", + "integrity": "sha512-jFhAPsOnJ/UIZCG1+iISKiczjnLWaQ4RatPkg5BZIcgz0m3C+txY28U0H7ij+fLSADmY+kHj9HZff6CLq9hrVA==", + "dependencies": { + "commoner": "~0.10.3", + "defs": "~1.1.0", + "esprima-fb": "~15001.1001.0-dev-harmony-fb", + "private": "~0.1.5", + "recast": "0.10.33", + "regenerator-runtime": "~0.9.5", + "through": "~2.3.8" + }, + "bin": { + "regenerator": "bin/regenerator" + }, + "engines": { + "node": ">= 0.6" + } + }, "node_modules/regenerator-runtime": { "version": "0.14.1", "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz", @@ -13417,6 +15076,23 @@ "@babel/runtime": "^7.8.4" } }, + "node_modules/regenerator/node_modules/esprima-fb": { + "version": "15001.1001.0-dev-harmony-fb", + "resolved": "https://registry.npmjs.org/esprima-fb/-/esprima-fb-15001.1001.0-dev-harmony-fb.tgz", + "integrity": "sha512-m7OsYzocA8OQ3+9CxmhIv7NPHtyDR2ixaLCO7kLZ+YH+xQ/BpaZmll9EXmc+kBxzWA8BRBXbNEuEQqQ6vfsgDw==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/regenerator/node_modules/regenerator-runtime": { + "version": "0.9.6", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.9.6.tgz", + "integrity": "sha512-D0Y/JJ4VhusyMOd/o25a3jdUqN/bC85EFsaoL9Oqmy/O4efCh+xhp7yj2EEOsj974qvMkcW8AwUzJ1jB/MbxCw==" + }, "node_modules/regex-parser": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/regex-parser/-/regex-parser-2.3.0.tgz", @@ -13464,6 +15140,14 @@ "jsesc": "bin/jsesc" } }, + "node_modules/repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w==", + "engines": { + "node": ">=0.10" + } + }, "node_modules/require-directory": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", @@ -13489,6 +15173,11 @@ "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", "license": "ISC" }, + "node_modules/requires": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/requires/-/requires-1.0.2.tgz", + "integrity": "sha512-X0owrXW/+IVhkwoYHL9ZKQQBfq+5NiPVmw6ev7LhWFecMmx9uhbBzjbR/xxv9bRSsHorSrUpQm6WNQdUxnlGtg==" + }, "node_modules/requires-port": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", @@ -13617,6 +15306,17 @@ "node": ">= 0.8.15" } }, + "node_modules/right-align": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", + "integrity": "sha512-yqINtL/G7vs2v+dFIZmFUDbnVyFUJFKd6gK22Kgo6R4jfJGFtisKyncWDDULgjfqf4ASQuIQyjJ7XZ+3aWpsAg==", + "dependencies": { + "align-text": "^0.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/rimraf": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", @@ -13736,6 +15436,38 @@ "integrity": "sha512-LRneZZRXNgjzwG4bDQdOTSbze3fHm1EAKN/8bePxnlEZiBmkYEDggaHbuvHI9/hoqHbGfsEA7tWS9GhYHZBBsw==", "license": "Apache-2.0" }, + "node_modules/sane": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/sane/-/sane-0.8.1.tgz", + "integrity": "sha512-hWKZiIn39itnpdiiLT+Zh1gIQfS22Nwp9h4GrriMe9iCBcrcuUF264ELNADbBjiLIJqCzEIAtNR8uD+WCYVtTQ==", + "deprecated": "some dependency vulnerabilities fixed, support for node < 10 dropped, and newer ECMAScript syntax/features added", + "dependencies": { + "minimatch": "~0.2.14", + "walker": "~1.0.5", + "watch": "~0.10.0" + }, + "engines": { + "node": ">=0.6.0" + } + }, + "node_modules/sane/node_modules/lru-cache": { + "version": "2.7.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-2.7.3.tgz", + "integrity": "sha512-WpibWJ60c3AgAz8a2iYErDrcT2C7OmKnsWhIcHOjkUHFjkXncJhtLxNSqUmxRxRunpb5I8Vprd7aNSd2NtksJQ==" + }, + "node_modules/sane/node_modules/minimatch": { + "version": "0.2.14", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-0.2.14.tgz", + "integrity": "sha512-zZ+Jy8lVWlvqqeM8iZB7w7KmQkoJn8djM585z88rywrEbzoqawVa9FR5p2hwD+y74nfuKOjmNvi9gtWJNLqHvA==", + "deprecated": "Please update to minimatch 3.0.2 or higher to avoid a RegExp DoS issue", + "dependencies": { + "lru-cache": "2", + "sigmund": "~1.0.0" + }, + "engines": { + "node": "*" + } + }, "node_modules/sass": { "version": "1.71.1", "resolved": "https://registry.npmjs.org/sass/-/sass-1.71.1.tgz", @@ -14166,6 +15898,11 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/sigmund": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", + "integrity": "sha512-fCvEXfh6NWpm+YSuY2bpXb/VIihqWA6hLsgboC+0nl71Q7N7o2eaCW8mJa/NLvQhs6jpd3VZV4UiUQlV6+lc8g==" + }, "node_modules/signal-exit": { "version": "3.0.7", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", @@ -14210,6 +15947,11 @@ ], "license": "MIT" }, + "node_modules/simple-fmt": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/simple-fmt/-/simple-fmt-0.1.0.tgz", + "integrity": "sha512-9a3zTDDh9LXbTR37qBhACWIQ/mP/ry5xtmbE98BJM8GR02sanCkfMzp7AdCTqYhkBZggK/w7hJtc8Pb9nmo16A==" + }, "node_modules/simple-get": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.1.tgz", @@ -14221,6 +15963,11 @@ "simple-concat": "^1.0.0" } }, + "node_modules/simple-is": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/simple-is/-/simple-is-0.2.0.tgz", + "integrity": "sha512-GJXhv3r5vdj5tGWO+rcrWgjU2azLB+fb7Ehh3SmZpXE0o4KrrFLti0w4mdDCbR29X/z0Ls20ApjZitlpAXhAeg==" + }, "node_modules/sirv": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/sirv/-/sirv-2.0.4.tgz", @@ -14532,6 +16279,17 @@ "specificity": "bin/specificity" } }, + "node_modules/split": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/split/-/split-1.0.1.tgz", + "integrity": "sha512-mTyOoPbrivtXnwnIxZRFYRrPNtEFKlpB2fvjSnCQUiAA6qAZzqwna5envK4uk6OIeP17CsdF3rSBGYVBsU0Tkg==", + "dependencies": { + "through": "2" + }, + "engines": { + "node": "*" + } + }, "node_modules/sprintf-js": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", @@ -14551,6 +16309,12 @@ "node": "^14.17.0 || ^16.13.0 || >=18.0.0" } }, + "node_modules/stable": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz", + "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==", + "deprecated": "Modern JS already guarantees Array#sort() is a stable sort, so this library is deprecated. See the compatibility table on MDN: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#browser_compatibility" + }, "node_modules/stackblur-canvas": { "version": "2.7.0", "resolved": "https://registry.npmjs.org/stackblur-canvas/-/stackblur-canvas-2.7.0.tgz", @@ -14572,12 +16336,27 @@ "version": "1.5.0", "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", - "dev": true, "license": "MIT", "engines": { "node": ">= 0.6" } }, + "node_modules/stream-combiner": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", + "integrity": "sha512-rT00SPnTVyRsaSz5zgSPma/aHSOic5U1prhYdRy5HS2kTZviFpmDgzilbtsJsxiroqACmayynDN/9VzIbX5DOw==", + "dependencies": { + "duplexer": "~0.1.1" + } + }, + "node_modules/stream-to-array": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/stream-to-array/-/stream-to-array-1.0.0.tgz", + "integrity": "sha512-Z+ny0tylkXcRS4Jq49BNcKVmt0MrF3E/I500a18zckGt0ZMrOh1ILlbUz+FSjJePYeVbNUBCdvjfDDol27Ld1g==", + "engines": { + "node": ">= 0.10.0" + } + }, "node_modules/streamroller": { "version": "3.1.5", "resolved": "https://registry.npmjs.org/streamroller/-/streamroller-3.1.5.tgz", @@ -14631,6 +16410,16 @@ "node": ">=8" } }, + "node_modules/stringmap": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/stringmap/-/stringmap-0.2.2.tgz", + "integrity": "sha512-mR1LEHDw6TsHa+LwJeeBc9ZqZqEOm7bHidgxMmDg8HB/rbA1HhDeT08gS67CCCG/xrgIfQx5tW42pd8vFpLUow==" + }, + "node_modules/stringset": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/stringset/-/stringset-0.2.1.tgz", + "integrity": "sha512-km3jeiRpmySChl1oLiBE2ESdG5k/4+6tjENVL6BB3mdmKBiUikI5ks4paad2WAKsxzpNiBqBBbXCC12QqlpLWA==" + }, "node_modules/strip-ansi": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", @@ -14685,6 +16474,60 @@ "node": ">=0.10.0" } }, + "node_modules/superagent": { + "version": "0.17.0", + "resolved": "https://registry.npmjs.org/superagent/-/superagent-0.17.0.tgz", + "integrity": "sha512-ASGnKAf/X5HxEKjW+mpy8sk53a0Mi9XwBhQpPfqkFh+cl7K41NvUhsIJ/RAMCkQDZEfqu/FYQJoAK5JVp86p9g==", + "deprecated": "Please upgrade to v9.0.0+ as we have fixed a public vulnerability with formidable dependency. Note that v9.0.0+ requires Node.js v14.18.0+. See https://github.com/ladjs/superagent/pull/1800 for insight. This project is supported and maintained by the team at Forward Email @ https://forwardemail.net", + "dependencies": { + "cookiejar": "1.3.0", + "debug": "~0.7.2", + "emitter-component": "1.0.0", + "extend": "~1.2.1", + "formidable": "1.0.14", + "methods": "0.0.1", + "mime": "1.2.5", + "qs": "0.6.5", + "reduce-component": "1.0.1" + }, + "engines": { + "node": "*" + } + }, + "node_modules/superagent/node_modules/debug": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-0.7.4.tgz", + "integrity": "sha512-EohAb3+DSHSGx8carOSKJe8G0ayV5/i609OD0J2orCkuyae7SyZSz2aoLmQF2s0Pj5gITDebwPH7GFBlqOUQ1Q==", + "engines": { + "node": "*" + } + }, + "node_modules/superagent/node_modules/extend": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/extend/-/extend-1.2.1.tgz", + "integrity": "sha512-2/JwIYRpMBDSjbQjUUppNSrmc719crhFaWIdT+TRSVA8gE+6HEobQWqJ6VkPt/H8twS7h/0WWs7veh8wmp98Ng==" + }, + "node_modules/superagent/node_modules/methods": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/methods/-/methods-0.0.1.tgz", + "integrity": "sha512-pB8oFfci/xcfUgM6DTxc7lbTKifPPgs3mZUOsEgaH+1TTWpmcmv3sHl+5sUHIj2X2W8aPYa2+nJealRHK+Lo6A==" + }, + "node_modules/superagent/node_modules/mime": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.2.5.tgz", + "integrity": "sha512-QfwTOA+zRHSZXxl9Y7ue5ifKDhU1prnh0dO67Vgcl7Lcx0+79vL9A1ln0qtVur8CFSdYq5Zhnw9DDZQgwDh8Ng==", + "engines": { + "node": "*" + } + }, + "node_modules/superagent/node_modules/qs": { + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/qs/-/qs-0.6.5.tgz", + "integrity": "sha512-n7wA/f30O3SsOw2BVkGUDzjWMw7kXvQJWKtDdgfq5HJvDoad+Jbc6osN1AQ0Iain5plo9e7Cs5fE+xR+DVkPTw==", + "engines": { + "node": "*" + } + }, "node_modules/supports-color": { "version": "5.5.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", @@ -14746,6 +16589,14 @@ "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", "license": "MIT" }, + "node_modules/syntax-error": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/syntax-error/-/syntax-error-1.4.0.tgz", + "integrity": "sha512-YPPlu67mdnHGTup2A8ff7BC2Pjq0e0Yp/IyTFN03zWO0RcK07uLcbi7C2KpGR2FvWbaB0+bfE27a+sBKebSo7w==", + "dependencies": { + "acorn-node": "^1.2.0" + } + }, "node_modules/tapable": { "version": "2.2.1", "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", @@ -14872,6 +16723,23 @@ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", "license": "ISC" }, + "node_modules/tempfile": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/tempfile/-/tempfile-0.1.3.tgz", + "integrity": "sha512-eW5GbbQLBEpa21WNlpvJcvv/DNXLyMNOQBnhellCzQdXAf5Ctmrr8GDLc/YAymOF3t+17wmeE+kZCKBoaanEtA==", + "dependencies": { + "uuid": "~1.4.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/tempfile/node_modules/uuid": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-1.4.2.tgz", + "integrity": "sha512-woV5Ei+GBJyrqMXt0mJ9p8/I+47LYKp/4urH76FNTMjl22EhLPz1tNrQufTsrFf/PYV/7ctSZYAK7fKPWQKg+Q==", + "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details." + }, "node_modules/terser": { "version": "5.29.1", "resolved": "https://registry.npmjs.org/terser/-/terser-5.29.1.tgz", @@ -15009,6 +16877,11 @@ "integrity": "sha512-iC/hUBbl1vzFny7f5GtqzVXYjMJKaTPxiCxXfrvVdBi1Sf+jhd1CAkitiFwC7mIBFCo3MrDLJG97yisoaWig0w==", "license": "MIT" }, + "node_modules/through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==" + }, "node_modules/through2": { "version": "0.6.5", "resolved": "https://registry.npmjs.org/through2/-/through2-0.6.5.tgz", @@ -15043,6 +16916,11 @@ "integrity": "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==", "license": "MIT" }, + "node_modules/thunkify": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/thunkify/-/thunkify-2.1.2.tgz", + "integrity": "sha512-w9foI80XcGImrhMQ19pxunaEC5Rp2uzxZZg4XBAFRfiLOplk3F0l7wo+bO16vC2/nlQfR/mXZxcduo0MF2GWLg==" + }, "node_modules/thunky": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", @@ -15050,6 +16928,44 @@ "dev": true, "license": "MIT" }, + "node_modules/tiny-lr-fork": { + "version": "0.0.5", + "resolved": "https://registry.npmjs.org/tiny-lr-fork/-/tiny-lr-fork-0.0.5.tgz", + "integrity": "sha512-vhcvny/8f46rrViKV0BOUjVl4c/rDTztnT1+kT7iyD/Igqb/uyiRsKLxMc2Z8CNvTE1Px1tuNrPM+BOUL+3vlQ==", + "dependencies": { + "debug": "~0.7.0", + "faye-websocket": "~0.4.3", + "noptify": "~0.0.3", + "qs": "~0.5.2" + }, + "bin": { + "tiny-lr-fork": "bin/tiny-lr" + } + }, + "node_modules/tiny-lr-fork/node_modules/debug": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-0.7.4.tgz", + "integrity": "sha512-EohAb3+DSHSGx8carOSKJe8G0ayV5/i609OD0J2orCkuyae7SyZSz2aoLmQF2s0Pj5gITDebwPH7GFBlqOUQ1Q==", + "engines": { + "node": "*" + } + }, + "node_modules/tiny-lr-fork/node_modules/faye-websocket": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.4.4.tgz", + "integrity": "sha512-78pqrJbvGZSe8i+PLsPd+aJqTyGqgyWLnMw5NOwtXCTVMzEFh1zQPwIuIL/ycTj4rkDy5zZ9B6frYPqVPJBzyQ==", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/tiny-lr-fork/node_modules/qs": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/qs/-/qs-0.5.6.tgz", + "integrity": "sha512-KbOrQrP5Ye+0gmq+hwxoJwAFRwExACWqwxj1IDFFgqOw9Poxy3wwSbafd9ZqP6T6ykMfnxM573kt/a4i9ybatQ==", + "engines": { + "node": "*" + } + }, "node_modules/tmp": { "version": "0.0.33", "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", @@ -15063,6 +16979,16 @@ "node": ">=0.6.0" } }, + "node_modules/tmpl": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", + "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==" + }, + "node_modules/to-descriptor": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-descriptor/-/to-descriptor-1.0.1.tgz", + "integrity": "sha512-wxfaAjsoz5ptZjuqkEe7KLQ0VvdBH8a+FFzdmeVD9c7TWU9KCzLAC3li4bZ8xiPJsZMqVnZWM/7glZQngMTeEQ==" + }, "node_modules/to-fast-properties": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", @@ -15169,6 +17095,11 @@ "tree-kill": "cli.js" } }, + "node_modules/tryor": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/tryor/-/tryor-0.1.2.tgz", + "integrity": "sha512-2+ilNA00DGvbUYYbRrm3ux+snbo7I6uPXMw8I4p/QMl7HUOWBBZFbk+Mpr8/IAPDQE+LQ8vOdlI6xEzjc+e/BQ==" + }, "node_modules/ts-node": { "version": "10.9.2", "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz", @@ -15261,6 +17192,17 @@ "node": "*" } }, + "node_modules/type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg==", + "dependencies": { + "prelude-ls": "~1.1.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/type-fest": { "version": "0.21.3", "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", @@ -15336,6 +17278,14 @@ "node": "*" } }, + "node_modules/underscore.string": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/underscore.string/-/underscore.string-2.3.3.tgz", + "integrity": "sha512-hbD5MibthuDAu4yA5wxes5bzFgqd3PpBJuClbRxaNddxfdsz+qf+1kHwrGQFrmchmDHb9iNU+6EHDn8uj0xDJg==", + "engines": { + "node": "*" + } + }, "node_modules/undici": { "version": "6.11.1", "resolved": "https://registry.npmjs.org/undici/-/undici-6.11.1.tgz", @@ -15353,6 +17303,60 @@ "dev": true, "license": "MIT" }, + "node_modules/unglob": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/unglob/-/unglob-0.1.2.tgz", + "integrity": "sha512-L+VIVtnV3YV9INYG6rWVXaq7yBVzecxstKEuns5niJiKh1XLC3xrOsbVEnyyHhjlTL4eEeaFCmXQhZgXAEw9pA==", + "dependencies": { + "generator-supported": "~0.0.1", + "glob": "~3.2.8", + "minimatch": "~0.2.14" + } + }, + "node_modules/unglob/node_modules/glob": { + "version": "3.2.11", + "resolved": "https://registry.npmjs.org/glob/-/glob-3.2.11.tgz", + "integrity": "sha512-hVb0zwEZwC1FXSKRPFTeOtN7AArJcJlI6ULGLtrstaswKNlrTJqAA+1lYlSUop4vjA423xlBzqfVS3iWGlqJ+g==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dependencies": { + "inherits": "2", + "minimatch": "0.3" + }, + "engines": { + "node": "*" + } + }, + "node_modules/unglob/node_modules/glob/node_modules/minimatch": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-0.3.0.tgz", + "integrity": "sha512-WFX1jI1AaxNTZVOHLBVazwTWKaQjoykSzCBNXB72vDTCzopQGtyP91tKdFK5cv1+qMwPyiTu1HqUriqplI8pcA==", + "deprecated": "Please update to minimatch 3.0.2 or higher to avoid a RegExp DoS issue", + "dependencies": { + "lru-cache": "2", + "sigmund": "~1.0.0" + }, + "engines": { + "node": "*" + } + }, + "node_modules/unglob/node_modules/lru-cache": { + "version": "2.7.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-2.7.3.tgz", + "integrity": "sha512-WpibWJ60c3AgAz8a2iYErDrcT2C7OmKnsWhIcHOjkUHFjkXncJhtLxNSqUmxRxRunpb5I8Vprd7aNSd2NtksJQ==" + }, + "node_modules/unglob/node_modules/minimatch": { + "version": "0.2.14", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-0.2.14.tgz", + "integrity": "sha512-zZ+Jy8lVWlvqqeM8iZB7w7KmQkoJn8djM585z88rywrEbzoqawVa9FR5p2hwD+y74nfuKOjmNvi9gtWJNLqHvA==", + "deprecated": "Please update to minimatch 3.0.2 or higher to avoid a RegExp DoS issue", + "dependencies": { + "lru-cache": "2", + "sigmund": "~1.0.0" + }, + "engines": { + "node": "*" + } + }, "node_modules/unicode-canonical-property-names-ecmascript": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.1.tgz", @@ -16088,6 +18092,22 @@ "node": ">=18" } }, + "node_modules/walker": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", + "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", + "dependencies": { + "makeerror": "1.0.12" + } + }, + "node_modules/watch": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/watch/-/watch-0.10.0.tgz", + "integrity": "sha512-FAk18nzhYggg939xgRRLJjvqmAKZciO24wr8neoxNPl87w8J3m784wxL4zFBwME+0gNQ2Sv/vfsCrUxPxU2Dmg==", + "engines": [ + "node >=0.1.95" + ] + }, "node_modules/watchpack": { "version": "2.4.0", "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.0.tgz", @@ -16590,6 +18610,43 @@ "dev": true, "license": "MIT" }, + "node_modules/win-fork": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/win-fork/-/win-fork-1.1.1.tgz", + "integrity": "sha512-kMnrXXHyb/Zx1ynkiMtcEgq+rxXFIfs/IhhxVBmIk+1KwPyIggZU0RAiADExhSyf0NESvCWQyfO4eGdlU9fBSw==", + "bin": { + "win-fork": "bin/win-spawn", + "win-line-endings": "bin/win-line-endings", + "win-spawn": "bin/win-spawn" + } + }, + "node_modules/window-size": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.4.tgz", + "integrity": "sha512-2thx4pB0cV3h+Bw7QmMXcEbdmOzv9t0HFplJH/Lz6yu60hXYy5RT8rUu+wlIreVxWsGN20mo+MHeCSfUpQBwPw==", + "bin": { + "window-size": "cli.js" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/wordwrap": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", + "integrity": "sha512-xSBsCeh+g+dinoBv3GAOWM4LcVVO68wLXRanibtBSdUvkGWQRGeE9P7IwU9EmDDi4jA6L44lz15CGMwdw9N5+Q==", + "engines": { + "node": ">=0.4.0" + } + }, "node_modules/wrap-ansi": { "version": "6.2.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", @@ -16694,6 +18751,18 @@ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", "license": "ISC" }, + "node_modules/write-to": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/write-to/-/write-to-1.1.1.tgz", + "integrity": "sha512-pcG7jO2XQm49G+oCJhFtQC2Dh7U//K0jzXnCetNERZn57/HbyuQQ+FFDOCUq61Sw3KGHqxO9uEWVaj/tJeAhxw==", + "dependencies": { + "dethroy": "1", + "mkdirp": "0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/ws": { "version": "8.18.0", "resolved": "https://registry.npmjs.org/ws/-/ws-8.18.0.tgz", @@ -16739,6 +18808,14 @@ "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", "license": "MIT" }, + "node_modules/xregexp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz", + "integrity": "sha512-xl/50/Cf32VsGq/1R8jJE5ajH1yMCQkpmoS10QbFZWl2Oor4H0Me64Pu2yxvsRWK3m6soJbmGfzSR7BYmDcWAA==", + "engines": { + "node": "*" + } + }, "node_modules/xtend": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", diff --git a/firebird-ng/package.json b/firebird-ng/package.json index 4b852e4..0137688 100644 --- a/firebird-ng/package.json +++ b/firebird-ng/package.json @@ -25,7 +25,8 @@ "@angular/router": "^17.3.0", "@tweenjs/tween.js": "^23.1.2", "@types/picomatch": "^2.3.3", - "angular-split": "^17.2.0", + "angular-split": "^17.1.1", + "component": "^1.1.0", "jsdom": "^24.0.0", "jsonc-parser": "^3.3.1", "jsrootdi": "^7.6.101", diff --git a/firebird-ng/src/app/app.routes.ts b/firebird-ng/src/app/app.routes.ts index 3c8acce..72603a6 100644 --- a/firebird-ng/src/app/app.routes.ts +++ b/firebird-ng/src/app/app.routes.ts @@ -16,4 +16,8 @@ export const routes: Routes = [ path: 'geometry', loadComponent: () => import('./pages/geometry-tree/geometry-tree.component').then(m => m.GeometryTreeComponent) }, + { + path: 'split-window', + loadComponent: () => import('./pages/split-window/split-window.component').then(m => m.SplitWindowComponent) + }, ]; diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html index 8c04cba..c9ee010 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html @@ -2,17 +2,13 @@ {{ windowOpenState ? 'close' : 'account_tree' }} -
-
- Geometry Tree +
- - -
+
+ + - + +
-
diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss index bc5a556..1abfa18 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss @@ -2,93 +2,96 @@ background-color: #2e2e2e; color: white; border-radius: 50%; - width: 48px; - height: 48px; + width: 40px; + height: 40px; display: flex; - justify-content: center; - align-items: center; + + transition: background-color 0.3s; position: fixed; - top: 150px; - right: 20px; + top: 10px; + left: 520px; &:hover { background-color: #95A5A5; } mat-icon { - font-size: 24px; + font-size: 18px; } } - - -.window { - position: absolute; - width: 400px; - height: 400px; - border: 1px solid #ccc; - background-color: #2e2e2e; - display: flex; - flex-direction: column; - border-radius: 8px; - overflow: hidden; - resize: both; - min-width: 200px; - min-height: 200px; - color: white; - overflow-y: auto; +.window-container { + width: 100%; + height: 100%; + //overflow: hidden; } +//.window { +// position: absolute; +// width: 400px; +// height: 400px; +// border: 1px solid #ccc; +// background-color: #2e2e2e; +// display: flex; +// flex-direction: column; +// border-radius: 8px; +// overflow: hidden; +// resize: both; +// min-width: 200px; +// min-height: 200px; +// color: white; +// overflow-y: auto; +//} + .window-header { background-color: #3e3e3e; - padding: 8px; - cursor: move; - display: flex; + //cursor: move; + //display: flex; justify-content: space-between; align-items: center; } -.resize-handle { - width: 16px; - height: 16px; - position: absolute; - bottom: 0; - right: 0; - cursor: se-resize; -} +//.resize-handle { +// width: 16px; +// height: 16px; +// position: absolute; +// bottom: 0; +// right: 0; +// cursor: se-resize; +//} -.window { - position: absolute; - border: 1px solid #2e2e2e; - transition: width 0.3s ease; - - &.side-nav { - left: 0; - top: 0; - height: 100%; - width: 250px; - max-width: 250px; - } - - .window-header { - - padding: 8px; - display: flex; - justify-content: space-between; - align-items: center; - cursor: move; - } - - .side-nav-button { - margin-left: auto; - } - - .resize-handle { - width: 10px; - height: 10px; - position: absolute; - bottom: 0; - right: 0; - cursor: nwse-resize; - } -} +//.window { +// position: absolute; +// border: 1px solid #2e2e2e; +// transition: width 0.3s ease; +// +// &.side-nav { +// left: 0; +// top: 0; +// height: 100%; +// width: 250px; +// max-width: 250px; +// } +// +// .window-header { +// +// padding: 8px; +// display: flex; +// justify-content: space-between; +// align-items: center; +// cursor: move; +// } +// +// .side-nav-button { +// margin-left: auto; +// } +// +// .resize-handle { +// width: 10px; +// height: 10px; +// position: absolute; +// bottom: 0; +// right: 0; +// cursor: nwse-resize; +// } +//} diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts index e6c29db..adfe20c 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts @@ -18,141 +18,120 @@ import {NgIf} from "@angular/common"; }) export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { windowOpenState = false; - sideNavOpen = false; @ViewChild('windowContainer', { static: false }) windowContainer!: ElementRef; - @ViewChild('windowHeader', { static: false }) windowHeader!: ElementRef; - @ViewChild('resizeHandle', { static: false }) resizeHandle!: ElementRef; - private isDragging = false; - private isResizing = false; - private lastX = 0; - private lastY = 0; - - private dragMouseMoveHandler: any; - private dragMouseUpHandler: any; - private resizeMouseMoveHandler: any; - private resizeMouseUpHandler: any; ngAfterViewInit() { - if (this.windowOpenState) { - this.initDrag(); - this.initResize(); - } + // if (this.windowOpenState) { + // this.initDrag(); + // this.initResize(); + // } } ngOnDestroy() { - this.removeDragListeners(); - this.removeResizeListeners(); + // this.removeDragListeners(); + // this.removeResizeListeners(); } toggleWindow() { this.windowOpenState = !this.windowOpenState; - if (this.windowOpenState) { - setTimeout(() => { - this.initDrag(); - this.initResize(); - }); - } else { - this.removeDragListeners(); - this.removeResizeListeners(); - } - } - - initDrag() { - if (!this.windowContainer) return; - - const windowElement = this.windowContainer.nativeElement; - - windowElement.addEventListener('mousedown', (e: MouseEvent) => { - if ((e.target).classList.contains('window-header')) { - this.isDragging = true; - this.lastX = e.clientX; - this.lastY = e.clientY; - e.preventDefault(); - } - }); - - this.dragMouseMoveHandler = (e: MouseEvent) => { - if (this.isDragging) { - const dx = e.clientX - this.lastX; - const dy = e.clientY - this.lastY; - - const rect = windowElement.getBoundingClientRect(); - windowElement.style.left = rect.left + dx + 'px'; - windowElement.style.top = rect.top + dy + 'px'; - - this.lastX = e.clientX; - this.lastY = e.clientY; - } - }; - - this.dragMouseUpHandler = () => { - this.isDragging = false; - }; - - document.addEventListener('mousemove', this.dragMouseMoveHandler); - document.addEventListener('mouseup', this.dragMouseUpHandler); + // if (this.windowOpenState) { + // setTimeout(() => { + // this.initDrag(); + // this.initResize(); + // }); + // } else { + // this.removeDragListeners(); + // this.removeResizeListeners(); + // } } - initResize() { - if (!this.resizeHandle || !this.windowContainer) return; - - const resizeHandle = this.resizeHandle.nativeElement; - const windowElement = this.windowContainer.nativeElement; - - resizeHandle.addEventListener('mousedown', (e: MouseEvent) => { - this.isResizing = true; - this.lastX = e.clientX; - this.lastY = e.clientY; - e.preventDefault(); - }); + // initDrag() { + // if (!this.windowContainer) return; + // + // const windowElement = this.windowContainer.nativeElement; + // + // windowElement.addEventListener('mousedown', (e: MouseEvent) => { + // if ((e.target).classList.contains('window-header')) { + // this.isDragging = true; + // this.lastX = e.clientX; + // this.lastY = e.clientY; + // e.preventDefault(); + // } + // }); + // + // this.dragMouseMoveHandler = (e: MouseEvent) => { + // if (this.isDragging) { + // const dx = e.clientX - this.lastX; + // const dy = e.clientY - this.lastY; + // + // const rect = windowElement.getBoundingClientRect(); + // windowElement.style.left = rect.left + dx + 'px'; + // windowElement.style.top = rect.top + dy + 'px'; + // + // this.lastX = e.clientX; + // this.lastY = e.clientY; + // } + // }; + // + // this.dragMouseUpHandler = () => { + // this.isDragging = false; + // }; + // + // document.addEventListener('mousemove', this.dragMouseMoveHandler); + // document.addEventListener('mouseup', this.dragMouseUpHandler); + // } + // + // initResize() { + // if (!this.resizeHandle || !this.windowContainer) return; + // + // const resizeHandle = this.resizeHandle.nativeElement; + // const windowElement = this.windowContainer.nativeElement; + // + // resizeHandle.addEventListener('mousedown', (e: MouseEvent) => { + // this.isResizing = true; + // this.lastX = e.clientX; + // this.lastY = e.clientY; + // e.preventDefault(); + // }); + // + // this.resizeMouseMoveHandler = (e: MouseEvent) => { + // if (this.isResizing) { + // const dx = e.clientX - this.lastX; + // const dy = e.clientY - this.lastY; + // + // windowElement.style.width = windowElement.offsetWidth + dx + 'px'; + // windowElement.style.height = windowElement.offsetHeight + dy + 'px'; + // + // this.lastX = e.clientX; + // this.lastY = e.clientY; + // } + // }; + // + // this.resizeMouseUpHandler = () => { + // this.isResizing = false; + // }; + // + // document.addEventListener('mousemove', this.resizeMouseMoveHandler); + // document.addEventListener('mouseup', this.resizeMouseUpHandler); + // } + // + // removeDragListeners() { + // if (this.dragMouseMoveHandler && this.dragMouseUpHandler) { + // document.removeEventListener('mousemove', this.dragMouseMoveHandler); + // document.removeEventListener('mouseup', this.dragMouseUpHandler); + // } + // } + // + // removeResizeListeners() { + // if (this.resizeMouseMoveHandler && this.resizeMouseUpHandler) { + // document.removeEventListener('mousemove', this.resizeMouseMoveHandler); + // document.removeEventListener('mouseup', this.resizeMouseUpHandler); + // } + // } - this.resizeMouseMoveHandler = (e: MouseEvent) => { - if (this.isResizing) { - const dx = e.clientX - this.lastX; - const dy = e.clientY - this.lastY; - windowElement.style.width = windowElement.offsetWidth + dx + 'px'; - windowElement.style.height = windowElement.offsetHeight + dy + 'px'; - - this.lastX = e.clientX; - this.lastY = e.clientY; - } - }; - - this.resizeMouseUpHandler = () => { - this.isResizing = false; - }; - - document.addEventListener('mousemove', this.resizeMouseMoveHandler); - document.addEventListener('mouseup', this.resizeMouseUpHandler); - } - - removeDragListeners() { - if (this.dragMouseMoveHandler && this.dragMouseUpHandler) { - document.removeEventListener('mousemove', this.dragMouseMoveHandler); - document.removeEventListener('mouseup', this.dragMouseUpHandler); - } - } - - removeResizeListeners() { - if (this.resizeMouseMoveHandler && this.resizeMouseUpHandler) { - document.removeEventListener('mousemove', this.resizeMouseMoveHandler); - document.removeEventListener('mouseup', this.resizeMouseUpHandler); - } - } - - toggleSideNav() { - this.sideNavOpen = !this.sideNavOpen; - - if (this.sideNavOpen) { - this.windowContainer.nativeElement.style.left = '0px'; - this.windowContainer.nativeElement.style.width = '400px'; - } else { - this.windowContainer.nativeElement.style.width = ''; - } - } } diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.html b/firebird-ng/src/app/pages/main-display/main-display.component.html index 5ebf5a9..fbaf661 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.html +++ b/firebird-ng/src/app/pages/main-display/main-display.component.html @@ -1,127 +1,164 @@ - - - - - - - - - - - - - - +
+ - - - + + - - + + +
+ +
+
- + + +
+
- +
+
- - - - + + + - - + + + + + + + + + + + +
+ +
+ + - - + + + - - + + - - + - - + - - + + - - + + - - + + - - + + - - + + - - + + + + -
+ + -
+ + + + + + - - - - - + + + + -
{{currentTime | number:'1.1-1'}}
- - - -
{{maxTime | number:'1.0-0'}} [ns]   
- - - - + - - - -
{{message}}
-    - - +
-
{{currentGeometry}}
+ + +
-
- + + + + + + + +
{{currentTime | number:'1.1-1'}}
+ + + +
{{maxTime | number:'1.0-0'}} [ns]   
+ + + + + + + + + +
{{message}}
+    + + -
+ +
{{currentGeometry}}
+ + +
+ + +
+ + + + +
diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.scss b/firebird-ng/src/app/pages/main-display/main-display.component.scss index 50e0419..b6d3fb3 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.scss +++ b/firebird-ng/src/app/pages/main-display/main-display.component.scss @@ -6,4 +6,3 @@ padding-right: 0; } - diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.ts b/firebird-ng/src/app/pages/main-display/main-display.component.ts index 4876378..0bfa4b2 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.ts +++ b/firebird-ng/src/app/pages/main-display/main-display.component.ts @@ -1,6 +1,7 @@ import {Component, Input, OnInit} from '@angular/core'; import {HttpClient, HttpClientModule} from '@angular/common/http'; + import { EventDataFormat, EventDataImportOption, @@ -43,6 +44,7 @@ import {MatFormField} from "@angular/material/form-field"; import {MatOption, MatSelect} from "@angular/material/select"; import {GeometryTreeWindowComponent} from "../geometry-tree/geometry-tree-window/geometry-tree-window.component"; import {DataModelService} from "../../services/data-model.service"; +import {AngularSplitModule} from "angular-split"; // import { LineMaterial } from 'three/addons/lines/LineMaterial.js'; @@ -51,7 +53,7 @@ import {DataModelService} from "../../services/data-model.service"; @Component({ selector: 'app-test-experiment', templateUrl: './main-display.component.html', - imports: [PhoenixUIModule, IoOptionsComponent, MatSlider, MatIcon, MatButton, MatSliderThumb, DecimalPipe, MatTooltip, MatFormField, MatSelect, MatOption, NgForOf, GeometryTreeWindowComponent], + imports: [PhoenixUIModule, IoOptionsComponent, MatSlider, MatIcon, MatButton, MatSliderThumb, DecimalPipe, MatTooltip, MatFormField, MatSelect, MatOption, NgForOf, GeometryTreeWindowComponent, AngularSplitModule], standalone: true, styleUrls: ['./main-display.component.scss'] }) @@ -496,16 +498,16 @@ export class MainDisplayComponent implements OnInit { // // GUI // const globalPlane = new THREE.Plane( new THREE.Vector3( - 1, 0, 0 ), 0.1 ); // - const gui = new GUI({ - container: document.getElementById("lil-gui-place") ?? undefined, - }); - - gui.title("Dev Controls"); - gui.add(this, "produceRenderOrder"); - gui.add(this, "logGamepadStates").name( 'Log controls' ); - gui.add(this, "logCamera").name( 'Log camera' ); - gui.add(this, "updateProjectionMatrix").name( 'Try to screw up the camera =)' ); - gui.close(); + // const gui = new GUI({ + // container: document.getElementById("lil-gui-place") ?? undefined, + // }); + + // gui.title("Dev Controls"); + // gui.add(this, "produceRenderOrder"); + // gui.add(this, "logGamepadStates").name( 'Log controls' ); + // gui.add(this, "logCamera").name( 'Log camera' ); + // gui.add(this, "updateProjectionMatrix").name( 'Try to screw up the camera =)' ); + // gui.close(); // Set default clipping this.eventDisplay.getUIManager().setClipping(true); diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.html b/firebird-ng/src/app/pages/split-window/split-window.component.html new file mode 100644 index 0000000..5036092 --- /dev/null +++ b/firebird-ng/src/app/pages/split-window/split-window.component.html @@ -0,0 +1 @@ +

split-window works!

diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.scss b/firebird-ng/src/app/pages/split-window/split-window.component.scss new file mode 100644 index 0000000..e69de29 diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.spec.ts b/firebird-ng/src/app/pages/split-window/split-window.component.spec.ts new file mode 100644 index 0000000..5f05a1a --- /dev/null +++ b/firebird-ng/src/app/pages/split-window/split-window.component.spec.ts @@ -0,0 +1,23 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; + +import { SplitWindowComponent } from './split-window.component'; + +describe('SplitWindowComponent', () => { + let component: SplitWindowComponent; + let fixture: ComponentFixture; + + beforeEach(async () => { + await TestBed.configureTestingModule({ + imports: [SplitWindowComponent] + }) + .compileComponents(); + + fixture = TestBed.createComponent(SplitWindowComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.ts b/firebird-ng/src/app/pages/split-window/split-window.component.ts new file mode 100644 index 0000000..1ce1154 --- /dev/null +++ b/firebird-ng/src/app/pages/split-window/split-window.component.ts @@ -0,0 +1,58 @@ +import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core' +// import { AComponent } from '../../ui/components/AComponent' +// import { SplitAreaSize, SplitGutterInteractionEvent } from 'angular-split' + +// interface IConfig { +// columns: Array<{ +// visible: boolean +// size: SplitAreaSize +// rows: Array<{ +// visible: boolean +// size: SplitAreaSize +// type: string +// }> +// }> +// disabled: boolean +// } + +// const defaultConfig: IConfig = { +// columns: [ +// { +// visible: true, +// size: 25, +// rows: [ +// { visible: true, size: 25, type: 'A' }, +// { visible: true, size: 75, type: 'B' }, +// ], +// }, +// { +// visible: true, +// size: 50, +// rows: [ +// { visible: true, size: 60, type: 'doc' }, +// { visible: true, size: 40, type: 'C' }, +// ], +// }, +// { +// visible: true, +// size: 25, +// rows: [ +// { visible: true, size: 20, type: 'D' }, +// { visible: true, size: 30, type: 'E' }, +// { visible: true, size: 50, type: 'F' }, +// ], +// }, +// ], +// disabled: false, +// } + +@Component({ + selector: 'app-split-window', + standalone: true, + imports: [], + templateUrl: './split-window.component.html', + styleUrl: './split-window.component.scss' +}) +export class SplitWindowComponent { + +} diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..eb4dd3b --- /dev/null +++ b/package-lock.json @@ -0,0 +1,77 @@ +{ + "name": "firebird", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "dependencies": { + "angular-split": "^18.0.0-beta.1" + } + }, + "node_modules/@angular/common": { + "version": "18.2.6", + "resolved": "https://registry.npmjs.org/@angular/common/-/common-18.2.6.tgz", + "integrity": "sha512-89793ow+wrI1c7C6kyMbnweLNIZHzXthosxAEjipRZGBrqBYjvTtkE45Fl+5yBa3JO7bAhyGkUnEoyvWtZIAEA==", + "peer": true, + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "@angular/core": "18.2.6", + "rxjs": "^6.5.3 || ^7.4.0" + } + }, + "node_modules/@angular/core": { + "version": "18.2.6", + "resolved": "https://registry.npmjs.org/@angular/core/-/core-18.2.6.tgz", + "integrity": "sha512-PjFad2j4YBwLVTw+0Te8CJCa/tV0W8caTHG8aOjj3ObdL6ihGI+FKnwerLc9RVzDFd14BOO4C6/+LbOQAh3Ltw==", + "peer": true, + "dependencies": { + "tslib": "^2.3.0" + }, + "engines": { + "node": "^18.19.1 || ^20.11.1 || >=22.0.0" + }, + "peerDependencies": { + "rxjs": "^6.5.3 || ^7.4.0", + "zone.js": "~0.14.10" + } + }, + "node_modules/angular-split": { + "version": "18.0.0-beta.1", + "resolved": "https://registry.npmjs.org/angular-split/-/angular-split-18.0.0-beta.1.tgz", + "integrity": "sha512-g5QVRhESXNDh6kD6MiN2//Urd+N1sGt1MAGmkXCZgoDFPBHOZ87fY4tc/SokC4n2Nchtt1MJSTEekchtO+sjIg==", + "dependencies": { + "tslib": "^2.0.0" + }, + "peerDependencies": { + "@angular/common": ">=18.0.0", + "@angular/core": ">=18.0.0", + "rxjs": ">=7.0.0" + } + }, + "node_modules/rxjs": { + "version": "7.8.1", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz", + "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==", + "peer": true, + "dependencies": { + "tslib": "^2.1.0" + } + }, + "node_modules/tslib": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.7.0.tgz", + "integrity": "sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==" + }, + "node_modules/zone.js": { + "version": "0.14.10", + "resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.14.10.tgz", + "integrity": "sha512-YGAhaO7J5ywOXW6InXNlLmfU194F8lVgu7bRntUF3TiG8Y3nBK0x1UJJuHUP/e8IyihkjCYqhCScpSwnlaSRkQ==", + "peer": true + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..c7a8f68 --- /dev/null +++ b/package.json @@ -0,0 +1,5 @@ +{ + "dependencies": { + "angular-split": "^18.0.0-beta.1" + } +} From 255b28b8dab78498aaea3b1d6df2650413b6add4 Mon Sep 17 00:00:00 2001 From: "sqrd.max" Date: Thu, 3 Oct 2024 00:01:31 +0300 Subject: [PATCH 2/5] Fix ui. Flexbox integration --- .../geometry-tree-window.component.html | 14 +- .../geometry-tree-window.component.scss | 134 ++++----- .../geometry-tree-window.component.ts | 260 +++++++++++------- .../main-display/main-display.component.html | 218 +++++++-------- .../main-display/main-display.component.scss | 58 ++++ 5 files changed, 380 insertions(+), 304 deletions(-) diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html index c9ee010..272d8fc 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html @@ -2,13 +2,17 @@ {{ windowOpenState ? 'close' : 'account_tree' }} -
+
+
+ Geometry Tree -
+ - - -
+ + +
diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss index 1abfa18..fb13917 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss @@ -2,96 +2,84 @@ background-color: #2e2e2e; color: white; border-radius: 50%; - width: 40px; - height: 40px; + width: 48px; + height: 48px; display: flex; - - + justify-content: center; + align-items: center; transition: background-color 0.3s; position: fixed; - top: 10px; - left: 520px; + top: 150px; + right: 20px; &:hover { background-color: #95A5A5; } mat-icon { - font-size: 18px; + font-size: 24px; } } -.window-container { - width: 100%; - height: 100%; - //overflow: hidden; -} -//.window { -// position: absolute; -// width: 400px; -// height: 400px; -// border: 1px solid #ccc; -// background-color: #2e2e2e; -// display: flex; -// flex-direction: column; -// border-radius: 8px; -// overflow: hidden; -// resize: both; -// min-width: 200px; -// min-height: 200px; -// color: white; -// overflow-y: auto; -//} +.window { + position: absolute; + width: 400px; + height: 400px; + background-color: #2e2e2e; + display: flex; + flex-direction: column; + border-radius: 8px; + overflow: hidden; + resize: both; + min-width: 200px; + min-height: 200px; + color: white; + overflow-y: auto; + transition: width 0.3s ease, left 0.3s ease; + z-index: 1000; + + &.side-nav { + position: fixed; + left: 0; + top: 60px; + height: 100%; + width: 250px; + max-width: 250px; + z-index: 1100; + } + + &.shifted { + margin-left: 400px; + } +} .window-header { background-color: #3e3e3e; - //cursor: move; - //display: flex; + padding: 8px; + cursor: move; + display: flex; justify-content: space-between; align-items: center; } -//.resize-handle { -// width: 16px; -// height: 16px; -// position: absolute; -// bottom: 0; -// right: 0; -// cursor: se-resize; -//} +.resize-handle { + width: 16px; + height: 16px; + position: absolute; + bottom: 0; + right: 0; + cursor: se-resize; +} + +.side-nav-button { + margin-left: auto; +} -//.window { -// position: absolute; -// border: 1px solid #2e2e2e; -// transition: width 0.3s ease; -// -// &.side-nav { -// left: 0; -// top: 0; -// height: 100%; -// width: 250px; -// max-width: 250px; -// } -// -// .window-header { -// -// padding: 8px; -// display: flex; -// justify-content: space-between; -// align-items: center; -// cursor: move; -// } -// -// .side-nav-button { -// margin-left: auto; -// } -// -// .resize-handle { -// width: 10px; -// height: 10px; -// position: absolute; -// bottom: 0; -// right: 0; -// cursor: nwse-resize; -// } -//} +.resize-handle { + width: 10px; + height: 10px; + position: absolute; + bottom: 0; + right: 0; + cursor: nwse-resize; +} diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts index adfe20c..7cb0878 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts @@ -1,8 +1,8 @@ -import { Component, ElementRef, ViewChild, AfterViewInit, OnDestroy } from '@angular/core'; -import {MatIconButton} from "@angular/material/button"; -import {MatIcon} from "@angular/material/icon"; -import {GeometryTreeComponent} from "../geometry-tree.component"; -import {NgIf} from "@angular/common"; +import { Component, ElementRef, ViewChild, AfterViewInit, OnDestroy, Renderer2 } from '@angular/core'; +import { MatIconButton } from "@angular/material/button"; +import { MatIcon } from "@angular/material/icon"; +import { GeometryTreeComponent } from "../geometry-tree.component"; +import { NgIf } from "@angular/common"; @Component({ selector: 'geometry-tree-window', @@ -18,120 +18,174 @@ import {NgIf} from "@angular/common"; }) export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { windowOpenState = false; + sideNavOpen = true; + isDetached = true; @ViewChild('windowContainer', { static: false }) windowContainer!: ElementRef; + @ViewChild('windowHeader', { static: false }) windowHeader!: ElementRef; + @ViewChild('resizeHandle', { static: false }) resizeHandle!: ElementRef; + private isDragging = false; + private isResizing = false; + private lastX = 0; + private lastY = 0; + + private dragMouseMoveHandler: any; + private dragMouseUpHandler: any; + private resizeMouseMoveHandler: any; + private resizeMouseUpHandler: any; + + constructor(private renderer: Renderer2) {} ngAfterViewInit() { - // if (this.windowOpenState) { - // this.initDrag(); - // this.initResize(); - // } + if (this.windowOpenState) { + this.initDrag(); + this.initResize(); + this.updateMainContentShift(); + } } ngOnDestroy() { - // this.removeDragListeners(); - // this.removeResizeListeners(); + this.removeDragListeners(); + this.removeResizeListeners(); } toggleWindow() { this.windowOpenState = !this.windowOpenState; + if (this.windowOpenState) { + setTimeout(() => { + this.initDrag(); + this.initResize(); + this.updateMainContentShift(); + }); + } else { + this.removeDragListeners(); + this.removeResizeListeners(); + this.updateMainContentShift(); + } + } + + toggleSideNav() { + this.isDetached = !this.isDetached; + + if (!this.isDetached) { + + this.sideNavOpen = true; + this.renderer.setStyle(this.windowContainer.nativeElement, 'left', '0px'); + this.renderer.setStyle(this.windowContainer.nativeElement, 'top', '60px'); + this.renderer.setStyle(this.windowContainer.nativeElement, 'position', 'fixed'); + this.renderer.setStyle(this.windowContainer.nativeElement, 'width', '300px'); + this.renderer.setStyle(this.windowContainer.nativeElement, 'height', '100vh'); + this.removeDragListeners(); + } else { + + this.sideNavOpen = false; + this.renderer.setStyle(this.windowContainer.nativeElement, 'position', 'absolute'); + this.renderer.setStyle(this.windowContainer.nativeElement, 'width', '400px'); + this.renderer.setStyle(this.windowContainer.nativeElement, 'height', '400px'); + this.initDrag(); + } + this.updateMainContentShift(); + } + + + + updateMainContentShift() { + const mainContentElement = document.getElementById('eventDisplay'); + if (mainContentElement) { + if (this.windowOpenState && !this.isDetached) { + this.renderer.addClass(mainContentElement, 'shifted'); + } else { + this.renderer.removeClass(mainContentElement, 'shifted'); + } + } + } + + initDrag() { + if (!this.windowContainer || !this.isDetached) return; + + const windowElement = this.windowContainer.nativeElement; - // if (this.windowOpenState) { - // setTimeout(() => { - // this.initDrag(); - // this.initResize(); - // }); - // } else { - // this.removeDragListeners(); - // this.removeResizeListeners(); - // } + windowElement.addEventListener('mousedown', (e: MouseEvent) => { + if ((e.target).classList.contains('window-header')) { + this.isDragging = true; + this.lastX = e.clientX; + this.lastY = e.clientY; + e.preventDefault(); + } + }); + + this.dragMouseMoveHandler = (e: MouseEvent) => { + if (this.isDragging) { + const dx = e.clientX - this.lastX; + const dy = e.clientY - this.lastY; + + const rect = windowElement.getBoundingClientRect(); + windowElement.style.left = rect.left + dx + 'px'; + windowElement.style.top = rect.top + dy + 'px'; + + this.lastX = e.clientX; + this.lastY = e.clientY; + } + }; + + this.dragMouseUpHandler = () => { + this.isDragging = false; + }; + + document.addEventListener('mousemove', this.dragMouseMoveHandler); + document.addEventListener('mouseup', this.dragMouseUpHandler); } - // initDrag() { - // if (!this.windowContainer) return; - // - // const windowElement = this.windowContainer.nativeElement; - // - // windowElement.addEventListener('mousedown', (e: MouseEvent) => { - // if ((e.target).classList.contains('window-header')) { - // this.isDragging = true; - // this.lastX = e.clientX; - // this.lastY = e.clientY; - // e.preventDefault(); - // } - // }); - // - // this.dragMouseMoveHandler = (e: MouseEvent) => { - // if (this.isDragging) { - // const dx = e.clientX - this.lastX; - // const dy = e.clientY - this.lastY; - // - // const rect = windowElement.getBoundingClientRect(); - // windowElement.style.left = rect.left + dx + 'px'; - // windowElement.style.top = rect.top + dy + 'px'; - // - // this.lastX = e.clientX; - // this.lastY = e.clientY; - // } - // }; - // - // this.dragMouseUpHandler = () => { - // this.isDragging = false; - // }; - // - // document.addEventListener('mousemove', this.dragMouseMoveHandler); - // document.addEventListener('mouseup', this.dragMouseUpHandler); - // } - // - // initResize() { - // if (!this.resizeHandle || !this.windowContainer) return; - // - // const resizeHandle = this.resizeHandle.nativeElement; - // const windowElement = this.windowContainer.nativeElement; - // - // resizeHandle.addEventListener('mousedown', (e: MouseEvent) => { - // this.isResizing = true; - // this.lastX = e.clientX; - // this.lastY = e.clientY; - // e.preventDefault(); - // }); - // - // this.resizeMouseMoveHandler = (e: MouseEvent) => { - // if (this.isResizing) { - // const dx = e.clientX - this.lastX; - // const dy = e.clientY - this.lastY; - // - // windowElement.style.width = windowElement.offsetWidth + dx + 'px'; - // windowElement.style.height = windowElement.offsetHeight + dy + 'px'; - // - // this.lastX = e.clientX; - // this.lastY = e.clientY; - // } - // }; - // - // this.resizeMouseUpHandler = () => { - // this.isResizing = false; - // }; - // - // document.addEventListener('mousemove', this.resizeMouseMoveHandler); - // document.addEventListener('mouseup', this.resizeMouseUpHandler); - // } - // - // removeDragListeners() { - // if (this.dragMouseMoveHandler && this.dragMouseUpHandler) { - // document.removeEventListener('mousemove', this.dragMouseMoveHandler); - // document.removeEventListener('mouseup', this.dragMouseUpHandler); - // } - // } - // - // removeResizeListeners() { - // if (this.resizeMouseMoveHandler && this.resizeMouseUpHandler) { - // document.removeEventListener('mousemove', this.resizeMouseMoveHandler); - // document.removeEventListener('mouseup', this.resizeMouseUpHandler); - // } - // } + initResize() { + if (!this.resizeHandle || !this.windowContainer) return; + + const resizeHandle = this.resizeHandle.nativeElement; + const windowElement = this.windowContainer.nativeElement; + + resizeHandle.addEventListener('mousedown', (e: MouseEvent) => { + this.isResizing = true; + this.lastX = e.clientX; + this.lastY = e.clientY; + e.preventDefault(); + }); + this.resizeMouseMoveHandler = (e: MouseEvent) => { + if (this.isResizing) { + const dx = e.clientX - this.lastX; + const dy = e.clientY - this.lastY; + if (this.sideNavOpen) { + windowElement.style.width = windowElement.offsetWidth + dx + 'px'; + } else { + windowElement.style.width = windowElement.offsetWidth + dx + 'px'; + windowElement.style.height = windowElement.offsetHeight + dy + 'px'; + } + this.lastX = e.clientX; + this.lastY = e.clientY; + } + }; + + this.resizeMouseUpHandler = () => { + this.isResizing = false; + }; + + document.addEventListener('mousemove', this.resizeMouseMoveHandler); + document.addEventListener('mouseup', this.resizeMouseUpHandler); + } + + removeDragListeners() { + if (this.dragMouseMoveHandler && this.dragMouseUpHandler) { + document.removeEventListener('mousemove', this.dragMouseMoveHandler); + document.removeEventListener('mouseup', this.dragMouseUpHandler); + } + } + + removeResizeListeners() { + if (this.resizeMouseMoveHandler && this.resizeMouseUpHandler) { + document.removeEventListener('mousemove', this.resizeMouseMoveHandler); + document.removeEventListener('mouseup', this.resizeMouseUpHandler); + } + } } diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.html b/firebird-ng/src/app/pages/main-display/main-display.component.html index fbaf661..3bd0f3c 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.html +++ b/firebird-ng/src/app/pages/main-display/main-display.component.html @@ -1,164 +1,136 @@ -
- + + + + + + + +
- - + - - -
- -
-
+
+ + + + + + + - - -
-
+ + + - - + + + - - - + - - - - - - - - - - - -
- -
- - + + - - - + + - - + + - + + - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - + + - - - - +
- - +
+
- - - - +
- + + + + + -
+
{{currentTime | number:'1.1-1'}}
+ + + +
{{maxTime | number:'1.0-0'}} [ns]   
- + + + + - -
+ + + +
{{message}}
+    + - - - - - + +
{{currentGeometry}}
-
{{currentTime | number:'1.1-1'}}
- - - -
{{maxTime | number:'1.0-0'}} [ns]   
- - - - +
- - - -
{{message}}
-    - - - -
{{currentGeometry}}
- - -
- -
- - - -
diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.scss b/firebird-ng/src/app/pages/main-display/main-display.component.scss index b6d3fb3..94a0026 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.scss +++ b/firebird-ng/src/app/pages/main-display/main-display.component.scss @@ -6,3 +6,61 @@ padding-right: 0; } +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} +// +//html, body { +// height: 100%; +//} + +.container { + display: flex; + flex-direction: column; + width: 100%; + height: 100vh; +} + +.navbar { + background-color: #2e2e2e; + width: 250px; + height: 100vh; + position: fixed; + top: 60px; + left: 0; + display: flex; + flex-direction: column; + border-right: 2px solid black; + z-index: 10; +} + +.main { + width: 100%; + display: flex; + flex: 1; + margin-left: 250px; + background-color: white; +} + +.main-content { + flex: 1; + overflow: auto; +} + +.time-controls { + background-color: #424242; + padding: 2px; + display: flex; + gap: 3px; + align-items: center; + justify-content: center; + height: 50px; + position: fixed; + bottom: 0; + left: 0; + width: 100%; + +} + From 195cfeebf8a30a58ec64fe2cf93d16dde376cfda Mon Sep 17 00:00:00 2001 From: "sqrd.max" Date: Fri, 4 Oct 2024 01:14:48 +0300 Subject: [PATCH 3/5] Window resizing is working --- .../geometry-tree-window.component.ts | 4 +- .../main-display/main-display.component.html | 99 ++++++++++--------- .../main-display/main-display.component.scss | 94 ++++++++++++------ .../main-display/main-display.component.ts | 39 +++++++- .../split-window/split-window.component.html | 5 + .../split-window/split-window.component.scss | 40 ++++++++ .../split-window/split-window.component.ts | 40 +++++++- 7 files changed, 238 insertions(+), 83 deletions(-) diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts index 7cb0878..5defe6d 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts @@ -19,7 +19,7 @@ import { NgIf } from "@angular/common"; export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { windowOpenState = false; sideNavOpen = true; - isDetached = true; + isDetached = false; @ViewChild('windowContainer', { static: false }) windowContainer!: ElementRef; @ViewChild('windowHeader', { static: false }) windowHeader!: ElementRef; @@ -138,7 +138,7 @@ export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { } initResize() { - if (!this.resizeHandle || !this.windowContainer) return; + if (!this.resizeHandle || !this.windowContainer || !this.isDetached) return; const resizeHandle = this.resizeHandle.nativeElement; const windowElement = this.windowContainer.nativeElement; diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.html b/firebird-ng/src/app/pages/main-display/main-display.component.html index 3bd0f3c..a79c1db 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.html +++ b/firebird-ng/src/app/pages/main-display/main-display.component.html @@ -5,11 +5,15 @@ -
+
- + + +
-
+
@@ -71,66 +75,67 @@ -
-
- +
-
+
- - - - - + + + + + -
{{currentTime | number:'1.1-1'}}
- - - -
{{maxTime | number:'1.0-0'}} [ns]   
+
{{currentTime | number:'1.1-1'}}
+ + + +
{{maxTime | number:'1.0-0'}} [ns]   
- - - - + + + + - - - -
{{message}}
-    + + + +
{{message}}
+    - + - + -
{{currentGeometry}}
+
{{currentGeometry}}
+
+ +
diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.scss b/firebird-ng/src/app/pages/main-display/main-display.component.scss index 94a0026..0a1732c 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.scss +++ b/firebird-ng/src/app/pages/main-display/main-display.component.scss @@ -5,62 +5,94 @@ padding-left: 13px; padding-right: 0; } - +// * { margin: 0; padding: 0; box-sizing: border-box; } -// -//html, body { -// height: 100%; -//} -.container { +.wrapper { display: flex; - flex-direction: column; + + //flex-direction: column; width: 100%; height: 100vh; } -.navbar { +.sidebar { background-color: #2e2e2e; - width: 250px; - height: 100vh; - position: fixed; - top: 60px; + //width: 250px; + //height: 100vh; + //position: fixed; + //top: 60px; left: 0; - display: flex; - flex-direction: column; - border-right: 2px solid black; - z-index: 10; -} -.main { - width: 100%; - display: flex; - flex: 1; - margin-left: 250px; - background-color: white; -} + //border-right: 2px solid black; + //z-index: 10; -.main-content { - flex: 1; - overflow: auto; } - +//// +////.main { +//// //width: 100%; +//// //margin-left: 250px; +//// flex: 1 1 auto; +////} +// +////.main-content { +//// flex: 1; +////} +// .time-controls { + display: flex; background-color: #424242; padding: 2px; - display: flex; gap: 3px; align-items: center; justify-content: center; height: 50px; - position: fixed; bottom: 0; - left: 0; width: 100%; } +// +//.handler { +// width: 20px; +// padding: 0; +// cursor: ew-resize; +// flex: 0 0 auto; +//} +// +//.handler::before { +// content: ''; +// display: block; +// width: 4px; +// height: 100%; +// background: red; +// margin: 0 auto; +//} + + +.box { + /* Use box-sizing so that element's outerwidth will match width property */ + box-sizing: border-box; + + /* Allow box to grow and shrink, and ensure they are all equally sized */ + flex: 1 1 auto; +} +.handler { + width: 20px; + padding: 0; + cursor: ew-resize; + flex: 0 0 auto; +} + +.handler::before { + content: ''; + display: block; + width: 4px; + height: 100%; + background: red; + margin: 0 auto; +} diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.ts b/firebird-ng/src/app/pages/main-display/main-display.component.ts index 0bfa4b2..46dd99b 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.ts +++ b/firebird-ng/src/app/pages/main-display/main-display.component.ts @@ -1,4 +1,4 @@ -import {Component, Input, OnInit} from '@angular/core'; +import {Component, ElementRef, Input, OnInit, Renderer2} from '@angular/core'; import {HttpClient, HttpClientModule} from '@angular/common/http'; @@ -101,6 +101,8 @@ export class MainDisplayComponent implements OnInit { selectedEventKey: string|undefined; private beamAnimationTime: number = 1000; + private isHandlerDragging = false; + constructor( private geomService: GeometryService, @@ -109,11 +111,46 @@ export class MainDisplayComponent implements OnInit { private route: ActivatedRoute, private settings: UserConfigService, private dataService: DataModelService, + private elRef: ElementRef, private renderer2: Renderer2, private _snackBar: MatSnackBar) { this.threeFacade = new PhoenixThreeFacade(this.eventDisplay); } + ngAfterViewInit() { + const handler = this.elRef.nativeElement.querySelector('.handler'); + const wrapper = handler.closest('.wrapper'); + const boxA = wrapper.querySelector('.box'); + + this.renderer2.listen(handler, 'mousedown', (e: MouseEvent) => { + + this.isHandlerDragging = true; + }); + + this.renderer2.listen(document, 'mousemove', (e: MouseEvent) => { + if (!this.isHandlerDragging) { + return; + } + + + const containerOffsetLeft = wrapper.offsetLeft; + + + const pointerRelativeXpos = e.clientX - containerOffsetLeft; + + + const boxAminWidth = 60; + + + boxA.style.width = `${Math.max(boxAminWidth, pointerRelativeXpos - 8)}px`; + boxA.style.flexGrow = '0'; + }); + + this.renderer2.listen(document, 'mouseup', () => { + this.isHandlerDragging = false; + }); + } + logRendererInfo() { let renderer = this.threeFacade.mainRenderer; console.log('Draw calls:', renderer.info.render.calls); diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.html b/firebird-ng/src/app/pages/split-window/split-window.component.html index 5036092..00d32a0 100644 --- a/firebird-ng/src/app/pages/split-window/split-window.component.html +++ b/firebird-ng/src/app/pages/split-window/split-window.component.html @@ -1 +1,6 @@

split-window works!

+
+
A
+
+
B
+
diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.scss b/firebird-ng/src/app/pages/split-window/split-window.component.scss index e69de29..ecb1e1e 100644 --- a/firebird-ng/src/app/pages/split-window/split-window.component.scss +++ b/firebird-ng/src/app/pages/split-window/split-window.component.scss @@ -0,0 +1,40 @@ +body { + margin: 40px; +} + +.wrapper { + background-color: #fff; + color: #444; + /* Use flexbox */ + display: flex; +} + +.box { + background-color: #444; + color: #fff; + border-radius: 5px; + padding: 20px; + font-size: 150%; + + /* Use box-sizing so that element's outerwidth will match width property */ + box-sizing: border-box; + + /* Allow box to grow and shrink, and ensure they are all equally sized */ + flex: 1 1 auto; +} + +.handler { + width: 20px; + padding: 0; + cursor: ew-resize; + flex: 0 0 auto; +} + +.handler::before { + content: ''; + display: block; + width: 4px; + height: 100%; + background: red; + margin: 0 auto; +} diff --git a/firebird-ng/src/app/pages/split-window/split-window.component.ts b/firebird-ng/src/app/pages/split-window/split-window.component.ts index 1ce1154..9c73c6f 100644 --- a/firebird-ng/src/app/pages/split-window/split-window.component.ts +++ b/firebird-ng/src/app/pages/split-window/split-window.component.ts @@ -1,4 +1,4 @@ -import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core' +import {Component, OnInit, ChangeDetectionStrategy, AfterViewInit, ElementRef, Renderer2} from '@angular/core' // import { AComponent } from '../../ui/components/AComponent' // import { SplitAreaSize, SplitGutterInteractionEvent } from 'angular-split' @@ -53,6 +53,42 @@ import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core' templateUrl: './split-window.component.html', styleUrl: './split-window.component.scss' }) -export class SplitWindowComponent { +export class SplitWindowComponent implements AfterViewInit { + private isHandlerDragging = false; + constructor(private elRef: ElementRef, private renderer: Renderer2) {} + + ngAfterViewInit() { + const handler = this.elRef.nativeElement.querySelector('.handler'); + const wrapper = handler.closest('.container'); + const boxA = wrapper.querySelector('.box'); + + this.renderer.listen(handler, 'mousedown', (e: MouseEvent) => { + // Если событие mousedown произошло на элементе .handler, флаг переключается на true + this.isHandlerDragging = true; + }); + + this.renderer.listen(document, 'mousemove', (e: MouseEvent) => { + if (!this.isHandlerDragging) { + return; + } + + + const containerOffsetLeft = wrapper.offsetLeft; + + + const pointerRelativeXpos = e.clientX - containerOffsetLeft; + + + const boxAminWidth = 60; + + + boxA.style.width = `${Math.max(boxAminWidth, pointerRelativeXpos - 8)}px`; + boxA.style.flexGrow = '0'; + }); + + this.renderer.listen(document, 'mouseup', () => { + this.isHandlerDragging = false; + }); + } } From 85105a73bb71781080beda2ad7937d5e44b0e1bc Mon Sep 17 00:00:00 2001 From: "sqrd.max" Date: Fri, 4 Oct 2024 02:32:14 +0300 Subject: [PATCH 4/5] Try to make geometry tree as sidebar --- .../geometry-tree-window.component.html | 21 +++-- .../geometry-tree-window.component.scss | 70 +++++--------- .../geometry-tree-window.component.ts | 91 +++++++++---------- .../main-display/main-display.component.html | 2 +- .../main-display/main-display.component.ts | 3 +- 5 files changed, 81 insertions(+), 106 deletions(-) diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html index 272d8fc..4c936ba 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.html @@ -1,18 +1,21 @@ - + + + -
+
Geometry Tree - + + +
- + -
+
+ + + diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss index fb13917..f27094f 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.scss @@ -22,35 +22,33 @@ } .window { - position: absolute; + width: 400px; - height: 400px; + //height: 400px; background-color: #2e2e2e; - display: flex; - flex-direction: column; - border-radius: 8px; - overflow: hidden; - resize: both; - min-width: 200px; - min-height: 200px; - color: white; - overflow-y: auto; - transition: width 0.3s ease, left 0.3s ease; - z-index: 1000; - - &.side-nav { - position: fixed; - left: 0; - top: 60px; - height: 100%; - width: 250px; - max-width: 250px; - z-index: 1100; - } + //display: flex; + //flex-direction: column; + //border-radius: 8px; + //min-width: 200px; + //min-height: 200px; + //color: white; + //overflow-y: auto; + //transition: width 0.3s ease, left 0.3s ease; + //z-index: 1000; - &.shifted { - margin-left: 400px; - } + //&.side-nav { + // position: fixed; + // left: 0; + // top: 60px; + // height: 100%; + // width: 250px; + // max-width: 250px; + // z-index: 1100; + //} + // + //&.shifted { + // margin-left: 400px; + //} } .window-header { @@ -62,24 +60,6 @@ align-items: center; } -.resize-handle { - width: 16px; - height: 16px; - position: absolute; - bottom: 0; - right: 0; - cursor: se-resize; -} -.side-nav-button { - margin-left: auto; -} -.resize-handle { - width: 10px; - height: 10px; - position: absolute; - bottom: 0; - right: 0; - cursor: nwse-resize; -} + diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts index 5defe6d..710e466 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree-window/geometry-tree-window.component.ts @@ -17,7 +17,7 @@ import { NgIf } from "@angular/common"; standalone: true }) export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { - windowOpenState = false; + // windowOpenState = false; sideNavOpen = true; isDetached = false; @@ -38,11 +38,11 @@ export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { constructor(private renderer: Renderer2) {} ngAfterViewInit() { - if (this.windowOpenState) { - this.initDrag(); - this.initResize(); - this.updateMainContentShift(); - } + // if (this.windowOpenState) { + // this.initDrag(); + // this.initResize(); + // + // } } ngOnDestroy() { @@ -51,55 +51,46 @@ export class GeometryTreeWindowComponent implements AfterViewInit, OnDestroy { } toggleWindow() { - this.windowOpenState = !this.windowOpenState; - if (this.windowOpenState) { - setTimeout(() => { - this.initDrag(); - this.initResize(); - this.updateMainContentShift(); - }); - } else { - this.removeDragListeners(); - this.removeResizeListeners(); - this.updateMainContentShift(); - } + // this.windowOpenState = !this.windowOpenState; + // if (this.windowOpenState) { + // setTimeout(() => { + // this.initDrag(); + // this.initResize(); + // + // }); + // } else { + // this.removeDragListeners(); + // this.removeResizeListeners(); + // + // } } - toggleSideNav() { - this.isDetached = !this.isDetached; - - if (!this.isDetached) { - - this.sideNavOpen = true; - this.renderer.setStyle(this.windowContainer.nativeElement, 'left', '0px'); - this.renderer.setStyle(this.windowContainer.nativeElement, 'top', '60px'); - this.renderer.setStyle(this.windowContainer.nativeElement, 'position', 'fixed'); - this.renderer.setStyle(this.windowContainer.nativeElement, 'width', '300px'); - this.renderer.setStyle(this.windowContainer.nativeElement, 'height', '100vh'); - this.removeDragListeners(); - } else { - - this.sideNavOpen = false; - this.renderer.setStyle(this.windowContainer.nativeElement, 'position', 'absolute'); - this.renderer.setStyle(this.windowContainer.nativeElement, 'width', '400px'); - this.renderer.setStyle(this.windowContainer.nativeElement, 'height', '400px'); - this.initDrag(); - } - this.updateMainContentShift(); - } + // toggleSideNav() { + // this.isDetached = !this.isDetached; + // + // if (!this.isDetached) { + // + // this.sideNavOpen = true; + // this.renderer.setStyle(this.windowContainer.nativeElement, 'left', '0px'); + // this.renderer.setStyle(this.windowContainer.nativeElement, 'top', '60px'); + // this.renderer.setStyle(this.windowContainer.nativeElement, 'position', 'fixed'); + // this.renderer.setStyle(this.windowContainer.nativeElement, 'width', '300px'); + // this.renderer.setStyle(this.windowContainer.nativeElement, 'height', '100vh'); + // this.removeDragListeners(); + // } else { + // + // this.sideNavOpen = false; + // this.renderer.setStyle(this.windowContainer.nativeElement, 'position', 'absolute'); + // this.renderer.setStyle(this.windowContainer.nativeElement, 'width', '400px'); + // this.renderer.setStyle(this.windowContainer.nativeElement, 'height', '400px'); + // this.initDrag(); + // } + // this.updateMainContentShift(); + // } + - updateMainContentShift() { - const mainContentElement = document.getElementById('eventDisplay'); - if (mainContentElement) { - if (this.windowOpenState && !this.isDetached) { - this.renderer.addClass(mainContentElement, 'shifted'); - } else { - this.renderer.removeClass(mainContentElement, 'shifted'); - } - } - } initDrag() { if (!this.windowContainer || !this.isDetached) return; diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.html b/firebird-ng/src/app/pages/main-display/main-display.component.html index a79c1db..44586c2 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.html +++ b/firebird-ng/src/app/pages/main-display/main-display.component.html @@ -8,7 +8,7 @@
diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.ts b/firebird-ng/src/app/pages/main-display/main-display.component.ts index 46dd99b..ab2983b 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.ts +++ b/firebird-ng/src/app/pages/main-display/main-display.component.ts @@ -45,6 +45,7 @@ import {MatOption, MatSelect} from "@angular/material/select"; import {GeometryTreeWindowComponent} from "../geometry-tree/geometry-tree-window/geometry-tree-window.component"; import {DataModelService} from "../../services/data-model.service"; import {AngularSplitModule} from "angular-split"; +import {GeometryTreeComponent} from "../geometry-tree/geometry-tree.component"; // import { LineMaterial } from 'three/addons/lines/LineMaterial.js'; @@ -53,7 +54,7 @@ import {AngularSplitModule} from "angular-split"; @Component({ selector: 'app-test-experiment', templateUrl: './main-display.component.html', - imports: [PhoenixUIModule, IoOptionsComponent, MatSlider, MatIcon, MatButton, MatSliderThumb, DecimalPipe, MatTooltip, MatFormField, MatSelect, MatOption, NgForOf, GeometryTreeWindowComponent, AngularSplitModule], + imports: [PhoenixUIModule, IoOptionsComponent, MatSlider, MatIcon, MatButton, MatSliderThumb, DecimalPipe, MatTooltip, MatFormField, MatSelect, MatOption, NgForOf, GeometryTreeWindowComponent, AngularSplitModule, GeometryTreeComponent], standalone: true, styleUrls: ['./main-display.component.scss'] }) From bd93c4d84c721a39c5e669ee3b1e66df647b2db5 Mon Sep 17 00:00:00 2001 From: Dmitry Romanov Date: Fri, 4 Oct 2024 11:32:21 -0400 Subject: [PATCH 5/5] Update --- .../pages/geometry-tree/geometry-tree.component.html | 4 +++- .../pages/geometry-tree/geometry-tree.component.ts | 12 ++++++++++-- .../pages/main-display/main-display.component.html | 2 +- 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.html b/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.html index ae07d61..5e3e314 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.html +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.html @@ -1,4 +1,6 @@ -

geometry-tree works!

+ diff --git a/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.ts b/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.ts index 28ad2df..2437c09 100644 --- a/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.ts +++ b/firebird-ng/src/app/pages/geometry-tree/geometry-tree.component.ts @@ -11,11 +11,12 @@ import {NestedTreeControl, FlatTreeControl, } from '@angular/cdk/tree'; import {MatTreeFlatDataSource, MatTreeFlattener} from '@angular/material/tree'; import {MatIcon, MatIconModule} from '@angular/material/icon'; -import {MatButtonModule, MatIconButton} from '@angular/material/button'; +import {MatButton, MatButtonModule, MatIconButton} from '@angular/material/button'; import {GeometryService} from "../../services/geometry.service"; import {Object3D} from "three"; import {EventDisplayService} from "phoenix-ui-components"; import {PhoenixThreeFacade} from "../../utils/phoenix-three-facade"; +import {MatTooltip} from "@angular/material/tooltip"; /** * Food data with nested structure. @@ -68,7 +69,9 @@ interface ExampleFlatNode { MatTreeNodeDef, MatIcon, MatTreeNodeOutlet, - MatTreeNodePadding + MatTreeNodePadding, + MatButton, + MatTooltip ], templateUrl: './geometry-tree.component.html', styleUrl: './geometry-tree.component.scss' @@ -135,4 +138,9 @@ export class GeometryTreeComponent implements OnInit{ this.geomService.toggleVisibility(node.object3D); node.visible = !node.visible; } + + refreshGeometry() { + this.dataSource.data = []; + this.dataSource.data = this.threeFacade.scene.children; + } } diff --git a/firebird-ng/src/app/pages/main-display/main-display.component.html b/firebird-ng/src/app/pages/main-display/main-display.component.html index 44586c2..ee6ce0e 100644 --- a/firebird-ng/src/app/pages/main-display/main-display.component.html +++ b/firebird-ng/src/app/pages/main-display/main-display.component.html @@ -8,7 +8,7 @@