├── python-flask-server ├── README.md ├── src │ ├── server │ │ ├── __init__.py │ │ ├── api.py │ │ ├── app.py │ │ └── cli.py │ └── x_x │ │ ├── splashes │ │ ├── frog.txt │ │ └── sword.txt │ │ └── __init__.py ├── pyproject.toml ├── .gitignore ├── tests │ └── server │ │ └── flask_test.py ├── setup.cfg ├── LICENSE └── UNLICENSE ├── .gitignore ├── worm-food ├── .gitignore ├── .babelrc ├── app │ ├── favicon.ico │ ├── style.css │ ├── index.html │ └── dat.gui.min.js ├── webpack.config.js ├── src │ ├── Bas3d.js │ ├── objs │ │ └── WeirdRing.js │ └── index.js └── package.json ├── python-lib ├── pyproject.toml ├── README.md ├── src │ └── x_x │ │ ├── cli.py │ │ ├── splashes │ │ ├── cat.txt │ │ ├── tails.txt │ │ └── sword.txt │ │ └── __init__.py ├── tests │ └── x_x │ │ ├── cli_test.py │ │ └── x_x_test.py ├── setup.cfg ├── LICENSE └── UNLICENSE └── python-sanic-server ├── pyproject.toml ├── README.md ├── src ├── x_x │ ├── cli.py │ ├── splashes │ │ ├── cat.txt │ │ ├── tails.txt │ │ └── sword.txt │ └── __init__.py └── server │ ├── cli.py │ ├── static │ └── index.html │ └── app.py ├── tests ├── server │ └── server_test.py └── x_x │ └── x_x_test.py ├── setup.cfg ├── LICENSE └── UNLICENSE /python-flask-server/README.md: -------------------------------------------------------------------------------- 1 | :hocho: 2 | -------------------------------------------------------------------------------- /python-flask-server/src/server/__init__.py: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | *.egg-info 2 | *.swp 3 | .DS_Store 4 | __pycache__ 5 | -------------------------------------------------------------------------------- /worm-food/.gitignore: -------------------------------------------------------------------------------- 1 | *.swp 2 | .DS_Store 3 | node_modules/ 4 | dist/ 5 | dist-zipped/ 6 | yarn.lock 7 | -------------------------------------------------------------------------------- /worm-food/.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": [ 3 | [ 4 | "@babel/preset-env" 5 | ] 6 | ] 7 | } 8 | -------------------------------------------------------------------------------- /worm-food/app/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/whatever/templates/main/worm-food/app/favicon.ico -------------------------------------------------------------------------------- /python-lib/pyproject.toml: -------------------------------------------------------------------------------- 1 | [build-system] 2 | requires = ["setuptools"] 3 | build-backend = "setuptools.build_meta" 4 | -------------------------------------------------------------------------------- /python-flask-server/pyproject.toml: -------------------------------------------------------------------------------- 1 | [build-system] 2 | requires = ["setuptools"] 3 | build-backend = "setuptools.build_meta" 4 | -------------------------------------------------------------------------------- /python-sanic-server/pyproject.toml: -------------------------------------------------------------------------------- 1 | [build-system] 2 | requires = ["setuptools"] 3 | build-backend = "setuptools.build_meta" 4 | -------------------------------------------------------------------------------- /python-flask-server/.gitignore: -------------------------------------------------------------------------------- 1 | *.bak 2 | *.db 3 | *.egg-info 4 | *.sqlite 5 | *.swp 6 | .DS_Store 7 | __pycache__ 8 | node_modules 9 | -------------------------------------------------------------------------------- /python-flask-server/src/server/api.py: -------------------------------------------------------------------------------- 1 | import flask 2 | 3 | 4 | def blueprint(): 5 | """Register basic api routes""" 6 | 7 | blueprint = flask.Blueprint("api", __name__) 8 | 9 | @blueprint.route("/api/1/") 10 | def index(): 11 | return {"status":" ok"}, 200 12 | 13 | return blueprint 14 | -------------------------------------------------------------------------------- /worm-food/app/style.css: -------------------------------------------------------------------------------- 1 | html, body { 2 | margin: 0; 3 | padding: 0; 4 | height: 100%; 5 | width: 100%; 6 | } 7 | 8 | body { 9 | background-color: black; 10 | } 11 | 12 | .app { 13 | width: 100%; 14 | height: 100%; 15 | margin: 0; 16 | padding: 0; 17 | position: fixed; 18 | top: 0; 19 | left: 0; 20 | z-index: -666; 21 | } 22 | -------------------------------------------------------------------------------- /python-lib/README.md: -------------------------------------------------------------------------------- 1 | # :cake: 2 | 3 | Not-really opinionated python project template 4 | 5 | 6 | ## Install 7 | 8 | ```bash 9 | pip3 intall -e . 10 | pip3 install -e ".[dev]" 11 | ``` 12 | 13 | 14 | ## Test 15 | 16 | WIP: Should this be tox nowadays? 17 | 18 | ```bash 19 | pytest 20 | ``` 21 | 22 | 23 | ## Lint 24 | 25 | WIP: What should this be? 26 | 27 | ```bash 28 | flake8 src 29 | ``` 30 | -------------------------------------------------------------------------------- /python-flask-server/src/x_x/splashes/frog.txt: -------------------------------------------------------------------------------- 1 | .--._.--. 2 | ( O O ) 3 | / . . \ 4 | .`._______.'. 5 | /( )\ 6 | _/ \ \ / / \_ 7 | .~ ` \ \ / / ' ~. 8 | { -. \ V / .- } 9 | _ _`. \ | | | / .'_ _ 10 | >_ _} | | | {_ _< 11 | /. - ~ ,_-' .^. `-_, ~ - .\ 12 | '-'|/ \|`-` 13 | -------------------------------------------------------------------------------- /python-lib/src/x_x/cli.py: -------------------------------------------------------------------------------- 1 | import argparse 2 | 3 | 4 | from x_x import splash, x_x 5 | 6 | 7 | def main(): 8 | """CLI stub""" 9 | 10 | parser = argparse.ArgumentParser() 11 | parser.add_argument("--splash", action="store_true", help="show splash screen") 12 | args = parser.parse_args() 13 | 14 | if args.splash: 15 | print(splash("sword")) 16 | else: 17 | print(x_x()) 18 | -------------------------------------------------------------------------------- /python-sanic-server/README.md: -------------------------------------------------------------------------------- 1 | # :cake: 2 | 3 | Not-really opinionated python project template 4 | 5 | 6 | ## Install 7 | 8 | ```bash 9 | pip3 intall -e . 10 | pip3 install -e ".[dev]" 11 | ``` 12 | 13 | 14 | ## Test 15 | 16 | WIP: Should this be tox nowadays? 17 | 18 | ```bash 19 | pytest 20 | ``` 21 | 22 | 23 | ## Lint 24 | 25 | WIP: What should this be? 26 | 27 | ```bash 28 | flake8 src 29 | ``` 30 | -------------------------------------------------------------------------------- /python-sanic-server/src/x_x/cli.py: -------------------------------------------------------------------------------- 1 | import argparse 2 | 3 | 4 | from x_x import splash, x_x 5 | 6 | 7 | def main(): 8 | """CLI stub""" 9 | 10 | parser = argparse.ArgumentParser() 11 | parser.add_argument("--splash", action="store_true", help="show splash screen") 12 | args = parser.parse_args() 13 | 14 | if args.splash: 15 | print(splash("sword")) 16 | else: 17 | print(x_x()) 18 | -------------------------------------------------------------------------------- /python-lib/tests/x_x/cli_test.py: -------------------------------------------------------------------------------- 1 | import unittest 2 | 3 | from x_x.cli import ( 4 | main, 5 | splash, 6 | ) 7 | 8 | 9 | class TestCLI(unittest.TestCase): 10 | """Test that the CLI tool still works""" 11 | 12 | def test_splash(self): 13 | """Test whether the splash screen returns""" 14 | 15 | self.assertTrue(splash("sword")) 16 | 17 | def test_main(self): 18 | """Test whether the main function runs""" 19 | 20 | main() 21 | -------------------------------------------------------------------------------- /python-flask-server/tests/server/flask_test.py: -------------------------------------------------------------------------------- 1 | import unittest 2 | 3 | 4 | from server.app import get_app 5 | 6 | 7 | class TestFlaskServer(unittest.TestCase): 8 | def test_can_init(self): 9 | """Test whether we can initialize the flask app and hit some pre-defined routes""" 10 | 11 | app = get_app() 12 | 13 | with app.test_client() as c: 14 | response = c.get("/api/1/") 15 | self.assertEqual(response.status_code, 200) 16 | -------------------------------------------------------------------------------- /python-sanic-server/tests/server/server_test.py: -------------------------------------------------------------------------------- 1 | import pytest 2 | from sanic import request, response 3 | import unittest 4 | 5 | from server.app import get_app 6 | from sanic_testing.testing import SanicTestClient 7 | 8 | 9 | # XXX: Is this necessay? 10 | @pytest.fixture 11 | def app(): 12 | return get_app(0) 13 | 14 | 15 | class TestServer(unittest.TestCase): 16 | def test_server(self): 17 | app = get_app(0) 18 | client = SanicTestClient(app) 19 | request, response = app.test_client.get("/static/index.html") 20 | self.assertEqual(200, response.status) 21 | -------------------------------------------------------------------------------- /python-lib/tests/x_x/x_x_test.py: -------------------------------------------------------------------------------- 1 | import unittest 2 | 3 | 4 | from x_x import x_x 5 | 6 | 7 | class TestX_X(unittest.TestCase): 8 | """Test x_x""" 9 | 10 | def test_x_x_structure(self): 11 | """Test whether x_x() is structured correctly.""" 12 | 13 | for i in range(1000): 14 | smiley = x_x() 15 | self.assertEqual(len(smiley), 3) 16 | self.assertEqual(smiley[1], "_") 17 | self.assertIn(smiley[0], "xXOo0Uu@*^-") 18 | self.assertIn(smiley[2], "xXOo0Uu@*^-") 19 | 20 | 21 | if __name__ == "__main__": 22 | unittest.main() 23 | -------------------------------------------------------------------------------- /python-sanic-server/tests/x_x/x_x_test.py: -------------------------------------------------------------------------------- 1 | import unittest 2 | 3 | 4 | from x_x import x_x 5 | 6 | 7 | class TestX_X(unittest.TestCase): 8 | """Test x_x""" 9 | 10 | def test_x_x_structure(self): 11 | """Test whether x_x() is structured correctly.""" 12 | 13 | for i in range(1000): 14 | smiley = x_x() 15 | self.assertEqual(len(smiley), 3) 16 | self.assertEqual(smiley[1], "_") 17 | self.assertIn(smiley[0], "xXOo0Uu@*^-") 18 | self.assertIn(smiley[2], "xXOo0Uu@*^-") 19 | 20 | 21 | if __name__ == "__main__": 22 | unittest.main() 23 | -------------------------------------------------------------------------------- /python-lib/src/x_x/splashes/cat.txt: -------------------------------------------------------------------------------- 1 | 2 | .__....._ _.....__, 3 | .": o :': ;': o :". 4 | `. `-' .'. .'. `-' .' 5 | `---' `---' 6 | 7 | _...----... ... ... ...----..._ 8 | .-'__..-""'---- `. `"` .' ----'""-..__`-. 9 | '.-' _.--"""' `-._.-' '"""--._ `-.` 10 | ' .-"' : `"-. ` 11 | ' `. _.'"'._ .' ` 12 | `. ,.-'" "'-., .' 13 | `. .' 14 | `-._ _.-' 15 | `"'--...___...--'"` 16 | -------------------------------------------------------------------------------- /python-sanic-server/src/x_x/splashes/cat.txt: -------------------------------------------------------------------------------- 1 | 2 | .__....._ _.....__, 3 | .": o :': ;': o :". 4 | `. `-' .'. .'. `-' .' 5 | `---' `---' 6 | 7 | _...----... ... ... ...----..._ 8 | .-'__..-""'---- `. `"` .' ----'""-..__`-. 9 | '.-' _.--"""' `-._.-' '"""--._ `-.` 10 | ' .-"' : `"-. ` 11 | ' `. _.'"'._ .' ` 12 | `. ,.-'" "'-., .' 13 | `. .' 14 | `-._ _.-' 15 | `"'--...___...--'"` 16 | -------------------------------------------------------------------------------- /python-lib/src/x_x/__init__.py: -------------------------------------------------------------------------------- 1 | import os.path 2 | import random 3 | 4 | 5 | EYES = [ 6 | "x", 7 | "X", 8 | "O", 9 | "o", 10 | "0", 11 | "U", 12 | "u", 13 | "@", 14 | "*", 15 | "^", 16 | "-", 17 | ] 18 | 19 | 20 | def x_x(): 21 | """Return a random face with an eye.""" 22 | return random.choice(EYES) + "_" + random.choice(EYES) 23 | 24 | 25 | def splash(choice: str) -> str: 26 | """Return a splash screen""" 27 | 28 | fname = os.path.join( 29 | os.path.dirname(__file__), 30 | "splashes", 31 | f"{choice}.txt", 32 | ) 33 | 34 | with open(fname, "r") as fi: 35 | return fi.read() 36 | -------------------------------------------------------------------------------- /python-flask-server/src/x_x/__init__.py: -------------------------------------------------------------------------------- 1 | import os.path 2 | import random 3 | 4 | 5 | EYES = [ 6 | "x", 7 | "X", 8 | "O", 9 | "o", 10 | "0", 11 | "U", 12 | "u", 13 | "@", 14 | "*", 15 | "^", 16 | "-", 17 | ] 18 | 19 | 20 | def x_x(): 21 | """Return a random face with an eye.""" 22 | return random.choice(EYES) + "_" + random.choice(EYES) 23 | 24 | 25 | def splash(choice: str) -> str: 26 | """Return a splash screen""" 27 | 28 | fname = os.path.join( 29 | os.path.dirname(__file__), 30 | "splashes", 31 | f"{choice}.txt", 32 | ) 33 | 34 | with open(fname, "r") as fi: 35 | return fi.read() 36 | -------------------------------------------------------------------------------- /python-sanic-server/src/x_x/__init__.py: -------------------------------------------------------------------------------- 1 | import os.path 2 | import random 3 | 4 | 5 | EYES = [ 6 | "x", 7 | "X", 8 | "O", 9 | "o", 10 | "0", 11 | "U", 12 | "u", 13 | "@", 14 | "*", 15 | "^", 16 | "-", 17 | ] 18 | 19 | 20 | def x_x(): 21 | """Return a random face with an eye.""" 22 | return random.choice(EYES) + "_" + random.choice(EYES) 23 | 24 | 25 | def splash(choice: str) -> str: 26 | """Return a splash screen""" 27 | 28 | fname = os.path.join( 29 | os.path.dirname(__file__), 30 | "splashes", 31 | f"{choice}.txt", 32 | ) 33 | 34 | with open(fname, "r") as fi: 35 | return fi.read() 36 | -------------------------------------------------------------------------------- /worm-food/webpack.config.js: -------------------------------------------------------------------------------- 1 | const webpack = require('webpack'); 2 | 3 | module.exports = { 4 | context: __dirname + "/src", 5 | entry: './index.js', 6 | output: { 7 | path: __dirname + '/dist', 8 | filename: 'pool-water.bundled.js', 9 | libraryTarget: 'var', 10 | library: 'svv', 11 | }, 12 | module: { 13 | rules: [ 14 | { 15 | test: /\.gltf$/, 16 | loader: 'raw-loader', 17 | }, 18 | { 19 | test: /\.(frag|vert)?$/, 20 | loader: 'raw-loader', 21 | }, 22 | { 23 | test: /\.js$/, 24 | exclude: /node_modules/, 25 | use: ['babel-loader'], 26 | } 27 | ], 28 | }, 29 | resolve: { 30 | extensions: ['*', '.js'], 31 | }, 32 | mode: "development", 33 | }; 34 | -------------------------------------------------------------------------------- /python-flask-server/src/server/app.py: -------------------------------------------------------------------------------- 1 | from .api import blueprint 2 | from .db import CustomerRequests 3 | from flask import Flask 4 | from flask_sqlalchemy import SQLAlchemy 5 | from x_x import x_x 6 | 7 | 8 | def get_app(debug=False): 9 | 10 | app = Flask(__name__) 11 | app.config["DEBUG"] = True 12 | app.config["SECRET_KEY"] = "WHATEVER" 13 | app.config["SQLALCHEMY_DATABASE_URI"] = "sqlite:///:memory:" 14 | app.config["TEMPLATES_AUTO_RELOAD"] = True 15 | app.config["TESTING"] = True 16 | app.jinja_env.globals["x_x"] = x_x 17 | 18 | db = SQLAlchemy() 19 | 20 | db.init_app(app) 21 | 22 | if debug: 23 | app.config["SQLALCHEMY_ECHO"] = True 24 | logger = app.logger 25 | logger.setLevel("DEBUG") 26 | 27 | # ... 28 | app.register_blueprint(blueprint()) 29 | 30 | return app 31 | -------------------------------------------------------------------------------- /python-lib/src/x_x/splashes/tails.txt: -------------------------------------------------------------------------------- 1 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛⬜⬜⬜⬜⬜⬜⬜⬛⬛⬜⬜⬜ 2 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬛⬜⬜⬜⬜⬜⬛🟧⬛⬜⬜⬜ 3 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧🟧⬛⬜⬛⬛⬛🟧🟧⬛🟧🟧🟧 4 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬛🟧⬛🟧🟧🟧🟧🟧🟧🟧⬛⬛ 5 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬜⬛🟧🟧🟧🟧🟧🟧🟧⬛⬛⬛ 6 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬜⬜🟧🟧🟧🟧🟧🟧🟧🟧🟧⬜ 7 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛⬜⬜🟧🟧🟧⬜⬜🟧⬜⬛⬜⬜ 8 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛🟧🟧🟧🟧⬜⬜🟦🟧🟦⬛⬜⬜ 9 | ⬜⬜⬜⬜⬜⬜⬜⬜⬜⬛🟧🟧🟧⬜⬜⬛🟧⬛⬛⬜⬜ 10 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛⬜⬜⬜🟧🟧⬜🟦⬜🟦⬛⬜⬜ 11 | ⬜⬜⬜⬜⬜⬜⬜⬛⬜⬛🟧⬜⬜⬜⬜⬜⬜⬛⬛⬛⬜ 12 | ⬜⬜⬜⬜⬛⬛⬛⬛⬛⬜⬜⬜⬜⬜⬜⬜⬜⬜⬛⬛⬜ 13 | ⬜⬜⬛⬛⬜⬜⬜⬜⬛⬜⬛🟧⬜⬜⬜⬜⬜⬜⬛⬜⬜ 14 | ⬜⬛⬜⬜⬜⬜⬜⬜⬜⬛⬛⬛🟧🟧🟧🟧⬛⬛⬜⬜⬜ 15 | ⬛⬜⬛⬛⬜⬜⬜⬜⬜🟧⬛🟧🟧🟧🟧⬜⬜⬛⬜⬜⬜ 16 | ⬜⬛⬛⬛⬜⬜⬜⬜🟧⬛⬛🟧⬛🟧⬜⬜⬜⬜⬛⬜⬜ 17 | ⬜⬜⬛⬛⬜⬜🟧🟧🟧⬛🟧⬛🟧🟧⬜⬜⬜⬜⬛⬜⬜ 18 | ⬜⬛🟧⬛🟧🟧🟧🟧🟧🟧🟧⬛🟧🟧⬜⬜⬜⬜⬛⬜⬜ 19 | ⬜⬛🟧⬛🟧🟧🟧🟧⬛⬜⬜⬜⬛🟧⬛⬜⬜⬛⬜⬛⬜ 20 | ⬛🟧⬛🟧🟧🟧🟧🟧⬛⬜⬜⬜⬛🟧⬛⬛⬛⬜⬜⬜⬛ 21 | ⬛🟧⬛🟧🟧🟧🟧🟧⬛⬜⬜⬛⬛🟧⬛🟧⬛⬜⬜⬛⬜ 22 | ⬛🟧⬛🟧🟧🟧🟧🟧⬛⬛⬛🟧⬛🟧⬛🟧⬛⬛⬛⬜⬜ 23 | ⬛🟧🟧⬛🟧🟧🟧🟧🟧🟧🟧⬛⬜⬜⬛⬛⬜⬛⬛⬜⬜ 24 | ⬛⬛🟧🟧⬛⬛🟧🟧🟧🟧⬛🟥🟥🟥⬜⬜🟥⬜⬜⬛⬜ 25 | ⬜⬛⬛🟧🟧🟧⬛⬛⬛⬛🟥🟥🟥⬜⬜⬜⬜🟥⬜⬜⬛ 26 | ⬜⬜⬜⬛⬛⬛⬛⬛⬜⬛⬛⬛⬛⬛⬛⬛⬛⬛⬛⬛⬛ 27 | -------------------------------------------------------------------------------- /python-sanic-server/src/x_x/splashes/tails.txt: -------------------------------------------------------------------------------- 1 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛⬜⬜⬜⬜⬜⬜⬜⬛⬛⬜⬜⬜ 2 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬛⬜⬜⬜⬜⬜⬛🟧⬛⬜⬜⬜ 3 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧🟧⬛⬜⬛⬛⬛🟧🟧⬛🟧🟧🟧 4 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬛🟧⬛🟧🟧🟧🟧🟧🟧🟧⬛⬛ 5 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬜⬛🟧🟧🟧🟧🟧🟧🟧⬛⬛⬛ 6 | ⬜⬜⬜⬜⬜⬜⬜⬛🟧⬜⬜🟧🟧🟧🟧🟧🟧🟧🟧🟧⬜ 7 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛⬜⬜🟧🟧🟧⬜⬜🟧⬜⬛⬜⬜ 8 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛🟧🟧🟧🟧⬜⬜🟦🟧🟦⬛⬜⬜ 9 | ⬜⬜⬜⬜⬜⬜⬜⬜⬜⬛🟧🟧🟧⬜⬜⬛🟧⬛⬛⬜⬜ 10 | ⬜⬜⬜⬜⬜⬜⬜⬜⬛⬜⬜⬜🟧🟧⬜🟦⬜🟦⬛⬜⬜ 11 | ⬜⬜⬜⬜⬜⬜⬜⬛⬜⬛🟧⬜⬜⬜⬜⬜⬜⬛⬛⬛⬜ 12 | ⬜⬜⬜⬜⬛⬛⬛⬛⬛⬜⬜⬜⬜⬜⬜⬜⬜⬜⬛⬛⬜ 13 | ⬜⬜⬛⬛⬜⬜⬜⬜⬛⬜⬛🟧⬜⬜⬜⬜⬜⬜⬛⬜⬜ 14 | ⬜⬛⬜⬜⬜⬜⬜⬜⬜⬛⬛⬛🟧🟧🟧🟧⬛⬛⬜⬜⬜ 15 | ⬛⬜⬛⬛⬜⬜⬜⬜⬜🟧⬛🟧🟧🟧🟧⬜⬜⬛⬜⬜⬜ 16 | ⬜⬛⬛⬛⬜⬜⬜⬜🟧⬛⬛🟧⬛🟧⬜⬜⬜⬜⬛⬜⬜ 17 | ⬜⬜⬛⬛⬜⬜🟧🟧🟧⬛🟧⬛🟧🟧⬜⬜⬜⬜⬛⬜⬜ 18 | ⬜⬛🟧⬛🟧🟧🟧🟧🟧🟧🟧⬛🟧🟧⬜⬜⬜⬜⬛⬜⬜ 19 | ⬜⬛🟧⬛🟧🟧🟧🟧⬛⬜⬜⬜⬛🟧⬛⬜⬜⬛⬜⬛⬜ 20 | ⬛🟧⬛🟧🟧🟧🟧🟧⬛⬜⬜⬜⬛🟧⬛⬛⬛⬜⬜⬜⬛ 21 | ⬛🟧⬛🟧🟧🟧🟧🟧⬛⬜⬜⬛⬛🟧⬛🟧⬛⬜⬜⬛⬜ 22 | ⬛🟧⬛🟧🟧🟧🟧🟧⬛⬛⬛🟧⬛🟧⬛🟧⬛⬛⬛⬜⬜ 23 | ⬛🟧🟧⬛🟧🟧🟧🟧🟧🟧🟧⬛⬜⬜⬛⬛⬜⬛⬛⬜⬜ 24 | ⬛⬛🟧🟧⬛⬛🟧🟧🟧🟧⬛🟥🟥🟥⬜⬜🟥⬜⬜⬛⬜ 25 | ⬜⬛⬛🟧🟧🟧⬛⬛⬛⬛🟥🟥🟥⬜⬜⬜⬜🟥⬜⬜⬛ 26 | ⬜⬜⬜⬛⬛⬛⬛⬛⬜⬛⬛⬛⬛⬛⬛⬛⬛⬛⬛⬛⬛ 27 | -------------------------------------------------------------------------------- /python-lib/src/x_x/splashes/sword.txt: -------------------------------------------------------------------------------- 1 | ,--. 2 | { } 3 | K, } 4 | / ~Y` 5 | , / / 6 | {_'-K.__/ 7 | `/-.__L._ 8 | / ' /`\_} 9 | / ' / 10 | ____ / ' / 11 | ,-'~~~~ ~~/ ' /_ 12 | ,' ``~~~ ', 13 | ( Y 14 | { I 15 | { - `, 16 | | ', ) 17 | | | ,..__ __. Y 18 | | .,_./ Y ' / ^Y J )| 19 | \ |' / | | || 20 | \ L_/ . _ (_,.'( 21 | \, , ^^""' / | ) 22 | \_ \ /,L] / 23 | '-_~-, ` ` ./` 24 | `'{_ ) 25 | ^^\..___,.--` ZEUS 26 | -------------------------------------------------------------------------------- /python-flask-server/src/x_x/splashes/sword.txt: -------------------------------------------------------------------------------- 1 | ,--. 2 | { } 3 | K, } 4 | / ~Y` 5 | , / / 6 | {_'-K.__/ 7 | `/-.__L._ 8 | / ' /`\_} 9 | / ' / 10 | ____ / ' / 11 | ,-'~~~~ ~~/ ' /_ 12 | ,' ``~~~ ', 13 | ( Y 14 | { I 15 | { - `, 16 | | ', ) 17 | | | ,..__ __. Y 18 | | .,_./ Y ' / ^Y J )| 19 | \ |' / | | || 20 | \ L_/ . _ (_,.'( 21 | \, , ^^""' / | ) 22 | \_ \ /,L] / 23 | '-_~-, ` ` ./` 24 | `'{_ ) 25 | ^^\..___,.--` ZEUS 26 | -------------------------------------------------------------------------------- /python-sanic-server/src/x_x/splashes/sword.txt: -------------------------------------------------------------------------------- 1 | ,--. 2 | { } 3 | K, } 4 | / ~Y` 5 | , / / 6 | {_'-K.__/ 7 | `/-.__L._ 8 | / ' /`\_} 9 | / ' / 10 | ____ / ' / 11 | ,-'~~~~ ~~/ ' /_ 12 | ,' ``~~~ ', 13 | ( Y 14 | { I 15 | { - `, 16 | | ', ) 17 | | | ,..__ __. Y 18 | | .,_./ Y ' / ^Y J )| 19 | \ |' / | | || 20 | \ L_/ . _ (_,.'( 21 | \, , ^^""' / | ) 22 | \_ \ /,L] / 23 | '-_~-, ` ` ./` 24 | `'{_ ) 25 | ^^\..___,.--` ZEUS 26 | -------------------------------------------------------------------------------- /python-lib/setup.cfg: -------------------------------------------------------------------------------- 1 | [metadata] 2 | name = x_x 3 | version = 1.0.0 4 | author = Matt <3 5 | author_email = matt@worldshadowgovernment.com 6 | url = https://github.com/whatever/x_x 7 | description = wip 8 | long_description = file: README.md 9 | long_description_content_type = text/markdown 10 | keywords = x_x 11 | license = UNLICENSE 12 | classifiers = 13 | Programming Language :: Python :: 3 14 | License :: UNLICENSE 15 | 16 | [options] 17 | package_dir = 18 | = src 19 | packages = find: 20 | install_requires = 21 | 22 | [options.packages.find] 23 | where = src 24 | exclude = 25 | examples* 26 | tools* 27 | docs* 28 | x_x.tests* 29 | 30 | [options.entry_points] 31 | console_scripts = 32 | x_x = x_x.cli:main 33 | 34 | [options.package_data] 35 | * = README.md 36 | 37 | [options.extras_require] 38 | dev = 39 | pyright >= 1.1.0 40 | pytest >= 7.0.0 41 | flake8 >= 7.0.0 42 | 43 | [flake8] 44 | max-line-length = 120 45 | 46 | -------------------------------------------------------------------------------- /python-sanic-server/src/server/cli.py: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env python3 2 | 3 | import argparse 4 | 5 | import random 6 | 7 | from sanic import Sanic 8 | from sanic.worker.loader import AppLoader 9 | from .app import get_app 10 | 11 | from x_x import splash 12 | 13 | 14 | def parameterized_app(): 15 | return get_app(random.randint(0, 666_666)) 16 | 17 | 18 | def main(): 19 | parser = argparse.ArgumentParser(description='Run the Sanic app') 20 | parser.add_argument("--host", type=str) 21 | parser.add_argument("--port", type=int) 22 | parser.add_argument("--workers", type=int, default=5) 23 | parser.add_argument("--message", type=str) 24 | args = parser.parse_args() 25 | 26 | print(splash("tails")) 27 | 28 | loader = AppLoader(factory=parameterized_app) 29 | 30 | app = loader.load() 31 | 32 | app.prepare( 33 | host=args.host, 34 | port=args.port, 35 | workers=args.workers, 36 | dev=True, 37 | ) 38 | 39 | Sanic.serve(primary=app, app_loader=loader) 40 | -------------------------------------------------------------------------------- /python-sanic-server/src/server/static/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | believe in me because i believe in you 5 | 6 | 7 | 12 | 13 | 14 | 15 | 30 | 31 | 32 | 33 | 34 | 35 | -------------------------------------------------------------------------------- /worm-food/src/Bas3d.js: -------------------------------------------------------------------------------- 1 | import * as THREE from "three"; 2 | 3 | import {App} from "@pool-water/secret-sauce"; 4 | 5 | export class Bas3d extends App { 6 | constructor({el}) { 7 | super({el: el}); 8 | 9 | this.el = el; 10 | 11 | this.clock = new THREE.Clock(); 12 | 13 | this.ctx = el.getContext("webgl", {preserveDrawingBuffer: true}); 14 | 15 | this.renderer = new THREE.WebGLRenderer({ 16 | canvas: el, 17 | antialias: true, 18 | }); 19 | 20 | this.camera = new THREE.PerspectiveCamera( 21 | 80, 22 | window.innerWidth/window.innerHeight, 23 | 0.1, 24 | 1000, 25 | ); 26 | 27 | this.renderer.setPixelRatio(window.devicePixelRation); 28 | 29 | this.renderer.setSize(el.width, el.height); 30 | 31 | this.scene = new THREE.Scene(); 32 | } 33 | 34 | update() { 35 | } 36 | 37 | draw() { 38 | this.renderer.render(this.scene, this.camera); 39 | } 40 | 41 | setSize(w, h) { 42 | this.renderer.setSize(w, h); 43 | this.camera.aspect = w/h; 44 | this.camera.updateProjectionMatrix(); 45 | } 46 | } 47 | -------------------------------------------------------------------------------- /python-sanic-server/setup.cfg: -------------------------------------------------------------------------------- 1 | [metadata] 2 | name = x_x 3 | version = 1.0.0 4 | author = Matt <3 5 | author_email = matt@worldshadowgovernment.com 6 | url = https://github.com/whatever/templates/ 7 | description = gotta go fast 8 | long_description = file: README.md 9 | long_description_content_type = text/markdown 10 | keywords = x_x 11 | license = UNLICENSE 12 | classifiers = 13 | Programming Language :: Python :: 3 14 | License :: UNLICENSE 15 | 16 | [options] 17 | package_dir = 18 | = src 19 | packages = find: 20 | install_requires = 21 | python-socketio[asyncio_client] >= 5.11.2 22 | sanic >= 23.12.1 23 | 24 | [options.packages.find] 25 | where = src 26 | exclude = 27 | examples* 28 | tools* 29 | docs* 30 | x_x.tests* 31 | 32 | [options.entry_points] 33 | console_scripts = 34 | gotta-go-fast = server.cli:main 35 | 36 | [options.package_data] 37 | * = README.md 38 | 39 | [options.extras_require] 40 | dev = 41 | flake8 >= 7.0.0 42 | pyright >= 1.1.0 43 | pytest >= 7.0.0 44 | pytest-asyncio >= 0.23.6 45 | sanic-testing >= 23.12.0 46 | 47 | [flake8] 48 | max-line-length = 120 49 | 50 | -------------------------------------------------------------------------------- /python-flask-server/setup.cfg: -------------------------------------------------------------------------------- 1 | [metadata] 2 | name = server 3 | version = 1.0.0 4 | author = Matt <3 5 | author_email = matt@worldshadowgovernment.com 6 | url = https://github.com/whatever/templates/ 7 | description = x_x 8 | long_description = file: README.md 9 | long_description_content_type = text/markdown 10 | keywords = x_x 11 | license = UNLICENSED 12 | classifiers = 13 | Programming Language :: Python :: 3 14 | 15 | [options] 16 | package_dir = 17 | = src 18 | packages = find: 19 | install_requires = 20 | Flask >= 3.0.2 21 | Flask-Login >= 0.6.3 22 | Flask-SQLAlchemy >= 3.1.1 23 | gunicorn >= 21.2.0 24 | 25 | [options.packages.find] 26 | where = src 27 | exclude = 28 | examples* 29 | tools* 30 | docs* 31 | x_x.tests* 32 | 33 | [options.entry_points] 34 | console_scripts = 35 | server = server.cli:main 36 | # x_x = x_x.cli:main 37 | # knockknock = knock_knock.cli:main 38 | # knock = knock_knock.cli:register 39 | 40 | [options.package_data] 41 | * = README.md 42 | 43 | [options.extras_require] 44 | dev = 45 | pyright >= 1.1.0 46 | pytest >= 7.0.0 47 | flake8 >= 7.0.0 48 | 49 | [flake8] 50 | max-line-length = 120 51 | 52 | -------------------------------------------------------------------------------- /python-sanic-server/src/server/app.py: -------------------------------------------------------------------------------- 1 | import os.path 2 | import socketio 3 | 4 | from sanic import Sanic 5 | from sanic.response import json 6 | 7 | 8 | def get_app(r): 9 | 10 | app = Sanic("x_x") 11 | 12 | sio = socketio.AsyncServer(async_mode='sanic') 13 | 14 | sio.attach(app) 15 | 16 | @app.listener('before_server_start') 17 | async def setup_background(app, loop): 18 | # app.add_task(background(sio)) 19 | pass 20 | 21 | @app.route("/lmk/status") 22 | def status(request): 23 | return json({"status": "ok"}) 24 | 25 | @app.route("/lmk/ping") 26 | def ping(request): 27 | return json({"ping": "pong"}) 28 | 29 | @sio.on("connect") 30 | async def connect(sid, environ): 31 | print("connect ", sid) 32 | 33 | @sio.event 34 | async def disconnect(sid): 35 | print("disconnect ", sid) 36 | 37 | @sio.event 38 | async def update(sid, data): 39 | print("update ", data) 40 | await sio.emit("update", {"weom": "meow"}) 41 | 42 | dirname = os.path.join( 43 | os.path.dirname(__file__), 44 | "static", 45 | ) 46 | 47 | app.static('/static', dirname) 48 | 49 | return app 50 | -------------------------------------------------------------------------------- /python-lib/LICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /python-lib/UNLICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /python-flask-server/LICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /python-flask-server/UNLICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /python-sanic-server/LICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /python-sanic-server/UNLICENSE: -------------------------------------------------------------------------------- 1 | This is free and unencumbered software released into the public domain. 2 | 3 | Anyone is free to copy, modify, publish, use, compile, sell, or 4 | distribute this software, either in source code form or as a compiled 5 | binary, for any purpose, commercial or non-commercial, and by any 6 | means. 7 | 8 | In jurisdictions that recognize copyright laws, the author or authors 9 | of this software dedicate any and all copyright interest in the 10 | software to the public domain. We make this dedication for the benefit 11 | of the public at large and to the detriment of our heirs and 12 | successors. We intend this dedication to be an overt act of 13 | relinquishment in perpetuity of all present and future rights to this 14 | software under copyright law. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR 20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 22 | OTHER DEALINGS IN THE SOFTWARE. 23 | 24 | For more information, please refer to 25 | -------------------------------------------------------------------------------- /worm-food/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "art-practice", 3 | "version": "0.0.2", 4 | "description": "a boilerplate to create a generative token on fxhash", 5 | "main": "src/index.js", 6 | "author": "fxhash", 7 | "license": "MIT", 8 | "scripts": { 9 | "ayy": "webpack", 10 | "bleach": "javascript-obfuscator dist/pool-water.bundled.js", 11 | "livest": "node ./node_modules/webpack/bin/webpack.js --watch --progresswebpack", 12 | "lmao": "webpack serve --static app --no-hot --open", 13 | "test": "mocha --require @babel/register tests" 14 | }, 15 | "dependencies": { 16 | "alea": "^1.0.1", 17 | "assert": "^2.0.0", 18 | "npm": "^9.2.0", 19 | "three": "^0.135.0" 20 | }, 21 | "devDependencies": { 22 | "@babel/core": "^7.2.2", 23 | "@babel/preset-env": "^7.1.6", 24 | "@babel/register": "^7.0.0", 25 | "@eslint/create-config": "^0.1.2", 26 | "@pool-water/math": "file:../../pool-water/math", 27 | "@pool-water/secret-sauce": "file:../../pool-water/secret-sauce", 28 | "babel-loader": "^8.0.4", 29 | "chai": "^4.3.6", 30 | "copy-webpack-plugin": "^9.0.1", 31 | "css-loader": "^6.4.0", 32 | "deep-eql": "^4.0.0", 33 | "eslint": "^8.8.0", 34 | "html-webpack-plugin": "^5.4.0", 35 | "javascript-obfuscator": "^4.0.0", 36 | "mocha": "^9.2.0", 37 | "raw-loader": "4.0.2", 38 | "simplex-noise": "^4.0.1", 39 | "webpack": "^5.59.0", 40 | "webpack-cli": "^4.9.1", 41 | "webpack-dev-server": "^4.3.1" 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /python-flask-server/src/server/cli.py: -------------------------------------------------------------------------------- 1 | import argparse 2 | 3 | from getpass import getpass 4 | from .app import get_app 5 | from .wsgi import KnockKnockApp 6 | from werkzeug.security import generate_password_hash 7 | 8 | from x_x import splash 9 | 10 | 11 | def main(): 12 | 13 | parser = argparse.ArgumentParser(description="knock*knock") 14 | parser.add_argument("--host", default="0.0.0.0", help="host address") 15 | parser.add_argument("--port", default=8181, help="port number") 16 | parser.add_argument("--workers", default=2, help="number of workers") 17 | parser.add_argument("--bootstrap", action="store_true", help="bootstrap the database") 18 | args = parser.parse_args() 19 | 20 | print(f"\033[92m{splash('frog')}\033[0m", end="\n\n") 21 | 22 | options = { 23 | "bind": f"{args.host}:{args.port}", 24 | "workers": args.workers, 25 | } 26 | 27 | app = get_app() 28 | 29 | KnockKnockApp(app, options).run() 30 | 31 | 32 | # def register(): 33 | # """Register an email with a password""" 34 | # 35 | # parser = argparse.ArgumentParser(description="register user/password") 36 | # parser.add_argument("email", type=str, help="email address") 37 | # args = parser.parse_args() 38 | # 39 | # email = args.email 40 | # hashword = generate_password_hash( 41 | # getpass("enter password:"), 42 | # # method="sha256", 43 | # ) 44 | # 45 | # user = AdminUser( 46 | # email=email, 47 | # password=hashword, 48 | # ) 49 | # 50 | # app = get_app(None, False) 51 | # 52 | # with app.app_context(): 53 | # try: 54 | # auth_db.session.add(user) 55 | # auth_db.session.commit() 56 | # except Exception as e: 57 | # print("Failed with error:", e) 58 | -------------------------------------------------------------------------------- /worm-food/src/objs/WeirdRing.js: -------------------------------------------------------------------------------- 1 | import * as THREE from "three"; 2 | 3 | export class Rod extends THREE.BufferGeometry { 4 | constructor(w, h, d, segments, twist) { 5 | super(); 6 | 7 | let hinc = h / segments; 8 | 9 | let positions = []; 10 | 11 | let normals = []; 12 | 13 | for (let i=0; i < segments+1; i++) { 14 | 15 | let x1 = -w/2.0; 16 | let x2 = +w/2.0; 17 | let z1 = -d/2.0; 18 | let z2 = +d/2.0; 19 | 20 | let y = hinc*i - h/2.0; 21 | 22 | // Circle 23 | for (let j=0; j < 4; j++) { 24 | let theta = j/4 * 2 * Math.PI; 25 | let x = w*Math.cos(-theta+twist*i); 26 | let y = hinc*i - h/2.0; 27 | let z = w*Math.sin(-theta+twist*i); 28 | positions.push(x, y, z); 29 | } 30 | 31 | /* 32 | positions.push( 33 | x1, y, z1, // 0 34 | x1, y, z2, // 1 35 | x2, y, z2, // 2 36 | x2, y, z1, // 3 37 | ); 38 | */ 39 | 40 | normals.push( 41 | x1, 0, z1, // 0 42 | x1, 0, z2, // 1 43 | x2, 0, z2, // 2 44 | x2, 0, z1, // 3 45 | ); 46 | 47 | } 48 | 49 | let indices = [] 50 | 51 | for (let i=0; i < segments; i++) { 52 | let j = 4*i; 53 | indices.push( 54 | // Face 1 55 | j+0, j+1, j+4, 56 | j+1, j+5, j+4, 57 | 58 | // Face 2 59 | j+1, j+2, j+5, 60 | j+2, j+6, j+5, 61 | 62 | // Face 3 63 | j+2, j+3, j+7, 64 | j+2, j+7, j+6, 65 | 66 | // Face 4 67 | j+3, j+0, j+7, 68 | j+0, j+4, j+7, 69 | ); 70 | } 71 | 72 | this.setAttribute("position", new THREE.Float32BufferAttribute(positions, 3)); 73 | // this.setAttribute("normal", new THREE.Float32BufferAttribute(normals, 3)); 74 | this.setIndex(indices); 75 | this.computeVertexNormals(); 76 | } 77 | } 78 | 79 | export class WeirdRing extends THREE.Object3D { 80 | constructor() { 81 | super(); 82 | } 83 | } 84 | -------------------------------------------------------------------------------- /worm-food/app/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | i wanna be your joey ramone 5 | 6 | 7 | 8 | 9 | 10 | 11 | 124 | 125 | 126 | -------------------------------------------------------------------------------- /worm-food/src/index.js: -------------------------------------------------------------------------------- 1 | import * as THREE from "three"; 2 | import {Bas3d} from "/Bas3d.js"; 3 | import {Rod, WeirdRing} from "/objs/WeirdRing.js"; 4 | 5 | import {OBJLoader} from "three/examples/jsm/loaders/ObjLoader.js"; 6 | import {EffectComposer} from "three/examples/jsm/postprocessing/EffectComposer.js"; 7 | import {RenderPass} from "three/examples/jsm/postprocessing/RenderPass.js"; 8 | import {UnrealBloomPass} from "three/examples/jsm/postprocessing/UnrealBloomPass.js"; 9 | import {VertexNormalsHelper} from "three/examples/jsm/helpers/VertexNormalsHelper.js"; 10 | 11 | 12 | export class WorldShadowGovernmentApp extends Bas3d { 13 | 14 | constructor({el}) { 15 | super({el: el}); 16 | 17 | this.outsider = new THREE.PerspectiveCamera( 18 | 80, 19 | window.innerWidth/window.innerHeight, 20 | 0.1, 21 | 1000, 22 | ); 23 | 24 | const bloomParams = { 25 | exposure: 1.0, 26 | bloomStrength: 2.5, 27 | bloomThreshold: 0.2, 28 | bloomRadius: 3.0, 29 | }; 30 | 31 | this.bloomPass = new UnrealBloomPass( 32 | new THREE.Vector2(window.innerWidth, window.innerHeight), 33 | 1.5, 0.4, 0.85, 34 | ); 35 | 36 | const renderScene = new RenderPass(this.scene, this.outsider); 37 | 38 | this.composer = new EffectComposer(this.renderer); 39 | this.composer.addPass(renderScene); 40 | this.composer.addPass(this.bloomPass); 41 | 42 | this.bloomPass.threshold = bloomParams.bloomThreshold; 43 | this.bloomPass.strength = bloomParams.bloomStrength; 44 | this.bloomPass.radius = bloomParams.bloomRadius; 45 | 46 | this.renderer.shadowMap.enabled = true; 47 | this.renderer.shadowMap.type = THREE.PCFSoftShadowMap; 48 | 49 | let fake_props = { 50 | color: 0x775555, 51 | emissive: 0x000000, 52 | roughness: 0.524, 53 | metalness: 0.7, 54 | reflectivity: 0.8, 55 | clearcoat: 0.67, 56 | clearcoatRoughness: 0.0, 57 | // flatShading: true, 58 | }; 59 | 60 | let props = { 61 | color: 0x000000, 62 | emissive: 0x000000, 63 | roughness: 0.524, 64 | metalness: 0.7, 65 | reflectivity: 0.8, 66 | clearcoat: 0.67, 67 | clearcoatRoughness: 0.0, 68 | // flatShading: true, 69 | }; 70 | 71 | this.mat = new THREE.MeshPhysicalMaterial(props); 72 | 73 | let mat = new THREE.MeshPhysicalMaterial(props); 74 | 75 | let s = 3.0; 76 | 77 | this.mesh = new THREE.Mesh( 78 | new THREE.IcosahedronGeometry(1.0), 79 | mat, 80 | ); 81 | 82 | // this.scene.add(this.mesh); 83 | 84 | let amb = new THREE.AmbientLight(0xCCCCCC); 85 | this.scene.add(amb); 86 | 87 | let intensity = 4.0; 88 | this.distance = 0.4; 89 | 90 | this.hot = new THREE.DirectionalLight(0xCC00CC, intensity); 91 | this.hot.position.set(10.0, 4.0, this.distance/2.0); 92 | this.scene.add(this.hot); 93 | 94 | this.cold = new THREE.DirectionalLight(0x00CCCC, intensity); 95 | this.cold.position.set(10.0, 4.0, -this.distance/2.0); 96 | this.scene.add(this.cold); 97 | 98 | this.rings = []; 99 | 100 | this.group = new THREE.Object3D(); 101 | 102 | for (let i=0; i < 5; i++) { 103 | 104 | if (i == 2) { 105 | continue; 106 | } 107 | 108 | let radius = 6*(i+1); 109 | let mesh = new THREE.Mesh( 110 | new THREE.TorusGeometry(radius, Math.sqrt(radius)/2.0, 16 , 128), 111 | // new THREE.MeshBasicMaterial({color: 0xFF00FF}), 112 | new THREE.MeshPhysicalMaterial(props), 113 | 114 | ); 115 | mesh.receiveShadow = true; 116 | mesh.castShadow = true; 117 | 118 | this.rings.push(mesh); 119 | this.group.add(mesh); 120 | } 121 | 122 | this.scene.add(this.group); 123 | 124 | this.getHandObj(); 125 | 126 | 127 | this.helpers = new THREE.Group(); 128 | this.helpers.add(new THREE.CameraHelper(this.camera)); 129 | this.scene.add(this.helpers); 130 | 131 | this.outsiderView = true; 132 | this.bloom = true; 133 | 134 | let testProps = new THREE.MeshPhysicalMaterial({ 135 | color: 0x333333, 136 | emissive: 0x000000, 137 | flatShading: true, 138 | side: THREE.DoubleSide, 139 | }); 140 | 141 | // XXX: DEBUG CODE 142 | this.group.visible = true; 143 | this.ring = new THREE.Mesh( 144 | new Rod(1.0, 10.0, 1.0, 3, 3/2/Math.PI), 145 | props, 146 | ); 147 | // this.ring.add(new VertexNormalsHelper(this.ring)); 148 | 149 | 150 | this.scene.add(this.ring); 151 | } 152 | 153 | update() { 154 | 155 | this.composer.passes[0].camera = this.outsiderView ? this.outsider : this.camera; 156 | this.helpers.visible = this.outsiderView; 157 | 158 | let s = 40.0; 159 | this.camera.position.set(0.0, 0.0, 20.0); 160 | this.camera.lookAt(new THREE.Vector3(0, 0, 0)); 161 | 162 | this.outsider.position.set(s, s, s); 163 | this.outsider.lookAt(new THREE.Vector3(0, 0, 0)); 164 | 165 | 166 | let t = +new Date(); 167 | let u = t / 1000.0 / 30.0; 168 | 169 | this.ring.rotation.x = Math.PI/8; 170 | this.ring.rotation.y = +2*t/1000.0; 171 | 172 | this.mesh.rotation.set(3*u, -2*u, 1*u); 173 | 174 | this.rings.forEach((v, i) => { 175 | const c = t / 1000.0 / 69.0; 176 | const x = (11*(i+0))%7 - 4; 177 | const y = (17*(i+1))%7 - 4; 178 | const z = (29*(i+2))%7 - 4; 179 | v.rotation.set(c*x, c*y, c*z); 180 | }); 181 | } 182 | 183 | draw() { 184 | 185 | if (this.bloom) { 186 | this.composer.render(this.scene, undefined); 187 | } else { 188 | this.renderer.render(this.scene, this.composer.passes[0].camera); 189 | } 190 | } 191 | 192 | setSize(w, h) { 193 | this.renderer.setSize(w, h); 194 | this.composer.setSize(w, h); 195 | this.camera.aspect = w/h; 196 | this.camera.updateProjectionMatrix(); 197 | this.outsider.aspect = w/h; 198 | this.outsider.updateProjectionMatrix(); 199 | } 200 | 201 | getHandObj() { 202 | 203 | const loader = new OBJLoader(); 204 | 205 | // load a resource 206 | loader.load( 207 | // resource URL 208 | 'hand.obj', 209 | 210 | (object) => { 211 | let geo = object.children[0].geometry; 212 | let mat = new THREE.MeshPhysicalMaterial({ 213 | color: 0x000000, 214 | emissive: 0x000000, 215 | roughness: 0.524, 216 | metalness: 0.7, 217 | reflectivity: 0.8, 218 | clearcoat: 0.67, 219 | clearcoatRoughness: 0.0, 220 | // flatShading: true, 221 | }); 222 | let mesh = new THREE.Mesh(geo, mat); 223 | mesh.scale.set(3, 3, 3); 224 | // this.scene.add(mesh); 225 | }, 226 | (xhr) => { 227 | }, 228 | (error) => { 229 | console.log(error); 230 | }, 231 | ); 232 | } 233 | 234 | tweak({bloomThreshold, bloomStrength, bloomRadius, outsiderView, bloom, hot, cold, distance}) { 235 | this.bloomPass["threshold"] = bloomThreshold; 236 | this.bloomPass["strength"] = bloomStrength; 237 | this.bloomPass["radius"] = bloomRadius; 238 | this.outsiderView = outsiderView; 239 | this.bloom = bloom; 240 | this.hot.intensity = hot; 241 | this.cold.intensity = cold; 242 | this.distance = distance; 243 | this.hot.position.set(10.0, 4.0, this.distance/2.0); 244 | this.cold.position.set(10.0, 4.0, -this.distance/2.0); 245 | } 246 | 247 | } 248 | -------------------------------------------------------------------------------- /worm-food/app/dat.gui.min.js: -------------------------------------------------------------------------------- 1 | /** 2 | * dat-gui JavaScript Controller Library 3 | * https://github.com/dataarts/dat.gui 4 | * 5 | * Copyright 2011 Data Arts Team, Google Creative Lab 6 | * 7 | * Licensed under the Apache License, Version 2.0 (the "License"); 8 | * you may not use this file except in compliance with the License. 9 | * You may obtain a copy of the License at 10 | * 11 | * http://www.apache.org/licenses/LICENSE-2.0 12 | */ 13 | !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t(e.dat={})}(this,function(e){"use strict";function t(e,t){var n=e.__state.conversionName.toString(),o=Math.round(e.r),i=Math.round(e.g),r=Math.round(e.b),s=e.a,a=Math.round(e.h),l=e.s.toFixed(1),d=e.v.toFixed(1);if(t||"THREE_CHAR_HEX"===n||"SIX_CHAR_HEX"===n){for(var c=e.hex.toString(16);c.length<6;)c="0"+c;return"#"+c}return"CSS_RGB"===n?"rgb("+o+","+i+","+r+")":"CSS_RGBA"===n?"rgba("+o+","+i+","+r+","+s+")":"HEX"===n?"0x"+e.hex.toString(16):"RGB_ARRAY"===n?"["+o+","+i+","+r+"]":"RGBA_ARRAY"===n?"["+o+","+i+","+r+","+s+"]":"RGB_OBJ"===n?"{r:"+o+",g:"+i+",b:"+r+"}":"RGBA_OBJ"===n?"{r:"+o+",g:"+i+",b:"+r+",a:"+s+"}":"HSV_OBJ"===n?"{h:"+a+",s:"+l+",v:"+d+"}":"HSVA_OBJ"===n?"{h:"+a+",s:"+l+",v:"+d+",a:"+s+"}":"unknown format"}function n(e,t,n){Object.defineProperty(e,t,{get:function(){return"RGB"===this.__state.space?this.__state[t]:(I.recalculateRGB(this,t,n),this.__state[t])},set:function(e){"RGB"!==this.__state.space&&(I.recalculateRGB(this,t,n),this.__state.space="RGB"),this.__state[t]=e}})}function o(e,t){Object.defineProperty(e,t,{get:function(){return"HSV"===this.__state.space?this.__state[t]:(I.recalculateHSV(this),this.__state[t])},set:function(e){"HSV"!==this.__state.space&&(I.recalculateHSV(this),this.__state.space="HSV"),this.__state[t]=e}})}function i(e){if("0"===e||S.isUndefined(e))return 0;var t=e.match(U);return S.isNull(t)?0:parseFloat(t[1])}function r(e){var t=e.toString();return t.indexOf(".")>-1?t.length-t.indexOf(".")-1:0}function s(e,t){var n=Math.pow(10,t);return Math.round(e*n)/n}function a(e,t,n,o,i){return o+(e-t)/(n-t)*(i-o)}function l(e,t,n,o){e.style.background="",S.each(ee,function(i){e.style.cssText+="background: "+i+"linear-gradient("+t+", "+n+" 0%, "+o+" 100%); "})}function d(e){e.style.background="",e.style.cssText+="background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);",e.style.cssText+="background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",e.style.cssText+="background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",e.style.cssText+="background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);",e.style.cssText+="background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);"}function c(e,t,n){var o=document.createElement("li");return t&&o.appendChild(t),n?e.__ul.insertBefore(o,n):e.__ul.appendChild(o),e.onResize(),o}function u(e){X.unbind(window,"resize",e.__resizeHandler),e.saveToLocalStorageIfPossible&&X.unbind(window,"unload",e.saveToLocalStorageIfPossible)}function _(e,t){var n=e.__preset_select[e.__preset_select.selectedIndex];n.innerHTML=t?n.value+"*":n.value}function h(e,t,n){if(n.__li=t,n.__gui=e,S.extend(n,{options:function(t){if(arguments.length>1){var o=n.__li.nextElementSibling;return n.remove(),f(e,n.object,n.property,{before:o,factoryArgs:[S.toArray(arguments)]})}if(S.isArray(t)||S.isObject(t)){var i=n.__li.nextElementSibling;return n.remove(),f(e,n.object,n.property,{before:i,factoryArgs:[t]})}},name:function(e){return n.__li.firstElementChild.firstElementChild.innerHTML=e,n},listen:function(){return n.__gui.listen(n),n},remove:function(){return n.__gui.remove(n),n}}),n instanceof q){var o=new Q(n.object,n.property,{min:n.__min,max:n.__max,step:n.__step});S.each(["updateDisplay","onChange","onFinishChange","step","min","max"],function(e){var t=n[e],i=o[e];n[e]=o[e]=function(){var e=Array.prototype.slice.call(arguments);return i.apply(o,e),t.apply(n,e)}}),X.addClass(t,"has-slider"),n.domElement.insertBefore(o.domElement,n.domElement.firstElementChild)}else if(n instanceof Q){var i=function(t){if(S.isNumber(n.__min)&&S.isNumber(n.__max)){var o=n.__li.firstElementChild.firstElementChild.innerHTML,i=n.__gui.__listening.indexOf(n)>-1;n.remove();var r=f(e,n.object,n.property,{before:n.__li.nextElementSibling,factoryArgs:[n.__min,n.__max,n.__step]});return r.name(o),i&&r.listen(),r}return t};n.min=S.compose(i,n.min),n.max=S.compose(i,n.max)}else n instanceof K?(X.bind(t,"click",function(){X.fakeEvent(n.__checkbox,"click")}),X.bind(n.__checkbox,"click",function(e){e.stopPropagation()})):n instanceof Z?(X.bind(t,"click",function(){X.fakeEvent(n.__button,"click")}),X.bind(t,"mouseover",function(){X.addClass(n.__button,"hover")}),X.bind(t,"mouseout",function(){X.removeClass(n.__button,"hover")})):n instanceof $&&(X.addClass(t,"color"),n.updateDisplay=S.compose(function(e){return t.style.borderLeftColor=n.__color.toString(),e},n.updateDisplay),n.updateDisplay());n.setValue=S.compose(function(t){return e.getRoot().__preset_select&&n.isModified()&&_(e.getRoot(),!0),t},n.setValue)}function p(e,t){var n=e.getRoot(),o=n.__rememberedObjects.indexOf(t.object);if(-1!==o){var i=n.__rememberedObjectIndecesToControllers[o];if(void 0===i&&(i={},n.__rememberedObjectIndecesToControllers[o]=i),i[t.property]=t,n.load&&n.load.remembered){var r=n.load.remembered,s=void 0;if(r[e.preset])s=r[e.preset];else{if(!r[se])return;s=r[se]}if(s[o]&&void 0!==s[o][t.property]){var a=s[o][t.property];t.initialValue=a,t.setValue(a)}}}}function f(e,t,n,o){if(void 0===t[n])throw new Error('Object "'+t+'" has no property "'+n+'"');var i=void 0;if(o.color)i=new $(t,n);else{var r=[t,n].concat(o.factoryArgs);i=ne.apply(e,r)}o.before instanceof z&&(o.before=o.before.__li),p(e,i),X.addClass(i.domElement,"c");var s=document.createElement("span");X.addClass(s,"property-name"),s.innerHTML=i.property;var a=document.createElement("div");a.appendChild(s),a.appendChild(i.domElement);var l=c(e,a,o.before);return X.addClass(l,he.CLASS_CONTROLLER_ROW),i instanceof $?X.addClass(l,"color"):X.addClass(l,H(i.getValue())),h(e,l,i),e.__controllers.push(i),i}function m(e,t){return document.location.href+"."+t}function g(e,t,n){var o=document.createElement("option");o.innerHTML=t,o.value=t,e.__preset_select.appendChild(o),n&&(e.__preset_select.selectedIndex=e.__preset_select.length-1)}function b(e,t){t.style.display=e.useLocalStorage?"block":"none"}function v(e){var t=e.__save_row=document.createElement("li");X.addClass(e.domElement,"has-save"),e.__ul.insertBefore(t,e.__ul.firstChild),X.addClass(t,"save-row");var n=document.createElement("span");n.innerHTML=" ",X.addClass(n,"button gears");var o=document.createElement("span");o.innerHTML="Save",X.addClass(o,"button"),X.addClass(o,"save");var i=document.createElement("span");i.innerHTML="New",X.addClass(i,"button"),X.addClass(i,"save-as");var r=document.createElement("span");r.innerHTML="Revert",X.addClass(r,"button"),X.addClass(r,"revert");var s=e.__preset_select=document.createElement("select");if(e.load&&e.load.remembered?S.each(e.load.remembered,function(t,n){g(e,n,n===e.preset)}):g(e,se,!1),X.bind(s,"change",function(){for(var t=0;t=0;n--)t=[e[n].apply(this,t)];return t[0]}},each:function(e,t,n){if(e)if(A&&e.forEach&&e.forEach===A)e.forEach(t,n);else if(e.length===e.length+0){var o=void 0,i=void 0;for(o=0,i=e.length;o1?S.toArray(arguments):arguments[0];return S.each(O,function(t){if(t.litmus(e))return S.each(t.conversions,function(t,n){if(T=t.read(e),!1===L&&!1!==T)return L=T,T.conversionName=n,T.conversion=t,S.BREAK}),S.BREAK}),L},B=void 0,N={hsv_to_rgb:function(e,t,n){var o=Math.floor(e/60)%6,i=e/60-Math.floor(e/60),r=n*(1-t),s=n*(1-i*t),a=n*(1-(1-i)*t),l=[[n,a,r],[s,n,r],[r,n,a],[r,s,n],[a,r,n],[n,r,s]][o];return{r:255*l[0],g:255*l[1],b:255*l[2]}},rgb_to_hsv:function(e,t,n){var o=Math.min(e,t,n),i=Math.max(e,t,n),r=i-o,s=void 0,a=void 0;return 0===i?{h:NaN,s:0,v:0}:(a=r/i,s=e===i?(t-n)/r:t===i?2+(n-e)/r:4+(e-t)/r,(s/=6)<0&&(s+=1),{h:360*s,s:a,v:i/255})},rgb_to_hex:function(e,t,n){var o=this.hex_with_component(0,2,e);return o=this.hex_with_component(o,1,t),o=this.hex_with_component(o,0,n)},component_from_hex:function(e,t){return e>>8*t&255},hex_with_component:function(e,t,n){return n<<(B=8*t)|e&~(255<this.__max&&(n=this.__max),void 0!==this.__step&&n%this.__step!=0&&(n=Math.round(n/this.__step)*this.__step),D(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"setValue",this).call(this,n)}},{key:"min",value:function(e){return this.__min=e,this}},{key:"max",value:function(e){return this.__max=e,this}},{key:"step",value:function(e){return this.__step=e,this.__impliedStep=e,this.__precision=r(e),this}}]),t}(),Q=function(e){function t(e,n,o){function i(){l.__onFinishChange&&l.__onFinishChange.call(l,l.getValue())}function r(e){var t=d-e.clientY;l.setValue(l.getValue()+t*l.__impliedStep),d=e.clientY}function s(){X.unbind(window,"mousemove",r),X.unbind(window,"mouseup",s),i()}F(this,t);var a=V(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,o));a.__truncationSuspended=!1;var l=a,d=void 0;return a.__input=document.createElement("input"),a.__input.setAttribute("type","text"),X.bind(a.__input,"change",function(){var e=parseFloat(l.__input.value);S.isNaN(e)||l.setValue(e)}),X.bind(a.__input,"blur",function(){i()}),X.bind(a.__input,"mousedown",function(e){X.bind(window,"mousemove",r),X.bind(window,"mouseup",s),d=e.clientY}),X.bind(a.__input,"keydown",function(e){13===e.keyCode&&(l.__truncationSuspended=!0,this.blur(),l.__truncationSuspended=!1,i())}),a.updateDisplay(),a.domElement.appendChild(a.__input),a}return j(t,W),P(t,[{key:"updateDisplay",value:function(){return this.__input.value=this.__truncationSuspended?this.getValue():s(this.getValue(),this.__precision),D(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(),q=function(e){function t(e,n,o,i,r){function s(e){e.preventDefault();var t=_.__background.getBoundingClientRect();return _.setValue(a(e.clientX,t.left,t.right,_.__min,_.__max)),!1}function l(){X.unbind(window,"mousemove",s),X.unbind(window,"mouseup",l),_.__onFinishChange&&_.__onFinishChange.call(_,_.getValue())}function d(e){var t=e.touches[0].clientX,n=_.__background.getBoundingClientRect();_.setValue(a(t,n.left,n.right,_.__min,_.__max))}function c(){X.unbind(window,"touchmove",d),X.unbind(window,"touchend",c),_.__onFinishChange&&_.__onFinishChange.call(_,_.getValue())}F(this,t);var u=V(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,{min:o,max:i,step:r})),_=u;return u.__background=document.createElement("div"),u.__foreground=document.createElement("div"),X.bind(u.__background,"mousedown",function(e){document.activeElement.blur(),X.bind(window,"mousemove",s),X.bind(window,"mouseup",l),s(e)}),X.bind(u.__background,"touchstart",function(e){1===e.touches.length&&(X.bind(window,"touchmove",d),X.bind(window,"touchend",c),d(e))}),X.addClass(u.__background,"slider"),X.addClass(u.__foreground,"slider-fg"),u.updateDisplay(),u.__background.appendChild(u.__foreground),u.domElement.appendChild(u.__background),u}return j(t,W),P(t,[{key:"updateDisplay",value:function(){var e=(this.getValue()-this.__min)/(this.__max-this.__min);return this.__foreground.style.width=100*e+"%",D(t.prototype.__proto__||Object.getPrototypeOf(t.prototype),"updateDisplay",this).call(this)}}]),t}(),Z=function(e){function t(e,n,o){F(this,t);var i=V(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n)),r=i;return i.__button=document.createElement("div"),i.__button.innerHTML=void 0===o?"Fire":o,X.bind(i.__button,"click",function(e){return e.preventDefault(),r.fire(),!1}),X.addClass(i.__button,"button"),i.domElement.appendChild(i.__button),i}return j(t,z),P(t,[{key:"fire",value:function(){this.__onChange&&this.__onChange.call(this),this.getValue().call(this.object),this.__onFinishChange&&this.__onFinishChange.call(this,this.getValue())}}]),t}(),$=function(e){function t(e,n){function o(e){u(e),X.bind(window,"mousemove",u),X.bind(window,"touchmove",u),X.bind(window,"mouseup",r),X.bind(window,"touchend",r)}function i(e){_(e),X.bind(window,"mousemove",_),X.bind(window,"touchmove",_),X.bind(window,"mouseup",s),X.bind(window,"touchend",s)}function r(){X.unbind(window,"mousemove",u),X.unbind(window,"touchmove",u),X.unbind(window,"mouseup",r),X.unbind(window,"touchend",r),c()}function s(){X.unbind(window,"mousemove",_),X.unbind(window,"touchmove",_),X.unbind(window,"mouseup",s),X.unbind(window,"touchend",s),c()}function a(){var e=R(this.value);!1!==e?(p.__color.__state=e,p.setValue(p.__color.toOriginal())):this.value=p.__color.toString()}function c(){p.__onFinishChange&&p.__onFinishChange.call(p,p.__color.toOriginal())}function u(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=p.__saturation_field.getBoundingClientRect(),n=e.touches&&e.touches[0]||e,o=n.clientX,i=n.clientY,r=(o-t.left)/(t.right-t.left),s=1-(i-t.top)/(t.bottom-t.top);return s>1?s=1:s<0&&(s=0),r>1?r=1:r<0&&(r=0),p.__color.v=s,p.__color.s=r,p.setValue(p.__color.toOriginal()),!1}function _(e){-1===e.type.indexOf("touch")&&e.preventDefault();var t=p.__hue_field.getBoundingClientRect(),n=1-((e.touches&&e.touches[0]||e).clientY-t.top)/(t.bottom-t.top);return n>1?n=1:n<0&&(n=0),p.__color.h=360*n,p.setValue(p.__color.toOriginal()),!1}F(this,t);var h=V(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n));h.__color=new I(h.getValue()),h.__temp=new I(0);var p=h;h.domElement=document.createElement("div"),X.makeSelectable(h.domElement,!1),h.__selector=document.createElement("div"),h.__selector.className="selector",h.__saturation_field=document.createElement("div"),h.__saturation_field.className="saturation-field",h.__field_knob=document.createElement("div"),h.__field_knob.className="field-knob",h.__field_knob_border="2px solid ",h.__hue_knob=document.createElement("div"),h.__hue_knob.className="hue-knob",h.__hue_field=document.createElement("div"),h.__hue_field.className="hue-field",h.__input=document.createElement("input"),h.__input.type="text",h.__input_textShadow="0 1px 1px ",X.bind(h.__input,"keydown",function(e){13===e.keyCode&&a.call(this)}),X.bind(h.__input,"blur",a),X.bind(h.__selector,"mousedown",function(){X.addClass(this,"drag").bind(window,"mouseup",function(){X.removeClass(p.__selector,"drag")})}),X.bind(h.__selector,"touchstart",function(){X.addClass(this,"drag").bind(window,"touchend",function(){X.removeClass(p.__selector,"drag")})});var f=document.createElement("div");return S.extend(h.__selector.style,{width:"122px",height:"102px",padding:"3px",backgroundColor:"#222",boxShadow:"0px 1px 3px rgba(0,0,0,0.3)"}),S.extend(h.__field_knob.style,{position:"absolute",width:"12px",height:"12px",border:h.__field_knob_border+(h.__color.v<.5?"#fff":"#000"),boxShadow:"0px 1px 3px rgba(0,0,0,0.5)",borderRadius:"12px",zIndex:1}),S.extend(h.__hue_knob.style,{position:"absolute",width:"15px",height:"2px",borderRight:"4px solid #fff",zIndex:1}),S.extend(h.__saturation_field.style,{width:"100px",height:"100px",border:"1px solid #555",marginRight:"3px",display:"inline-block",cursor:"pointer"}),S.extend(f.style,{width:"100%",height:"100%",background:"none"}),l(f,"top","rgba(0,0,0,0)","#000"),S.extend(h.__hue_field.style,{width:"15px",height:"100px",border:"1px solid #555",cursor:"ns-resize",position:"absolute",top:"3px",right:"3px"}),d(h.__hue_field),S.extend(h.__input.style,{outline:"none",textAlign:"center",color:"#fff",border:0,fontWeight:"bold",textShadow:h.__input_textShadow+"rgba(0,0,0,0.7)"}),X.bind(h.__saturation_field,"mousedown",o),X.bind(h.__saturation_field,"touchstart",o),X.bind(h.__field_knob,"mousedown",o),X.bind(h.__field_knob,"touchstart",o),X.bind(h.__hue_field,"mousedown",i),X.bind(h.__hue_field,"touchstart",i),h.__saturation_field.appendChild(f),h.__selector.appendChild(h.__field_knob),h.__selector.appendChild(h.__saturation_field),h.__selector.appendChild(h.__hue_field),h.__hue_field.appendChild(h.__hue_knob),h.domElement.appendChild(h.__input),h.domElement.appendChild(h.__selector),h.updateDisplay(),h}return j(t,z),P(t,[{key:"updateDisplay",value:function(){var e=R(this.getValue());if(!1!==e){var t=!1;S.each(I.COMPONENTS,function(n){if(!S.isUndefined(e[n])&&!S.isUndefined(this.__color.__state[n])&&e[n]!==this.__color.__state[n])return t=!0,{}},this),t&&S.extend(this.__color.__state,e)}S.extend(this.__temp.__state,this.__color.__state),this.__temp.a=1;var n=this.__color.v<.5||this.__color.s>.5?255:0,o=255-n;S.extend(this.__field_knob.style,{marginLeft:100*this.__color.s-7+"px",marginTop:100*(1-this.__color.v)-7+"px",backgroundColor:this.__temp.toHexString(),border:this.__field_knob_border+"rgb("+n+","+n+","+n+")"}),this.__hue_knob.style.marginTop=100*(1-this.__color.h/360)+"px",this.__temp.s=1,this.__temp.v=1,l(this.__saturation_field,"left","#fff",this.__temp.toHexString()),this.__input.value=this.__color.toString(),S.extend(this.__input.style,{backgroundColor:this.__color.toHexString(),color:"rgb("+n+","+n+","+n+")",textShadow:this.__input_textShadow+"rgba("+o+","+o+","+o+",.7)"})}}]),t}(),ee=["-moz-","-o-","-webkit-","-ms-",""],te={load:function(e,t){var n=t||document,o=n.createElement("link");o.type="text/css",o.rel="stylesheet",o.href=e,n.getElementsByTagName("head")[0].appendChild(o)},inject:function(e,t){var n=t||document,o=document.createElement("style");o.type="text/css",o.innerHTML=e;var i=n.getElementsByTagName("head")[0];try{i.appendChild(o)}catch(e){}}},ne=function(e,t){var n=e[t];return S.isArray(arguments[2])||S.isObject(arguments[2])?new Y(e,t,arguments[2]):S.isNumber(n)?S.isNumber(arguments[2])&&S.isNumber(arguments[3])?S.isNumber(arguments[4])?new q(e,t,arguments[2],arguments[3],arguments[4]):new q(e,t,arguments[2],arguments[3]):S.isNumber(arguments[4])?new Q(e,t,{min:arguments[2],max:arguments[3],step:arguments[4]}):new Q(e,t,{min:arguments[2],max:arguments[3]}):S.isString(n)?new J(e,t):S.isFunction(n)?new Z(e,t,""):S.isBoolean(n)?new K(e,t):null},oe=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)},ie=function(){function e(){F(this,e),this.backgroundElement=document.createElement("div"),S.extend(this.backgroundElement.style,{backgroundColor:"rgba(0,0,0,0.8)",top:0,left:0,display:"none",zIndex:"1000",opacity:0,WebkitTransition:"opacity 0.2s linear",transition:"opacity 0.2s linear"}),X.makeFullscreen(this.backgroundElement),this.backgroundElement.style.position="fixed",this.domElement=document.createElement("div"),S.extend(this.domElement.style,{position:"fixed",display:"none",zIndex:"1001",opacity:0,WebkitTransition:"-webkit-transform 0.2s ease-out, opacity 0.2s linear",transition:"transform 0.2s ease-out, opacity 0.2s linear"}),document.body.appendChild(this.backgroundElement),document.body.appendChild(this.domElement);var t=this;X.bind(this.backgroundElement,"click",function(){t.hide()})}return P(e,[{key:"show",value:function(){var e=this;this.backgroundElement.style.display="block",this.domElement.style.display="block",this.domElement.style.opacity=0,this.domElement.style.webkitTransform="scale(1.1)",this.layout(),S.defer(function(){e.backgroundElement.style.opacity=1,e.domElement.style.opacity=1,e.domElement.style.webkitTransform="scale(1)"})}},{key:"hide",value:function(){var e=this,t=function t(){e.domElement.style.display="none",e.backgroundElement.style.display="none",X.unbind(e.domElement,"webkitTransitionEnd",t),X.unbind(e.domElement,"transitionend",t),X.unbind(e.domElement,"oTransitionEnd",t)};X.bind(this.domElement,"webkitTransitionEnd",t),X.bind(this.domElement,"transitionend",t),X.bind(this.domElement,"oTransitionEnd",t),this.backgroundElement.style.opacity=0,this.domElement.style.opacity=0,this.domElement.style.webkitTransform="scale(1.1)"}},{key:"layout",value:function(){this.domElement.style.left=window.innerWidth/2-X.getWidth(this.domElement)/2+"px",this.domElement.style.top=window.innerHeight/2-X.getHeight(this.domElement)/2+"px"}}]),e}(),re=function(e){if(e&&"undefined"!=typeof window){var t=document.createElement("style");return t.setAttribute("type","text/css"),t.innerHTML=e,document.head.appendChild(t),e}}(".dg ul{list-style:none;margin:0;padding:0;width:100%;clear:both}.dg.ac{position:fixed;top:0;left:0;right:0;height:0;z-index:0}.dg:not(.ac) .main{overflow:hidden}.dg.main{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear}.dg.main.taller-than-window{overflow-y:auto}.dg.main.taller-than-window .close-button{opacity:1;margin-top:-1px;border-top:1px solid #2c2c2c}.dg.main ul.closed .close-button{opacity:1 !important}.dg.main:hover .close-button,.dg.main .close-button.drag{opacity:1}.dg.main .close-button{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear;border:0;line-height:19px;height:20px;cursor:pointer;text-align:center;background-color:#000}.dg.main .close-button.close-top{position:relative}.dg.main .close-button.close-bottom{position:absolute}.dg.main .close-button:hover{background-color:#111}.dg.a{float:right;margin-right:15px;overflow-y:visible}.dg.a.has-save>ul.close-top{margin-top:0}.dg.a.has-save>ul.close-bottom{margin-top:27px}.dg.a.has-save>ul.closed{margin-top:0}.dg.a .save-row{top:0;z-index:1002}.dg.a .save-row.close-top{position:relative}.dg.a .save-row.close-bottom{position:fixed}.dg li{-webkit-transition:height .1s ease-out;-o-transition:height .1s ease-out;-moz-transition:height .1s ease-out;transition:height .1s ease-out;-webkit-transition:overflow .1s linear;-o-transition:overflow .1s linear;-moz-transition:overflow .1s linear;transition:overflow .1s linear}.dg li:not(.folder){cursor:auto;height:27px;line-height:27px;padding:0 4px 0 5px}.dg li.folder{padding:0;border-left:4px solid rgba(0,0,0,0)}.dg li.title{cursor:pointer;margin-left:-4px}.dg .closed li:not(.title),.dg .closed ul li,.dg .closed ul li>*{height:0;overflow:hidden;border:0}.dg .cr{clear:both;padding-left:3px;height:27px;overflow:hidden}.dg .property-name{cursor:default;float:left;clear:left;width:40%;overflow:hidden;text-overflow:ellipsis}.dg .cr.function .property-name{width:100%}.dg .c{float:left;width:60%;position:relative}.dg .c input[type=text]{border:0;margin-top:4px;padding:3px;width:100%;float:right}.dg .has-slider input[type=text]{width:30%;margin-left:0}.dg .slider{float:left;width:66%;margin-left:-5px;margin-right:0;height:19px;margin-top:4px}.dg .slider-fg{height:100%}.dg .c input[type=checkbox]{margin-top:7px}.dg .c select{margin-top:5px}.dg .cr.function,.dg .cr.function .property-name,.dg .cr.function *,.dg .cr.boolean,.dg .cr.boolean *{cursor:pointer}.dg .cr.color{overflow:visible}.dg .selector{display:none;position:absolute;margin-left:-9px;margin-top:23px;z-index:10}.dg .c:hover .selector,.dg .selector.drag{display:block}.dg li.save-row{padding:0}.dg li.save-row .button{display:inline-block;padding:0px 6px}.dg.dialogue{background-color:#222;width:460px;padding:15px;font-size:13px;line-height:15px}#dg-new-constructor{padding:10px;color:#222;font-family:Monaco, monospace;font-size:10px;border:0;resize:none;box-shadow:inset 1px 1px 1px #888;word-wrap:break-word;margin:12px 0;display:block;width:440px;overflow-y:scroll;height:100px;position:relative}#dg-local-explain{display:none;font-size:11px;line-height:17px;border-radius:3px;background-color:#333;padding:8px;margin-top:10px}#dg-local-explain code{font-size:10px}#dat-gui-save-locally{display:none}.dg{color:#eee;font:11px 'Lucida Grande', sans-serif;text-shadow:0 -1px 0 #111}.dg.main::-webkit-scrollbar{width:5px;background:#1a1a1a}.dg.main::-webkit-scrollbar-corner{height:0;display:none}.dg.main::-webkit-scrollbar-thumb{border-radius:5px;background:#676767}.dg li:not(.folder){background:#1a1a1a;border-bottom:1px solid #2c2c2c}.dg li.save-row{line-height:25px;background:#dad5cb;border:0}.dg li.save-row select{margin-left:5px;width:108px}.dg li.save-row .button{margin-left:5px;margin-top:1px;border-radius:2px;font-size:9px;line-height:7px;padding:4px 4px 5px 4px;background:#c5bdad;color:#fff;text-shadow:0 1px 0 #b0a58f;box-shadow:0 -1px 0 #b0a58f;cursor:pointer}.dg li.save-row .button.gears{background:#c5bdad url() 2px 1px no-repeat;height:7px;width:8px}.dg li.save-row .button:hover{background-color:#bab19e;box-shadow:0 -1px 0 #b0a58f}.dg li.folder{border-bottom:0}.dg li.title{padding-left:16px;background:#000 url() 6px 10px no-repeat;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.2)}.dg .closed li.title{background-image:url()}.dg .cr.boolean{border-left:3px solid #806787}.dg .cr.color{border-left:3px solid}.dg .cr.function{border-left:3px solid #e61d5f}.dg .cr.number{border-left:3px solid #2FA1D6}.dg .cr.number input[type=text]{color:#2FA1D6}.dg .cr.string{border-left:3px solid #1ed36f}.dg .cr.string input[type=text]{color:#1ed36f}.dg .cr.function:hover,.dg .cr.boolean:hover{background:#111}.dg .c input[type=text]{background:#303030;outline:none}.dg .c input[type=text]:hover{background:#3c3c3c}.dg .c input[type=text]:focus{background:#494949;color:#fff}.dg .c .slider{background:#303030;cursor:ew-resize}.dg .c .slider-fg{background:#2FA1D6;max-width:100%}.dg .c .slider:hover{background:#3c3c3c}.dg .c .slider:hover .slider-fg{background:#44abda}\n");te.inject(re);var se="Default",ae=function(){try{return!!window.localStorage}catch(e){return!1}}(),le=void 0,de=!0,ce=void 0,ue=!1,_e=[],he=function e(t){var n=this,o=t||{};this.domElement=document.createElement("div"),this.__ul=document.createElement("ul"),this.domElement.appendChild(this.__ul),X.addClass(this.domElement,"dg"),this.__folders={},this.__controllers=[],this.__rememberedObjects=[],this.__rememberedObjectIndecesToControllers=[],this.__listening=[],o=S.defaults(o,{closeOnTop:!1,autoPlace:!0,width:e.DEFAULT_WIDTH}),o=S.defaults(o,{resizable:o.autoPlace,hideable:o.autoPlace}),S.isUndefined(o.load)?o.load={preset:se}:o.preset&&(o.load.preset=o.preset),S.isUndefined(o.parent)&&o.hideable&&_e.push(this),o.resizable=S.isUndefined(o.parent)&&o.resizable,o.autoPlace&&S.isUndefined(o.scrollable)&&(o.scrollable=!0);var i=ae&&"true"===localStorage.getItem(m(this,"isLocal")),r=void 0,s=void 0;if(Object.defineProperties(this,{parent:{get:function(){return o.parent}},scrollable:{get:function(){return o.scrollable}},autoPlace:{get:function(){return o.autoPlace}},closeOnTop:{get:function(){return o.closeOnTop}},preset:{get:function(){return n.parent?n.getRoot().preset:o.load.preset},set:function(e){n.parent?n.getRoot().preset=e:o.load.preset=e,E(this),n.revert()}},width:{get:function(){return o.width},set:function(e){o.width=e,w(n,e)}},name:{get:function(){return o.name},set:function(e){o.name=e,s&&(s.innerHTML=o.name)}},closed:{get:function(){return o.closed},set:function(t){o.closed=t,o.closed?X.addClass(n.__ul,e.CLASS_CLOSED):X.removeClass(n.__ul,e.CLASS_CLOSED),this.onResize(),n.__closeButton&&(n.__closeButton.innerHTML=t?e.TEXT_OPEN:e.TEXT_CLOSED)}},load:{get:function(){return o.load}},useLocalStorage:{get:function(){return i},set:function(e){ae&&(i=e,e?X.bind(window,"unload",r):X.unbind(window,"unload",r),localStorage.setItem(m(n,"isLocal"),e))}}}),S.isUndefined(o.parent)){if(this.closed=o.closed||!1,X.addClass(this.domElement,e.CLASS_MAIN),X.makeSelectable(this.domElement,!1),ae&&i){n.useLocalStorage=!0;var a=localStorage.getItem(m(this,"gui"));a&&(o.load=JSON.parse(a))}this.__closeButton=document.createElement("div"),this.__closeButton.innerHTML=e.TEXT_CLOSED,X.addClass(this.__closeButton,e.CLASS_CLOSE_BUTTON),o.closeOnTop?(X.addClass(this.__closeButton,e.CLASS_CLOSE_TOP),this.domElement.insertBefore(this.__closeButton,this.domElement.childNodes[0])):(X.addClass(this.__closeButton,e.CLASS_CLOSE_BOTTOM),this.domElement.appendChild(this.__closeButton)),X.bind(this.__closeButton,"click",function(){n.closed=!n.closed})}else{void 0===o.closed&&(o.closed=!0);var l=document.createTextNode(o.name);X.addClass(l,"controller-name"),s=c(n,l);X.addClass(this.__ul,e.CLASS_CLOSED),X.addClass(s,"title"),X.bind(s,"click",function(e){return e.preventDefault(),n.closed=!n.closed,!1}),o.closed||(this.closed=!1)}o.autoPlace&&(S.isUndefined(o.parent)&&(de&&(ce=document.createElement("div"),X.addClass(ce,"dg"),X.addClass(ce,e.CLASS_AUTO_PLACE_CONTAINER),document.body.appendChild(ce),de=!1),ce.appendChild(this.domElement),X.addClass(this.domElement,e.CLASS_AUTO_PLACE)),this.parent||w(n,o.width)),this.__resizeHandler=function(){n.onResizeDebounced()},X.bind(window,"resize",this.__resizeHandler),X.bind(this.__ul,"webkitTransitionEnd",this.__resizeHandler),X.bind(this.__ul,"transitionend",this.__resizeHandler),X.bind(this.__ul,"oTransitionEnd",this.__resizeHandler),this.onResize(),o.resizable&&y(this),r=function(){ae&&"true"===localStorage.getItem(m(n,"isLocal"))&&localStorage.setItem(m(n,"gui"),JSON.stringify(n.getSaveObject()))},this.saveToLocalStorageIfPossible=r,o.parent||function(){var e=n.getRoot();e.width+=1,S.defer(function(){e.width-=1})}()};he.toggleHide=function(){ue=!ue,S.each(_e,function(e){e.domElement.style.display=ue?"none":""})},he.CLASS_AUTO_PLACE="a",he.CLASS_AUTO_PLACE_CONTAINER="ac",he.CLASS_MAIN="main",he.CLASS_CONTROLLER_ROW="cr",he.CLASS_TOO_TALL="taller-than-window",he.CLASS_CLOSED="closed",he.CLASS_CLOSE_BUTTON="close-button",he.CLASS_CLOSE_TOP="close-top",he.CLASS_CLOSE_BOTTOM="close-bottom",he.CLASS_DRAG="drag",he.DEFAULT_WIDTH=245,he.TEXT_CLOSED="Close Controls",he.TEXT_OPEN="Open Controls",he._keydownHandler=function(e){"text"===document.activeElement.type||72!==e.which&&72!==e.keyCode||he.toggleHide()},X.bind(window,"keydown",he._keydownHandler,!1),S.extend(he.prototype,{add:function(e,t){return f(this,e,t,{factoryArgs:Array.prototype.slice.call(arguments,2)})},addColor:function(e,t){return f(this,e,t,{color:!0})},remove:function(e){this.__ul.removeChild(e.__li),this.__controllers.splice(this.__controllers.indexOf(e),1);var t=this;S.defer(function(){t.onResize()})},destroy:function(){if(this.parent)throw new Error("Only the root GUI should be removed with .destroy(). For subfolders, use gui.removeFolder(folder) instead.");this.autoPlace&&ce.removeChild(this.domElement);var e=this;S.each(this.__folders,function(t){e.removeFolder(t)}),X.unbind(window,"keydown",he._keydownHandler,!1),u(this)},addFolder:function(e){if(void 0!==this.__folders[e])throw new Error('You already have a folder in this GUI by the name "'+e+'"');var t={name:e,parent:this};t.autoPlace=this.autoPlace,this.load&&this.load.folders&&this.load.folders[e]&&(t.closed=this.load.folders[e].closed,t.load=this.load.folders[e]);var n=new he(t);this.__folders[e]=n;var o=c(this,n.domElement);return X.addClass(o,"folder"),n},removeFolder:function(e){this.__ul.removeChild(e.domElement.parentElement),delete this.__folders[e.name],this.load&&this.load.folders&&this.load.folders[e.name]&&delete this.load.folders[e.name],u(e);var t=this;S.each(e.__folders,function(t){e.removeFolder(t)}),S.defer(function(){t.onResize()})},open:function(){this.closed=!1},close:function(){this.closed=!0},hide:function(){this.domElement.style.display="none"},show:function(){this.domElement.style.display=""},onResize:function(){var e=this.getRoot();if(e.scrollable){var t=X.getOffset(e.__ul).top,n=0;S.each(e.__ul.childNodes,function(t){e.autoPlace&&t===e.__save_row||(n+=X.getHeight(t))}),window.innerHeight-t-20GUI\'s constructor:\n\n \n\n
\n\n Automatically save\n values to localStorage on exit.\n\n
The values saved to localStorage will\n override those passed to dat.GUI\'s constructor. This makes it\n easier to work incrementally, but localStorage is fragile,\n and your friends may not see the same values you do.\n\n
\n\n
\n\n'),this.parent)throw new Error("You can only call remember on a top level GUI.");var e=this;S.each(Array.prototype.slice.call(arguments),function(t){0===e.__rememberedObjects.length&&v(e),-1===e.__rememberedObjects.indexOf(t)&&e.__rememberedObjects.push(t)}),this.autoPlace&&w(this,this.width)},getRoot:function(){for(var e=this;e.parent;)e=e.parent;return e},getSaveObject:function(){var e=this.load;return e.closed=this.closed,this.__rememberedObjects.length>0&&(e.preset=this.preset,e.remembered||(e.remembered={}),e.remembered[this.preset]=x(this)),e.folders={},S.each(this.__folders,function(t,n){e.folders[n]=t.getSaveObject()}),e},save:function(){this.load.remembered||(this.load.remembered={}),this.load.remembered[this.preset]=x(this),_(this,!1),this.saveToLocalStorageIfPossible()},saveAs:function(e){this.load.remembered||(this.load.remembered={},this.load.remembered[se]=x(this,!0)),this.load.remembered[e]=x(this),this.preset=e,g(this,e,!0),this.saveToLocalStorageIfPossible()},revert:function(e){S.each(this.__controllers,function(t){this.getRoot().load.remembered?p(e||this.getRoot(),t):t.setValue(t.initialValue),t.__onFinishChange&&t.__onFinishChange.call(t,t.getValue())},this),S.each(this.__folders,function(e){e.revert(e)}),e||_(this.getRoot(),!1)},listen:function(e){var t=0===this.__listening.length;this.__listening.push(e),t&&C(this.__listening)},updateDisplay:function(){S.each(this.__controllers,function(e){e.updateDisplay()}),S.each(this.__folders,function(e){e.updateDisplay()})}});var pe={Color:I,math:N,interpret:R},fe={Controller:z,BooleanController:K,OptionController:Y,StringController:J,NumberController:W,NumberControllerBox:Q,NumberControllerSlider:q,FunctionController:Z,ColorController:$},me={dom:X},ge={GUI:he},be=he,ve={color:pe,controllers:fe,dom:me,gui:ge,GUI:be};e.color=pe,e.controllers=fe,e.dom=me,e.gui=ge,e.GUI=be,e.default=ve,Object.defineProperty(e,"__esModule",{value:!0})}); 14 | --------------------------------------------------------------------------------