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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at <http://mozilla.org/MPL/2.0/>. */
// @flow
import { clearDocuments } from "../utils/editor";
import sourceQueue from "../utils/source-queue";
import { evaluateExpressions } from "./expressions";
import { clearWasmStates } from "../utils/wasm";
import { getMainThread, getThreadContext } from "../selectors";
import type { Action, ThunkArgs } from "./types";
import type { ActorId, URL } from "../types";
/**
* Redux actions for the navigation state
* @module actions/navigation
*/
/**
* @memberof actions/navigation
* @static
*/
export function willNavigate(event: Object) {
return async function({
dispatch,
getState,
client,
sourceMaps,
parser,
}: ThunkArgs) {
sourceQueue.clear();
sourceMaps.clearSourceMaps();
clearWasmStates();
clearDocuments();
parser.clear();
const thread = getMainThread(getState());
dispatch({
type: "NAVIGATE",
mainThread: { ...thread, url: event.url },
});
};
}
export function connect(
url: URL,
actor: ActorId,
traits: Object,
isWebExtension: boolean
) {
return async function({ dispatch, getState }: ThunkArgs) {
await dispatch(
({
type: "CONNECT",
traits,
mainThreadActorID: actor,
isWebExtension,
}: Action)
);
const cx = getThreadContext(getState());
dispatch(evaluateExpressions(cx));
};
}
/**
* @memberof actions/navigation
* @static
*/
export function navigated() {
return async function({ dispatch, panel }: ThunkArgs) {
panel.emit("reloaded");
};
}
|