7d8f19e6e4
- The previous commits moved the majority of the remaining global css into components; move the remaining @emotion/css references into ticks.scss and the styling of the Graph.svelte. This is not as elegant as the emotion solution, but builds a whole lot faster, and most of our styling can be scoped to a component anyway. - Leave the .html files in ts/ for now. AnkiMobile uses them, and AnkiDroid likely will in the future too. In the long run we'll likely move to loading the JS into an existing page instead of loading a separate page, but at that point we can just exclude the .html file from copy_files_into_group() without affecting other clients. Closes #1074
76 lines
2.3 KiB
Svelte
76 lines
2.3 KiB
Svelte
<script lang="typescript">
|
|
import type pb from "anki/backend_proto";
|
|
import type { I18n } from "anki/i18n";
|
|
|
|
import Graph from "./Graph.svelte";
|
|
import InputBox from "./InputBox.svelte";
|
|
import NoDataOverlay from "./NoDataOverlay.svelte";
|
|
import CumulativeOverlay from "./CumulativeOverlay.svelte";
|
|
import GraphRangeRadios from "./GraphRangeRadios.svelte";
|
|
import TableData from "./TableData.svelte";
|
|
import AxisTicks from "./AxisTicks.svelte";
|
|
import HoverColumns from "./HoverColumns.svelte";
|
|
|
|
import { defaultGraphBounds, RevlogRange, GraphRange } from "./graph-helpers";
|
|
import type { TableDatum } from "./graph-helpers";
|
|
import { gatherData, renderReviews } from "./reviews";
|
|
import type { GraphData } from "./reviews";
|
|
|
|
export let sourceData: pb.BackendProto.GraphsOut | null = null;
|
|
export let revlogRange: RevlogRange;
|
|
export let i18n: I18n;
|
|
|
|
let graphData: GraphData | null = null;
|
|
|
|
let bounds = defaultGraphBounds();
|
|
let svg = null as HTMLElement | SVGElement | null;
|
|
let graphRange: GraphRange = GraphRange.Month;
|
|
let showTime = false;
|
|
|
|
$: if (sourceData) {
|
|
graphData = gatherData(sourceData);
|
|
}
|
|
|
|
let tableData: TableDatum[] = [] as any;
|
|
$: if (graphData) {
|
|
tableData = renderReviews(
|
|
svg as SVGElement,
|
|
bounds,
|
|
graphData,
|
|
graphRange,
|
|
showTime,
|
|
i18n
|
|
);
|
|
}
|
|
|
|
const title = i18n.tr(i18n.TR.STATISTICS_REVIEWS_TITLE);
|
|
const time = i18n.tr(i18n.TR.STATISTICS_REVIEWS_TIME_CHECKBOX);
|
|
|
|
let subtitle = "";
|
|
$: if (showTime) {
|
|
subtitle = i18n.tr(i18n.TR.STATISTICS_REVIEWS_TIME_SUBTITLE);
|
|
} else {
|
|
subtitle = i18n.tr(i18n.TR.STATISTICS_REVIEWS_COUNT_SUBTITLE);
|
|
}
|
|
</script>
|
|
|
|
<Graph {title} {subtitle}>
|
|
<InputBox>
|
|
<label> <input type="checkbox" bind:checked={showTime} /> {time} </label>
|
|
|
|
<GraphRangeRadios bind:graphRange {i18n} {revlogRange} followRevlog={true} />
|
|
</InputBox>
|
|
|
|
<svg bind:this={svg} viewBox={`0 0 ${bounds.width} ${bounds.height}`}>
|
|
{#each [4, 3, 2, 1, 0] as i}
|
|
<g class="bars{i}" />
|
|
{/each}
|
|
<CumulativeOverlay />
|
|
<HoverColumns />
|
|
<AxisTicks {bounds} />
|
|
<NoDataOverlay {bounds} {i18n} />
|
|
</svg>
|
|
|
|
<TableData {i18n} {tableData} />
|
|
</Graph>
|