@sotnak/react-wakatime-global-stats 0.1.10 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -1
- package/dist/components/waka.d.ts +9 -5
- package/dist/components/wakaInteractive.d.ts +5 -2
- package/dist/index.js +1 -1
- package/package.json +4 -2
package/README.md
CHANGED
|
@@ -9,10 +9,14 @@ export declare enum Category {
|
|
|
9
9
|
editors = 1,
|
|
10
10
|
operating_systems = 2
|
|
11
11
|
}
|
|
12
|
-
export
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
12
|
+
export type UrlGetter = (year: number) => string;
|
|
13
|
+
interface WakaProps {
|
|
14
|
+
aggregateFunction?: AggregateFunction;
|
|
15
|
+
category?: Category;
|
|
16
|
+
year?: number;
|
|
17
|
+
urlGetter: UrlGetter;
|
|
18
|
+
fetcher?: ((url: string) => Promise<any>);
|
|
16
19
|
limit: number | undefined;
|
|
17
20
|
}
|
|
18
|
-
export declare const Waka: ({ aggregateFunction, category, year, ...props }: WakaProps) => JSX.Element;
|
|
21
|
+
export declare const Waka: ({ aggregateFunction, category, year, urlGetter, fetcher, ...props }: WakaProps) => JSX.Element;
|
|
22
|
+
export {};
|
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
+
import { UrlGetter } from "./waka";
|
|
2
3
|
import "./wakaInteractive.css";
|
|
3
|
-
export declare const WakaInteractive: ({ limit }: {
|
|
4
|
-
limit
|
|
4
|
+
export declare const WakaInteractive: ({ limit, urlGetter, fetcher }: {
|
|
5
|
+
limit: number;
|
|
6
|
+
urlGetter: UrlGetter;
|
|
7
|
+
fetcher?: ((url: string) => Promise<any>) | undefined;
|
|
5
8
|
}) => JSX.Element;
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import"bootstrap/dist/css/bootstrap.css";import React,{useState
|
|
1
|
+
import"bootstrap/dist/css/bootstrap.css";import React,{useState}from"react";import Spinner from"react-bootstrap/Spinner";import{ListGroup,Stack,ProgressBar,Pagination,ToggleButtonGroup,ToggleButton}from"react-bootstrap";import useSWR from"swr";import axios from"axios";function __rest(e,t){var a={};for(n in e)Object.prototype.hasOwnProperty.call(e,n)&&t.indexOf(n)<0&&(a[n]=e[n]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols)for(var r=0,n=Object.getOwnPropertySymbols(e);r<n.length;r++)t.indexOf(n[r])<0&&Object.prototype.propertyIsEnumerable.call(e,n[r])&&(a[n[r]]=e[n[r]]);return a}const defaultFetcher=e=>axios.get(e).then(e=>e.data);var AggregateFunction,Category;!function(e){e[e.sum=0]="sum",e[e.average=1]="average",e[e.median=2]="median"}(AggregateFunction=AggregateFunction||{}),function(e){e[e.languages=0]="languages",e[e.editors=1]="editors",e[e.operating_systems=2]="operating_systems"}(Category=Category||{});const Waka=e=>{var{aggregateFunction:t=AggregateFunction.sum,category:a=Category.languages,year:r=2023,urlGetter:n,fetcher:o=defaultFetcher}=e,e=__rest(e,["aggregateFunction","category","year","urlGetter","fetcher"]),{data:n,error:r,isLoading:o}=useSWR(n(r),o);if(o)return React.createElement("div",null,React.createElement(Spinner,{animation:"border",role:"status"}),React.createElement("span",null," Loading..."));if(r)return React.createElement("div",null,React.createElement("span",null,r.message));var g=n.data;let c,s=(c=e.limit||1e6,[]);switch(a){case Category.languages:s=g.languages;break;case Category.editors:s=g.editors;break;case Category.operating_systems:s=g.operating_systems;break;default:throw Error("unknown category: "+a)}var i=s.filter(e=>"Other"!=e.name);let l=[];switch(t){case AggregateFunction.average:l=i.map(e=>({name:e.name,value:e.average}));break;case AggregateFunction.median:l=i.map(e=>({name:e.name,value:e.median}));break;case AggregateFunction.sum:l=i.map(e=>({name:e.name,value:e.sum}));break;default:throw Error("unknown aggregate function: "+t)}o=l.sort((e,t)=>t.value.seconds-e.value.seconds).slice(0,c);let u;o[0]&&(u=o[0].value.seconds);r=o.map(e=>React.createElement(ListGroup.Item,{key:e.name},React.createElement(Stack,{direction:"horizontal",gap:3},React.createElement("div",null,e.name),React.createElement("div",{className:"ms-auto"},e.value.text)),React.createElement(ProgressBar,{max:u,now:e.value.seconds})));return React.createElement(React.Fragment,null,React.createElement(ListGroup,null,r))};function styleInject(e,t){var a,r,t=(t=void 0===t?{}:t).insertAt;e&&"undefined"!=typeof document&&(a=document.head||document.getElementsByTagName("head")[0],(r=document.createElement("style")).type="text/css","top"===t&&a.firstChild?a.insertBefore(r,a.firstChild):a.appendChild(r),r.styleSheet?r.styleSheet.cssText=e:r.appendChild(document.createTextNode(e)))}var css_248z="#wakaContainer {\n overflow-y: scroll;\n height: 100%;\n}\n\n#full {\n position: absolute;\n top: 0;\n bottom: 0;\n width: 100%;\n}\n\n.center {\n margin-left: auto;\n margin-right: auto;\n}";styleInject(css_248z);const firstYear=2013,itemLimit=100,latestYear=Math.max(firstYear,(new Date).getFullYear()-1),WakaInteractive=({limit:e=itemLimit,urlGetter:t,fetcher:a})=>{const[r,n]=useState(AggregateFunction.sum),[o,g]=useState(Category.languages),[c,s]=useState(latestYear);var i=[];for(let t=firstYear;t<=latestYear;t++)i.push(React.createElement(Pagination.Item,{key:t,active:t===c,onClick:()=>{var e;e=t,s(e)}},t));return React.createElement(Stack,{id:"full"},React.createElement(Stack,{direction:"horizontal",gap:3},React.createElement(ToggleButtonGroup,{type:"radio",name:"agg options",defaultValue:AggregateFunction.sum,onChange:e=>{n(e)}},React.createElement(ToggleButton,{id:"tbg-agg-1",value:AggregateFunction.sum},"Sum"),React.createElement(ToggleButton,{id:"tbg-agg-2",value:AggregateFunction.average},"Average"),React.createElement(ToggleButton,{id:"tbg-agg-3",value:AggregateFunction.median},"Median")),React.createElement(ToggleButtonGroup,{className:"ms-auto",type:"radio",name:"category options",defaultValue:Category.languages,onChange:e=>{g(e)}},React.createElement(ToggleButton,{id:"tbg-category-1",variant:"success",value:Category.languages},"Languages"),React.createElement(ToggleButton,{id:"tbg-category-2",variant:"success",value:Category.editors},"Editors"),React.createElement(ToggleButton,{id:"tbg-category-3",variant:"success",value:Category.operating_systems},"Operating Systems"))),React.createElement("div",{id:"wakaContainer"},React.createElement(Waka,{aggregateFunction:r,limit:e,category:o,year:c,urlGetter:t,fetcher:a})),React.createElement(Pagination,{className:"center"},i))};export{AggregateFunction,Category,Waka,WakaInteractive};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sotnak/react-wakatime-global-stats",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -56,9 +56,11 @@
|
|
|
56
56
|
"react-dom": "^18.2.0"
|
|
57
57
|
},
|
|
58
58
|
"dependencies": {
|
|
59
|
+
"axios": "^1.13.2",
|
|
59
60
|
"bootstrap": "^5.2.3",
|
|
60
61
|
"react": "^18.2.0",
|
|
61
62
|
"react-bootstrap": "^2.7.0",
|
|
62
|
-
"react-dom": "^18.2.0"
|
|
63
|
+
"react-dom": "^18.2.0",
|
|
64
|
+
"swr": "^2.3.8"
|
|
63
65
|
}
|
|
64
66
|
}
|