1
0
mirror of https://github.com/Foltik/Shimapan synced 2025-01-07 08:42:49 -05:00

Restructure and add video index

This commit is contained in:
Jack 2017-10-14 15:16:58 -04:00
parent de709abe89
commit 1c97b75667
Signed by: foltik
GPG Key ID: 303F88F996E95541
28 changed files with 878 additions and 49 deletions

View File

@ -1,4 +1,5 @@
var index = require('./routes/index.js'); var index = require('./routes/index.js');
var home = require('./routes/home.js');
var upload = require('./routes/upload.js'); var upload = require('./routes/upload.js');
var view = require('./routes/view.js'); var view = require('./routes/view.js');
var auth = require('./routes/auth.js'); var auth = require('./routes/auth.js');
@ -16,6 +17,7 @@ var jwtauth = jwt({
module.exports = function(app) { module.exports = function(app) {
app.use('/', index); app.use('/', index);
app.use('/home', home);
app.use('/v', view); app.use('/v', view);
app.use('/api/upload', jwtauth, upload); app.use('/api/upload', jwtauth, upload);
app.use('/api/auth', auth); app.use('/api/auth', auth);

9
app/routes/home.js Normal file
View File

@ -0,0 +1,9 @@
var express = require('express');
var router = express.Router();
var path = require('path');
router.get('/', function(req, res) {
res.sendFile(path.join(__dirname, '../../public/views', 'home.html'));
});
module.exports = router;

47
public/css/index.css Normal file
View File

@ -0,0 +1,47 @@
* {
margin: 0;
}
body {
background: #000;
}
a {
position: absolute;
top: 5px;
left: 48%;
opacity: 0.1;
height: 30px;
width: 30px;
z-index: 100;
cursor: default;
}
a img {
width: 30px;
height: 30px;
}
canvas {
position: absolute;
top: 0;
left: 0;
}
video {
position: fixed;
top: 50%;
left: 50%;
min-width: 100%;
min-height: 100%;
width: 1920px;
height: 760px;
z-index: -100;
transform: translateX(-50%) translateY(-50%);
background-size: cover;
transition: 1s opacity;
}
#buffer {
display: none;
}

View File

@ -0,0 +1,110 @@
*, *:before, *:after {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html, body {
height: 100vh;
}
body {
font: 600 14px 'Roboto', sans-serif;
color: #000000;
background: #000000;
overflow-x: hidden;
}
.container {
display: flex;
min-height: 100%;
}
.sidebar {
position: absolute;
width: 220px;
}
.content {
flex: 1;
padding: 30px;
background: #444444;
box-shadow: 0 0 5px rgba(0,0,0,1);
transform: translate3d(0,0,0);
transition: transform .3s;
color: #cccccc;
}
.content.isOpen {
transform: translate3d(220px,0,0);
}
.button {
cursor: pointer;
}
.button:before {
content: '\f0c9';
font: 42px fontawesome;
color: #eeeeee;
}
.sidebar-title {
font-size: 16px;
line-height: 50px;
text-align: center;
text-transform: uppercase;
letter-spacing: 7px;
color: #eee;
border-bottom: 1px solid #222;
background: #2a2a2a;
}
.nav li a {
position: relative;
display: block;
padding: 20px 0 20px 50px;
font-size: 14px;
color: #eee;
background: #333333;
border-bottom: 1px solid #222;
text-decoration: none;
}
.nav li a:before {
font: 14px fontawesome;
position: absolute;
top: 19px;
left: 20px;
}
.nav li:nth-child(1) a:before { content: '\f00a'; }
.nav li:nth-child(2) a:before { content: '\f002'; }
.nav li:nth-child(3) a:before { content: '\f084'; }
.nav li:nth-child(4) a:before { content: '\f0e0'; }
.nav li:nth-child(5) a:before { content: '\f0c0'; }
.nav li:nth-child(6) a:before { content: '\f233'; }
.nav li:nth-child(7) a:before { content: '\f023'; left: 23px; }
.nav li a:hover {
background: #444;
}
.nav li a.active {
box-shadow: inset 5px 0 0 #2A9FD6, inset 6px 0 0 #222;
background: #444;
}
/* Demo Description */
h1 {
margin: 25px 0 15px;
font-size: 28px;
font-weight: 400;
}
h2 {
font-size: 18px;
font-weight: 400;
color: #999;
}

View File

@ -68,4 +68,9 @@ angular.module('AuthSvc', []).service('AuthService', ['$http', '$window', functi
var payload = decodeToken(getToken()); var payload = decodeToken(getToken());
return payload.username; return payload.username;
}; };
this.currentScope = function() {
var payload = decodeToken(getToken());
return payload.scope;
}
}]); }]);

