jormungandr-bite/src/web/app/desktop/script.ts

138 lines
3.1 KiB
TypeScript
Raw Normal View History

2016-12-28 15:49:51 -07:00
/**
* Desktop Client
*/
2017-02-18 20:31:23 -07:00
// Style
2017-02-18 23:36:53 -07:00
import './style.styl';
2017-02-18 20:31:23 -07:00
2017-05-17 14:06:55 -06:00
import init from '../init';
2017-03-18 05:05:11 -06:00
import fuckAdBlock from './scripts/fuck-ad-block';
2017-11-16 09:24:44 -07:00
import HomeStreamManager from '../common/scripts/streaming/home-stream-manager';
2017-11-20 13:09:45 -07:00
import composeNotification from '../common/scripts/compose-notification';
2016-12-28 15:49:51 -07:00
2018-02-17 02:14:23 -07:00
import chooseDriveFolder from './api/choose-drive-folder';
2018-02-17 20:35:18 -07:00
import chooseDriveFile from './api/choose-drive-file';
import dialog from './api/dialog';
import input from './api/input';
2018-02-20 06:53:34 -07:00
import post from './api/post';
2018-02-17 02:14:23 -07:00
2018-02-09 22:56:33 -07:00
import MkIndex from './views/pages/index.vue';
2018-02-18 22:29:42 -07:00
import MkUser from './views/pages/user/user.vue';
2018-02-20 07:37:35 -07:00
import MkSelectDrive from './views/pages/selectdrive.vue';
import MkDrive from './views/pages/drive.vue';
2018-02-09 18:27:05 -07:00
2016-12-28 15:49:51 -07:00
/**
2017-05-17 14:06:55 -06:00
* init
2016-12-28 15:49:51 -07:00
*/
2018-02-10 20:08:43 -07:00
init(async (launch) => {
2016-12-28 15:49:51 -07:00
/**
* Fuck AD Block
*/
fuckAdBlock();
2018-02-16 10:24:10 -07:00
// Register directives
require('./views/directives');
2018-02-10 20:08:43 -07:00
// Register components
require('./views/components');
2018-02-17 02:14:23 -07:00
const app = launch({
2018-02-17 20:35:18 -07:00
chooseDriveFolder,
chooseDriveFile,
dialog,
2018-02-20 06:53:34 -07:00
input,
post
2018-02-17 02:14:23 -07:00
});
2018-02-10 20:08:43 -07:00
2016-12-28 15:49:51 -07:00
/**
* Init Notification
*/
if ('Notification' in window) {
// 許可を得ていなかったらリクエスト
2017-11-13 02:05:35 -07:00
if ((Notification as any).permission == 'default') {
2017-06-06 09:04:28 -06:00
await Notification.requestPermission();
}
2017-11-13 02:05:35 -07:00
if ((Notification as any).permission == 'granted') {
2018-02-10 20:08:43 -07:00
registerNotifications(app.$data.os.stream);
2016-12-28 15:49:51 -07:00
}
}
2018-02-09 18:27:05 -07:00
app.$router.addRoutes([{
2018-02-10 20:08:43 -07:00
path: '/', component: MkIndex
2018-02-20 07:37:35 -07:00
}, {
path: '/i/drive', component: MkDrive
}, {
path: '/i/drive/folder/:folder', component: MkDrive
}, {
path: '/selectdrive', component: MkSelectDrive
2018-02-18 22:29:42 -07:00
}, {
path: '/:user', component: MkUser
2018-02-09 18:27:05 -07:00
}]);
2017-11-20 18:01:00 -07:00
}, true);
2017-06-06 09:04:28 -06:00
2017-11-16 09:24:44 -07:00
function registerNotifications(stream: HomeStreamManager) {
2017-06-07 00:19:28 -06:00
if (stream == null) return;
2017-11-16 09:24:44 -07:00
if (stream.hasConnection) {
attach(stream.borrow());
}
stream.on('connected', connection => {
attach(connection);
2017-06-06 09:04:28 -06:00
});
2017-11-16 09:24:44 -07:00
function attach(connection) {
connection.on('drive_file_created', file => {
2017-11-20 13:09:45 -07:00
const _n = composeNotification('drive_file_created', file);
const n = new Notification(_n.title, {
body: _n.body,
icon: _n.icon
2017-11-16 09:24:44 -07:00
});
setTimeout(n.close.bind(n), 5000);
2017-06-06 09:04:28 -06:00
});
2017-11-16 09:24:44 -07:00
connection.on('mention', post => {
2017-11-20 13:09:45 -07:00
const _n = composeNotification('mention', post);
const n = new Notification(_n.title, {
body: _n.body,
icon: _n.icon
2017-11-16 09:24:44 -07:00
});
setTimeout(n.close.bind(n), 6000);
2017-06-06 09:04:28 -06:00
});
2017-11-16 09:24:44 -07:00
connection.on('reply', post => {
2017-11-20 13:09:45 -07:00
const _n = composeNotification('reply', post);
const n = new Notification(_n.title, {
body: _n.body,
icon: _n.icon
2017-11-16 09:24:44 -07:00
});
setTimeout(n.close.bind(n), 6000);
2017-06-06 09:04:28 -06:00
});
2017-11-16 09:24:44 -07:00
connection.on('quote', post => {
2017-11-20 13:09:45 -07:00
const _n = composeNotification('quote', post);
const n = new Notification(_n.title, {
body: _n.body,
icon: _n.icon
2017-11-16 09:24:44 -07:00
});
setTimeout(n.close.bind(n), 6000);
});
2017-11-16 09:24:44 -07:00
connection.on('unread_messaging_message', message => {
2017-11-20 13:09:45 -07:00
const _n = composeNotification('unread_messaging_message', message);
const n = new Notification(_n.title, {
body: _n.body,
icon: _n.icon
});
2017-11-16 09:24:44 -07:00
n.onclick = () => {
n.close();
2018-02-09 18:27:05 -07:00
/*(riot as any).mount(document.body.appendChild(document.createElement('mk-messaging-room-window')), {
2017-11-16 09:24:44 -07:00
user: message.user
2018-02-09 18:27:05 -07:00
});*/
2017-11-16 09:24:44 -07:00
};
setTimeout(n.close.bind(n), 7000);
});
}
2017-06-06 09:04:28 -06:00
}