2020-08-13 04:35:31 -07:00
|
|
|
import React from "react";
|
|
|
|
import { ActionManager } from "../actions/manager";
|
2020-12-02 23:57:51 +02:00
|
|
|
import { EVENT_CHANGE, trackEvent } from "../analytics";
|
2020-08-13 04:35:31 -07:00
|
|
|
import { AppState } from "../types";
|
|
|
|
import { DarkModeToggle } from "./DarkModeToggle";
|
|
|
|
|
|
|
|
export const BackgroundPickerAndDarkModeToggle = ({
|
|
|
|
appState,
|
|
|
|
setAppState,
|
|
|
|
actionManager,
|
|
|
|
}: {
|
|
|
|
actionManager: ActionManager;
|
|
|
|
appState: AppState;
|
2020-10-16 11:53:40 +02:00
|
|
|
setAppState: React.Component<any, AppState>["setState"];
|
2020-08-13 04:35:31 -07:00
|
|
|
}) => (
|
|
|
|
<div style={{ display: "flex" }}>
|
|
|
|
{actionManager.renderAction("changeViewBackgroundColor")}
|
|
|
|
<div style={{ marginInlineStart: "0.25rem" }}>
|
|
|
|
<DarkModeToggle
|
|
|
|
value={appState.appearance}
|
|
|
|
onChange={(appearance) => {
|
2020-12-02 23:57:51 +02:00
|
|
|
// TODO: track the theme on the first load too
|
|
|
|
trackEvent(EVENT_CHANGE, "theme", appearance);
|
2020-08-13 04:35:31 -07:00
|
|
|
setAppState({ appearance });
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|