feat(MemberTtrHistory): implement TTR history management and UI enhancements
- Added new endpoints in the member controller for retrieving and refreshing TTR history. - Integrated TTR history functionality into the member service, allowing for seamless data retrieval and updates. - Updated the member model to include a field for TTR history player ID, enhancing data tracking. - Enhanced the MembersView to display TTR history with a dedicated dialog for better user interaction. - Improved the MyTischtennisClient to support fetching historical player IDs, enriching the data provided to users. - Refactored various components to ensure consistent styling and functionality across the application.
This commit is contained in:
@@ -5,6 +5,8 @@ import {
|
||||
uploadMemberImage,
|
||||
getMemberImage,
|
||||
updateRatingsFromMyTischtennis,
|
||||
getMemberTtrHistory,
|
||||
refreshMemberTtrHistory,
|
||||
rotateMemberImage,
|
||||
transferMembers,
|
||||
quickUpdateTestMembership,
|
||||
@@ -35,6 +37,8 @@ router.get('/gallery/:clubId', authenticate, authorize('members', 'read'), gener
|
||||
router.post('/set/:id', authenticate, authorize('members', 'write'), setClubMembers);
|
||||
router.get('/notapproved/:id', authenticate, authorize('members', 'read'), getWaitingApprovals);
|
||||
router.post('/update-ratings/:id', authenticate, authorize('mytischtennis', 'write'), updateRatingsFromMyTischtennis);
|
||||
router.get('/ttr-history/:clubId/:memberId', authenticate, authorize('members', 'read'), getMemberTtrHistory);
|
||||
router.post('/ttr-history/:clubId/:memberId/refresh', authenticate, authorize('members', 'read'), refreshMemberTtrHistory);
|
||||
router.post('/rotate-image/:clubId/:memberId/:imageId', authenticate, authorize('members', 'write'), rotateMemberImage);
|
||||
router.post('/transfer/:id', authenticate, authorize('members', 'write'), transferMembers);
|
||||
router.post('/quick-update-test-membership/:clubId/:memberId', authenticate, authorize('members', 'write'), quickUpdateTestMembership);
|
||||
|
||||
@@ -188,18 +188,6 @@ router.put('/submit/:uuid', async (req, res) => {
|
||||
const { uuid } = req.params;
|
||||
const reportData = req.body;
|
||||
|
||||
console.log('[nuscore submit] request', {
|
||||
uuid,
|
||||
wo: reportData?.wo ?? null,
|
||||
isCompleted: reportData?.isCompleted ?? null,
|
||||
homePin: reportData?.homePin ?? null,
|
||||
guestPin: reportData?.guestPin ?? null,
|
||||
releaseSignatureHome: reportData?.signature?.releaseSignatureHome ?? null,
|
||||
releaseSignatureGuest: reportData?.signature?.releaseSignatureGuest ?? null,
|
||||
lineupSignatureHome: reportData?.signature?.lineupSignatureHome ?? null,
|
||||
lineupSignatureGuest: reportData?.signature?.lineupSignatureGuest ?? null
|
||||
});
|
||||
|
||||
try {
|
||||
// Hole Cookies für diese UUID (falls vorhanden)
|
||||
// Versuche zuerst UUID, dann Code als Fallback
|
||||
@@ -241,17 +229,6 @@ router.put('/submit/:uuid', async (req, res) => {
|
||||
responseData = { message: responseText };
|
||||
}
|
||||
|
||||
console.log('[nuscore submit] response', {
|
||||
uuid,
|
||||
httpStatus: response.status,
|
||||
resultState: responseData?.resultState ?? null,
|
||||
validationErrors: responseData?.validationErrors ?? [],
|
||||
releaseSignatureHome: responseData?.object?.signature?.releaseSignatureHome ?? null,
|
||||
releaseSignatureGuest: responseData?.object?.signature?.releaseSignatureGuest ?? null,
|
||||
lineupSignatureHome: responseData?.object?.signature?.lineupSignatureHome ?? null,
|
||||
lineupSignatureGuest: responseData?.object?.signature?.lineupSignatureGuest ?? null
|
||||
});
|
||||
|
||||
const resultState = responseData?.resultState;
|
||||
const validationErrors = Array.isArray(responseData?.validationErrors) ? responseData.validationErrors : [];
|
||||
|
||||
@@ -320,18 +297,6 @@ router.put('/validate/:uuid', async (req, res) => {
|
||||
const { uuid } = req.params;
|
||||
const reportData = req.body;
|
||||
|
||||
console.log('[nuscore validate] request', {
|
||||
uuid,
|
||||
wo: reportData?.wo ?? null,
|
||||
isCompleted: reportData?.isCompleted ?? null,
|
||||
homePin: reportData?.homePin ?? null,
|
||||
guestPin: reportData?.guestPin ?? null,
|
||||
releaseSignatureHome: reportData?.signature?.releaseSignatureHome ?? null,
|
||||
releaseSignatureGuest: reportData?.signature?.releaseSignatureGuest ?? null,
|
||||
lineupSignatureHome: reportData?.signature?.lineupSignatureHome ?? null,
|
||||
lineupSignatureGuest: reportData?.signature?.lineupSignatureGuest ?? null
|
||||
});
|
||||
|
||||
try {
|
||||
// Hole Cookies für diese UUID (falls vorhanden)
|
||||
// Versuche zuerst UUID, dann Code als Fallback
|
||||
@@ -373,17 +338,6 @@ router.put('/validate/:uuid', async (req, res) => {
|
||||
responseData = { message: responseText };
|
||||
}
|
||||
|
||||
console.log('[nuscore validate] response', {
|
||||
uuid,
|
||||
httpStatus: response.status,
|
||||
resultState: responseData?.resultState ?? null,
|
||||
validationErrors: responseData?.validationErrors ?? [],
|
||||
releaseSignatureHome: responseData?.object?.signature?.releaseSignatureHome ?? null,
|
||||
releaseSignatureGuest: responseData?.object?.signature?.releaseSignatureGuest ?? null,
|
||||
lineupSignatureHome: responseData?.object?.signature?.lineupSignatureHome ?? null,
|
||||
lineupSignatureGuest: responseData?.object?.signature?.lineupSignatureGuest ?? null
|
||||
});
|
||||
|
||||
// Speichere neue Cookies falls vorhanden
|
||||
const newCookies = extractCookies(response.headers.raw()['set-cookie']);
|
||||
if (Object.keys(newCookies).length > 0) {
|
||||
|
||||
Reference in New Issue
Block a user