View File

@ -1 +0,0 @@
var app = angular.module('shimapan-panel', ['ui.router', 'PanelRoutes']);

View File

@ -0,0 +1,17 @@
angular.module('NavCtrl', ['AuthSvc']).controller('NavController', ['$scope', '$window', 'AuthService', function($scope, $window, AuthService) {
$scope.isLoggedIn = AuthService.isLoggedIn();
$scope.currentUser = AuthService.currentUser();
$scope.currentScope = AuthService.currentScope();
$scope.logout = AuthService.logout;
$scope.goLogout = function() {
$scope.logout();
$window.location.href = '/';
};
$scope.hasPermission = function(permission) {
if (!$scope.currentScope) return false;
return $scope.currentScope.indexOf(permission) !== -1;
};
}]);

View File

@ -6,9 +6,9 @@ angular.module('PanelRoutes', ['ui.router']).config(['$stateProvider', '$urlRout
$stateProvider $stateProvider
.state('/panel', { .state('/panel', {
url: '/panel', url: '/panel',
templateUrl: '/views/panel-home.html' templateUrl: '/views/shimapan-panel/panel-home.html'
}).state('/panel/api', { }).state('/panel/api', {
url: '/panel/api', url: '/panel/api',
templateUrl: '/views/panel-api.html' templateUrl: '/views/shimapan-panel/panel-api.html'
}); });
}]); }]);

View File

@ -0,0 +1,6 @@
var app = angular.module('shimapan-panel', ['ui.router', 'NavCtrl', 'PanelRoutes']);
app.run(['$rootScope', '$state', '$stateParams', function($rootScope, $state, $stateParams) {
$rootScope.$state = $state;
$rootScope.$stateParams = $stateParams;
}]);

View File

@ -10,6 +10,6 @@ function LoginController($scope, AuthService) {
} }
angular.module('LoginComp', ['AuthSvc']).component('loginComponent', { angular.module('LoginComp', ['AuthSvc']).component('loginComponent', {
templateUrl: '/views/login-form.html', templateUrl: '/views/shimapan/login-form.html',
controller: LoginController controller: LoginController
}); });

View File

@ -11,6 +11,6 @@ function RegisterController($scope, AuthService) {
} }
angular.module('RegisterComp', ['AuthSvc']).component('registerComponent', { angular.module('RegisterComp', ['AuthSvc']).component('registerComponent', {
templateUrl: '/views/register-form.html', templateUrl: '/views/shimapan/register-form.html',
controller: RegisterController controller: RegisterController
}); });

View File

