@tasenor/common-plugins 1.9.16 → 1.9.18
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/.turbo/turbo-build.log +4 -0
- package/.turbo/turbo-lint.log +1 -1
- package/.turbo/turbo-show-version.log +5 -0
- package/dist/CoinAPI/backend/index.d.ts +22 -0
- package/dist/CoinAPI/backend/index.js +91 -0
- package/dist/CoinAPI/backend/index.js.map +1 -0
- package/dist/CoinbaseImport/backend/CoinbaseHandler.d.ts +11 -0
- package/dist/CoinbaseImport/backend/CoinbaseHandler.js +30 -0
- package/dist/CoinbaseImport/backend/CoinbaseHandler.js.map +1 -0
- package/dist/CoinbaseImport/backend/index.d.ts +5 -0
- package/dist/CoinbaseImport/backend/index.js +18 -0
- package/dist/CoinbaseImport/backend/index.js.map +1 -0
- package/dist/DocumentCleaner/ui/index.d.ts +43 -0
- package/dist/DocumentCleaner/ui/index.js +139 -0
- package/dist/DocumentCleaner/ui/index.js.map +1 -0
- package/dist/Euro/ui/index.d.ts +15 -0
- package/dist/Euro/ui/index.js +22 -0
- package/dist/Euro/ui/index.js.map +1 -0
- package/dist/Finnish/ui/finnish.json +341 -0
- package/dist/Finnish/ui/index.d.ts +17 -0
- package/dist/Finnish/ui/index.js +47 -0
- package/dist/Finnish/ui/index.js.map +1 -0
- package/dist/FinnishBalanceSheetReport/backend/index.d.ts +18 -0
- package/dist/FinnishBalanceSheetReport/backend/index.js +96 -0
- package/dist/FinnishBalanceSheetReport/backend/index.js.map +1 -0
- package/dist/FinnishBalanceSheetReportInvestment/backend/index.d.ts +18 -0
- package/dist/FinnishBalanceSheetReportInvestment/backend/index.js +96 -0
- package/dist/FinnishBalanceSheetReportInvestment/backend/index.js.map +1 -0
- package/dist/FinnishBalanceSheetReportLite/backend/index.d.ts +19 -0
- package/dist/FinnishBalanceSheetReportLite/backend/index.js +109 -0
- package/dist/FinnishBalanceSheetReportLite/backend/index.js.map +1 -0
- package/dist/FinnishIncomeStatementReport/backend/index.d.ts +26 -0
- package/dist/FinnishIncomeStatementReport/backend/index.js +190 -0
- package/dist/FinnishIncomeStatementReport/backend/index.js.map +1 -0
- package/dist/FinnishIncomeStatementReportInvestment/backend/index.d.ts +26 -0
- package/dist/FinnishIncomeStatementReportInvestment/backend/index.js +190 -0
- package/dist/FinnishIncomeStatementReportInvestment/backend/index.js.map +1 -0
- package/dist/FinnishIncomeStatementReportLite/backend/index.d.ts +26 -0
- package/dist/FinnishIncomeStatementReportLite/backend/index.js +188 -0
- package/dist/FinnishIncomeStatementReportLite/backend/index.js.map +1 -0
- package/dist/FinnishInvestmentCompany/backend/index.d.ts +10 -0
- package/dist/FinnishInvestmentCompany/backend/index.js +36 -0
- package/dist/FinnishInvestmentCompany/backend/index.js.map +1 -0
- package/dist/FinnishInvestmentCompany/ui/index.d.ts +16 -0
- package/dist/FinnishInvestmentCompany/ui/index.js +22 -0
- package/dist/FinnishInvestmentCompany/ui/index.js.map +1 -0
- package/dist/FinnishLimitedCompanyComplete/backend/index.d.ts +10 -0
- package/dist/FinnishLimitedCompanyComplete/backend/index.js +36 -0
- package/dist/FinnishLimitedCompanyComplete/backend/index.js.map +1 -0
- package/dist/FinnishLimitedCompanyComplete/ui/index.d.ts +16 -0
- package/dist/FinnishLimitedCompanyComplete/ui/index.js +22 -0
- package/dist/FinnishLimitedCompanyComplete/ui/index.js.map +1 -0
- package/dist/FinnishLimitedCompanyLite/backend/index.d.ts +10 -0
- package/dist/FinnishLimitedCompanyLite/backend/index.js +43 -0
- package/dist/FinnishLimitedCompanyLite/backend/index.js.map +1 -0
- package/dist/FinnishLimitedCompanyLite/ui/index.d.ts +16 -0
- package/dist/FinnishLimitedCompanyLite/ui/index.js +24 -0
- package/dist/FinnishLimitedCompanyLite/ui/index.js.map +1 -0
- package/dist/GitBackup/backend/index.d.ts +26 -0
- package/dist/GitBackup/backend/index.js +91 -0
- package/dist/GitBackup/backend/index.js.map +1 -0
- package/dist/GitBackup/ui/index.d.ts +44 -0
- package/dist/GitBackup/ui/index.js +114 -0
- package/dist/GitBackup/ui/index.js.map +1 -0
- package/dist/IncomeAndExpenses/backend/index.d.ts +5 -0
- package/dist/IncomeAndExpenses/backend/index.js +350 -0
- package/dist/IncomeAndExpenses/backend/index.js.map +1 -0
- package/dist/JournalReport/backend/index.d.ts +15 -0
- package/dist/JournalReport/backend/index.js +143 -0
- package/dist/JournalReport/backend/index.js.map +1 -0
- package/dist/KrakenImport/backend/KrakenHandler.d.ts +23 -0
- package/dist/KrakenImport/backend/KrakenHandler.js +83 -0
- package/dist/KrakenImport/backend/KrakenHandler.js.map +1 -0
- package/dist/KrakenImport/backend/index.d.ts +5 -0
- package/dist/KrakenImport/backend/index.js +18 -0
- package/dist/KrakenImport/backend/index.js.map +1 -0
- package/dist/LedgerReport/backend/index.d.ts +15 -0
- package/dist/LedgerReport/backend/index.js +150 -0
- package/dist/LedgerReport/backend/index.js.map +1 -0
- package/dist/LynxImport/backend/LynxHandler.d.ts +28 -0
- package/dist/LynxImport/backend/LynxHandler.js +340 -0
- package/dist/LynxImport/backend/LynxHandler.js.map +1 -0
- package/dist/LynxImport/backend/index.d.ts +5 -0
- package/dist/LynxImport/backend/index.js +18 -0
- package/dist/LynxImport/backend/index.js.map +1 -0
- package/dist/NordeaImport/backend/NordeaHandler.d.ts +11 -0
- package/dist/NordeaImport/backend/NordeaHandler.js +39 -0
- package/dist/NordeaImport/backend/NordeaHandler.js.map +1 -0
- package/dist/NordeaImport/backend/index.d.ts +5 -0
- package/dist/NordeaImport/backend/index.js +18 -0
- package/dist/NordeaImport/backend/index.js.map +1 -0
- package/dist/NordnetImport/backend/NordnetHandler.d.ts +17 -0
- package/dist/NordnetImport/backend/NordnetHandler.js +66 -0
- package/dist/NordnetImport/backend/NordnetHandler.js.map +1 -0
- package/dist/NordnetImport/backend/index.d.ts +5 -0
- package/dist/NordnetImport/backend/index.js +18 -0
- package/dist/NordnetImport/backend/index.js.map +1 -0
- package/dist/Rand/ui/index.d.ts +15 -0
- package/dist/Rand/ui/index.js +22 -0
- package/dist/Rand/ui/index.js.map +1 -0
- package/dist/RapidAPI/backend/index.d.ts +22 -0
- package/dist/RapidAPI/backend/index.js +119 -0
- package/dist/RapidAPI/backend/index.js.map +1 -0
- package/dist/TITOImport/backend/TITOHandler.d.ts +13 -0
- package/dist/TITOImport/backend/TITOHandler.js +241 -0
- package/dist/TITOImport/backend/TITOHandler.js.map +1 -0
- package/dist/TITOImport/backend/index.d.ts +5 -0
- package/dist/TITOImport/backend/index.js +18 -0
- package/dist/TITOImport/backend/index.js.map +1 -0
- package/dist/TagEditor/ui/index.d.ts +31 -0
- package/dist/TagEditor/ui/index.js +349 -0
- package/dist/TagEditor/ui/index.js.map +1 -0
- package/dist/USDollar/ui/index.d.ts +15 -0
- package/dist/USDollar/ui/index.js +22 -0
- package/dist/USDollar/ui/index.js.map +1 -0
- package/dist/VAT/ui/index.d.ts +69 -0
- package/dist/VAT/ui/index.js +509 -0
- package/dist/VAT/ui/index.js.map +1 -0
- package/dist/VATFinland/backend/index.d.ts +5 -0
- package/dist/VATFinland/backend/index.js +17 -0
- package/dist/VATFinland/backend/index.js.map +1 -0
- package/package.json +7 -6
- package/src/CoinAPI/backend/index.ts +2 -2
- package/src/CoinbaseImport/backend/CoinbaseHandler.ts +2 -2
- package/src/CoinbaseImport/backend/index.ts +2 -2
- package/src/DocumentCleaner/ui/index.tsx +2 -2
- package/src/Euro/ui/index.tsx +1 -1
- package/src/Finnish/ui/index.tsx +1 -1
- package/src/FinnishBalanceSheetReport/backend/index.ts +2 -2
- package/src/FinnishBalanceSheetReportInvestment/backend/index.ts +2 -2
- package/src/FinnishBalanceSheetReportLite/backend/index.ts +2 -2
- package/src/FinnishIncomeStatementReport/backend/index.ts +2 -2
- package/src/FinnishIncomeStatementReportInvestment/backend/index.ts +2 -2
- package/src/FinnishIncomeStatementReportLite/backend/index.ts +2 -2
- package/src/FinnishInvestmentCompany/backend/index.ts +2 -2
- package/src/FinnishInvestmentCompany/ui/index.tsx +1 -1
- package/src/FinnishLimitedCompanyComplete/backend/index.ts +2 -2
- package/src/FinnishLimitedCompanyComplete/ui/index.tsx +1 -1
- package/src/FinnishLimitedCompanyLite/backend/index.ts +2 -2
- package/src/FinnishLimitedCompanyLite/ui/index.tsx +1 -1
- package/src/GitBackup/backend/index.ts +2 -2
- package/src/GitBackup/ui/index.tsx +1 -1
- package/src/IncomeAndExpenses/backend/index.ts +2 -2
- package/src/JournalReport/backend/index.ts +2 -2
- package/src/KrakenImport/backend/KrakenHandler.ts +2 -2
- package/src/KrakenImport/backend/index.ts +2 -2
- package/src/LedgerReport/backend/index.ts +2 -2
- package/src/LynxImport/backend/LynxHandler.ts +2 -2
- package/src/LynxImport/backend/index.ts +2 -2
- package/src/NordeaImport/backend/NordeaHandler.ts +2 -2
- package/src/NordeaImport/backend/index.ts +2 -2
- package/src/NordnetImport/backend/NordnetHandler.ts +2 -2
- package/src/NordnetImport/backend/index.ts +2 -2
- package/src/Rand/ui/index.tsx +1 -1
- package/src/RapidAPI/backend/index.ts +2 -2
- package/src/TITOImport/backend/TITOHandler.ts +2 -2
- package/src/TITOImport/backend/index.ts +2 -2
- package/src/TagEditor/ui/index.tsx +2 -2
- package/src/USDollar/ui/index.tsx +1 -1
- package/src/VAT/ui/index.tsx +2 -2
- package/src/VATFinland/backend/index.ts +2 -2
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { Title, ToolPlugin, QuestionMarkInline, FileUploader } from '@tasenor/common-ui';
|
|
3
|
+
import { haveCursor, isTag } from '@tasenor/common';
|
|
4
|
+
import { Trans, useTranslation } from 'react-i18next';
|
|
5
|
+
import { Box, Button, Card, CardContent, CardMedia, Grid, IconButton, Tab, Tabs, TextField, Typography } from '@mui/material';
|
|
6
|
+
import { Add, Cancel, CheckCircle } from '@mui/icons-material';
|
|
7
|
+
import { runInAction } from 'mobx';
|
|
8
|
+
import clone from 'clone';
|
|
9
|
+
import { green, red } from '@mui/material/colors';
|
|
10
|
+
import { observer } from 'mobx-react';
|
|
11
|
+
const TagCard = observer((props) => {
|
|
12
|
+
const { t } = useTranslation();
|
|
13
|
+
const cursor = haveCursor();
|
|
14
|
+
const [edit, setEdit] = useState(false);
|
|
15
|
+
const [changed, setChanged] = useState(false);
|
|
16
|
+
const [isNew, setIsNew] = useState(false);
|
|
17
|
+
const [isDeleting, setIsDeleting] = useState(false);
|
|
18
|
+
const { name, tag, order, picture, mime } = props.tag ? props.tag : { name: '', tag: '', order: 0, picture: '', mime: '' };
|
|
19
|
+
const [tagName, setTagName] = useState(name);
|
|
20
|
+
const [tagTag, setTagTag] = useState(tag);
|
|
21
|
+
const [tagPicture, setTagPicture] = useState('');
|
|
22
|
+
const [tagMime, setTagMime] = useState(mime);
|
|
23
|
+
let url = props.tag && props.tag.url;
|
|
24
|
+
if (tagPicture) {
|
|
25
|
+
url = `data:${tagMime};base64,${tagPicture}`;
|
|
26
|
+
}
|
|
27
|
+
else if (props.tag && props.tag.picture) {
|
|
28
|
+
url = `data:image/png;base64,${props.tag.picture}`;
|
|
29
|
+
}
|
|
30
|
+
if (!url) {
|
|
31
|
+
url = QuestionMarkInline;
|
|
32
|
+
}
|
|
33
|
+
// Handle saving the tag.
|
|
34
|
+
const onSave = async () => {
|
|
35
|
+
if (isNew) {
|
|
36
|
+
props.onCreate && await props.onCreate({ name: tagName, tag: tagTag, picture: tagPicture, mime: tagMime });
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
props.onSave && await props.onSave({ name: tagName, tag: tagTag, picture: tagPicture, mime: tagMime });
|
|
40
|
+
}
|
|
41
|
+
setEdit(false);
|
|
42
|
+
setTagName('');
|
|
43
|
+
setTagTag('');
|
|
44
|
+
setTagPicture('');
|
|
45
|
+
setTagMime('');
|
|
46
|
+
};
|
|
47
|
+
// Handle deleting the tag.
|
|
48
|
+
const onDelete = async () => {
|
|
49
|
+
props.onDelete && await props.onDelete(tag);
|
|
50
|
+
};
|
|
51
|
+
// Handle file upload.
|
|
52
|
+
const onUpload = (file) => {
|
|
53
|
+
setTagPicture(file.data);
|
|
54
|
+
setTagMime(file.type);
|
|
55
|
+
setChanged(true);
|
|
56
|
+
};
|
|
57
|
+
// Cancel editing.
|
|
58
|
+
const onCancel = () => {
|
|
59
|
+
setEdit(false);
|
|
60
|
+
setTagName('');
|
|
61
|
+
setTagTag('');
|
|
62
|
+
setTagPicture('');
|
|
63
|
+
setTagMime('');
|
|
64
|
+
};
|
|
65
|
+
// Key shortcuts.
|
|
66
|
+
const onKeyUp = (key) => {
|
|
67
|
+
if (key === 'Enter') {
|
|
68
|
+
if (validateName() === null && validateTag() === null) {
|
|
69
|
+
onSave();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (key === 'Escape') {
|
|
73
|
+
onCancel();
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
// Validator for name.
|
|
77
|
+
const validateName = () => {
|
|
78
|
+
if (!changed) {
|
|
79
|
+
return null;
|
|
80
|
+
}
|
|
81
|
+
return tagName ? null : t('Tag name is required');
|
|
82
|
+
};
|
|
83
|
+
// Validator for tag.
|
|
84
|
+
const validateTag = () => {
|
|
85
|
+
if (!changed) {
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
if (!tagTag) {
|
|
89
|
+
return t('Tag code is required');
|
|
90
|
+
}
|
|
91
|
+
if ((!props.tag || tagTag !== props.tag.tag) && props.existingTags.has(tagTag)) {
|
|
92
|
+
return 'Tag already exists';
|
|
93
|
+
}
|
|
94
|
+
return isTag(tagTag) ? null : 'Invalid tag';
|
|
95
|
+
};
|
|
96
|
+
return (React.createElement(Card, { raised: true, sx: { display: 'flex', width: 450 } },
|
|
97
|
+
React.createElement(CardContent, { sx: { flex: '1 0 auto' } },
|
|
98
|
+
!edit && React.createElement(React.Fragment, null,
|
|
99
|
+
React.createElement(Typography, { component: "div", variant: "h5" }, name),
|
|
100
|
+
React.createElement(Typography, { variant: "subtitle1", color: "text.secondary", component: "div" },
|
|
101
|
+
tag,
|
|
102
|
+
" \u00A0\u00A0\u00A0\u00A0\u00A0\u00A0",
|
|
103
|
+
React.createElement(Typography, { variant: "subtitle2", component: "span" }, order ? `#${order}` : '')),
|
|
104
|
+
props.tag && !isDeleting &&
|
|
105
|
+
React.createElement(React.Fragment, null,
|
|
106
|
+
React.createElement(Button, { size: "small", onClick: () => {
|
|
107
|
+
setIsNew(false);
|
|
108
|
+
setEdit(true);
|
|
109
|
+
setTagName(name);
|
|
110
|
+
setTagTag(tag);
|
|
111
|
+
setTagPicture(picture || '');
|
|
112
|
+
setTagMime(mime);
|
|
113
|
+
} },
|
|
114
|
+
React.createElement(Trans, null, "Edit")),
|
|
115
|
+
React.createElement(Button, { size: "small", onClick: () => { setIsDeleting(true); } },
|
|
116
|
+
React.createElement(Trans, null, "Delete"))),
|
|
117
|
+
isDeleting &&
|
|
118
|
+
React.createElement(React.Fragment, null,
|
|
119
|
+
React.createElement(Trans, null, "Are you sure?"),
|
|
120
|
+
React.createElement(Button, { size: "small", onClick: () => { setIsDeleting(false); } },
|
|
121
|
+
React.createElement(Trans, null, "No")),
|
|
122
|
+
React.createElement(Button, { size: "small", onClick: () => { setIsDeleting(false); onDelete(); } },
|
|
123
|
+
React.createElement(Trans, null, "Yes"))),
|
|
124
|
+
!props.tag &&
|
|
125
|
+
React.createElement(Button, { size: "small", onClick: () => { setIsNew(true); setEdit(!edit); } },
|
|
126
|
+
React.createElement(Trans, null, "Add New"))),
|
|
127
|
+
edit && React.createElement(React.Fragment, null,
|
|
128
|
+
React.createElement(TextField, { autoFocus: true, onFocus: () => cursor.disableHandler(), onBlur: () => cursor.enableHandler(), error: !!validateName(), label: validateName(), value: tagName, onChange: (ev) => { setTagName(ev.target.value); setChanged(true); }, onKeyUp: (ev) => onKeyUp(ev.key) }),
|
|
129
|
+
React.createElement(IconButton, { title: t('Cancel'), onClick: onCancel, sx: { color: red[800] } },
|
|
130
|
+
React.createElement(Cancel, null)),
|
|
131
|
+
React.createElement("br", null),
|
|
132
|
+
React.createElement(TextField, { onFocus: () => cursor.disableHandler(), onBlur: () => cursor.enableHandler(), value: tagTag, error: !!validateTag(), label: validateTag(), onChange: (ev) => { setTagTag(ev.target.value); setChanged(true); }, onKeyUp: (ev) => onKeyUp(ev.key) }),
|
|
133
|
+
React.createElement(IconButton, { title: t('Save'), onClick: onSave, sx: { color: green[800] } },
|
|
134
|
+
React.createElement(CheckCircle, null)))),
|
|
135
|
+
edit &&
|
|
136
|
+
React.createElement(Box, { sx: {
|
|
137
|
+
width: 150,
|
|
138
|
+
height: 150,
|
|
139
|
+
borderLeft: 1,
|
|
140
|
+
opacity: 0.5,
|
|
141
|
+
borderColor: 'divider',
|
|
142
|
+
backgroundImage: `url(${url})`,
|
|
143
|
+
backgroundSize: 'cover',
|
|
144
|
+
backgroundRepeat: 'no-repeat'
|
|
145
|
+
} },
|
|
146
|
+
React.createElement(FileUploader, { text: "", color: "info", iconSize: 130, onUpload: (files) => onUpload(files[0]) })),
|
|
147
|
+
!edit &&
|
|
148
|
+
React.createElement(CardMedia, { component: "img", sx: { width: 150, height: 150, borderLeft: 1, borderColor: 'divider' }, image: url, alt: name })));
|
|
149
|
+
});
|
|
150
|
+
const GroupPanel = observer((props) => {
|
|
151
|
+
// Handler for saving a tag
|
|
152
|
+
const onSave = async (tag, changes) => {
|
|
153
|
+
runInAction(() => {
|
|
154
|
+
tag.name = changes.name || '';
|
|
155
|
+
tag.tag = changes.tag;
|
|
156
|
+
tag.picture = changes.picture || null;
|
|
157
|
+
tag.mime = changes.mime || null;
|
|
158
|
+
tag.type = props.group;
|
|
159
|
+
});
|
|
160
|
+
await props.onSave(tag);
|
|
161
|
+
};
|
|
162
|
+
// Handler for creating a tag
|
|
163
|
+
const onCreate = async (changes) => {
|
|
164
|
+
await props.onCreate(changes);
|
|
165
|
+
};
|
|
166
|
+
// Handler for deleting a tag
|
|
167
|
+
const onDelete = async (tag) => {
|
|
168
|
+
await props.onDelete(tag);
|
|
169
|
+
};
|
|
170
|
+
return (React.createElement(Grid, { container: true, spacing: 2 },
|
|
171
|
+
props.tags.map((tag, idx) => (React.createElement(Grid, { item: true, key: idx },
|
|
172
|
+
React.createElement(TagCard, { tag: tag, existingTags: props.existingTags, onSave: (changes) => onSave(tag, changes), onDelete: () => onDelete(tag) })))),
|
|
173
|
+
React.createElement(Grid, { item: true, key: -1 },
|
|
174
|
+
React.createElement(TagCard, { existingTags: props.existingTags, onCreate: (tag) => onCreate(tag) }))));
|
|
175
|
+
});
|
|
176
|
+
const TagsEditor = observer((props) => {
|
|
177
|
+
const cursor = haveCursor();
|
|
178
|
+
const { t } = useTranslation();
|
|
179
|
+
const tags = props.database.tagsByTag;
|
|
180
|
+
const [tab, setTab] = useState(0);
|
|
181
|
+
const [addingTab, setAddingTab] = useState('');
|
|
182
|
+
// Sort types and tags by their order number found.
|
|
183
|
+
const typeRange = {};
|
|
184
|
+
const byGroups = {};
|
|
185
|
+
const orderNumbers = new Set();
|
|
186
|
+
const existingTags = new Set();
|
|
187
|
+
Object.values(tags).forEach(tag => {
|
|
188
|
+
if (!tag.tag || !tag.type) {
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
if (typeRange[tag.type] === undefined) {
|
|
192
|
+
typeRange[tag.type] = { min: tag.order, max: tag.order };
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
if (tag.order < typeRange[tag.type].min) {
|
|
196
|
+
typeRange[tag.type].min = tag.order;
|
|
197
|
+
}
|
|
198
|
+
else if (tag.order > typeRange[tag.type].max) {
|
|
199
|
+
typeRange[tag.type].max = tag.order;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
orderNumbers.add(tag.order);
|
|
203
|
+
existingTags.add(tag.tag);
|
|
204
|
+
byGroups[tag.type] = byGroups[tag.type] || [];
|
|
205
|
+
byGroups[tag.type].push(tag);
|
|
206
|
+
});
|
|
207
|
+
// Sort each group and types and make types as a state.
|
|
208
|
+
const sortedTypes = Object.keys(typeRange).sort((a, b) => typeRange[a].min - typeRange[b].min);
|
|
209
|
+
Object.keys(byGroups).forEach(name => {
|
|
210
|
+
byGroups[name] = byGroups[name].sort((a, b) => a.order - b.order);
|
|
211
|
+
});
|
|
212
|
+
const [types, setTypes] = useState(sortedTypes);
|
|
213
|
+
const [groups, setGroups] = useState(byGroups);
|
|
214
|
+
// Handler for new type creation.
|
|
215
|
+
const onCreateTab = () => {
|
|
216
|
+
if (!addingTab) {
|
|
217
|
+
setTab(types.length - 1);
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
setTypes(types.concat(addingTab));
|
|
221
|
+
setGroups({ ...groups, [addingTab]: [] });
|
|
222
|
+
setAddingTab('');
|
|
223
|
+
};
|
|
224
|
+
// Handler for saving a tag
|
|
225
|
+
const onSave = async (tag) => {
|
|
226
|
+
await props.onSave(tag);
|
|
227
|
+
};
|
|
228
|
+
// Handler for deleting a tag
|
|
229
|
+
const onDelete = async (tag) => {
|
|
230
|
+
await props.onDelete(tag);
|
|
231
|
+
const newGroups = clone(groups);
|
|
232
|
+
newGroups[tag.type] = newGroups[tag.type].filter(t => t.tag !== tag.tag);
|
|
233
|
+
setGroups(newGroups);
|
|
234
|
+
};
|
|
235
|
+
// Handler for creating a tag
|
|
236
|
+
const onCreate = async (tag) => {
|
|
237
|
+
const type = types[tab];
|
|
238
|
+
let order = Math.max(...groups[type].map(t => t.order)) + 1;
|
|
239
|
+
// Set number to new group.
|
|
240
|
+
if (groups[type].length === 0) {
|
|
241
|
+
const idx = types.indexOf(type);
|
|
242
|
+
order = (idx + 1) * 1000 + 1;
|
|
243
|
+
}
|
|
244
|
+
// Ensure non-overlapping.
|
|
245
|
+
while (orderNumbers.has(order)) {
|
|
246
|
+
order++;
|
|
247
|
+
}
|
|
248
|
+
if (tag.tag) {
|
|
249
|
+
const model = await props.onCreate({
|
|
250
|
+
tag: tag.tag,
|
|
251
|
+
name: tag.name,
|
|
252
|
+
picture: tag.picture,
|
|
253
|
+
mime: tag.mime,
|
|
254
|
+
type,
|
|
255
|
+
order
|
|
256
|
+
});
|
|
257
|
+
setGroups({ ...groups, [type]: groups[type].concat([model]) });
|
|
258
|
+
}
|
|
259
|
+
};
|
|
260
|
+
// Handler for tab editor key presses.
|
|
261
|
+
const onKeyUp = (key) => {
|
|
262
|
+
if (key === 'Enter') {
|
|
263
|
+
onCreateTab();
|
|
264
|
+
}
|
|
265
|
+
if (key === 'Escape') {
|
|
266
|
+
setAddingTab('');
|
|
267
|
+
if (tab)
|
|
268
|
+
setTab(tab - 1);
|
|
269
|
+
}
|
|
270
|
+
};
|
|
271
|
+
// TODO: Editing type name by clicking already selected tab.
|
|
272
|
+
return (React.createElement(Box, { sx: { borderBottom: 1, borderColor: 'divider' } },
|
|
273
|
+
React.createElement(Tabs, { value: tab, onChange: (event, newValue) => setTab(newValue) },
|
|
274
|
+
types.map((type, idx) => (React.createElement(Tab, { key: idx, label: type }))),
|
|
275
|
+
React.createElement(Tab, { key: -1, disableRipple: true, icon: types[tab] && React.createElement(Add, null), iconPosition: "start", label: types[tab]
|
|
276
|
+
? t('Add Tag Type')
|
|
277
|
+
: React.createElement(TextField, { autoFocus: true, onFocus: () => cursor.disableHandler(), onBlur: () => cursor.enableHandler(), value: addingTab, onChange: ev => setAddingTab(ev.target.value), onKeyUp: (ev) => onKeyUp(ev.key) }) })),
|
|
278
|
+
types[tab] && (React.createElement(React.Fragment, null,
|
|
279
|
+
React.createElement(GroupPanel, { group: types[tab], tags: groups[types[tab]], existingTags: existingTags, onSave: tag => onSave(tag), onCreate: tag => onCreate(tag), onDelete: tag => onDelete(tag) }))),
|
|
280
|
+
types.length === 0 && (React.createElement(Typography, { variant: "h6", sx: { padding: 1 } },
|
|
281
|
+
React.createElement(Trans, null, "You don't have any tag groups yet. Please create the firt one by naming it above.")))));
|
|
282
|
+
});
|
|
283
|
+
class TagEditor extends ToolPlugin {
|
|
284
|
+
static code = 'TagEditor';
|
|
285
|
+
static title = 'Tag Editor';
|
|
286
|
+
static version = '1.0.33';
|
|
287
|
+
static icon = '<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="#000000"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M16 7H5v10h11l3.55-5z" opacity=".3"/><path d="M17.63 5.84C17.27 5.33 16.67 5 16 5L5 5.01C3.9 5.01 3 5.9 3 7v10c0 1.1.9 1.99 2 1.99L16 19c.67 0 1.27-.33 1.63-.84L22 12l-4.37-6.16zM16 17H5V7h11l3.55 5L16 17z"/></svg>';
|
|
288
|
+
static releaseDate = '2022-03-11';
|
|
289
|
+
static use = 'ui';
|
|
290
|
+
static type = 'tool';
|
|
291
|
+
static description = 'Allows creating, deleting and editing tags and tag groups. Tags are useful for example for filtering transaction lists and combining reports by customizable groups.';
|
|
292
|
+
constructor() {
|
|
293
|
+
super();
|
|
294
|
+
this.languages = {
|
|
295
|
+
fi: {
|
|
296
|
+
'Add Tag Type': 'Lisää uusi ryhmä',
|
|
297
|
+
'Tag Editor': 'Tägieditori',
|
|
298
|
+
'Tag name is required': 'Tägillä pitää olla nimi',
|
|
299
|
+
'Tag code is required': 'Tägillä pitää olla koodi',
|
|
300
|
+
'Tag already exists': 'Tägi on jo olemassa',
|
|
301
|
+
'Invalid tag': 'Virheellinen tägi',
|
|
302
|
+
'Edit Tags in the Database': 'Muokkaa tietokannan tägejä',
|
|
303
|
+
'A tag is a special notation that can be added to the beginning of the transaction description.': 'Tägi on erityisnotaatio, jota voidaan käyttää tapahtuman kuvauksen alussa.',
|
|
304
|
+
'A short code, e.g. XYZ an be added in the beginning of the description as [XYZ].': 'Esimerkiksi tägi, jonka koodi on XYZ, voidaan lisätä kuvauksen alkuun kirjoittamalla [XYZ].',
|
|
305
|
+
'Once added, the tag can be used in transaction list as a filter by showing only the transactions with the give tag.': 'Kun tapahtumaan on lisätty tägi, sitä voidaan käyttää tapahtumalistan filtteröintiin näyttämään vain kyseise tägin sisältämät rivit.',
|
|
306
|
+
'Tag grouping is used to keep tags of the specific dimension in the single group.': 'Tägien ryhmittelyä käytetään tietyn dimension tägien yhdistämiseen saman nimen alle.',
|
|
307
|
+
'It is usable in some reports for example.': 'Ryhmittelyä voidaan hyödyntää esimerkiksi joissakin raporteissa.',
|
|
308
|
+
'You don't have any tag groups yet. Please create the firt one by naming it above.': 'Yhtään tägiryhmää ei ole vielä olemassa. Ole hyvä ja luo ensimmäinen antamalla sille nimi yllä.',
|
|
309
|
+
}
|
|
310
|
+
};
|
|
311
|
+
}
|
|
312
|
+
toolMenu() {
|
|
313
|
+
return [{ title: 'Tag Editor', disabled: !this.store || !this.store.db }];
|
|
314
|
+
}
|
|
315
|
+
toolTitle() {
|
|
316
|
+
return 'Tag Editor';
|
|
317
|
+
}
|
|
318
|
+
toolTopPanel() {
|
|
319
|
+
return React.createElement(Typography, { sx: { padding: 1 } },
|
|
320
|
+
React.createElement(Trans, null, "A tag is a special notation that can be added to the beginning of the transaction description."),
|
|
321
|
+
React.createElement(Trans, null, "A short code, e.g. XYZ an be added in the beginning of the description as [XYZ]."),
|
|
322
|
+
React.createElement(Trans, null, "Once added, the tag can be used in transaction list as a filter by showing only the transactions with the give tag."),
|
|
323
|
+
React.createElement(Trans, null, "Tag grouping is used to keep tags of the specific dimension in the single group."),
|
|
324
|
+
React.createElement(Trans, null, "It is usable in some reports for example."));
|
|
325
|
+
}
|
|
326
|
+
toolMainPanel() {
|
|
327
|
+
const { store } = this;
|
|
328
|
+
if (!store || !store.database) {
|
|
329
|
+
return React.createElement(React.Fragment, null);
|
|
330
|
+
}
|
|
331
|
+
const onSave = async (tag) => {
|
|
332
|
+
await tag.save();
|
|
333
|
+
};
|
|
334
|
+
const onDelete = async (tag) => {
|
|
335
|
+
await tag.delete();
|
|
336
|
+
};
|
|
337
|
+
const onCreate = async (tag) => {
|
|
338
|
+
const model = await store.database.addTag(tag);
|
|
339
|
+
await model.save();
|
|
340
|
+
return model;
|
|
341
|
+
};
|
|
342
|
+
return (React.createElement(Box, { sx: { padding: 1 } },
|
|
343
|
+
React.createElement(Title, null,
|
|
344
|
+
React.createElement(Trans, null, "Edit Tags in the Database")),
|
|
345
|
+
React.createElement(TagsEditor, { database: store.database, onDelete: onDelete, onSave: onSave, onCreate: onCreate })));
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
export default TagEditor;
|
|
349
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/TagEditor/ui/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { CurrencyPlugin } from '@tasenor/common-ui';
|
|
2
|
+
declare class USDollar extends CurrencyPlugin {
|
|
3
|
+
static code: string;
|
|
4
|
+
static title: string;
|
|
5
|
+
static version: string;
|
|
6
|
+
static icon: string;
|
|
7
|
+
static releaseDate: string;
|
|
8
|
+
static use: string;
|
|
9
|
+
static type: string;
|
|
10
|
+
static description: string;
|
|
11
|
+
getCurrencySymbol(): string;
|
|
12
|
+
getCurrencyCode(): string;
|
|
13
|
+
money2str(cents: any): string;
|
|
14
|
+
}
|
|
15
|
+
export default USDollar;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { CurrencyPlugin } from '@tasenor/common-ui';
|
|
2
|
+
class USDollar extends CurrencyPlugin {
|
|
3
|
+
static code = 'USDollar';
|
|
4
|
+
static title = 'Currency US Dollar';
|
|
5
|
+
static version = '1.0.9';
|
|
6
|
+
static icon = '<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="#000000"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M11.8 10.9c-2.27-.59-3-1.2-3-2.15 0-1.09 1.01-1.85 2.7-1.85 1.78 0 2.44.85 2.5 2.1h2.21c-.07-1.72-1.12-3.3-3.21-3.81V3h-3v2.16c-1.94.42-3.5 1.68-3.5 3.61 0 2.31 1.91 3.46 4.7 4.13 2.5.6 3 1.48 3 2.41 0 .69-.49 1.79-2.7 1.79-2.06 0-2.87-.92-2.98-2.1h-2.2c.12 2.19 1.76 3.42 3.68 3.83V21h3v-2.15c1.95-.37 3.5-1.5 3.5-3.55 0-2.84-2.43-3.81-4.7-4.4z"/></svg>';
|
|
7
|
+
static releaseDate = '2022-04-08';
|
|
8
|
+
static use = 'ui';
|
|
9
|
+
static type = 'currency';
|
|
10
|
+
static description = 'Support for US dollar currency.';
|
|
11
|
+
getCurrencySymbol() {
|
|
12
|
+
return '$';
|
|
13
|
+
}
|
|
14
|
+
getCurrencyCode() {
|
|
15
|
+
return 'USD';
|
|
16
|
+
}
|
|
17
|
+
money2str(cents) {
|
|
18
|
+
return this.makeMoney(cents, 100, 2, '$ ', ',', '.', '');
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export default USDollar;
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/USDollar/ui/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAA;AAEnD,MAAM,QAAS,SAAQ,cAAc;IAEnC,MAAM,CAAC,IAAI,GAAG,UAAU,CAAA;IACxB,MAAM,CAAC,KAAK,GAAG,oBAAoB,CAAA;IACnC,MAAM,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,MAAM,CAAC,IAAI,GAAG,0fAA0f,CAAA;IACxgB,MAAM,CAAC,WAAW,GAAG,YAAY,CAAA;IACjC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAA;IACjB,MAAM,CAAC,IAAI,GAAG,UAAU,CAAA;IACxB,MAAM,CAAC,WAAW,GAAG,iCAAiC,CAAA;IAEtD,iBAAiB;QACf,OAAO,GAAG,CAAA;IACZ,CAAC;IAED,eAAe;QACb,OAAO,KAAK,CAAA;IACd,CAAC;IAED,SAAS,CAAC,KAAK;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAA;IAC1D,CAAC;;AAGH,eAAe,QAAQ,CAAA"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ToolPlugin } from '@tasenor/common-ui';
|
|
3
|
+
declare class VAT extends ToolPlugin {
|
|
4
|
+
showVatTable: boolean;
|
|
5
|
+
requirements: boolean;
|
|
6
|
+
static code: string;
|
|
7
|
+
static title: string;
|
|
8
|
+
static version: string;
|
|
9
|
+
static icon: string;
|
|
10
|
+
static releaseDate: string;
|
|
11
|
+
static use: string;
|
|
12
|
+
static type: string;
|
|
13
|
+
static description: string;
|
|
14
|
+
constructor();
|
|
15
|
+
init(catalog: any): void;
|
|
16
|
+
toolMenu(): {
|
|
17
|
+
title: string;
|
|
18
|
+
disabled: boolean;
|
|
19
|
+
}[];
|
|
20
|
+
toolTitle(): string;
|
|
21
|
+
/**
|
|
22
|
+
* Gather documents with non-reconciled VAT entries.
|
|
23
|
+
*/
|
|
24
|
+
openVATDocuments(): any;
|
|
25
|
+
/**
|
|
26
|
+
* Calculate sum of unprocessed payable and receivable for VAT.
|
|
27
|
+
* @return {Object} An object with `sales` and `purchases`.
|
|
28
|
+
*/
|
|
29
|
+
VATSummary(): {
|
|
30
|
+
sales: number;
|
|
31
|
+
purchases: number;
|
|
32
|
+
};
|
|
33
|
+
/**
|
|
34
|
+
* Icons and VAT table viewer.
|
|
35
|
+
* @param index
|
|
36
|
+
* @returns
|
|
37
|
+
*/
|
|
38
|
+
toolTopPanel(): JSX.Element;
|
|
39
|
+
toolMainPanel(): JSX.Element;
|
|
40
|
+
/**
|
|
41
|
+
* Combine unprocessed VAT to new payable or receivable entry.
|
|
42
|
+
*/
|
|
43
|
+
createVATEntry(): Promise<void>;
|
|
44
|
+
editTransaction(document: any, row: any, column: any, originalValue: any): Promise<Set<any> | undefined>;
|
|
45
|
+
getSettings(): {
|
|
46
|
+
type: string;
|
|
47
|
+
elements: ({
|
|
48
|
+
type: string;
|
|
49
|
+
name: string;
|
|
50
|
+
filter: {
|
|
51
|
+
type: string;
|
|
52
|
+
};
|
|
53
|
+
label?: undefined;
|
|
54
|
+
actions?: undefined;
|
|
55
|
+
} | {
|
|
56
|
+
type: string;
|
|
57
|
+
label: string;
|
|
58
|
+
actions: {
|
|
59
|
+
onClick: {
|
|
60
|
+
type: string;
|
|
61
|
+
plugin: string;
|
|
62
|
+
};
|
|
63
|
+
};
|
|
64
|
+
name?: undefined;
|
|
65
|
+
filter?: undefined;
|
|
66
|
+
})[];
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
export default VAT;
|