mirror of
https://github.com/bakhirev/assayo.git
synced 2025-01-18 16:37:50 +00:00
update
This commit is contained in:
parent
de843015b9
commit
b5c0fd7167
|
@ -8,7 +8,7 @@
|
|||
<meta name="HandheldFriendly" content="True">
|
||||
<meta name="format-detection" content="telephone=no">
|
||||
<meta name="format-detection" content="address=no">
|
||||
<meta name="apple-mobile-web-app-capable" content="yes">
|
||||
<meta name="mobile-web-app-capable" content="yes">
|
||||
<meta name="apple-mobile-web-app-status-bar-style" content="default">
|
||||
<meta name="theme-color" content="white"/>
|
||||
|
||||
|
@ -25,7 +25,6 @@
|
|||
</script>
|
||||
<link rel="icon" href="%PUBLIC_URL%/favicon.svg" />
|
||||
<link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" />
|
||||
<link rel="manifest" href="%PUBLIC_URL%/manifest.json" />
|
||||
|
||||
<title>Git Statistics</title>
|
||||
<meta name="description" content="Simple and fast report on git commit history.">
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import React from 'react';
|
||||
import { render } from 'react-dom';
|
||||
import { createRoot } from 'react-dom/client';
|
||||
import { HashRouter } from 'react-router-dom';
|
||||
|
||||
import localization from 'ts/helpers/Localization';
|
||||
|
@ -45,14 +45,16 @@ function renderReactApplication() {
|
|||
printStore.endPrint();
|
||||
};
|
||||
|
||||
render(
|
||||
const container = document.getElementById('root');
|
||||
if (!container) return;
|
||||
|
||||
createRoot(container).render(
|
||||
<React.StrictMode>
|
||||
<HashRouter>
|
||||
<Main />
|
||||
<Notifications/>
|
||||
</HashRouter>
|
||||
</React.StrictMode>,
|
||||
document.getElementById('root'),
|
||||
);
|
||||
}
|
||||
|
||||
|
|
|
@ -86,6 +86,7 @@ export class DataLoaderStore implements IDataLoaderStore {
|
|||
loadMore: action,
|
||||
showAll: action,
|
||||
updateSort: action,
|
||||
updateWatchedValue: action,
|
||||
canSendRequest: computed,
|
||||
});
|
||||
}
|
||||
|
|
29
src/ts/components/LineSVG/helpers/index.ts
Normal file
29
src/ts/components/LineSVG/helpers/index.ts
Normal file
|
@ -0,0 +1,29 @@
|
|||
function polarToCartesian(x: number, y: number, r: number, degrees: number) {
|
||||
const radians = degrees * Math.PI / 180;
|
||||
return [
|
||||
x + (r * Math.cos(radians)),
|
||||
y + (r * Math.sin(radians)),
|
||||
];
|
||||
}
|
||||
|
||||
export function getSegmentPath(
|
||||
x: number,
|
||||
y: number,
|
||||
r0: number,
|
||||
r1: number,
|
||||
d0: number,
|
||||
d1: number,
|
||||
) {
|
||||
const arc = Math.abs(d0 - d1) > 180 ? 1 : 0;
|
||||
const point = (radius: number, degree: number) =>
|
||||
polarToCartesian(x, y, radius, degree)
|
||||
.map(n => n.toPrecision(5))
|
||||
.join(',');
|
||||
return [
|
||||
`M${point(r0, d0)}`,
|
||||
`A${r0},${r0},0,${arc},1,${point(r0, d1)}`,
|
||||
`L${point(r1, d1)}`,
|
||||
`A${r1},${r1},0,${arc},0,${point(r1, d0)}`,
|
||||
'Z',
|
||||
].join('');
|
||||
}
|
12
src/ts/components/LineSVG/index.module.scss
Normal file
12
src/ts/components/LineSVG/index.module.scss
Normal file
|
@ -0,0 +1,12 @@
|
|||
@import 'src/styles/variables';
|
||||
|
||||
.pie_svg {
|
||||
display: inline-block;
|
||||
height: 100%;
|
||||
|
||||
&_sector {
|
||||
fill: transparent;
|
||||
stroke: var(--color-black);
|
||||
stroke-width: 2px;
|
||||
}
|
||||
}
|
4
src/ts/components/LineSVG/index.svg
Normal file
4
src/ts/components/LineSVG/index.svg
Normal file
|
@ -0,0 +1,4 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100">
|
||||
<path d="M 0 100 L 20 80 L 40 80 L 40 100 Z" fill="transparent" stroke="black"/>
|
||||
</svg>
|
After Width: | Height: | Size: 192 B |
56
src/ts/components/LineSVG/index.tsx
Normal file
56
src/ts/components/LineSVG/index.tsx
Normal file
|
@ -0,0 +1,56 @@
|
|||
import React from 'react';
|
||||
|
||||
import { IOptions, ISubLine } from 'ts/components/LineChart/interfaces';
|
||||
import { getSegmentPath } from './helpers';
|
||||
import style from './index.module.scss';
|
||||
|
||||
interface ILineSVGProps {
|
||||
options: IOptions;
|
||||
parts: ISubLine[];
|
||||
center?: number;
|
||||
}
|
||||
|
||||
const ROTATE = -90;
|
||||
|
||||
function LineSVG({
|
||||
options,
|
||||
parts,
|
||||
center,
|
||||
}: ILineSVGProps): React.ReactElement | null {
|
||||
const centerRadius = 49 * ((center || 72) / 100);
|
||||
|
||||
let prev = 0;
|
||||
const paths = parts.map((item: ISubLine) => {
|
||||
const stroke = options.color.get(item.title).first;
|
||||
const angle = 360 * item.width / 100;
|
||||
const next = Math.min(prev + angle, 360);
|
||||
const d = getSegmentPath(50, 50, centerRadius, 50, prev + ROTATE, next + ROTATE);
|
||||
prev += angle;
|
||||
|
||||
return (
|
||||
<path
|
||||
key={item.title}
|
||||
style={{ stroke }}
|
||||
d={d}
|
||||
className={style.pie_svg_sector}
|
||||
/>
|
||||
);
|
||||
});
|
||||
|
||||
return (
|
||||
<svg
|
||||
viewBox="0 0 100 100"
|
||||
preserveAspectRatio="xMidYMid meet"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
className={style.pie_svg}
|
||||
>
|
||||
{paths}
|
||||
</svg>
|
||||
);
|
||||
}
|
||||
|
||||
LineSVG.defaultProps = {
|
||||
className: '',
|
||||
};
|
||||
|
||||
export default LineSVG;
|
|
@ -12,7 +12,12 @@ import style from './styles/index.module.scss';
|
|||
|
||||
function addBannerInRandomIndex(list: any[]) {
|
||||
const className = `${styleCard.recommendations_card} ${styleCard.recommendations_card_banner}`;
|
||||
const item = (<Banner className={className} />);
|
||||
const item = (
|
||||
<Banner
|
||||
key="banner"
|
||||
className={className}
|
||||
/>
|
||||
);
|
||||
|
||||
const index = Math.floor(Math.random() * list.length);
|
||||
const last = list.splice(index);
|
||||
|
@ -32,12 +37,12 @@ function Recommendations({
|
|||
.filter(item => item)
|
||||
.map((recommendation) => (mode === 'print' ? (
|
||||
<CardForPrint
|
||||
key={recommendation[1]}
|
||||
key={recommendation.description}
|
||||
recommendation={recommendation}
|
||||
/>
|
||||
) : (
|
||||
<Card
|
||||
key={recommendation[1]}
|
||||
key={recommendation.description}
|
||||
recommendation={recommendation}
|
||||
onClick={() => {
|
||||
recommendationStore.open(recommendation);
|
||||
|
|
|
@ -21,22 +21,20 @@ function UiKitSelect({
|
|||
options,
|
||||
onChange,
|
||||
}: IUiKitSelectProps) {
|
||||
const items = (options || [])
|
||||
.map((option: any, index: number) => {
|
||||
const formattedOption = typeof option !== 'object'
|
||||
? ({ id: option, title: option })
|
||||
: option;
|
||||
const formattedOptions = (options || []).map((option: any) => (
|
||||
typeof option !== 'object'
|
||||
? ({ id: option, title: option })
|
||||
: option
|
||||
));
|
||||
|
||||
return (
|
||||
<option
|
||||
key={`${formattedOption?.id}_${index}`}
|
||||
value={formattedOption?.id ?? null}
|
||||
selected={value === formattedOption?.id}
|
||||
>
|
||||
{formattedOption?.title ?? formattedOption?.id ?? ''}
|
||||
</option>
|
||||
);
|
||||
});
|
||||
const items = formattedOptions.map((option: any, index: number) => (
|
||||
<option
|
||||
key={`${option?.id}_${index}`}
|
||||
value={option?.id ?? null}
|
||||
>
|
||||
{option?.title ?? option?.id ?? ''}
|
||||
</option>
|
||||
));
|
||||
|
||||
return (
|
||||
<Wrapper
|
||||
|
@ -47,6 +45,7 @@ function UiKitSelect({
|
|||
className={className}
|
||||
>
|
||||
<select
|
||||
value={value}
|
||||
className={`${style.ui_kit_common} ${styleSelect.ui_kit_select} ${className || ''}`}
|
||||
onChange={(event: ChangeEvent<HTMLSelectElement>) => {
|
||||
const selectedValue = event.target.value;
|
||||
|
|
|
@ -26,7 +26,7 @@ export default class DataGripByAuthor {
|
|||
}
|
||||
|
||||
addCommit(commit: ICommit) {
|
||||
if (this.commits[commit.author]) {
|
||||
if (this.commits.hasOwnProperty(commit.author)) {
|
||||
this.#updateCommitByAuthor(commit);
|
||||
} else {
|
||||
this.#addCommitByAuthor(commit);
|
||||
|
|
|
@ -32,7 +32,7 @@ export default class DataGripByScope {
|
|||
}
|
||||
|
||||
addCommit(commit: ICommit) {
|
||||
if (this.commits[commit.scope]) {
|
||||
if (this.commits.hasOwnProperty(commit.scope)) {
|
||||
this.#updateCommitByScope(commit);
|
||||
} else {
|
||||
this.#addCommitByScope(commit);
|
||||
|
|
|
@ -18,7 +18,7 @@ export default class DataGripByTasks {
|
|||
}
|
||||
|
||||
addCommit(commit: ICommit) {
|
||||
if (this.commits[commit.task]) {
|
||||
if (this.commits.hasOwnProperty(commit.task)) {
|
||||
this.#updateCommitByTask(commit);
|
||||
} else {
|
||||
this.#addCommitByTask(commit);
|
||||
|
|
|
@ -17,7 +17,7 @@ export default class DataGripByType {
|
|||
}
|
||||
|
||||
addCommit(commit: ICommit) {
|
||||
if (this.commits[commit.type]) {
|
||||
if (this.commits.hasOwnProperty(commit.type)) {
|
||||
this.#updateCommitByType(commit);
|
||||
} else {
|
||||
this.#addCommitByType(commit);
|
||||
|
|
|
@ -17,7 +17,7 @@ export default class DataGripByWeek {
|
|||
}
|
||||
|
||||
addCommit(commit: ICommit) {
|
||||
if (this.commits[commit.week]) {
|
||||
if (this.commits.hasOwnProperty(commit.week)) {
|
||||
this.#updateCommitByWeek(commit);
|
||||
} else {
|
||||
this.#addCommitByWeek(commit);
|
||||
|
|
|
@ -25,6 +25,7 @@ export default class FileBuilderCommon {
|
|||
}
|
||||
|
||||
static updateTotal(file: IDirtyFile) {
|
||||
if (Array.isArray(file?.path)) return;
|
||||
// @ts-ignore
|
||||
const { name, type, extension } = getNameTypeExtension(file?.path);
|
||||
file.name = name;
|
||||
|
|
|
@ -33,6 +33,8 @@ function getTopUser(listOfChanges: any) {
|
|||
}
|
||||
|
||||
export default function getAchievementByFile(fileGrip: any, byAuthor: any) {
|
||||
if (!fileGrip.files.list.length) return;
|
||||
|
||||
const moreLintHint: any = [];
|
||||
const moreReadMe: any = [];
|
||||
const moreStyle: any = [];
|
||||
|
|
|
@ -89,13 +89,16 @@ function ViewWithWelcome() {
|
|||
);
|
||||
}
|
||||
|
||||
let bugInReactWithDoubleInit = 1;
|
||||
const Main = observer(() => {
|
||||
const view = viewNameStore.view;
|
||||
|
||||
useEffect(() => {
|
||||
console.log('main');
|
||||
// @ts-ignore
|
||||
const list = window?.report || [];
|
||||
if (list?.length) {
|
||||
if (list?.length && bugInReactWithDoubleInit !== list?.length) {
|
||||
bugInReactWithDoubleInit = list?.length;
|
||||
dataGripStore.asyncSetCommits(list);
|
||||
} else {
|
||||
viewNameStore.toggle(ViewNameEnum.WELCOME);
|
||||
|
|
Loading…
Reference in a new issue