@ -27,11 +27,13 @@ function UploadController($scope, Upload, $timeout, AuthService) {
}); });
}, },
function (response) { function (response) {
if (response.status > 0) { if (response.status !== 200) {
if (response.status === 401) { if (response.status === 401) {
file.$error = "Invalid authorization token."; file.$error = "Invalid authorization token";
} else if (response.status === 403) {
file.$error = "Forbidden";
} else { } else {
file.$error = "Internal server error."; file.$error = "Unknown error " + response.status;
} }
var index = $scope.files.indexOf(file); var index = $scope.files.indexOf(file);
$scope.errorFiles.push(file); $scope.errorFiles.push(file);
@ -47,7 +49,7 @@ function UploadController($scope, Upload, $timeout, AuthService) {
} }
angular.module('UploadComp', ['ngFileUpload', 'AuthSvc']).component('uploadComponent', { angular.module('UploadComp', ['ngFileUpload', 'AuthSvc']).component('uploadComponent', {
templateUrl: '/views/upload-form.html', templateUrl: '/views/shimapan/upload-form.html',
controller: UploadController, controller: UploadController,
controllerAs: 'vm' controllerAs: 'vm'
}); });

599
public/js/typegraph.js Normal file
View File

@ -0,0 +1,599 @@
var camera = {
focus: 600,
self: {
x: 0,
y: 0,
z: 0
},
rotate: {
x: 0,
y: 0,
z: 0
},
up: {
x: 0,
y: 1,
z: 0
},
zoom: 1,
display: {
x: window.innerWidth / 2,
y: window.innerHeight * (13/16),
z: 0
}
};
var affine = {
world: {
size: function (p, size) {
return {
x: p.x * size.x,
y: p.y * size.y,
z: p.z * size.z
}
},
rotate: {
x: function (p, rotate) {
return {
x: p.x,
y: p.y * Math.cos(dtr(rotate.x)) - p.z * Math.sin(dtr(rotate.x)),
z: p.y * Math.sin(dtr(rotate.x)) + p.z * Math.cos(dtr(rotate.x))
}
},
y: function (p, rotate) {
return {
x: p.x * Math.cos(dtr(rotate.y)) + p.z * Math.sin(dtr(rotate.y)),
y: p.y,
z: -p.x * Math.sin(dtr(rotate.y)) + p.z * Math.cos(dtr(rotate.y))
}
},
z: function (p, rotate) {
return {
x: p.x * Math.cos(dtr(rotate.z)) - p.y * Math.sin(dtr(rotate.z)),
y: p.x * Math.sin(dtr(rotate.z)) + p.y * Math.cos(dtr(rotate.z)),
z: p.z
}
}
},
position: function (p, position) {
return {
x: p.x + position.x,
y: p.y + position.y,
z: p.z + position.z
}
}
},
view: {
point: function (p) {
return {
x: p.x - camera.self.x,
y: p.y - camera.self.y,
z: p.z - camera.self.z
}
},
x: function (p) {
return {
x: p.x,
y: p.y * Math.cos(dtr(camera.rotate.x)) - p.z * Math.sin(dtr(camera.rotate.x)),
z: p.y * Math.sin(dtr(camera.rotate.x)) + p.z * Math.cos(dtr(camera.rotate.x))
}
},
y: function (p) {
return {
x: p.x * Math.cos(dtr(camera.rotate.y)) + p.z * Math.sin(dtr(camera.rotate.y)),
y: p.y,
z: p.x * -Math.sin(dtr(camera.rotate.y)) + p.z * Math.cos(dtr(camera.rotate.y))
}
},
viewReset: function (p) {
return {
x: p.x - camera.self.x,
y: p.y - camera.self.y,
z: p.z - camera.self.z
}
},
righthandedReversal: function (p) {
return {
x: p.x,
y: -p.y,
z: p.z
}
}
},
perspective: function (p) {
return {
x: p.x * ((camera.focus - camera.self.z) / ((camera.focus - camera.self.z) - p.z)) * camera.zoom,
y: p.y * ((camera.focus - camera.self.z) / ((camera.focus - camera.self.z) - p.z)) * camera.zoom,
z: p.z * ((camera.focus - camera.self.z) / ((camera.focus - camera.self.z) - p.z)) * camera.zoom,
p: ((camera.focus - camera.self.z) / ((camera.focus - camera.self.z) - p.z)) * camera.zoom
}
},
display: function (p, display) {
return {
x: p.x + display.x,
y: p.y + display.y,
z: p.z + display.z,
p: p.p
}
},
process: function (model, size, rotate, position, display) {
var ret = affine.world.size(model, size);
ret = affine.world.rotate.x(ret, rotate);
ret = affine.world.rotate.y(ret, rotate);
ret = affine.world.rotate.z(ret, rotate);
ret = affine.world.position(ret, position);
ret = affine.view.point(ret);
ret = affine.view.x(ret);
ret = affine.view.y(ret);
ret = affine.view.viewReset(ret);
ret = affine.view.righthandedReversal(ret);
ret = affine.perspective(ret);
ret = affine.display(ret, display);
return ret;
}
};
var vertex3d = function (param) {
this.affineIn = {};
this.affineOut = {};
if (param.vertex !== undefined) {
this.affineIn.vertex = param.vertex;
} else {
this.affineIn.vertex = {x: 0, y: 0, z: 0};
}
if (param.size !== undefined) {
this.affineIn.size = param.size;
} else {
this.affineIn.size = {x: 1, y: 1, z: 1};
}
if (param.rotate !== undefined) {
this.affineIn.rotate = param.rotate;
} else {
this.affineIn.rotate = {x: 0, y: 0, z: 0};
}
if (param.position !== undefined) {
this.affineIn.position = param.position;
} else {
this.affineIn.position = {x: 0, y: 0, z: 0};
}
};
vertex3d.prototype = {
vertexUpdate: function () {
this.affineOut = affine.process(
this.affineIn.vertex,
this.affineIn.size,
this.affineIn.rotate,
this.affineIn.position,
camera.display
);
}
};
var dtr = function (v) {
return v * Math.PI / 180;
};
//cordinate system transformation.
//polar to rectangle.
var polarToRectangle = function (dX, dY, radius) {
var x = Math.sin(dtr(dX)) * Math.cos(dtr(dY)) * radius;
var y = Math.sin(dtr(dX)) * Math.sin(dtr(dY)) * radius;
var z = Math.cos(dtr(dX)) * radius;
return {x: y, y: z, z: x};
};
//rectangle to polar.
var rectangleToPolar = function (x, y, z) {
var xD;
var yD;
var zD;
if (x === 0) xD = 0.001;
else xD = x;
if (y === 0) yD = 0.001;
else yD = y;
if (z === 0) zD = 0.001;
else zD = z;
var radius = Math.sqrt(xD * xD + yD * yD + zD * zD);
var theta = Math.atan(zD / Math.sqrt(xD * xD + yD * yD));
var phi = Math.atan(yD / xD);
return {x: theta * (180 / Math.PI), y: phi * (180 / Math.PI), r: radius};
};
var closeValue = function (minTime, maxTime) {
this.flag = 0;
this.progress = 0;
this.startTime = 0;
this.durationTime = 0;
this.fromValue = 0;
this.toValue = 0;
this.minValue = 0;
this.maxValue = 1;
this.minDuration = minTime;
this.maxDuration = maxTime;
};
closeValue.prototype = {
init: function () {
this.durationTime = this.minDuration + (this.maxDuration - this.minDuration) * Math.random();
this.startTime = Date.now();
this.progress = Math.min(1, ((Date.now() - this.startTime) / this.durationTime));
this.fromValue = this.toValue;
this.toValue = this.minValue + this.maxValue * Math.random();
this.flag = 1;
return this.fromValue + (this.toValue - this.fromValue) * this.progress;
},
update: function () {
this.progress = Math.min(1, ((Date.now() - this.startTime) / this.durationTime));
if (this.progress === 1) this.flag = 0;
return this.fromValue + (this.toValue - this.fromValue) * this.progress;
},
execution: function () {
if (this.flag === 0) {
return this.init()
}
else if (this.flag === 1) {
return this.update()
}
}
};
var strokeColor = "rgba(255,255,255,0.1)";
var backgroundColor = "rgba(0,0,0,0)";
var vibrateFlag = false;
var canvas = document.getElementById("canvas");
var canvasWidth = window.innerWidth;
var canvasHeight = window.innerHeight;
canvas.width = canvasWidth;
canvas.height = canvasHeight;
var ctx = canvas.getContext("2d");
ctx.strokeStyle = strokeColor;
window.onresize = function () {
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
camera.display.x = window.innerWidth / 2;
camera.display.y = window.innerHeight * (13/16);
};
/* class */
var sphere = function (arg) {
this.flag = true;
this.type = "_";
this.particleNum = arg.particleNum;
this.center = {x: 0, y: 0, z: 0};
this.targetCenter = arg.center;
this.radius = 0;
this.targetRadius = arg.radius;
this.degree = [];
this.freeDegreeSpeed = [];
for (var j = 0; j < this.particleNum; j++) {
this.degree[j] = {theta: 0, phi: 0};
this.freeDegreeSpeed[j] = {theta: Math.random() - 0.5, phi: Math.random() - 0.5};
}
this.charsMap = {};
for (var i in chars) {
var buffer = document.getElementById(i).getContext("2d").getImageData(0, 0, 100, 100).data;
this.charsMap[i] = [];
var self = this;
for (var j = 0; j < this.particleNum; j++) {
var redo = function () {
var theta = Math.floor(Math.random() * 100);
var phi = Math.floor(Math.random() * 100);
if (buffer[(theta * 400 + (phi * 4))] === 0) {
self.charsMap[i].push(
{
theta: theta - 50 + 360 * Math.round(Math.random() * 2) - 1,
phi: phi - 50 + 360 * Math.round(Math.random() * 2) - 1
}
);
} else {
redo();
}
};
redo();
}
}
this.charsMap["@"] = [];
for (var i = 0; i < this.particleNum; i++) {
this.charsMap["@"][i] = {theta: 360 * Math.random(), phi: 360 * Math.random()};
}
this.charsMap["_"] = [];
for (var i = 0; i < this.particleNum; i++) {
this.charsMap["_"][i] = {theta: 0, phi: 0};
}
this.veticies = [];
for (var i = 0; i < this.particleNum; i++) {
this.veticies[i] = new vertex3d({});
}
};
sphere.prototype = {
update: function () {
for (var i = 0; i < this.charsMap[this.type].length; i++) {
if (this.degree[i].theta >= 30 && this.degree[i].phi >= 30) {
this.flag = true;
break;
} else {
this.flag = false;
}
}
this.radius = this.radius + (this.targetRadius - this.radius) / 8;
this.center.x = this.center.x + (this.targetCenter.x - this.center.x) / 8;
this.center.y = this.center.y + (this.targetCenter.y - this.center.y) / 8;
this.center.z = this.center.z + (this.targetCenter.z - this.center.z) / 8;
for (var i = 0; i < this.charsMap[this.type].length; i++) {
if (this.type === "@") {
this.charsMap[this.type][i].theta += this.freeDegreeSpeed[i].theta;
this.charsMap[this.type][i].phi += this.freeDegreeSpeed[i].phi;
}
this.degree[i].theta = this.degree[i].theta + (this.charsMap[this.type][i].theta - this.degree[i].theta) / (4 + 20 * Math.random());
this.degree[i].phi = this.degree[i].phi + (this.charsMap[this.type][i].phi - this.degree[i].phi) / (4 + 20 * Math.random());
var getPosition;
if (vibrateFlag === true) {
getPosition = polarToRectangle(this.degree[i].theta + 90, this.degree[i].phi, this.radius + Math.random() * 10);
} else {
getPosition = polarToRectangle(this.degree[i].theta + 90, this.degree[i].phi, this.radius);
}
this.veticies[i].affineIn.vertex = {
x: getPosition.x,
y: getPosition.y,
z: getPosition.z
};
this.veticies[i].affineIn.position = {
x: this.center.x,
y: this.center.y,
z: this.center.z
};
this.veticies[i].vertexUpdate();
}
},
draw: function () {
if (this.flag === true) {
ctx.beginPath();
for (var i = 0; i < this.veticies.length; i++) {
for (var j = i; j < this.veticies.length; j++) {
var distance =
(this.veticies[i].affineOut.x - this.veticies[j].affineOut.x) * (this.veticies[i].affineOut.x - this.veticies[j].affineOut.x) +
(this.veticies[i].affineOut.y - this.veticies[j].affineOut.y) * (this.veticies[i].affineOut.y - this.veticies[j].affineOut.y);
if (distance <= this.radius * 3) {
ctx.moveTo(
this.veticies[i].affineOut.x,
this.veticies[i].affineOut.y
);
ctx.lineTo(
this.veticies[j].affineOut.x,
this.veticies[j].affineOut.y
);
}
}
}
ctx.closePath();
ctx.stroke();
}
}
};
/* class */
var sphereNum = 20;
var s = [];
/*-----------------------------------------------------*/
var setup = function () {
for (var i = 0; i < sphereNum; i++) {
s[i] = new sphere({radius: 100, particleNum: 250, center: {x: 70 * i - (sphereNum - 1) * 70 / 2, y: 0, z: 0}});
}
};
/*-----------------------------------------------------*/
var update = function () {
for (var i = 0; i < sphereNum; i++) {
s[i].update();
}
};
/*-----------------------------------------------------*/
var draw = function () {
for (var i = 0; i < sphereNum; i++) {
s[i].draw();
}
};
var chars = {
A: "",
B: "",
C: "",
D: "",
E: "",
F: "",
G: "",
H: "",
I: "",
J: "",
K: "",
L: "",
M: "",
N: "",
O: "",
P: "",
Q: "",
R: "",
S: "",
T: "",
U: "",
V: "",
W: "",
X: "",
Y: "",
Z: "",
"!": "",
"?": "",
"0": "",
"1": "",
"2": "",
"3": "",
"4": "",
"5": "",
"6": "",
"7": "",
"8": "",
"9": "",
".": "",
"ガ": "",
"ラ": "",
"ス": "",
};
//ガラス
var charsLength = 0;
var charCounter = 0;
var bufferImages = {};
var bufferCanvases = {};
for (var i in chars) {
charsLength++;
bufferImages[i] = new Image();
bufferImages[i].src = chars[i];
bufferImages[i].onload = function () {
charCounter++;
if (charCounter === charsLength) {
bufferDraw();
}
};
}
var bufferDraw = function () {
for (var i in chars) {
var canvas = document.createElement("canvas");
canvas.id = i;
document.getElementById("buffer").appendChild(canvas);
document.getElementById(i).getContext("2d").drawImage(
bufferImages[i],
0,
0,
100,
100
);
}
start();
};
var textChanger = function (text, sphereRadius, sphereSpace, unitTime) {
var changeIncrement = 0;
var charNum = text.length;
var center = [];
for (var i = 0; i < charNum; i++) {
center[i] = {x: sphereSpace * i - sphereSpace * (charNum - 1) / 2, y: 0, z: 0};
}
var changer = function () {
setTimeout(function () {
s[changeIncrement].type = text[changeIncrement];
s[changeIncrement].targetCenter = center[changeIncrement];
s[changeIncrement].targetRadius = sphereRadius;
changeIncrement++;
if (changeIncrement < charNum) {
changer();
}
}, unitTime);
};
for (var i = charNum; i < s.length; i++) {
s[i].type = "_";
}
changer();
};
var fullSet = function () {
var alpha = "ABCDEFGHIJKLMNOPQRSTUVWXYZ__?!1234567890";
var col = 10;
var colUnit = 80;
var rowUnit = 120;
for (var i = 0; i < alpha.length; i++) {
s[i].targetCenter = {
x: (i % 10) * colUnit - (col - 1) * colUnit / 2,
y: Math.floor(i / 10) * -rowUnit + 180,
z: 0
};
s[i].type = alpha[i];
}
};
var textSet = [
{text: "SHIMAPAN.ROCKS", sphereRadius: 140, sphereSpace: 80, unitTime: 100, time: 3000},
{text: "@@@@@@", sphereRadius: 100, sphereSpace: 130, unitTime: 50, time: 5000},
{text: "FOLTIK", sphereRadius: 130, sphereSpace: 100, unitTime: 100, time: 750},
{text: "@@@@@@@@", sphereRadius: 100, sphereSpace: 130, unitTime: 50, time: 3000},
{text: "WXYZZYRD", sphereRadius: 130, sphereSpace: 100, unitTime: 100, time: 750},
{text: "@@@", sphereRadius: 100, sphereSpace: 130, unitTime: 100, time: 3000},
{text: "ガラス", sphereRadius: 100, sphereSpace: 160, unitTime: 50, time: 750},
{text: "@@@@", sphereRadius: 100, sphereSpace: 130, unitTime: 100, time: 3000},
{text: "ADQT", sphereRadius: 140, sphereSpace: 130, unitTime: 100, time: 750},
{text: "@@@@@@@", sphereRadius: 100, sphereSpace: 130, unitTime: 50, time: 3000},
{text: "YOWGURT", sphereRadius: 130, sphereSpace: 120, unitTime: 100, time: 750}
];
var textSetChangerIncrement = 0;
var textSetChanger = function () {
setTimeout(function () {
textChanger(
textSet[textSetChangerIncrement].text,
textSet[textSetChangerIncrement].sphereRadius,
textSet[textSetChangerIncrement].sphereSpace,
textSet[textSetChangerIncrement].unitTime
);
textSetChangerIncrement++;
if (textSetChangerIncrement === textSet.length) {
textSetChangerIncrement = 0;
}
textSetChanger();
}, textSet[textSetChangerIncrement].time);
};
var vibrateCV = new closeValue(200, 500);
var invertCV = new closeValue(1000, 1200);
var start = function () {
setup();
setInterval(function () {
vibrateFlag = vibrateCV.execution() > 0.8;
strokeColor = "rgba(255, 255, 255, 0.1)";
backgroundColor = "rgba(0, 0, 0, 0)";
ctx.clearRect(0, 0, canvasWidth, canvasHeight);
ctx.fillStyle = backgroundColor;
ctx.fillRect(0, 0, window.innerWidth, window.innerHeight);
ctx.strokeStyle = strokeColor;
update();
draw();
}, 1000 / 60);
textSetChanger();
};
document.body.onmousemove = function (e) {
camera.rotate.x = (e.pageY / window.innerHeight * 180 - 90) * 0.2;
camera.rotate.y = (e.pageX / window.innerWidth * 180 - 90) * 0.2;
document.onmousedown = function () {
camera.zoom = Math.random() + 1
};
document.onmouseup = function () {
camera.zoom = 1
};
};

35
public/views/home.html Normal file
View File

@ -0,0 +1,35 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8"/>
<base href="/"/>
<title>Shimapan</title>
<link rel="stylesheet" href="/css/splash.css"/>
<link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet"/>
<link href="https://fonts.googleapis.com/css?family=Roboto+Mono" rel="stylesheet"/>
<script src="/libs/angular/angular.min.js"></script>
<script src="/libs/ng-file-upload/ng-file-upload-all.min.js"></script>
<script src="https://cdn.rawgit.com/zenorocha/clipboard.js/master/dist/clipboard.min.js"></script>
<script src="/libs/ngclipboard/src/ngclipboard.js"></script>
<script src="/libs/app/shimapan.min.js"></script>
</head>
<body ng-app="shimapan">
<div id="container">
<h1>Shimapan~</h1>
<upload-component></upload-component>
<nav>
<ul>
<li><a href="/">Shimapan</a></li>
<li><a href="/panel">Panel</a></li>
<li><a href="">Tools</a></li>
<li><a href="">Git</a></li>
<li><a href="">FAQ</a></li>
</ul>
</nav>
</div>
</body>
</html>

View File

@ -1,35 +1,20 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en"> <html lang="en">
<head> <head>
<meta charset="utf-8"/> <meta charset="UTF-8">
<base href="/"/> <link href="/css/index.css" type="text/css" rel="stylesheet"/>
<title>Shimapan</title> <script src="/js/typegraph.js" defer></script>
<title>「shimapan.rocks」</title>
<link rel="stylesheet" href="/css/splash.css"/>
<link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet"/>
<link href="https://fonts.googleapis.com/css?family=Roboto+Mono" rel="stylesheet"/>
<script src="/libs/angular/angular.min.js"></script>
<script src="/libs/ng-file-upload/ng-file-upload-all.min.js"></script>
<script src="https://cdn.rawgit.com/zenorocha/clipboard.js/master/dist/clipboard.min.js"></script>
<script src="/libs/ngclipboard/src/ngclipboard.js"></script>
<script src="/libs/app/app.js"></script>
</head> </head>
<body ng-app="shimapan"> <body style="background:#000;margin:0;">
<div id="container"> <a href="/login"><img src="/img/flower.png"/></a>
<h1>Shimapan~</h1> <canvas id="canvas">
<upload-component></upload-component> きみのブラウザはキャンバスを対応しません。Chromeを ダウンロードしてください。
<nav> </canvas>
<ul> <video autoplay loop id="video">
<li><a href="/">Shimapan</a></li> <source src="/img/edge.mp4" type="video/mp4"/>
<li><a href="/panel">Panel</a></li> </video>
<li><a href="">Tools</a></li> <script>document.getElementById("video").volume = 0.2;</script>
<li><a href="">Git</a></li> <div id="buffer"></div>
<li><a href="">FAQ</a></li>
</ul>
</nav>
</div>
</body> </body>
</html> </html>

View File

@ -6,17 +6,11 @@
<title>Login</title> <title>Login</title>
<script src="/libs/angular/angular.min.js"></script> <script src="/libs/angular/angular.min.js"></script>
<script src="/libs/angular-route/angular-route.min.js"></script>
<script src="/libs/ng-file-upload/ng-file-upload-all.min.js"></script> <script src="/libs/ng-file-upload/ng-file-upload-all.min.js"></script>
<script src="https://cdn.rawgit.com/zenorocha/clipboard.js/master/dist/clipboard.min.js"></script> <script src="https://cdn.rawgit.com/zenorocha/clipboard.js/master/dist/clipboard.min.js"></script>
<script src="/libs/ngclipboard/src/ngclipboard.js"></script> <script src="/libs/ngclipboard/src/ngclipboard.js"></script>
<script src="/js/ngRoutes.js"></script> <script src="/libs/app/shimapan.min.js"></script>
<script src="/js/components/UploadComp.js"></script>
<script src="/js/components/RegisterComp.js"></script>
<script src="/js/components/LoginComp.js"></script>
<script src="/js/services/AuthSvc.js"></script>
<script src="/js/shimapan.js"></script>
</head> </head>
<body ng-app="shimapan"> <body ng-app="shimapan">
<div id="container"> <div id="container">

View File

@ -8,13 +8,32 @@
<link rel="stylesheet" href="/css/panel.css"/> <link rel="stylesheet" href="/css/panel.css"/>
<link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet"/> <link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet"/>
<link href="https://fonts.googleapis.com/css?family=Roboto+Mono" rel="stylesheet"/> <link href="https://fonts.googleapis.com/css?family=Roboto+Mono" rel="stylesheet"/>
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
<script src="/libs/angular/angular.min.js"></script> <script src="/libs/angular/angular.min.js"></script>
<script src="/libs/angular-ui-router/release/angular-ui-router.min.js"></script> <script src="/libs/angular-ui-router/release/angular-ui-router.min.js"></script>
<script src="/libs/app/app.js"></script> <script src="/js/shimapan-panel/controllers/NavCtrl.js" defer></script>
<script src="/libs/app/shimapan-panel.min.js"></script>
</head> </head>
<body ng-app="shimapan-panel"> <body ng-app="shimapan-panel">
<div id="container" ui-view></div> <div class="container">
<div class="sidebar" ng-controller="NavController">
<div class="sidebar-title">Shimapan</div>
<ul class="nav">
<li><a href="/panel" ng-class="{active: $state.$current.name=='/panel'}">Dashboard</a></li>
<li><a href="/panel/search" ng-class="{active: $state.$current.name=='/panel/search'}">Search</a></li>
<li><a href="/panel/api" ng-class="{active: $state.$current.name=='/panel/api'}">API</a></li>
<li><a href="/panel/invites" ng-class="{active: $state.$current.name=='/panel/invites'}">Invites</a></li>
<li ng-hide="!hasPermission('users.view')"><a href="/panel/users" ng-class="{active: $state.$current.name=='/panel/users'}">Users</a></li>
<li><a href="/panel/stats" ng-class="{active: $state.$current.name=='/panel/stats'}">Statistics</a></li>
<li><a href="" ng-click="goLogout()">Logout</a></li>
</ul>
</div>
<div class="content isOpen" ng-class="{isOpen: open}">
<a class="button" ng-init="open = true" ng-click="open = !open"></a>
<div class="view" ui-view></div>
</div>
</div>
</body> </body>
</html> </html>

View File

@ -10,7 +10,7 @@
<script src="https://cdn.rawgit.com/zenorocha/clipboard.js/master/dist/clipboard.min.js"></script> <script src="https://cdn.rawgit.com/zenorocha/clipboard.js/master/dist/clipboard.min.js"></script>
<script src="/libs/ngclipboard/src/ngclipboard.js"></script> <script src="/libs/ngclipboard/src/ngclipboard.js"></script>
<script src="/libs/app/app.js"></script> <script src="/libs/app/shimapan.min.js"></script>
</head> </head>
<body ng-app="shimapan"> <body ng-app="shimapan">
<div id="container"> <div id="container">

View File

@ -9,7 +9,7 @@
<span class="list-url"> <span class="list-url">
<a href="https://shimapan.rocks/v/{{file.result.name}}" ng-hide="file.progress < 100">https://shimapan.rocks/v/{{file.result.name}}</a> <a href="https://shimapan.rocks/v/{{file.result.name}}" ng-hide="file.progress < 100">https://shimapan.rocks/v/{{file.result.name}}</a>
<button class="list-url-clipboard-btn" ngclipboard data-clipboard-text="https://shimapan.rocks/v/{{file.result.name}}"> <button class="list-url-clipboard-btn" ngclipboard data-clipboard-text="https://shimapan.rocks/v/{{file.result.name}}">
<img src="/img/glyphicons-512-copy.png"/> <img src="/glyphicons-512-copy.png"/>
</button> </button>
</span> </span>
</li> </li>