mirror of
https://github.com/quine-global/hyper.git
synced 2026-01-13 04:28:41 -09:00
* 3.0.0 * 3.0.2 * Save * Save * Upgrade yarn lock packages * update node-gyp and node-pty * update travis and appveyor to node 12 * appveyor is outdated as always * update travis to xenial * update node-pty@0.9.0-beta26 * update yarn.lock * update electron to 6.0.8 * move node-pty to the correct package.json * Fix linting failure * Update yarn lockfile to try to fix appveyor build * Remove unnecessary changes from package.json * Try to fix appveyor by using a newer image * Fix linting after my last change * update electron to 6.0.9 * install windows-build-tools on appveyor * fix syntax * switch back to 2017 image * remove old resolutions field * revert accidental version change * update electron to 6.0.11 and electron-rebuild to 1.8.6 * downgrade yarn to 1.18 until this issue is resolved https://github.com/yarnpkg/yarn/issues/7584 * update node-gyp to 6.0.0 and generate a fresh yarn lockfile * update react and a few other dependencies * fix lint * this should actually be electron-builder, I think! * update a few dependencies * change to electron-store electron-config was renamed to electron-store a while ago * update xterm to v4.1.0 and ora to 4.0.2 * move pify to app/package.json * TODO: Revert maybe. Throw a fit on every change to maybe fix the resizing issues * a * fix react ref problem * fix split view focus problem * remove the unnecessary fit * remove the init col and row * fix the problem that cannot show about hyper * update electron to 6.0.12 * fix lint * add more todos for componentWillReceiveProps deprecation * update babel and plugins Co-authored-by: Juan Campa <juancampa@gmail.com> Co-authored-by: Benjamin Staneck <staneck@gmail.com> Co-authored-by: ivan <ivanwonder@outlook.com>
170 lines
3.6 KiB
JavaScript
170 lines
3.6 KiB
JavaScript
import rpc from '../rpc';
|
|
import {keys} from '../utils/object';
|
|
import findBySession from '../utils/term-groups';
|
|
import {
|
|
SESSION_ADD,
|
|
SESSION_RESIZE,
|
|
SESSION_REQUEST,
|
|
SESSION_ADD_DATA,
|
|
SESSION_PTY_DATA,
|
|
SESSION_PTY_EXIT,
|
|
SESSION_USER_EXIT,
|
|
SESSION_SET_ACTIVE,
|
|
SESSION_CLEAR_ACTIVE,
|
|
SESSION_USER_DATA,
|
|
SESSION_SET_XTERM_TITLE,
|
|
SESSION_SEARCH,
|
|
SESSION_SEARCH_CLOSE
|
|
} from '../constants/sessions';
|
|
|
|
export function addSession({uid, shell, pid, cols, rows, splitDirection}) {
|
|
return (dispatch, getState) => {
|
|
const {sessions} = getState();
|
|
const now = Date.now();
|
|
dispatch({
|
|
type: SESSION_ADD,
|
|
uid,
|
|
shell,
|
|
pid,
|
|
cols,
|
|
rows,
|
|
splitDirection,
|
|
activeUid: sessions.activeUid,
|
|
now
|
|
});
|
|
};
|
|
}
|
|
|
|
export function requestSession() {
|
|
return (dispatch, getState) => {
|
|
dispatch({
|
|
type: SESSION_REQUEST,
|
|
effect: () => {
|
|
const {ui} = getState();
|
|
// the cols and rows from preview session maybe not accurate. so remove.
|
|
const {/*cols, rows,*/ cwd} = ui;
|
|
rpc.emit('new', {cwd});
|
|
}
|
|
});
|
|
};
|
|
}
|
|
|
|
export function addSessionData(uid, data) {
|
|
return dispatch => {
|
|
dispatch({
|
|
type: SESSION_ADD_DATA,
|
|
data,
|
|
effect() {
|
|
const now = Date.now();
|
|
dispatch({
|
|
type: SESSION_PTY_DATA,
|
|
uid,
|
|
data,
|
|
now
|
|
});
|
|
}
|
|
});
|
|
};
|
|
}
|
|
|
|
function createExitAction(type) {
|
|
return uid => (dispatch, getState) => {
|
|
return dispatch({
|
|
type,
|
|
uid,
|
|
effect() {
|
|
if (type === SESSION_USER_EXIT) {
|
|
rpc.emit('exit', {uid});
|
|
}
|
|
|
|
const sessions = keys(getState().sessions.sessions);
|
|
if (sessions.length === 0) {
|
|
window.close();
|
|
}
|
|
}
|
|
});
|
|
};
|
|
}
|
|
|
|
// we want to distinguish an exit
|
|
// that's UI initiated vs pty initiated
|
|
export const userExitSession = createExitAction(SESSION_USER_EXIT);
|
|
export const ptyExitSession = createExitAction(SESSION_PTY_EXIT);
|
|
|
|
export function setActiveSession(uid) {
|
|
return dispatch => {
|
|
dispatch({
|
|
type: SESSION_SET_ACTIVE,
|
|
uid
|
|
});
|
|
};
|
|
}
|
|
|
|
export function clearActiveSession() {
|
|
return {
|
|
type: SESSION_CLEAR_ACTIVE
|
|
};
|
|
}
|
|
|
|
export function setSessionXtermTitle(uid, title) {
|
|
return {
|
|
type: SESSION_SET_XTERM_TITLE,
|
|
uid,
|
|
title
|
|
};
|
|
}
|
|
|
|
export function resizeSession(uid, cols, rows) {
|
|
return (dispatch, getState) => {
|
|
const {termGroups} = getState();
|
|
const group = findBySession(termGroups, uid);
|
|
const isStandaloneTerm = !group.parentUid && !group.children.length;
|
|
const now = Date.now();
|
|
dispatch({
|
|
type: SESSION_RESIZE,
|
|
uid,
|
|
cols,
|
|
rows,
|
|
isStandaloneTerm,
|
|
now,
|
|
effect() {
|
|
rpc.emit('resize', {uid, cols, rows});
|
|
}
|
|
});
|
|
};
|
|
}
|
|
|
|
export function onSearch(uid) {
|
|
return (dispatch, getState) => {
|
|
const targetUid = uid || getState().sessions.activeUid;
|
|
dispatch({
|
|
type: SESSION_SEARCH,
|
|
uid: targetUid
|
|
});
|
|
};
|
|
}
|
|
|
|
export function closeSearch(uid) {
|
|
return (dispatch, getState) => {
|
|
const targetUid = uid || getState().sessions.activeUid;
|
|
dispatch({
|
|
type: SESSION_SEARCH_CLOSE,
|
|
uid: targetUid
|
|
});
|
|
};
|
|
}
|
|
|
|
export function sendSessionData(uid, data, escaped) {
|
|
return (dispatch, getState) => {
|
|
dispatch({
|
|
type: SESSION_USER_DATA,
|
|
data,
|
|
effect() {
|
|
// If no uid is passed, data is sent to the active session.
|
|
const targetUid = uid || getState().sessions.activeUid;
|
|
|
|
rpc.emit('data', {uid: targetUid, data, escaped});
|
|
}
|
|
});
|
|
};
|
|
}
|