hyper/lib/actions/sessions.js

196 lines
4 KiB
JavaScript
Raw Normal View History

2016-07-13 12:44:24 -08:00
import rpc from '../rpc';
import getURL from '../utils/url-command';
import {keys} from '../utils/object';
2016-07-13 12:44:24 -08:00
import {
SESSION_ADD,
SESSION_RESIZE,
SESSION_REQUEST,
SESSION_ADD_DATA,
SESSION_PTY_DATA,
SESSION_PTY_EXIT,
SESSION_USER_EXIT,
SESSION_USER_EXIT_ACTIVE,
SESSION_SET_ACTIVE,
SESSION_CLEAR_ACTIVE,
SESSION_USER_DATA,
SESSION_URL_SET,
SESSION_URL_UNSET,
SESSION_SET_XTERM_TITLE,
SESSION_SET_PROCESS_TITLE
} from '../constants/sessions';
export function addSession(uid, shell, pid) {
return dispatch => {
2016-07-13 16:21:23 -08:00
dispatch({
type: SESSION_ADD,
2016-07-14 15:40:15 -08:00
uid,
shell,
pid
});
2016-07-13 12:44:24 -08:00
};
}
export function requestSession() {
2016-07-13 12:44:24 -08:00
return (dispatch, getState) => {
const {ui} = getState();
const {cols, rows, cwd} = ui;
2016-07-13 12:44:24 -08:00
dispatch({
type: SESSION_REQUEST,
effect: () => {
rpc.emit('new', {cols, rows, cwd});
2016-07-13 12:44:24 -08:00
}
});
};
}
export function addSessionData(uid, data) {
2016-07-14 15:40:15 -08:00
return function (dispatch, getState) {
2016-07-13 12:44:24 -08:00
dispatch({
type: SESSION_ADD_DATA,
data,
effect() {
const {shell} = getState().sessions.sessions[uid];
const enterKey = Boolean(data.match(/\n/));
const url = enterKey ? getURL(shell, data) : null;
if (url) {
2016-07-13 12:44:24 -08:00
dispatch({
type: SESSION_URL_SET,
uid,
url
});
} else {
dispatch({
type: SESSION_PTY_DATA,
uid,
data
});
}
}
});
};
}
export function sessionExit(uid) {
2016-07-13 12:44:24 -08:00
return (dispatch, getState) => {
return dispatch({
type: SESSION_PTY_EXIT,
uid,
effect() {
2016-07-13 12:44:24 -08:00
// we reiterate the same logic as below
// for SESSION_USER_EXIT since the exit
// could happen pty side or optimistic
const sessions = keys(getState().sessions.sessions);
if (!sessions.length) {
window.close();
}
}
});
};
}
// we want to distinguish an exit
// that's UI initiated vs pty initiated
export function userExitSession(uid) {
2016-07-13 12:44:24 -08:00
return (dispatch, getState) => {
return dispatch({
type: SESSION_USER_EXIT,
uid,
effect() {
rpc.emit('exit', {uid});
const sessions = keys(getState().sessions.sessions);
if (!sessions.length) {
window.close();
2016-07-13 12:44:24 -08:00
}
}
});
};
}
export function userExitActiveSession() {
2016-07-13 12:44:24 -08:00
return (dispatch, getState) => {
dispatch({
type: SESSION_USER_EXIT_ACTIVE,
effect() {
2016-07-13 12:44:24 -08:00
const uid = getState().sessions.activeUid;
dispatch(userExitSession(uid));
}
});
};
}
export function setActiveSession(uid) {
2016-07-13 12:44:24 -08:00
return (dispatch, getState) => {
const state = getState();
const prevUid = state.sessions.activeUid;
dispatch({
type: SESSION_SET_ACTIVE,
uid,
effect() {
2016-07-13 12:44:24 -08:00
// TODO: this goes away when we are able to poll
// for the title ourseleves, instead of relying
// on Session and focus/blur to subscribe
if (prevUid) {
rpc.emit('blur', {uid: prevUid});
}
rpc.emit('focus', {uid});
2016-07-13 12:44:24 -08:00
}
});
};
}
export function clearActiveSession() {
2016-07-13 12:44:24 -08:00
return {
type: SESSION_CLEAR_ACTIVE
};
}
export function setSessionProcessTitle(uid, title) {
2016-07-13 12:44:24 -08:00
return {
type: SESSION_SET_PROCESS_TITLE,
uid,
title
};
}
export function setSessionXtermTitle(uid, title) {
2016-07-13 12:44:24 -08:00
return {
type: SESSION_SET_XTERM_TITLE,
uid,
title
};
}
export function resizeSession(uid, cols, rows) {
2016-07-13 12:44:24 -08:00
return {
type: SESSION_RESIZE,
cols,
rows,
effect() {
rpc.emit('resize', {cols, rows});
2016-07-13 12:44:24 -08:00
}
};
}
export function sendSessionData(uid, data) {
return function (dispatch, getState) {
dispatch({
type: SESSION_USER_DATA,
data,
effect() {
// If no uid is passed, data is sended to the active session.
const targetUid = uid || getState().sessions.activeUid;
rpc.emit('data', {uid: targetUid, data});
}
});
2016-07-13 12:44:24 -08:00
};
}
export function exitSessionBrowser(uid) {
2016-07-13 12:44:24 -08:00
return {
type: SESSION_URL_UNSET,
uid
};
}