mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-13 07:45:54 +00:00
Merge branch 'master' into 2072-feature-usecase-contribution-messaging
This commit is contained in:
commit
76f3e7b849
@ -26,5 +26,5 @@ module.exports = {
|
|||||||
testMatch: ['**/?(*.)+(spec|test).js?(x)'],
|
testMatch: ['**/?(*.)+(spec|test).js?(x)'],
|
||||||
// snapshotSerializers: ['jest-serializer-vue'],
|
// snapshotSerializers: ['jest-serializer-vue'],
|
||||||
transformIgnorePatterns: ['<rootDir>/node_modules/(?!vee-validate/dist/rules)'],
|
transformIgnorePatterns: ['<rootDir>/node_modules/(?!vee-validate/dist/rules)'],
|
||||||
testEnvironment: 'jest-environment-jsdom-sixteen',
|
// testEnvironment: 'jest-environment-jsdom-sixteen', // not needed anymore since jest@26, see: https://www.npmjs.com/package/jest-environment-jsdom-sixteen
|
||||||
}
|
}
|
||||||
|
|||||||
@ -70,7 +70,6 @@
|
|||||||
"eslint-plugin-prettier": "3.3.1",
|
"eslint-plugin-prettier": "3.3.1",
|
||||||
"eslint-plugin-promise": "^5.1.1",
|
"eslint-plugin-promise": "^5.1.1",
|
||||||
"eslint-plugin-vue": "^7.20.0",
|
"eslint-plugin-vue": "^7.20.0",
|
||||||
"jest-environment-jsdom-sixteen": "^2.0.0",
|
|
||||||
"postcss": "^8.4.8",
|
"postcss": "^8.4.8",
|
||||||
"postcss-html": "^1.3.0",
|
"postcss-html": "^1.3.0",
|
||||||
"postcss-scss": "^4.0.3",
|
"postcss-scss": "^4.0.3",
|
||||||
|
|||||||
@ -1282,17 +1282,6 @@
|
|||||||
jest-message-util "^24.9.0"
|
jest-message-util "^24.9.0"
|
||||||
jest-mock "^24.9.0"
|
jest-mock "^24.9.0"
|
||||||
|
|
||||||
"@jest/fake-timers@^25.1.0":
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-25.5.0.tgz#46352e00533c024c90c2bc2ad9f2959f7f114185"
|
|
||||||
integrity sha512-9y2+uGnESw/oyOI3eww9yaxdZyHq7XvprfP/eeoCsjqKYts2yRlsHS/SgjPDV8FyMfn2nbMy8YzUk6nyvdLOpQ==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
jest-message-util "^25.5.0"
|
|
||||||
jest-mock "^25.5.0"
|
|
||||||
jest-util "^25.5.0"
|
|
||||||
lolex "^5.0.0"
|
|
||||||
|
|
||||||
"@jest/fake-timers@^26.6.2":
|
"@jest/fake-timers@^26.6.2":
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.6.2.tgz#459c329bcf70cee4af4d7e3f3e67848123535aad"
|
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.6.2.tgz#459c329bcf70cee4af4d7e3f3e67848123535aad"
|
||||||
@ -1504,16 +1493,6 @@
|
|||||||
"@types/istanbul-reports" "^1.1.1"
|
"@types/istanbul-reports" "^1.1.1"
|
||||||
"@types/yargs" "^13.0.0"
|
"@types/yargs" "^13.0.0"
|
||||||
|
|
||||||
"@jest/types@^25.5.0":
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/@jest/types/-/types-25.5.0.tgz#4d6a4793f7b9599fc3680877b856a97dbccf2a9d"
|
|
||||||
integrity sha512-OXD0RgQ86Tu3MazKo8bnrkDRaDXXMGUqd+kTtLtK1Zb7CRzQcaSRPPPV37SvYTdevXEBVxe0HXylEjs8ibkmCw==
|
|
||||||
dependencies:
|
|
||||||
"@types/istanbul-lib-coverage" "^2.0.0"
|
|
||||||
"@types/istanbul-reports" "^1.1.1"
|
|
||||||
"@types/yargs" "^15.0.0"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
|
|
||||||
"@jest/types@^26.6.2":
|
"@jest/types@^26.6.2":
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.6.2.tgz#bef5a532030e1d88a2f5a6d933f84e97226ed48e"
|
resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.6.2.tgz#bef5a532030e1d88a2f5a6d933f84e97226ed48e"
|
||||||
@ -4130,14 +4109,6 @@ chalk@^2.0.0, chalk@^2.0.1, chalk@^2.1.0, chalk@^2.3.0, chalk@^2.4.1, chalk@^2.4
|
|||||||
escape-string-regexp "^1.0.5"
|
escape-string-regexp "^1.0.5"
|
||||||
supports-color "^5.3.0"
|
supports-color "^5.3.0"
|
||||||
|
|
||||||
chalk@^3.0.0:
|
|
||||||
version "3.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4"
|
|
||||||
integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==
|
|
||||||
dependencies:
|
|
||||||
ansi-styles "^4.1.0"
|
|
||||||
supports-color "^7.1.0"
|
|
||||||
|
|
||||||
chalk@^4.0.0, chalk@^4.1.0:
|
chalk@^4.0.0, chalk@^4.1.0:
|
||||||
version "4.1.2"
|
version "4.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01"
|
resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01"
|
||||||
@ -8012,16 +7983,6 @@ jest-environment-jsdom-fifteen@^1.0.2:
|
|||||||
jest-util "^24.0.0"
|
jest-util "^24.0.0"
|
||||||
jsdom "^15.2.1"
|
jsdom "^15.2.1"
|
||||||
|
|
||||||
jest-environment-jsdom-sixteen@^2.0.0:
|
|
||||||
version "2.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-environment-jsdom-sixteen/-/jest-environment-jsdom-sixteen-2.0.0.tgz#0f8c12663ccd9836d248574decffc575bfb091e1"
|
|
||||||
integrity sha512-BF+8P67aEJcd78TQzwSb9P4a73cArOWb5KgqI8eU6cHRWDIJdDRE8XTeZAmOuDSDhKpuEXjKkXwWB3GOJvqHJQ==
|
|
||||||
dependencies:
|
|
||||||
"@jest/fake-timers" "^25.1.0"
|
|
||||||
jest-mock "^25.1.0"
|
|
||||||
jest-util "^25.1.0"
|
|
||||||
jsdom "^16.2.1"
|
|
||||||
|
|
||||||
jest-environment-jsdom@^24.9.0:
|
jest-environment-jsdom@^24.9.0:
|
||||||
version "24.9.0"
|
version "24.9.0"
|
||||||
resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-24.9.0.tgz#4b0806c7fc94f95edb369a69cc2778eec2b7375b"
|
resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-24.9.0.tgz#4b0806c7fc94f95edb369a69cc2778eec2b7375b"
|
||||||
@ -8236,20 +8197,6 @@ jest-message-util@^24.9.0:
|
|||||||
slash "^2.0.0"
|
slash "^2.0.0"
|
||||||
stack-utils "^1.0.1"
|
stack-utils "^1.0.1"
|
||||||
|
|
||||||
jest-message-util@^25.5.0:
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-25.5.0.tgz#ea11d93204cc7ae97456e1d8716251185b8880ea"
|
|
||||||
integrity sha512-ezddz3YCT/LT0SKAmylVyWWIGYoKHOFOFXx3/nA4m794lfVUskMcwhip6vTgdVrOtYdjeQeis2ypzes9mZb4EA==
|
|
||||||
dependencies:
|
|
||||||
"@babel/code-frame" "^7.0.0"
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
"@types/stack-utils" "^1.0.1"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
graceful-fs "^4.2.4"
|
|
||||||
micromatch "^4.0.2"
|
|
||||||
slash "^3.0.0"
|
|
||||||
stack-utils "^1.0.1"
|
|
||||||
|
|
||||||
jest-message-util@^26.6.2:
|
jest-message-util@^26.6.2:
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.6.2.tgz#58173744ad6fc0506b5d21150b9be56ef001ca07"
|
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.6.2.tgz#58173744ad6fc0506b5d21150b9be56ef001ca07"
|
||||||
@ -8272,13 +8219,6 @@ jest-mock@^24.0.0, jest-mock@^24.9.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^24.9.0"
|
"@jest/types" "^24.9.0"
|
||||||
|
|
||||||
jest-mock@^25.1.0, jest-mock@^25.5.0:
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-25.5.0.tgz#a91a54dabd14e37ecd61665d6b6e06360a55387a"
|
|
||||||
integrity sha512-eXWuTV8mKzp/ovHc5+3USJMYsTBhyQ+5A1Mak35dey/RG8GlM4YWVylZuGgVXinaW6tpvk/RSecmF37FKUlpXA==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
|
|
||||||
jest-mock@^26.6.2:
|
jest-mock@^26.6.2:
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.6.2.tgz#d6cb712b041ed47fe0d9b6fc3474bc6543feb302"
|
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.6.2.tgz#d6cb712b041ed47fe0d9b6fc3474bc6543feb302"
|
||||||
@ -8555,17 +8495,6 @@ jest-util@^24.0.0, jest-util@^24.9.0:
|
|||||||
slash "^2.0.0"
|
slash "^2.0.0"
|
||||||
source-map "^0.6.0"
|
source-map "^0.6.0"
|
||||||
|
|
||||||
jest-util@^25.1.0, jest-util@^25.5.0:
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-25.5.0.tgz#31c63b5d6e901274d264a4fec849230aa3fa35b0"
|
|
||||||
integrity sha512-KVlX+WWg1zUTB9ktvhsg2PXZVdkI1NBevOJSkTKYAyXyH4QSvh+Lay/e/v+bmaFfrkfx43xD8QTfgobzlEXdIA==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
graceful-fs "^4.2.4"
|
|
||||||
is-ci "^2.0.0"
|
|
||||||
make-dir "^3.0.0"
|
|
||||||
|
|
||||||
jest-util@^26.6.2:
|
jest-util@^26.6.2:
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.6.2.tgz#907535dbe4d5a6cb4c47ac9b926f6af29576cbc1"
|
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.6.2.tgz#907535dbe4d5a6cb4c47ac9b926f6af29576cbc1"
|
||||||
@ -8812,7 +8741,7 @@ jsdom@^15.2.1:
|
|||||||
ws "^7.0.0"
|
ws "^7.0.0"
|
||||||
xml-name-validator "^3.0.0"
|
xml-name-validator "^3.0.0"
|
||||||
|
|
||||||
jsdom@^16.2.1, jsdom@^16.4.0:
|
jsdom@^16.4.0:
|
||||||
version "16.7.0"
|
version "16.7.0"
|
||||||
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.7.0.tgz#918ae71965424b197c819f8183a754e18977b710"
|
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.7.0.tgz#918ae71965424b197c819f8183a754e18977b710"
|
||||||
integrity sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==
|
integrity sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==
|
||||||
@ -9167,13 +9096,6 @@ loglevel@^1.6.8:
|
|||||||
resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.7.1.tgz#005fde2f5e6e47068f935ff28573e125ef72f197"
|
resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.7.1.tgz#005fde2f5e6e47068f935ff28573e125ef72f197"
|
||||||
integrity sha512-Hesni4s5UkWkwCGJMQGAh71PaLUmKFM60dHvq0zi/vDhhrzuk+4GgNbTXJ12YYQJn6ZKBDNIjYcuQGKudvqrIw==
|
integrity sha512-Hesni4s5UkWkwCGJMQGAh71PaLUmKFM60dHvq0zi/vDhhrzuk+4GgNbTXJ12YYQJn6ZKBDNIjYcuQGKudvqrIw==
|
||||||
|
|
||||||
lolex@^5.0.0:
|
|
||||||
version "5.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/lolex/-/lolex-5.1.2.tgz#953694d098ce7c07bc5ed6d0e42bc6c0c6d5a367"
|
|
||||||
integrity sha512-h4hmjAvHTmd+25JSwrtTIuwbKdwg5NzZVRMLn9saij4SZaepCrTCxPr35H/3bjwfMJtN+t3CX8672UIkglz28A==
|
|
||||||
dependencies:
|
|
||||||
"@sinonjs/commons" "^1.7.0"
|
|
||||||
|
|
||||||
loose-envify@^1.0.0:
|
loose-envify@^1.0.0:
|
||||||
version "1.4.0"
|
version "1.4.0"
|
||||||
resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf"
|
resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf"
|
||||||
|
|||||||
@ -25,6 +25,14 @@
|
|||||||
"keepFileExt" : true,
|
"keepFileExt" : true,
|
||||||
"fileNameSep" : "_"
|
"fileNameSep" : "_"
|
||||||
},
|
},
|
||||||
|
"klicktipp":
|
||||||
|
{
|
||||||
|
"type": "dateFile",
|
||||||
|
"filename": "../logs/backend/klicktipp.log",
|
||||||
|
"pattern": "%d{ISO8601} %p %c %X{user} %f:%l %m",
|
||||||
|
"keepFileExt" : true,
|
||||||
|
"fileNameSep" : "_"
|
||||||
|
},
|
||||||
"errorFile":
|
"errorFile":
|
||||||
{
|
{
|
||||||
"type": "dateFile",
|
"type": "dateFile",
|
||||||
@ -90,6 +98,17 @@
|
|||||||
"level": "debug",
|
"level": "debug",
|
||||||
"enableCallStack": true
|
"enableCallStack": true
|
||||||
},
|
},
|
||||||
|
"klicktipp":
|
||||||
|
{
|
||||||
|
"appenders":
|
||||||
|
[
|
||||||
|
"klicktipp",
|
||||||
|
"out",
|
||||||
|
"errors"
|
||||||
|
],
|
||||||
|
"level": "debug",
|
||||||
|
"enableCallStack": true
|
||||||
|
},
|
||||||
"http":
|
"http":
|
||||||
{
|
{
|
||||||
"appenders":
|
"appenders":
|
||||||
|
|||||||
@ -30,6 +30,7 @@ export enum RIGHTS {
|
|||||||
LIST_CONTRIBUTIONS = 'LIST_CONTRIBUTIONS',
|
LIST_CONTRIBUTIONS = 'LIST_CONTRIBUTIONS',
|
||||||
LIST_ALL_CONTRIBUTIONS = 'LIST_ALL_CONTRIBUTIONS',
|
LIST_ALL_CONTRIBUTIONS = 'LIST_ALL_CONTRIBUTIONS',
|
||||||
UPDATE_CONTRIBUTION = 'UPDATE_CONTRIBUTION',
|
UPDATE_CONTRIBUTION = 'UPDATE_CONTRIBUTION',
|
||||||
|
LIST_CONTRIBUTION_LINKS = 'LIST_CONTRIBUTION_LINKS',
|
||||||
// Admin
|
// Admin
|
||||||
SEARCH_USERS = 'SEARCH_USERS',
|
SEARCH_USERS = 'SEARCH_USERS',
|
||||||
SET_USER_ROLE = 'SET_USER_ROLE',
|
SET_USER_ROLE = 'SET_USER_ROLE',
|
||||||
@ -45,7 +46,6 @@ export enum RIGHTS {
|
|||||||
CREATION_TRANSACTION_LIST = 'CREATION_TRANSACTION_LIST',
|
CREATION_TRANSACTION_LIST = 'CREATION_TRANSACTION_LIST',
|
||||||
LIST_TRANSACTION_LINKS_ADMIN = 'LIST_TRANSACTION_LINKS_ADMIN',
|
LIST_TRANSACTION_LINKS_ADMIN = 'LIST_TRANSACTION_LINKS_ADMIN',
|
||||||
CREATE_CONTRIBUTION_LINK = 'CREATE_CONTRIBUTION_LINK',
|
CREATE_CONTRIBUTION_LINK = 'CREATE_CONTRIBUTION_LINK',
|
||||||
LIST_CONTRIBUTION_LINKS = 'LIST_CONTRIBUTION_LINKS',
|
|
||||||
DELETE_CONTRIBUTION_LINK = 'DELETE_CONTRIBUTION_LINK',
|
DELETE_CONTRIBUTION_LINK = 'DELETE_CONTRIBUTION_LINK',
|
||||||
UPDATE_CONTRIBUTION_LINK = 'UPDATE_CONTRIBUTION_LINK',
|
UPDATE_CONTRIBUTION_LINK = 'UPDATE_CONTRIBUTION_LINK',
|
||||||
}
|
}
|
||||||
|
|||||||
@ -28,6 +28,7 @@ export const ROLE_USER = new Role('user', [
|
|||||||
RIGHTS.LIST_CONTRIBUTIONS,
|
RIGHTS.LIST_CONTRIBUTIONS,
|
||||||
RIGHTS.LIST_ALL_CONTRIBUTIONS,
|
RIGHTS.LIST_ALL_CONTRIBUTIONS,
|
||||||
RIGHTS.UPDATE_CONTRIBUTION,
|
RIGHTS.UPDATE_CONTRIBUTION,
|
||||||
|
RIGHTS.LIST_CONTRIBUTION_LINKS,
|
||||||
])
|
])
|
||||||
export const ROLE_ADMIN = new Role('admin', Object.values(RIGHTS)) // all rights
|
export const ROLE_ADMIN = new Role('admin', Object.values(RIGHTS)) // all rights
|
||||||
|
|
||||||
|
|||||||
@ -10,7 +10,7 @@ Decimal.set({
|
|||||||
})
|
})
|
||||||
|
|
||||||
const constants = {
|
const constants = {
|
||||||
DB_VERSION: '0044-insert_missing_contributions',
|
DB_VERSION: '0045-add_denied_type_and_status_to_contributions',
|
||||||
DECAY_START_TIME: new Date('2021-05-13 17:46:31-0000'), // GMT+0
|
DECAY_START_TIME: new Date('2021-05-13 17:46:31-0000'), // GMT+0
|
||||||
LOG4JS_CONFIG: 'log4js-config.json',
|
LOG4JS_CONFIG: 'log4js-config.json',
|
||||||
// default log level on production should be info
|
// default log level on production should be info
|
||||||
|
|||||||
14
backend/src/graphql/enum/ContributionStatus.ts
Normal file
14
backend/src/graphql/enum/ContributionStatus.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { registerEnumType } from 'type-graphql'
|
||||||
|
|
||||||
|
export enum ContributionStatus {
|
||||||
|
PENDING = 'PENDING',
|
||||||
|
DELETED = 'DELETED',
|
||||||
|
IN_PROGRESS = 'IN_PROGRESS',
|
||||||
|
DENIED = 'DENIED',
|
||||||
|
CONFIRMED = 'CONFIRMED',
|
||||||
|
}
|
||||||
|
|
||||||
|
registerEnumType(ContributionStatus, {
|
||||||
|
name: 'ContributionStatus',
|
||||||
|
description: 'Name of the Type of the Contribution Status',
|
||||||
|
})
|
||||||
12
backend/src/graphql/enum/ContributionType.ts
Normal file
12
backend/src/graphql/enum/ContributionType.ts
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import { registerEnumType } from 'type-graphql'
|
||||||
|
|
||||||
|
export enum ContributionType {
|
||||||
|
ADMIN = 'ADMIN',
|
||||||
|
USER = 'USER',
|
||||||
|
LINK = 'LINK',
|
||||||
|
}
|
||||||
|
|
||||||
|
registerEnumType(ContributionType, {
|
||||||
|
name: 'ContributionType',
|
||||||
|
description: 'Name of the Type of the Contribution',
|
||||||
|
})
|
||||||
@ -1857,11 +1857,17 @@ describe('AdminResolver', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// TODO: Set this test in new location to have datas
|
||||||
describe('listContributionLinks', () => {
|
describe('listContributionLinks', () => {
|
||||||
it('returns an error', async () => {
|
it('returns an empty object', async () => {
|
||||||
await expect(query({ query: listContributionLinks })).resolves.toEqual(
|
await expect(query({ query: listContributionLinks })).resolves.toEqual(
|
||||||
expect.objectContaining({
|
expect.objectContaining({
|
||||||
errors: [new GraphQLError('401 Unauthorized')],
|
data: {
|
||||||
|
listContributionLinks: {
|
||||||
|
count: 0,
|
||||||
|
links: [],
|
||||||
|
},
|
||||||
|
},
|
||||||
}),
|
}),
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|||||||
@ -36,6 +36,8 @@ import { LoginEmailOptIn } from '@entity/LoginEmailOptIn'
|
|||||||
import { User as dbUser } from '@entity/User'
|
import { User as dbUser } from '@entity/User'
|
||||||
import { User } from '@model/User'
|
import { User } from '@model/User'
|
||||||
import { TransactionTypeId } from '@enum/TransactionTypeId'
|
import { TransactionTypeId } from '@enum/TransactionTypeId'
|
||||||
|
import { ContributionType } from '@enum/ContributionType'
|
||||||
|
import { ContributionStatus } from '@enum/ContributionStatus'
|
||||||
import Decimal from 'decimal.js-light'
|
import Decimal from 'decimal.js-light'
|
||||||
import { Decay } from '@model/Decay'
|
import { Decay } from '@model/Decay'
|
||||||
import Paginated from '@arg/Paginated'
|
import Paginated from '@arg/Paginated'
|
||||||
@ -260,6 +262,8 @@ export class AdminResolver {
|
|||||||
contribution.contributionDate = creationDateObj
|
contribution.contributionDate = creationDateObj
|
||||||
contribution.memo = memo
|
contribution.memo = memo
|
||||||
contribution.moderatorId = moderator.id
|
contribution.moderatorId = moderator.id
|
||||||
|
contribution.contributionType = ContributionType.ADMIN
|
||||||
|
contribution.contributionStatus = ContributionStatus.PENDING
|
||||||
|
|
||||||
logger.trace('contribution to save', contribution)
|
logger.trace('contribution to save', contribution)
|
||||||
await Contribution.save(contribution)
|
await Contribution.save(contribution)
|
||||||
@ -337,6 +341,7 @@ export class AdminResolver {
|
|||||||
contributionToUpdate.memo = memo
|
contributionToUpdate.memo = memo
|
||||||
contributionToUpdate.contributionDate = new Date(creationDate)
|
contributionToUpdate.contributionDate = new Date(creationDate)
|
||||||
contributionToUpdate.moderatorId = moderator.id
|
contributionToUpdate.moderatorId = moderator.id
|
||||||
|
contributionToUpdate.contributionStatus = ContributionStatus.PENDING
|
||||||
|
|
||||||
await Contribution.save(contributionToUpdate)
|
await Contribution.save(contributionToUpdate)
|
||||||
const result = new AdminUpdateContribution()
|
const result = new AdminUpdateContribution()
|
||||||
@ -387,6 +392,8 @@ export class AdminResolver {
|
|||||||
if (!contribution) {
|
if (!contribution) {
|
||||||
throw new Error('Contribution not found for given id.')
|
throw new Error('Contribution not found for given id.')
|
||||||
}
|
}
|
||||||
|
contribution.contributionStatus = ContributionStatus.DELETED
|
||||||
|
await contribution.save()
|
||||||
const res = await contribution.softRemove()
|
const res = await contribution.softRemove()
|
||||||
return !!res
|
return !!res
|
||||||
}
|
}
|
||||||
@ -454,6 +461,7 @@ export class AdminResolver {
|
|||||||
contribution.confirmedAt = receivedCallDate
|
contribution.confirmedAt = receivedCallDate
|
||||||
contribution.confirmedBy = moderatorUser.id
|
contribution.confirmedBy = moderatorUser.id
|
||||||
contribution.transactionId = transaction.id
|
contribution.transactionId = transaction.id
|
||||||
|
contribution.contributionStatus = ContributionStatus.CONFIRMED
|
||||||
await queryRunner.manager.update(Contribution, { id: contribution.id }, contribution)
|
await queryRunner.manager.update(Contribution, { id: contribution.id }, contribution)
|
||||||
|
|
||||||
await queryRunner.commitTransaction()
|
await queryRunner.commitTransaction()
|
||||||
@ -501,7 +509,7 @@ export class AdminResolver {
|
|||||||
order: { updatedAt: 'DESC' },
|
order: { updatedAt: 'DESC' },
|
||||||
})
|
})
|
||||||
|
|
||||||
optInCode = await checkOptInCode(optInCode, user.id)
|
optInCode = await checkOptInCode(optInCode, user)
|
||||||
|
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||||
const emailSent = await sendAccountActivationEmail({
|
const emailSent = await sendAccountActivationEmail({
|
||||||
|
|||||||
@ -7,6 +7,8 @@ import { FindOperator, IsNull, getConnection } from '@dbTools/typeorm'
|
|||||||
import ContributionArgs from '@arg/ContributionArgs'
|
import ContributionArgs from '@arg/ContributionArgs'
|
||||||
import Paginated from '@arg/Paginated'
|
import Paginated from '@arg/Paginated'
|
||||||
import { Order } from '@enum/Order'
|
import { Order } from '@enum/Order'
|
||||||
|
import { ContributionType } from '@enum/ContributionType'
|
||||||
|
import { ContributionStatus } from '@enum/ContributionStatus'
|
||||||
import { Contribution, ContributionListResult } from '@model/Contribution'
|
import { Contribution, ContributionListResult } from '@model/Contribution'
|
||||||
import { UnconfirmedContribution } from '@model/UnconfirmedContribution'
|
import { UnconfirmedContribution } from '@model/UnconfirmedContribution'
|
||||||
import { User } from '@model/User'
|
import { User } from '@model/User'
|
||||||
@ -43,6 +45,8 @@ export class ContributionResolver {
|
|||||||
contribution.createdAt = new Date()
|
contribution.createdAt = new Date()
|
||||||
contribution.contributionDate = creationDateObj
|
contribution.contributionDate = creationDateObj
|
||||||
contribution.memo = memo
|
contribution.memo = memo
|
||||||
|
contribution.contributionType = ContributionType.USER
|
||||||
|
contribution.contributionStatus = ContributionStatus.PENDING
|
||||||
|
|
||||||
logger.trace('contribution to save', contribution)
|
logger.trace('contribution to save', contribution)
|
||||||
await dbContribution.save(contribution)
|
await dbContribution.save(contribution)
|
||||||
@ -66,6 +70,8 @@ export class ContributionResolver {
|
|||||||
if (contribution.confirmedAt) {
|
if (contribution.confirmedAt) {
|
||||||
throw new Error('A confirmed contribution can not be deleted')
|
throw new Error('A confirmed contribution can not be deleted')
|
||||||
}
|
}
|
||||||
|
contribution.contributionStatus = ContributionStatus.DELETED
|
||||||
|
await contribution.save()
|
||||||
const res = await contribution.softRemove()
|
const res = await contribution.softRemove()
|
||||||
return !!res
|
return !!res
|
||||||
}
|
}
|
||||||
@ -164,6 +170,7 @@ export class ContributionResolver {
|
|||||||
contributionToUpdate.amount = amount
|
contributionToUpdate.amount = amount
|
||||||
contributionToUpdate.memo = memo
|
contributionToUpdate.memo = memo
|
||||||
contributionToUpdate.contributionDate = new Date(creationDate)
|
contributionToUpdate.contributionDate = new Date(creationDate)
|
||||||
|
contributionToUpdate.contributionStatus = ContributionStatus.PENDING
|
||||||
dbContribution.save(contributionToUpdate)
|
dbContribution.save(contributionToUpdate)
|
||||||
|
|
||||||
return new UnconfirmedContribution(contributionToUpdate, user, creations)
|
return new UnconfirmedContribution(contributionToUpdate, user, creations)
|
||||||
|
|||||||
@ -26,6 +26,8 @@ import { User } from '@model/User'
|
|||||||
import { calculateDecay } from '@/util/decay'
|
import { calculateDecay } from '@/util/decay'
|
||||||
import { executeTransaction } from './TransactionResolver'
|
import { executeTransaction } from './TransactionResolver'
|
||||||
import { Order } from '@enum/Order'
|
import { Order } from '@enum/Order'
|
||||||
|
import { ContributionType } from '@enum/ContributionType'
|
||||||
|
import { ContributionStatus } from '@enum/ContributionStatus'
|
||||||
import { Contribution as DbContribution } from '@entity/Contribution'
|
import { Contribution as DbContribution } from '@entity/Contribution'
|
||||||
import { ContributionLink as DbContributionLink } from '@entity/ContributionLink'
|
import { ContributionLink as DbContributionLink } from '@entity/ContributionLink'
|
||||||
import { getUserCreation, validateContribution } from './util/creations'
|
import { getUserCreation, validateContribution } from './util/creations'
|
||||||
@ -231,6 +233,9 @@ export class TransactionLinkResolver {
|
|||||||
contribution.memo = contributionLink.memo
|
contribution.memo = contributionLink.memo
|
||||||
contribution.amount = contributionLink.amount
|
contribution.amount = contributionLink.amount
|
||||||
contribution.contributionLinkId = contributionLink.id
|
contribution.contributionLinkId = contributionLink.id
|
||||||
|
contribution.contributionType = ContributionType.LINK
|
||||||
|
contribution.contributionStatus = ContributionStatus.CONFIRMED
|
||||||
|
|
||||||
await queryRunner.manager.insert(DbContribution, contribution)
|
await queryRunner.manager.insert(DbContribution, contribution)
|
||||||
|
|
||||||
const lastTransaction = await queryRunner.manager
|
const lastTransaction = await queryRunner.manager
|
||||||
|
|||||||
@ -198,7 +198,7 @@ describe('UserResolver', () => {
|
|||||||
it('sets "de" as default language', async () => {
|
it('sets "de" as default language', async () => {
|
||||||
await mutate({
|
await mutate({
|
||||||
mutation: createUser,
|
mutation: createUser,
|
||||||
variables: { ...variables, email: 'bibi@bloxberg.de', language: 'es' },
|
variables: { ...variables, email: 'bibi@bloxberg.de', language: 'fr' },
|
||||||
})
|
})
|
||||||
await expect(User.find()).resolves.toEqual(
|
await expect(User.find()).resolves.toEqual(
|
||||||
expect.arrayContaining([
|
expect.arrayContaining([
|
||||||
|
|||||||
@ -43,7 +43,7 @@ const isPassword = (password: string): boolean => {
|
|||||||
return !!password.match(/^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[^a-zA-Z0-9 \\t\\n\\r]).{8,}$/)
|
return !!password.match(/^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[^a-zA-Z0-9 \\t\\n\\r]).{8,}$/)
|
||||||
}
|
}
|
||||||
|
|
||||||
const LANGUAGES = ['de', 'en']
|
const LANGUAGES = ['de', 'en', 'es']
|
||||||
const DEFAULT_LANGUAGE = 'de'
|
const DEFAULT_LANGUAGE = 'de'
|
||||||
const isLanguage = (language: string): boolean => {
|
const isLanguage = (language: string): boolean => {
|
||||||
return LANGUAGES.includes(language)
|
return LANGUAGES.includes(language)
|
||||||
@ -187,7 +187,7 @@ const newEmailOptIn = (userId: number): LoginEmailOptIn => {
|
|||||||
// if optIn does not exits, it is created
|
// if optIn does not exits, it is created
|
||||||
export const checkOptInCode = async (
|
export const checkOptInCode = async (
|
||||||
optInCode: LoginEmailOptIn | undefined,
|
optInCode: LoginEmailOptIn | undefined,
|
||||||
userId: number,
|
user: DbUser,
|
||||||
optInType: OptInType = OptInType.EMAIL_OPT_IN_REGISTER,
|
optInType: OptInType = OptInType.EMAIL_OPT_IN_REGISTER,
|
||||||
): Promise<LoginEmailOptIn> => {
|
): Promise<LoginEmailOptIn> => {
|
||||||
logger.info(`checkOptInCode... ${optInCode}`)
|
logger.info(`checkOptInCode... ${optInCode}`)
|
||||||
@ -207,15 +207,18 @@ export const checkOptInCode = async (
|
|||||||
optInCode.updatedAt = new Date()
|
optInCode.updatedAt = new Date()
|
||||||
optInCode.resendCount++
|
optInCode.resendCount++
|
||||||
} else {
|
} else {
|
||||||
logger.trace('create new OptIn for userId=' + userId)
|
logger.trace('create new OptIn for userId=' + user.id)
|
||||||
optInCode = newEmailOptIn(userId)
|
optInCode = newEmailOptIn(user.id)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (user.emailChecked) {
|
||||||
|
optInCode.emailOptInTypeId = optInType
|
||||||
}
|
}
|
||||||
optInCode.emailOptInTypeId = optInType
|
|
||||||
await LoginEmailOptIn.save(optInCode).catch(() => {
|
await LoginEmailOptIn.save(optInCode).catch(() => {
|
||||||
logger.error('Unable to save optin code= ' + optInCode)
|
logger.error('Unable to save optin code= ' + optInCode)
|
||||||
throw new Error('Unable to save optin code.')
|
throw new Error('Unable to save optin code.')
|
||||||
})
|
})
|
||||||
logger.debug(`checkOptInCode...successful: ${optInCode} for userid=${userId}`)
|
logger.debug(`checkOptInCode...successful: ${optInCode} for userid=${user.id}`)
|
||||||
return optInCode
|
return optInCode
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -493,7 +496,7 @@ export class UserResolver {
|
|||||||
userId: user.id,
|
userId: user.id,
|
||||||
})
|
})
|
||||||
|
|
||||||
optInCode = await checkOptInCode(optInCode, user.id, OptInType.EMAIL_OPT_IN_RESET_PASSWORD)
|
optInCode = await checkOptInCode(optInCode, user, OptInType.EMAIL_OPT_IN_RESET_PASSWORD)
|
||||||
logger.info(`optInCode for ${email}=${optInCode}`)
|
logger.info(`optInCode for ${email}=${optInCode}`)
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||||
const emailSent = await sendResetPasswordEmailMailer({
|
const emailSent = await sendResetPasswordEmailMailer({
|
||||||
|
|||||||
@ -2,6 +2,7 @@ import { MiddlewareFn } from 'type-graphql'
|
|||||||
import { /* klicktippSignIn, */ getKlickTippUser } from '@/apis/KlicktippController'
|
import { /* klicktippSignIn, */ getKlickTippUser } from '@/apis/KlicktippController'
|
||||||
import { KlickTipp } from '@model/KlickTipp'
|
import { KlickTipp } from '@model/KlickTipp'
|
||||||
import CONFIG from '@/config'
|
import CONFIG from '@/config'
|
||||||
|
import { klickTippLogger as logger } from '@/server/logger'
|
||||||
|
|
||||||
// export const klicktippRegistrationMiddleware: MiddlewareFn = async (
|
// export const klicktippRegistrationMiddleware: MiddlewareFn = async (
|
||||||
// // Only for demo
|
// // Only for demo
|
||||||
@ -29,7 +30,9 @@ export const klicktippNewsletterStateMiddleware: MiddlewareFn = async (
|
|||||||
if (klickTippUser) {
|
if (klickTippUser) {
|
||||||
klickTipp = new KlickTipp(klickTippUser)
|
klickTipp = new KlickTipp(klickTippUser)
|
||||||
}
|
}
|
||||||
} catch (err) {}
|
} catch (err) {
|
||||||
|
logger.error(`There is no user for (email='${result.email}') ${err}`)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
result.klickTipp = klickTipp
|
result.klickTipp = klickTipp
|
||||||
return result
|
return result
|
||||||
|
|||||||
@ -12,7 +12,8 @@ log4js.configure(options)
|
|||||||
|
|
||||||
const apolloLogger = log4js.getLogger('apollo')
|
const apolloLogger = log4js.getLogger('apollo')
|
||||||
const backendLogger = log4js.getLogger('backend')
|
const backendLogger = log4js.getLogger('backend')
|
||||||
|
const klickTippLogger = log4js.getLogger('klicktipp')
|
||||||
|
|
||||||
backendLogger.addContext('user', 'unknown')
|
backendLogger.addContext('user', 'unknown')
|
||||||
|
|
||||||
export { apolloLogger, backendLogger }
|
export { apolloLogger, backendLogger, klickTippLogger }
|
||||||
|
|||||||
@ -0,0 +1,83 @@
|
|||||||
|
import Decimal from 'decimal.js-light'
|
||||||
|
import {
|
||||||
|
BaseEntity,
|
||||||
|
Column,
|
||||||
|
Entity,
|
||||||
|
PrimaryGeneratedColumn,
|
||||||
|
DeleteDateColumn,
|
||||||
|
JoinColumn,
|
||||||
|
ManyToOne,
|
||||||
|
} from 'typeorm'
|
||||||
|
import { DecimalTransformer } from '../../src/typeorm/DecimalTransformer'
|
||||||
|
import { User } from '../User'
|
||||||
|
|
||||||
|
@Entity('contributions')
|
||||||
|
export class Contribution extends BaseEntity {
|
||||||
|
@PrimaryGeneratedColumn('increment', { unsigned: true })
|
||||||
|
id: number
|
||||||
|
|
||||||
|
@Column({ unsigned: true, nullable: false, name: 'user_id' })
|
||||||
|
userId: number
|
||||||
|
|
||||||
|
@ManyToOne(() => User, (user) => user.contributions)
|
||||||
|
@JoinColumn({ name: 'user_id' })
|
||||||
|
user: User
|
||||||
|
|
||||||
|
@Column({ type: 'datetime', default: () => 'CURRENT_TIMESTAMP', name: 'created_at' })
|
||||||
|
createdAt: Date
|
||||||
|
|
||||||
|
@Column({ type: 'datetime', nullable: false, name: 'contribution_date' })
|
||||||
|
contributionDate: Date
|
||||||
|
|
||||||
|
@Column({ length: 255, nullable: false, collation: 'utf8mb4_unicode_ci' })
|
||||||
|
memo: string
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
type: 'decimal',
|
||||||
|
precision: 40,
|
||||||
|
scale: 20,
|
||||||
|
nullable: false,
|
||||||
|
transformer: DecimalTransformer,
|
||||||
|
})
|
||||||
|
amount: Decimal
|
||||||
|
|
||||||
|
@Column({ unsigned: true, nullable: true, name: 'moderator_id' })
|
||||||
|
moderatorId: number
|
||||||
|
|
||||||
|
@Column({ unsigned: true, nullable: true, name: 'contribution_link_id' })
|
||||||
|
contributionLinkId: number
|
||||||
|
|
||||||
|
@Column({ unsigned: true, nullable: true, name: 'confirmed_by' })
|
||||||
|
confirmedBy: number
|
||||||
|
|
||||||
|
@Column({ nullable: true, name: 'confirmed_at' })
|
||||||
|
confirmedAt: Date
|
||||||
|
|
||||||
|
@Column({ unsigned: true, nullable: true, name: 'denied_by' })
|
||||||
|
deniedBy: number
|
||||||
|
|
||||||
|
@Column({ nullable: true, name: 'denied_at' })
|
||||||
|
deniedAt: Date
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
name: 'contribution_type',
|
||||||
|
length: 12,
|
||||||
|
nullable: false,
|
||||||
|
collation: 'utf8mb4_unicode_ci',
|
||||||
|
})
|
||||||
|
contributionType: string
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
name: 'contribution_status',
|
||||||
|
length: 12,
|
||||||
|
nullable: false,
|
||||||
|
collation: 'utf8mb4_unicode_ci',
|
||||||
|
})
|
||||||
|
contributionStatus: string
|
||||||
|
|
||||||
|
@Column({ unsigned: true, nullable: true, name: 'transaction_id' })
|
||||||
|
transactionId: number
|
||||||
|
|
||||||
|
@DeleteDateColumn({ name: 'deleted_at' })
|
||||||
|
deletedAt: Date | null
|
||||||
|
}
|
||||||
@ -1 +1 @@
|
|||||||
export { Contribution } from './0039-contributions_table/Contribution'
|
export { Contribution } from './0045-add_denied_type_and_status_to_contributions/Contribution'
|
||||||
|
|||||||
@ -0,0 +1,39 @@
|
|||||||
|
/* MIGRATION TO ADD denied_by, denied_at, contribution_type and contrinution_status
|
||||||
|
FIELDS TO contributions */
|
||||||
|
|
||||||
|
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */
|
||||||
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
||||||
|
|
||||||
|
export async function upgrade(queryFn: (query: string, values?: any[]) => Promise<Array<any>>) {
|
||||||
|
await queryFn(
|
||||||
|
'ALTER TABLE `contributions` ADD COLUMN `denied_at` datetime DEFAULT NULL AFTER `confirmed_at`;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'ALTER TABLE `contributions` ADD COLUMN `denied_by` int(10) unsigned DEFAULT NULL AFTER `denied_at`;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'ALTER TABLE `contributions` ADD COLUMN `contribution_type` varchar(12) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT "ADMIN" AFTER `denied_by`;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'ALTER TABLE `contributions` ADD COLUMN `contribution_status` varchar(12) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT "PENDING" AFTER `contribution_type`;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'UPDATE `contributions` SET `contribution_type` = "LINK" WHERE `contribution_link_id` IS NOT NULL;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'UPDATE `contributions` SET `contribution_type` = "USER" WHERE `contribution_link_id` IS NULL AND `moderator_id` IS NULL;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'UPDATE `contributions` SET `contribution_status` = "CONFIRMED" WHERE `confirmed_at` IS NOT NULL;',
|
||||||
|
)
|
||||||
|
await queryFn(
|
||||||
|
'UPDATE `contributions` SET `contribution_status` = "DELETED" WHERE `deleted_at` IS NOT NULL;',
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function downgrade(queryFn: (query: string, values?: any[]) => Promise<Array<any>>) {
|
||||||
|
await queryFn('ALTER TABLE `contributions` DROP COLUMN `contribution_status`;')
|
||||||
|
await queryFn('ALTER TABLE `contributions` DROP COLUMN `contribution_type`;')
|
||||||
|
await queryFn('ALTER TABLE `contributions` DROP COLUMN `denied_by`;')
|
||||||
|
await queryFn('ALTER TABLE `contributions` DROP COLUMN `denied_at`;')
|
||||||
|
}
|
||||||
BIN
docu/Locales/GRADIDO_register_page_spanish.xlsx
Normal file
BIN
docu/Locales/GRADIDO_register_page_spanish.xlsx
Normal file
Binary file not shown.
@ -23,5 +23,5 @@ module.exports = {
|
|||||||
testMatch: ['**/?(*.)+(spec|test).js?(x)'],
|
testMatch: ['**/?(*.)+(spec|test).js?(x)'],
|
||||||
// snapshotSerializers: ['jest-serializer-vue'],
|
// snapshotSerializers: ['jest-serializer-vue'],
|
||||||
transformIgnorePatterns: ['<rootDir>/node_modules/(?!vee-validate/dist/rules)'],
|
transformIgnorePatterns: ['<rootDir>/node_modules/(?!vee-validate/dist/rules)'],
|
||||||
testEnvironment: 'jest-environment-jsdom-sixteen',
|
// testEnvironment: 'jest-environment-jsdom-sixteen', // not needed anymore since jest@26, see: https://www.npmjs.com/package/jest-environment-jsdom-sixteen
|
||||||
}
|
}
|
||||||
|
|||||||
@ -44,7 +44,6 @@
|
|||||||
"identity-obj-proxy": "^3.0.0",
|
"identity-obj-proxy": "^3.0.0",
|
||||||
"jest": "^26.6.3",
|
"jest": "^26.6.3",
|
||||||
"jest-canvas-mock": "^2.3.1",
|
"jest-canvas-mock": "^2.3.1",
|
||||||
"jest-environment-jsdom-sixteen": "^2.0.0",
|
|
||||||
"jwt-decode": "^3.1.2",
|
"jwt-decode": "^3.1.2",
|
||||||
"portal-vue": "^2.1.7",
|
"portal-vue": "^2.1.7",
|
||||||
"prettier": "^2.2.1",
|
"prettier": "^2.2.1",
|
||||||
|
|||||||
@ -46,46 +46,274 @@ describe('ContributionForm', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
describe('empty form data', () => {
|
describe('empty form data', () => {
|
||||||
describe('buttons', () => {
|
describe('button', () => {
|
||||||
it('has reset enabled', () => {
|
it('has submit disabled', () => {
|
||||||
expect(wrapper.find('button[type="reset"]').attributes('disabled')).toBeFalsy()
|
expect(wrapper.find('button[data-test="button-submit"]').attributes('disabled')).toBe(
|
||||||
|
'disabled',
|
||||||
|
)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('dates', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.setData({
|
||||||
|
form: {
|
||||||
|
id: null,
|
||||||
|
date: '',
|
||||||
|
memo: '',
|
||||||
|
amount: '',
|
||||||
|
},
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('actual date', () => {
|
||||||
|
describe('same month', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
const now = new Date().toISOString()
|
||||||
|
await wrapper.findComponent({ name: 'BFormDatepicker' }).vm.$emit('input', now)
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isThisMonth', () => {
|
||||||
|
it('has true', () => {
|
||||||
|
expect(wrapper.vm.isThisMonth).toBe(true)
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has submit disabled', () => {
|
describe('month before', () => {
|
||||||
expect(wrapper.find('button[type="submit"]').attributes('disabled')).toBe('disabled')
|
beforeEach(async () => {
|
||||||
|
await wrapper
|
||||||
|
.findComponent({ name: 'BFormDatepicker' })
|
||||||
|
.vm.$emit('input', wrapper.vm.minimalDate)
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isThisMonth', () => {
|
||||||
|
it('has false', () => {
|
||||||
|
expect(wrapper.vm.isThisMonth).toBe(false)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('date in middle of year', () => {
|
||||||
|
describe('same month', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
// jest.useFakeTimers('modern')
|
||||||
|
// jest.setSystemTime(new Date('2020-07-06'))
|
||||||
|
// await wrapper.findComponent({ name: 'BFormDatepicker' }).vm.$emit('input', now)
|
||||||
|
await wrapper.setData({
|
||||||
|
maximalDate: new Date(2020, 6, 6),
|
||||||
|
form: { date: new Date(2020, 6, 6) },
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('minimalDate', () => {
|
||||||
|
it('has "2020-06-01T00:00:00.000Z"', () => {
|
||||||
|
expect(wrapper.vm.minimalDate.toISOString()).toBe('2020-06-01T00:00:00.000Z')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isThisMonth', () => {
|
||||||
|
it('has true', () => {
|
||||||
|
expect(wrapper.vm.isThisMonth).toBe(true)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('month before', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
// jest.useFakeTimers('modern')
|
||||||
|
// jest.setSystemTime(new Date('2020-07-06'))
|
||||||
|
// console.log('middle of year date – now:', wrapper.vm.minimalDate)
|
||||||
|
// await wrapper
|
||||||
|
// .findComponent({ name: 'BFormDatepicker' })
|
||||||
|
// .vm.$emit('input', wrapper.vm.minimalDate)
|
||||||
|
await wrapper.setData({
|
||||||
|
maximalDate: new Date(2020, 6, 6),
|
||||||
|
form: { date: new Date(2020, 5, 6) },
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('minimalDate', () => {
|
||||||
|
it('has "2020-06-01T00:00:00.000Z"', () => {
|
||||||
|
expect(wrapper.vm.minimalDate.toISOString()).toBe('2020-06-01T00:00:00.000Z')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isThisMonth', () => {
|
||||||
|
it('has false', () => {
|
||||||
|
expect(wrapper.vm.isThisMonth).toBe(false)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('date in january', () => {
|
||||||
|
describe('same month', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.setData({
|
||||||
|
maximalDate: new Date(2020, 0, 6),
|
||||||
|
form: { date: new Date(2020, 0, 6) },
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('minimalDate', () => {
|
||||||
|
it('has "2019-12-01T00:00:00.000Z"', () => {
|
||||||
|
expect(wrapper.vm.minimalDate.toISOString()).toBe('2019-12-01T00:00:00.000Z')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isThisMonth', () => {
|
||||||
|
it('has true', () => {
|
||||||
|
expect(wrapper.vm.isThisMonth).toBe(true)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('month before', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
// jest.useFakeTimers('modern')
|
||||||
|
// jest.setSystemTime(new Date('2020-07-06'))
|
||||||
|
// console.log('middle of year date – now:', wrapper.vm.minimalDate)
|
||||||
|
// await wrapper
|
||||||
|
// .findComponent({ name: 'BFormDatepicker' })
|
||||||
|
// .vm.$emit('input', wrapper.vm.minimalDate)
|
||||||
|
await wrapper.setData({
|
||||||
|
maximalDate: new Date(2020, 0, 6),
|
||||||
|
form: { date: new Date(2019, 11, 6) },
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('minimalDate', () => {
|
||||||
|
it('has "2019-12-01T00:00:00.000Z"', () => {
|
||||||
|
expect(wrapper.vm.minimalDate.toISOString()).toBe('2019-12-01T00:00:00.000Z')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isThisMonth', () => {
|
||||||
|
it('has false', () => {
|
||||||
|
expect(wrapper.vm.isThisMonth).toBe(false)
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('set contrubtion', () => {
|
describe('set contrubtion', () => {
|
||||||
describe('fill in form data', () => {
|
describe('fill in form data with "id === null"', () => {
|
||||||
const now = new Date().toISOString()
|
const now = new Date().toISOString()
|
||||||
|
|
||||||
beforeEach(async () => {
|
beforeEach(async () => {
|
||||||
await wrapper.setData({
|
await wrapper.setData({
|
||||||
form: {
|
form: {
|
||||||
id: null,
|
id: null,
|
||||||
date: now,
|
date: '',
|
||||||
memo: 'Mein Beitrag zur Gemeinschaft für diesen Monat ...',
|
memo: '',
|
||||||
amount: '200',
|
amount: '',
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('buttons', () => {
|
describe('invalid form data', () => {
|
||||||
it('has reset enabled', () => {
|
beforeEach(async () => {
|
||||||
expect(wrapper.find('button[type="reset"]').attributes('disabled')).toBeFalsy()
|
await wrapper.findComponent({ name: 'BFormDatepicker' }).vm.$emit('input', now)
|
||||||
|
await wrapper.find('#contribution-amount').find('input').setValue('200')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has submit enabled', () => {
|
describe('memo lenght < 5, others are valid', () => {
|
||||||
expect(wrapper.find('button[type="submit"]').attributes('disabled')).toBeFalsy()
|
beforeEach(async () => {
|
||||||
|
await wrapper.find('#contribution-memo').find('textarea').setValue('1234')
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('button', () => {
|
||||||
|
describe('submit', () => {
|
||||||
|
it('has disabled', () => {
|
||||||
|
expect(
|
||||||
|
wrapper.find('button[data-test="button-submit"]').attributes('disabled'),
|
||||||
|
).toBe('disabled')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('memo lenght > 255, others are valid', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper
|
||||||
|
.find('#contribution-memo')
|
||||||
|
.find('textarea')
|
||||||
|
.setValue(
|
||||||
|
'0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789' +
|
||||||
|
'0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789' +
|
||||||
|
'01234567890123456789012345678901234567890123456789012345',
|
||||||
|
)
|
||||||
|
await wrapper.vm.$nextTick()
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('button', () => {
|
||||||
|
describe('submit', () => {
|
||||||
|
it('has disabled', () => {
|
||||||
|
expect(
|
||||||
|
wrapper.find('button[data-test="button-submit"]').attributes('disabled'),
|
||||||
|
).toBe('disabled')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('valid form data', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.findComponent({ name: 'BFormDatepicker' }).vm.$emit('input', now)
|
||||||
|
await wrapper
|
||||||
|
.find('#contribution-memo')
|
||||||
|
.find('textarea')
|
||||||
|
.setValue('Mein Beitrag zur Gemeinschaft für diesen Monat ...')
|
||||||
|
await wrapper.find('#contribution-amount').find('input').setValue('200')
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('button', () => {
|
||||||
|
describe('submit', () => {
|
||||||
|
it('has enabled', () => {
|
||||||
|
expect(
|
||||||
|
wrapper.find('button[data-test="button-submit"]').attributes('disabled'),
|
||||||
|
).toBeFalsy()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('has label "contribution.submit"', () => {
|
||||||
|
expect(wrapper.find('button[data-test="button-submit"]').text()).toContain(
|
||||||
|
'contribution.submit',
|
||||||
|
)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('on trigger submit', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.find('form').trigger('submit')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('emits "set-contribution"', () => {
|
||||||
|
expect(wrapper.emitted('set-contribution')).toEqual(
|
||||||
|
expect.arrayContaining([
|
||||||
|
expect.arrayContaining([
|
||||||
|
{
|
||||||
|
id: null,
|
||||||
|
date: now,
|
||||||
|
memo: 'Mein Beitrag zur Gemeinschaft für diesen Monat ...',
|
||||||
|
amount: '200',
|
||||||
|
},
|
||||||
|
]),
|
||||||
|
]),
|
||||||
|
)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('update contrubtion', () => {
|
describe('update contrubtion', () => {
|
||||||
describe('fill in form data and "id"', () => {
|
describe('fill in form data with set "id"', () => {
|
||||||
const now = new Date().toISOString()
|
const now = new Date().toISOString()
|
||||||
|
|
||||||
beforeEach(async () => {
|
beforeEach(async () => {
|
||||||
@ -93,19 +321,104 @@ describe('ContributionForm', () => {
|
|||||||
form: {
|
form: {
|
||||||
id: 2,
|
id: 2,
|
||||||
date: now,
|
date: now,
|
||||||
memo: 'Mein Beitrag zur Gemeinschaft für diesen Monat ...',
|
memo: 'Mein kommerzieller Beitrag für diesen Monat ...',
|
||||||
amount: '200',
|
amount: '100',
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('buttons', () => {
|
describe('invalid form data', () => {
|
||||||
it('has reset enabled', () => {
|
beforeEach(async () => {
|
||||||
expect(wrapper.find('button[type="reset"]').attributes('disabled')).toBeFalsy()
|
await wrapper.findComponent({ name: 'BFormDatepicker' }).vm.$emit('input', now)
|
||||||
|
await wrapper.find('#contribution-amount').find('input').setValue('200')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has submit enabled', () => {
|
describe('memo lenght < 5, others are valid', () => {
|
||||||
expect(wrapper.find('button[type="submit"]').attributes('disabled')).toBeFalsy()
|
beforeEach(async () => {
|
||||||
|
await wrapper.find('#contribution-memo').find('textarea').setValue('1234')
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('button', () => {
|
||||||
|
describe('submit', () => {
|
||||||
|
it('has disabled', () => {
|
||||||
|
expect(
|
||||||
|
wrapper.find('button[data-test="button-submit"]').attributes('disabled'),
|
||||||
|
).toBe('disabled')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('memo lenght > 255, others are valid', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper
|
||||||
|
.find('#contribution-memo')
|
||||||
|
.find('textarea')
|
||||||
|
.setValue(
|
||||||
|
'0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789' +
|
||||||
|
'0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789' +
|
||||||
|
'01234567890123456789012345678901234567890123456789012345',
|
||||||
|
)
|
||||||
|
await wrapper.vm.$nextTick()
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('button', () => {
|
||||||
|
describe('submit', () => {
|
||||||
|
it('has disabled', () => {
|
||||||
|
expect(
|
||||||
|
wrapper.find('button[data-test="button-submit"]').attributes('disabled'),
|
||||||
|
).toBe('disabled')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('valid form data', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.findComponent({ name: 'BFormDatepicker' }).vm.$emit('input', now)
|
||||||
|
await wrapper
|
||||||
|
.find('#contribution-memo')
|
||||||
|
.find('textarea')
|
||||||
|
.setValue('Mein Beitrag zur Gemeinschaft für diesen Monat ...')
|
||||||
|
await wrapper.find('#contribution-amount').find('input').setValue('200')
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('button', () => {
|
||||||
|
describe('submit', () => {
|
||||||
|
it('has enabled', () => {
|
||||||
|
expect(
|
||||||
|
wrapper.find('button[data-test="button-submit"]').attributes('disabled'),
|
||||||
|
).toBeFalsy()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('has label "form.change"', () => {
|
||||||
|
expect(wrapper.find('button[data-test="button-submit"]').text()).toContain(
|
||||||
|
'form.change',
|
||||||
|
)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('on trigger submit', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.find('form').trigger('submit')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('emits "update-contribution"', () => {
|
||||||
|
expect(wrapper.emitted('update-contribution')).toEqual(
|
||||||
|
expect.arrayContaining([
|
||||||
|
expect.arrayContaining([
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
date: now,
|
||||||
|
memo: 'Mein Beitrag zur Gemeinschaft für diesen Monat ...',
|
||||||
|
amount: '200',
|
||||||
|
},
|
||||||
|
]),
|
||||||
|
]),
|
||||||
|
)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@ -4,8 +4,8 @@
|
|||||||
<h3>{{ $t('contribution.formText.yourContribution') }}</h3>
|
<h3>{{ $t('contribution.formText.yourContribution') }}</h3>
|
||||||
{{ $t('contribution.formText.bringYourTalentsTo') }}
|
{{ $t('contribution.formText.bringYourTalentsTo') }}
|
||||||
<ul class="my-3">
|
<ul class="my-3">
|
||||||
<li v-html="lastMonthObject"></li>
|
<li v-html="textForMonth(new Date(minimalDate), maxGddLastMonth)"></li>
|
||||||
<li v-html="thisMonthObject"></li>
|
<li v-html="textForMonth(new Date(), maxGddThisMonth)"></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="my-3">
|
<div class="my-3">
|
||||||
@ -73,12 +73,12 @@
|
|||||||
</div>
|
</div>
|
||||||
<b-row class="mt-3">
|
<b-row class="mt-3">
|
||||||
<b-col>
|
<b-col>
|
||||||
<b-button class="test-cancel" type="reset" variant="secondary" @click="reset">
|
<b-button type="reset" variant="secondary" @click="reset" data-test="button-cancel">
|
||||||
{{ $t('form.cancel') }}
|
{{ $t('form.cancel') }}
|
||||||
</b-button>
|
</b-button>
|
||||||
</b-col>
|
</b-col>
|
||||||
<b-col class="text-right">
|
<b-col class="text-right">
|
||||||
<b-button class="test-submit" type="submit" variant="primary" :disabled="disabled">
|
<b-button type="submit" variant="primary" :disabled="disabled" data-test="button-submit">
|
||||||
{{ form.id ? $t('form.change') : $t('contribution.submit') }}
|
{{ form.id ? $t('form.change') : $t('contribution.submit') }}
|
||||||
</b-button>
|
</b-button>
|
||||||
</b-col>
|
</b-col>
|
||||||
@ -108,11 +108,8 @@ export default {
|
|||||||
},
|
},
|
||||||
submit() {
|
submit() {
|
||||||
this.form.amount = this.numberFormat(this.form.amount)
|
this.form.amount = this.numberFormat(this.form.amount)
|
||||||
if (this.form.id) {
|
// spreading is needed for testing
|
||||||
this.$emit('update-contribution', this.form)
|
this.$emit(this.form.id ? 'update-contribution' : 'set-contribution', { ...this.form })
|
||||||
} else {
|
|
||||||
this.$emit('set-contribution', this.form)
|
|
||||||
}
|
|
||||||
this.reset()
|
this.reset()
|
||||||
},
|
},
|
||||||
reset() {
|
reset() {
|
||||||
@ -122,53 +119,47 @@ export default {
|
|||||||
this.form.memo = ''
|
this.form.memo = ''
|
||||||
this.form.amount = ''
|
this.form.amount = ''
|
||||||
},
|
},
|
||||||
|
textForMonth(date, availableAmount) {
|
||||||
|
const obj = {
|
||||||
|
monthAndYear: this.$d(date, 'monthAndYear'),
|
||||||
|
creation: availableAmount,
|
||||||
|
}
|
||||||
|
return this.$t('contribution.formText.openAmountForMonth', obj)
|
||||||
|
},
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
/*
|
|
||||||
* minimalDate() = Sets the date to the 1st of the previous month.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
minimalDate() {
|
minimalDate() {
|
||||||
return new Date(this.maximalDate.getFullYear(), this.maximalDate.getMonth() - 1, 1)
|
// sets the date to the 1st of the previous month
|
||||||
|
let date = new Date(this.maximalDate) // has to be a new object, because of 'setMonth' changes the objects date
|
||||||
|
date = new Date(date.setMonth(date.getMonth() - 1))
|
||||||
|
return new Date(date.getFullYear(), date.getMonth(), 1)
|
||||||
},
|
},
|
||||||
disabled() {
|
disabled() {
|
||||||
if (
|
return (
|
||||||
this.form.date === '' ||
|
this.form.date === '' ||
|
||||||
this.form.memo.length < this.minlength ||
|
this.form.memo.length < this.minlength ||
|
||||||
|
this.form.memo.length > this.maxlength ||
|
||||||
parseInt(this.form.amount) <= 0 ||
|
parseInt(this.form.amount) <= 0 ||
|
||||||
parseInt(this.form.amount) > 1000 ||
|
parseInt(this.form.amount) > 1000 ||
|
||||||
(this.isThisMonth && parseInt(this.form.amount) > parseInt(this.maxGddThisMonth)) ||
|
(this.isThisMonth && parseInt(this.form.amount) > parseInt(this.maxGddThisMonth)) ||
|
||||||
(!this.isThisMonth && parseInt(this.form.amount) > parseInt(this.maxGddLastMonth))
|
(!this.isThisMonth && parseInt(this.form.amount) > parseInt(this.maxGddLastMonth))
|
||||||
)
|
)
|
||||||
return true
|
|
||||||
return false
|
|
||||||
},
|
|
||||||
lastMonthObject() {
|
|
||||||
// new Date().getMonth === 1 If the current month is January, then one year must be gone back in the previous month
|
|
||||||
const obj = {
|
|
||||||
monthAndYear: this.$d(new Date(this.minimalDate), 'monthAndYear'),
|
|
||||||
creation: this.maxGddLastMonth,
|
|
||||||
}
|
|
||||||
return this.$t('contribution.formText.openAmountForMonth', obj)
|
|
||||||
},
|
|
||||||
thisMonthObject() {
|
|
||||||
const obj = {
|
|
||||||
monthAndYear: this.$d(new Date(), 'monthAndYear'),
|
|
||||||
creation: this.maxGddThisMonth,
|
|
||||||
}
|
|
||||||
return this.$t('contribution.formText.openAmountForMonth', obj)
|
|
||||||
},
|
},
|
||||||
isThisMonth() {
|
isThisMonth() {
|
||||||
return new Date(this.form.date).getMonth() === new Date().getMonth()
|
const formDate = new Date(this.form.date)
|
||||||
|
return (
|
||||||
|
formDate.getFullYear() === this.maximalDate.getFullYear() &&
|
||||||
|
formDate.getMonth() === this.maximalDate.getMonth()
|
||||||
|
)
|
||||||
},
|
},
|
||||||
maxGddLastMonth() {
|
maxGddLastMonth() {
|
||||||
// When edited, the amount is added back on top of the amount
|
// when existing contribution is edited, the amount is added back on top of the amount
|
||||||
return this.form.id && !this.isThisMonth
|
return this.form.id && !this.isThisMonth
|
||||||
? parseInt(this.$store.state.creation[1]) + parseInt(this.updateAmount)
|
? parseInt(this.$store.state.creation[1]) + parseInt(this.updateAmount)
|
||||||
: this.$store.state.creation[1]
|
: this.$store.state.creation[1]
|
||||||
},
|
},
|
||||||
maxGddThisMonth() {
|
maxGddThisMonth() {
|
||||||
// When edited, the amount is added back on top of the amount
|
// when existing contribution is edited, the amount is added back on top of the amount
|
||||||
return this.form.id && this.isThisMonth
|
return this.form.id && this.isThisMonth
|
||||||
? parseInt(this.$store.state.creation[2]) + parseInt(this.updateAmount)
|
? parseInt(this.$store.state.creation[2]) + parseInt(this.updateAmount)
|
||||||
: this.$store.state.creation[2]
|
: this.$store.state.creation[2]
|
||||||
|
|||||||
@ -46,5 +46,17 @@ describe('GddSend confirm', () => {
|
|||||||
expect(wrapper.findAll('div.confirm-box-link').at(0).exists()).toBeTruthy()
|
expect(wrapper.findAll('div.confirm-box-link').at(0).exists()).toBeTruthy()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('has total balance equal 0', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
await wrapper.setProps({
|
||||||
|
balance: 0,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('has send button disabled', () => {
|
||||||
|
expect(wrapper.find('.send-button').attributes('disabled')).toBe('disabled')
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@ -42,7 +42,12 @@
|
|||||||
<b-button @click="$emit('on-reset')">{{ $t('back') }}</b-button>
|
<b-button @click="$emit('on-reset')">{{ $t('back') }}</b-button>
|
||||||
</b-col>
|
</b-col>
|
||||||
<b-col class="text-right">
|
<b-col class="text-right">
|
||||||
<b-button variant="primary" :disabled="disabled" @click="$emit('send-transaction')">
|
<b-button
|
||||||
|
class="send-button"
|
||||||
|
variant="primary"
|
||||||
|
:disabled="disabled"
|
||||||
|
@click="$emit('send-transaction')"
|
||||||
|
>
|
||||||
{{ $t('form.generate_now') }}
|
{{ $t('form.generate_now') }}
|
||||||
</b-button>
|
</b-button>
|
||||||
</b-col>
|
</b-col>
|
||||||
|
|||||||
@ -45,7 +45,7 @@ describe('LanguageSwitch', () => {
|
|||||||
expect(wrapper.find('div.language-switch').exists()).toBeTruthy()
|
expect(wrapper.find('div.language-switch').exists()).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('with locales en and de', () => {
|
describe('with locales en, de and es', () => {
|
||||||
describe('empty store', () => {
|
describe('empty store', () => {
|
||||||
describe('navigator language is "en-US"', () => {
|
describe('navigator language is "en-US"', () => {
|
||||||
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
||||||
@ -69,11 +69,22 @@ describe('LanguageSwitch', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('navigator language is "es-ES" (not supported)', () => {
|
describe('navigator language is "es-ES"', () => {
|
||||||
|
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
||||||
|
|
||||||
|
it('shows Español as language ', async () => {
|
||||||
|
languageGetter.mockReturnValue('es-ES')
|
||||||
|
wrapper.vm.setCurrentLanguage()
|
||||||
|
await wrapper.vm.$nextTick()
|
||||||
|
expect(wrapper.find('button.dropdown-toggle').text()).toBe('Español - es')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('navigator language is "fr-FR" (not supported)', () => {
|
||||||
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
||||||
|
|
||||||
it('shows English as language ', async () => {
|
it('shows English as language ', async () => {
|
||||||
languageGetter.mockReturnValue('es-ES')
|
languageGetter.mockReturnValue('fr-FR')
|
||||||
wrapper.vm.setCurrentLanguage()
|
wrapper.vm.setCurrentLanguage()
|
||||||
await wrapper.vm.$nextTick()
|
await wrapper.vm.$nextTick()
|
||||||
expect(wrapper.find('button.dropdown-toggle').text()).toBe('English - en')
|
expect(wrapper.find('button.dropdown-toggle').text()).toBe('English - en')
|
||||||
@ -101,9 +112,18 @@ describe('LanguageSwitch', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('language "es" in store', () => {
|
||||||
|
it('shows Español as language', async () => {
|
||||||
|
wrapper.vm.$store.state.language = 'es'
|
||||||
|
wrapper.vm.setCurrentLanguage()
|
||||||
|
await wrapper.vm.$nextTick()
|
||||||
|
expect(wrapper.find('button.dropdown-toggle').text()).toBe('Español - es')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
describe('dropdown menu', () => {
|
describe('dropdown menu', () => {
|
||||||
it('has English and German as languages to choose', () => {
|
it('has English and German as languages to choose', () => {
|
||||||
expect(wrapper.findAll('li')).toHaveLength(2)
|
expect(wrapper.findAll('li')).toHaveLength(3)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has English as first language to choose', () => {
|
it('has English as first language to choose', () => {
|
||||||
@ -113,6 +133,10 @@ describe('LanguageSwitch', () => {
|
|||||||
it('has German as second language to choose', () => {
|
it('has German as second language to choose', () => {
|
||||||
expect(wrapper.findAll('li').at(1).text()).toBe('Deutsch')
|
expect(wrapper.findAll('li').at(1).text()).toBe('Deutsch')
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('has Español as second language to choose', () => {
|
||||||
|
expect(wrapper.findAll('li').at(2).text()).toBe('Español')
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@ -66,10 +66,19 @@ describe('LanguageSwitch', () => {
|
|||||||
expect(wrapper.findAll('span.locales').at(1).text()).toBe('Deutsch')
|
expect(wrapper.findAll('span.locales').at(1).text()).toBe('Deutsch')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
describe('navigator language is "es-ES" (not supported)', () => {
|
describe('navigator language is "es-ES"', () => {
|
||||||
|
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
||||||
|
it('shows Español as language ', async () => {
|
||||||
|
languageGetter.mockReturnValue('es-ES')
|
||||||
|
wrapper.vm.setCurrentLanguage()
|
||||||
|
await wrapper.vm.$nextTick()
|
||||||
|
expect(wrapper.findAll('span.locales').at(2).text()).toBe('Español')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
describe('navigator language is "fr-FR" (not supported)', () => {
|
||||||
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
const languageGetter = jest.spyOn(navigator, 'language', 'get')
|
||||||
it('shows English as language ', async () => {
|
it('shows English as language ', async () => {
|
||||||
languageGetter.mockReturnValue('es-ES')
|
languageGetter.mockReturnValue('fr-FR')
|
||||||
wrapper.vm.setCurrentLanguage()
|
wrapper.vm.setCurrentLanguage()
|
||||||
await wrapper.vm.$nextTick()
|
await wrapper.vm.$nextTick()
|
||||||
expect(wrapper.findAll('span.locales').at(0).text()).toBe('English')
|
expect(wrapper.findAll('span.locales').at(0).text()).toBe('English')
|
||||||
@ -93,9 +102,17 @@ describe('LanguageSwitch', () => {
|
|||||||
expect(wrapper.findAll('span.locales').at(1).text()).toBe('Deutsch')
|
expect(wrapper.findAll('span.locales').at(1).text()).toBe('Deutsch')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
describe('language "es" in store', () => {
|
||||||
|
it('shows Español as language', async () => {
|
||||||
|
wrapper.vm.$store.state.language = 'es'
|
||||||
|
wrapper.vm.setCurrentLanguage()
|
||||||
|
await wrapper.vm.$nextTick()
|
||||||
|
expect(wrapper.findAll('span.locales').at(2).text()).toBe('Español')
|
||||||
|
})
|
||||||
|
})
|
||||||
describe('language menu', () => {
|
describe('language menu', () => {
|
||||||
it('has English and German as languages to choose', () => {
|
it('has English, German and Español as languages to choose', () => {
|
||||||
expect(wrapper.findAll('span.locales')).toHaveLength(2)
|
expect(wrapper.findAll('span.locales')).toHaveLength(3)
|
||||||
})
|
})
|
||||||
it('has English as first language to choose', () => {
|
it('has English as first language to choose', () => {
|
||||||
expect(wrapper.findAll('span.locales').at(0).text()).toBe('English')
|
expect(wrapper.findAll('span.locales').at(0).text()).toBe('English')
|
||||||
@ -103,6 +120,9 @@ describe('LanguageSwitch', () => {
|
|||||||
it('has German as second language to choose', () => {
|
it('has German as second language to choose', () => {
|
||||||
expect(wrapper.findAll('span.locales').at(1).text()).toBe('Deutsch')
|
expect(wrapper.findAll('span.locales').at(1).text()).toBe('Deutsch')
|
||||||
})
|
})
|
||||||
|
it('has Español as third language to choose', () => {
|
||||||
|
expect(wrapper.findAll('span.locales').at(2).text()).toBe('Español')
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@ -16,6 +16,7 @@ export default {
|
|||||||
options: [
|
options: [
|
||||||
{ value: 'de', text: this.$t('settings.language.de') },
|
{ value: 'de', text: this.$t('settings.language.de') },
|
||||||
{ value: 'en', text: this.$t('settings.language.en') },
|
{ value: 'en', text: this.$t('settings.language.en') },
|
||||||
|
{ value: 'es', text: this.$t('settings.language.es') },
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@ -48,8 +48,8 @@ describe('Navbar', () => {
|
|||||||
expect(wrapper.find('.navbar-toggler').exists()).toBeTruthy()
|
expect(wrapper.find('.navbar-toggler').exists()).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has ten b-nav-item in the navbar', () => {
|
it('has twelve b-nav-item in the navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item')).toHaveLength(11)
|
expect(wrapper.findAll('.nav-item')).toHaveLength(12)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "amount GDD" in navbar', () => {
|
it('has first nav-item "amount GDD" in navbar', () => {
|
||||||
@ -68,29 +68,33 @@ describe('Navbar', () => {
|
|||||||
expect(wrapper.findAll('.nav-item').at(5).text()).toEqual('navigation.transactions')
|
expect(wrapper.findAll('.nav-item').at(5).text()).toEqual('navigation.transactions')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.transactions" in navbar', () => {
|
it('has first nav-item "gdt.gdt" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(6).text()).toEqual('navigation.community')
|
expect(wrapper.findAll('.nav-item').at(6).text()).toEqual('gdt.gdt')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('has first nav-item "navigation.community" in navbar', () => {
|
||||||
|
expect(wrapper.findAll('.nav-item').at(7).text()).toEqual('navigation.community')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.profile" in navbar', () => {
|
it('has first nav-item "navigation.profile" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(7).text()).toEqual('navigation.profile')
|
expect(wrapper.findAll('.nav-item').at(8).text()).toEqual('navigation.profile')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('navigation Navbar (user has an elopage account)', () => {
|
describe('navigation Navbar (user has an elopage account)', () => {
|
||||||
it('has a link to the members area', () => {
|
it('has a link to the members area', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(8).text()).toContain('navigation.members_area')
|
expect(wrapper.findAll('.nav-item').at(9).text()).toContain('navigation.members_area')
|
||||||
expect(wrapper.findAll('.nav-item').at(8).find('a').attributes('href')).toBe(
|
expect(wrapper.findAll('.nav-item').at(9).find('a').attributes('href')).toBe(
|
||||||
'https://elopage.com',
|
'https://elopage.com',
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(9).text()).toEqual('navigation.admin_area')
|
expect(wrapper.findAll('.nav-item').at(10).text()).toEqual('navigation.admin_area')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.logout" in navbar', () => {
|
it('has first nav-item "navigation.logout" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(10).text()).toEqual('navigation.logout')
|
expect(wrapper.findAll('.nav-item').at(11).text()).toEqual('navigation.logout')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -101,11 +105,11 @@ describe('Navbar', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(8).text()).toEqual('navigation.admin_area')
|
expect(wrapper.findAll('.nav-item').at(9).text()).toEqual('navigation.admin_area')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.logout" in navbar', () => {
|
it('has first nav-item "navigation.logout" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(9).text()).toEqual('navigation.logout')
|
expect(wrapper.findAll('.nav-item').at(10).text()).toEqual('navigation.logout')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@ -52,6 +52,10 @@
|
|||||||
<b-icon icon="layout-text-sidebar-reverse" aria-hidden="true"></b-icon>
|
<b-icon icon="layout-text-sidebar-reverse" aria-hidden="true"></b-icon>
|
||||||
{{ $t('navigation.transactions') }}
|
{{ $t('navigation.transactions') }}
|
||||||
</b-nav-item>
|
</b-nav-item>
|
||||||
|
<b-nav-item to="/gdt" class="mb-3">
|
||||||
|
<b-icon icon="layout-text-sidebar-reverse" aria-hidden="true"></b-icon>
|
||||||
|
{{ $t('gdt.gdt') }}
|
||||||
|
</b-nav-item>
|
||||||
<b-nav-item to="/community" class="mb-3">
|
<b-nav-item to="/community" class="mb-3">
|
||||||
<b-icon icon="people" aria-hidden="true"></b-icon>
|
<b-icon icon="people" aria-hidden="true"></b-icon>
|
||||||
{{ $t('navigation.community') }}
|
{{ $t('navigation.community') }}
|
||||||
|
|||||||
@ -45,31 +45,35 @@ describe('Sidebar', () => {
|
|||||||
expect(wrapper.findAll('.nav-item').at(2).text()).toEqual('navigation.transactions')
|
expect(wrapper.findAll('.nav-item').at(2).text()).toEqual('navigation.transactions')
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('has first nav-item "gdt.gdt" in navbar', () => {
|
||||||
|
expect(wrapper.findAll('.nav-item').at(3).text()).toEqual('gdt.gdt')
|
||||||
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.community" in navbar', () => {
|
it('has first nav-item "navigation.community" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(3).text()).toContain('navigation.community')
|
expect(wrapper.findAll('.nav-item').at(4).text()).toContain('navigation.community')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.profile" in navbar', () => {
|
it('has first nav-item "navigation.profile" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(4).text()).toEqual('navigation.profile')
|
expect(wrapper.findAll('.nav-item').at(5).text()).toEqual('navigation.profile')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('navigation Navbar (user has an elopage account)', () => {
|
describe('navigation Navbar (user has an elopage account)', () => {
|
||||||
it('has eight b-nav-item in the navbar', () => {
|
it('has eight b-nav-item in the navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item')).toHaveLength(8)
|
expect(wrapper.findAll('.nav-item')).toHaveLength(9)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has a link to the members area', () => {
|
it('has a link to the members area', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(5).text()).toEqual('navigation.members_area')
|
expect(wrapper.findAll('.nav-item').at(6).text()).toEqual('navigation.members_area')
|
||||||
expect(wrapper.findAll('.nav-item').at(5).find('a').attributes('href')).toBe('#')
|
expect(wrapper.findAll('.nav-item').at(6).find('a').attributes('href')).toBe('#')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(6).text()).toEqual('navigation.admin_area')
|
expect(wrapper.findAll('.nav-item').at(7).text()).toEqual('navigation.admin_area')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.logout" in navbar', () => {
|
it('has first nav-item "navigation.logout" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(7).text()).toEqual('navigation.logout')
|
expect(wrapper.findAll('.nav-item').at(8).text()).toEqual('navigation.logout')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -80,15 +84,15 @@ describe('Sidebar', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('has seven b-nav-item in the navbar', () => {
|
it('has seven b-nav-item in the navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item')).toHaveLength(7)
|
expect(wrapper.findAll('.nav-item')).toHaveLength(8)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
it('has first nav-item "navigation.admin_area" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(5).text()).toEqual('navigation.admin_area')
|
expect(wrapper.findAll('.nav-item').at(6).text()).toEqual('navigation.admin_area')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('has first nav-item "navigation.logout" in navbar', () => {
|
it('has first nav-item "navigation.logout" in navbar', () => {
|
||||||
expect(wrapper.findAll('.nav-item').at(6).text()).toEqual('navigation.logout')
|
expect(wrapper.findAll('.nav-item').at(7).text()).toEqual('navigation.logout')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@ -16,6 +16,10 @@
|
|||||||
<b-icon icon="layout-text-sidebar-reverse" aria-hidden="true"></b-icon>
|
<b-icon icon="layout-text-sidebar-reverse" aria-hidden="true"></b-icon>
|
||||||
{{ $t('navigation.transactions') }}
|
{{ $t('navigation.transactions') }}
|
||||||
</b-nav-item>
|
</b-nav-item>
|
||||||
|
<b-nav-item to="/gdt" class="mb-3">
|
||||||
|
<b-icon icon="layout-text-sidebar-reverse" aria-hidden="true"></b-icon>
|
||||||
|
{{ $t('gdt.gdt') }}
|
||||||
|
</b-nav-item>
|
||||||
<b-nav-item to="/community" class="mb-3">
|
<b-nav-item to="/community" class="mb-3">
|
||||||
<b-icon icon="people" aria-hidden="true"></b-icon>
|
<b-icon icon="people" aria-hidden="true"></b-icon>
|
||||||
{{ $t('navigation.community') }}
|
{{ $t('navigation.community') }}
|
||||||
|
|||||||
@ -3,6 +3,7 @@ import VueI18n from 'vue-i18n'
|
|||||||
|
|
||||||
import en from 'vee-validate/dist/locale/en'
|
import en from 'vee-validate/dist/locale/en'
|
||||||
import de from 'vee-validate/dist/locale/de'
|
import de from 'vee-validate/dist/locale/de'
|
||||||
|
import es from 'vee-validate/dist/locale/es'
|
||||||
|
|
||||||
Vue.use(VueI18n)
|
Vue.use(VueI18n)
|
||||||
|
|
||||||
@ -26,6 +27,12 @@ function loadLocaleMessages() {
|
|||||||
...messages[locale],
|
...messages[locale],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (locale === 'es') {
|
||||||
|
messages[locale] = {
|
||||||
|
validations: es,
|
||||||
|
...messages[locale],
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
return messages
|
return messages
|
||||||
@ -58,6 +65,19 @@ const numberFormats = {
|
|||||||
useGrouping: false,
|
useGrouping: false,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
es: {
|
||||||
|
decimal: {
|
||||||
|
style: 'decimal',
|
||||||
|
minimumFractionDigits: 2,
|
||||||
|
maximumFractionDigits: 2,
|
||||||
|
},
|
||||||
|
ungroupedDecimal: {
|
||||||
|
style: 'decimal',
|
||||||
|
minimumFractionDigits: 2,
|
||||||
|
maximumFractionDigits: 2,
|
||||||
|
useGrouping: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
const dateTimeFormats = {
|
const dateTimeFormats = {
|
||||||
@ -117,6 +137,34 @@ const dateTimeFormats = {
|
|||||||
year: 'numeric',
|
year: 'numeric',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
es: {
|
||||||
|
short: {
|
||||||
|
day: 'numeric',
|
||||||
|
month: 'numeric',
|
||||||
|
year: 'numeric',
|
||||||
|
},
|
||||||
|
long: {
|
||||||
|
day: 'numeric',
|
||||||
|
month: 'long',
|
||||||
|
year: 'numeric',
|
||||||
|
weekday: 'long',
|
||||||
|
hour: 'numeric',
|
||||||
|
minute: 'numeric',
|
||||||
|
},
|
||||||
|
monthShort: {
|
||||||
|
month: 'short',
|
||||||
|
},
|
||||||
|
month: {
|
||||||
|
month: 'long',
|
||||||
|
},
|
||||||
|
year: {
|
||||||
|
year: 'numeric',
|
||||||
|
},
|
||||||
|
monthAndYear: {
|
||||||
|
month: 'long',
|
||||||
|
year: 'numeric',
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
export default new VueI18n({
|
export default new VueI18n({
|
||||||
|
|||||||
@ -246,6 +246,7 @@
|
|||||||
"changeLanguage": "Sprache ändern",
|
"changeLanguage": "Sprache ändern",
|
||||||
"de": "Deutsch",
|
"de": "Deutsch",
|
||||||
"en": "English",
|
"en": "English",
|
||||||
|
"es": "Español",
|
||||||
"success": "Deine Sprache wurde erfolgreich geändert."
|
"success": "Deine Sprache wurde erfolgreich geändert."
|
||||||
},
|
},
|
||||||
"name": {
|
"name": {
|
||||||
|
|||||||
@ -246,6 +246,7 @@
|
|||||||
"changeLanguage": "Change language",
|
"changeLanguage": "Change language",
|
||||||
"de": "Deutsch",
|
"de": "Deutsch",
|
||||||
"en": "English",
|
"en": "English",
|
||||||
|
"es": "Español",
|
||||||
"success": "Your language has been successfully updated."
|
"success": "Your language has been successfully updated."
|
||||||
},
|
},
|
||||||
"name": {
|
"name": {
|
||||||
|
|||||||
324
frontend/src/locales/es.json
Normal file
324
frontend/src/locales/es.json
Normal file
@ -0,0 +1,324 @@
|
|||||||
|
{
|
||||||
|
"100": "100%",
|
||||||
|
"1000thanks": "1000 Gracias, por estar con nosotros!",
|
||||||
|
"125": "125%",
|
||||||
|
"85": "85%",
|
||||||
|
"advanced-calculation": "Proyección",
|
||||||
|
"auth": {
|
||||||
|
"left": {
|
||||||
|
"dignity": "Dignidad",
|
||||||
|
"donation": "Donación",
|
||||||
|
"gratitude": "Gratitud",
|
||||||
|
"hasAccount": "Ya estas registrado?",
|
||||||
|
"hereLogin": "Regístrate aquí",
|
||||||
|
"learnMore": "Infórmate aquí …",
|
||||||
|
"oneDignity": "Damos los unos a los otros y agradecemos con Gradido.",
|
||||||
|
"oneDonation": "Eres un regalo para la comunidad. 1000 gracias por estar con nosotros.",
|
||||||
|
"oneGratitude": "Por los demás, por toda la humanidad, por la naturaleza."
|
||||||
|
},
|
||||||
|
"navbar": {
|
||||||
|
"aboutGradido": "Sobre Gradido"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"back": "Volver",
|
||||||
|
"community": {
|
||||||
|
"choose-another-community": "Escoger otra comunidad",
|
||||||
|
"community": "Comunidad",
|
||||||
|
"continue-to-registration": "Continuar con el registro",
|
||||||
|
"current-community": "Comunidad actual",
|
||||||
|
"myContributions": "Mis contribuciones al bien común",
|
||||||
|
"other-communities": "Otras comunidades",
|
||||||
|
"submitContribution": "Aportar una contribución",
|
||||||
|
"switch-to-this-community": "cambiar a esta comunidad"
|
||||||
|
},
|
||||||
|
"contribution": {
|
||||||
|
"activity": "Actividad",
|
||||||
|
"alert": {
|
||||||
|
"communityNoteList": "Aquí encontrarás todas las contribuciones enviadas y confirmadas de todos los miembros de esta comunidad.",
|
||||||
|
"confirm": "confirmado",
|
||||||
|
"myContributionNoteList": "Puedes editar o eliminar las contribuciones enviadas que aún no han sido confirmadas en cualquier momento.",
|
||||||
|
"myContributionNoteSupport": "Pronto existirá la posibilidad de que puedas dialogar con los moderadores. Si tienes algún problema ahora, ponte en contacto con el equipo de asistencia.",
|
||||||
|
"pending": "Enviado y a la espera de confirmación",
|
||||||
|
"rejected": "rechazado"
|
||||||
|
},
|
||||||
|
"date": "Contribución para:",
|
||||||
|
"delete": "Eliminar la contribución. ¿Estás seguro?",
|
||||||
|
"deleted": "¡La contribución ha sido borrada! Pero seguirá siendo visible.",
|
||||||
|
"formText": {
|
||||||
|
"bringYourTalentsTo": "¡Contribuye a la comunidad con tus talentos! Premiamos tu compromiso voluntario con 20 GDD por hora hasta un máximo de 1.000 GDD al mes.",
|
||||||
|
"describeYourCommunity": "¡Describe tu contribución al bien-común con detalles de las horas e introduce una cantidad de 20 GDD por hora! Tras la confirmación de un moderador, el importe se abonará en tu cuenta.",
|
||||||
|
"maxGDDforMonth": "Sólo puede presentar un máximo de {amount} GDD para el mes seleccionado.",
|
||||||
|
"openAmountForMonth": "Para <b>{monthAndYear}</b> aún puedes presentar <b>{creation}</b> GDD.",
|
||||||
|
"yourContribution": "Tu contribución a la comunidad."
|
||||||
|
},
|
||||||
|
"noDateSelected": "Elige cualquier fecha del mes.",
|
||||||
|
"selectDate": "¿Cuando fue tu contribución?",
|
||||||
|
"submit": "Enviar",
|
||||||
|
"submitted": "Tu contribución ha sido enviada.",
|
||||||
|
"updated": "La contribución se modificó.",
|
||||||
|
"yourActivity": "¡Por favor, introduce una actividad!"
|
||||||
|
},
|
||||||
|
"contribution-link": {
|
||||||
|
"thanksYouWith": "agradecidos con"
|
||||||
|
},
|
||||||
|
"decay": {
|
||||||
|
"before_startblock_transaction": "Esta transacción no implica disminución en su valor.",
|
||||||
|
"calculation_decay": "Cálculo de la disminución gradual del valor",
|
||||||
|
"calculation_total": "Cálculo de la suma total",
|
||||||
|
"decay": "Disminución gradual del valor",
|
||||||
|
"decay_introduced": "La disminución gradual empezó el:",
|
||||||
|
"decay_since_last_transaction": "Disminución gradual",
|
||||||
|
"last_transaction": "Transacción anterior",
|
||||||
|
"past_time": "Tiempo transcurrido",
|
||||||
|
"Starting_block_decay": "Startblock disminución gradual",
|
||||||
|
"total": "Total",
|
||||||
|
"types": {
|
||||||
|
"creation": "Creado",
|
||||||
|
"noDecay": "sin disminución gradual",
|
||||||
|
"receive": "Recibido",
|
||||||
|
"send": "Enviado"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"delete": "Eliminar",
|
||||||
|
"em-dash": "—",
|
||||||
|
"error": {
|
||||||
|
"email-already-sent": "Ya te hemos enviado un correo electrónico hace menos de 10 minutos.",
|
||||||
|
"empty-transactionlist": "Ha habido un error en la transmisión del número de sus transacciones.",
|
||||||
|
"error": "Error!",
|
||||||
|
"no-account": "Lamentablemente no hemos podido encontrar una cuenta (activada) con estos datos.",
|
||||||
|
"no-transactionlist": "Lamentablemente, hubo un error. No se ha transmitido ninguna transacción desde el servidor.",
|
||||||
|
"no-user": "No hay usuario con estas referencias.",
|
||||||
|
"session-expired": "La sesión se cerró por razones de seguridad.",
|
||||||
|
"unknown-error": "Error desconocido: "
|
||||||
|
},
|
||||||
|
"followUs": "sigue nos:",
|
||||||
|
"footer": {
|
||||||
|
"app_version": "App versión {version}",
|
||||||
|
"copyright": {
|
||||||
|
"link": "Gradido-Akademie",
|
||||||
|
"year": "© {year}"
|
||||||
|
},
|
||||||
|
"imprint": "Aviso legal",
|
||||||
|
"privacy_policy": "Protección de Datos",
|
||||||
|
"short_hash": "({shortHash})",
|
||||||
|
"whitepaper": "Whitepaper"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"amount": "Importe",
|
||||||
|
"at": "am",
|
||||||
|
"cancel": "Cancelar",
|
||||||
|
"change": "Cambiar",
|
||||||
|
"check_now": "Revisar",
|
||||||
|
"close": "Cerrar",
|
||||||
|
"current_balance": "Saldo de cuenta actual",
|
||||||
|
"date": "Fecha",
|
||||||
|
"description": "Descripción",
|
||||||
|
"email": "E-Mail",
|
||||||
|
"firstname": "Nombre",
|
||||||
|
"from": "De",
|
||||||
|
"generate_now": "crear ahora",
|
||||||
|
"lastname": "Apellido",
|
||||||
|
"mandatoryField": "campo obligatorio",
|
||||||
|
"memo": "Mensaje",
|
||||||
|
"message": "Noticia",
|
||||||
|
"new_balance": "Saldo de cuenta nuevo depués de confirmación",
|
||||||
|
"no_gdd_available": "No dispones de GDD para enviar.",
|
||||||
|
"password": "Contraseña",
|
||||||
|
"passwordRepeat": "Repetir contraseña",
|
||||||
|
"password_new": "contraseña nueva",
|
||||||
|
"password_new_repeat": "Repetir contraseña nueva",
|
||||||
|
"password_old": "contraseña antigua",
|
||||||
|
"recipient": "Destinatario",
|
||||||
|
"reset": "Restablecer",
|
||||||
|
"save": "Guardar",
|
||||||
|
"scann_code": "<strong>QR Code Scanner</strong> - Escanea el código QR de tu pareja",
|
||||||
|
"sender": "Remitente",
|
||||||
|
"send_check": "Confirma tu transacción. Por favor revisa toda la información nuevamente!",
|
||||||
|
"send_now": "Enviar ahora",
|
||||||
|
"send_transaction_error": "Desafortunadamente, la transacción no se pudo ejecutar!",
|
||||||
|
"send_transaction_success": "Su transacción fue ejecutada con éxito",
|
||||||
|
"sorry": "Disculpa",
|
||||||
|
"thx": "Gracias",
|
||||||
|
"time": "Tiempo",
|
||||||
|
"to": "hasta",
|
||||||
|
"to1": "para",
|
||||||
|
"validation": {
|
||||||
|
"gddSendAmount": "El campo {_field_} debe ser un número entre {min} y {max} con un máximo de dos decimales",
|
||||||
|
"is-not": "No es posible transferirte Gradidos a ti mismo",
|
||||||
|
"usernmae-regex": "El nombre de usuario debe comenzar con una letra seguida de al menos dos caracteres alfanuméricos.",
|
||||||
|
"usernmae-unique": "Este nombre de usuario ya está adjudicado."
|
||||||
|
},
|
||||||
|
"your_amount": "Tu importe"
|
||||||
|
},
|
||||||
|
"GDD": "GDD",
|
||||||
|
"gdd_per_link": {
|
||||||
|
"choose-amount": "Selecciona una cantidad que te gustaría enviar a través de un enlace. También puedes ingresar un mensaje. Cuando haces clic en 'Generar ahora', se crea un enlace que puedes enviar.",
|
||||||
|
"copy-link": "Copiar enlace",
|
||||||
|
"copy-link-with-text": "Copiar texto y enlace",
|
||||||
|
"created": "El enlace ha sido creado",
|
||||||
|
"credit-your-gradido": "Para que se te acrediten los Gradidos, haz clic en el enlace!",
|
||||||
|
"decay-14-day": "Disminución gradual por 14 días",
|
||||||
|
"delete-the-link": "Eliminar el enlace?",
|
||||||
|
"deleted": "El enlace ha sido eliminado!",
|
||||||
|
"expiredOn": "Vencido el:",
|
||||||
|
"has-account": "Ya tienes una cuenta Gradido?",
|
||||||
|
"header": "Transferir Gradidos por medio de un enlace",
|
||||||
|
"isFree": "Gradido es gratis en todo el mundo.",
|
||||||
|
"link-and-text-copied": "El enlace y su mensaje se han copiado en el portapapeles. Ahora puedes ponerlo en un correo electrónico o mensaje.",
|
||||||
|
"link-copied": "El enlace se ha copiado en el portapapeles. Ahora puedes pegarlo en un correo electrónico o mensaje.",
|
||||||
|
"link-deleted": "El enlace se eliminó el {date}.",
|
||||||
|
"link-expired": "El enlace ya no es válido. La validez expiró el {date}.",
|
||||||
|
"link-overview": "Resumen de enlaces",
|
||||||
|
"links_count": "Enlaces activos",
|
||||||
|
"links_sum": "Enlaces abiertos y códigos QR",
|
||||||
|
"no-account": "Aún no tienes una cuenta de Gradido?",
|
||||||
|
"no-redeem": "No puedes canjear tu propio enlace!",
|
||||||
|
"not-copied": "¡Desafortunadamente, su dispositivo no permite copiar! Copie el enlace manualmente!",
|
||||||
|
"redeem": "Canjear",
|
||||||
|
"redeem-text": "¿Quieres canjear el importe ahora?",
|
||||||
|
"redeemed": "¡Canjeado con éxito! Tu cuenta ha sido acreditada con {n} GDD.",
|
||||||
|
"redeemed-at": "El enlace ya se canjeó el {date}.",
|
||||||
|
"redeemed-title": "canjeado",
|
||||||
|
"to-login": "iniciar sesión",
|
||||||
|
"to-register": "Registre una nueva cuenta.",
|
||||||
|
"validUntil": "Válido hasta",
|
||||||
|
"validUntilDate": "El enlace es válido hasta el {date} ."
|
||||||
|
},
|
||||||
|
"gdt": {
|
||||||
|
"calculation": "Cálculo del Gradido Transform",
|
||||||
|
"contribution": "Importe",
|
||||||
|
"conversion": "Conversión",
|
||||||
|
"conversion-gdt-euro": "Conversión Euro / Gradido Transform (GDT)",
|
||||||
|
"credit": "Abono",
|
||||||
|
"factor": "Factor",
|
||||||
|
"formula": "Formula de cálculo",
|
||||||
|
"funding": "Las donaciones",
|
||||||
|
"gdt": "Gradido Transform",
|
||||||
|
"gdt-received": "Gradido Transform (GDT) recibido",
|
||||||
|
"no-transactions": "Aún no tienes un Gradido Transform (GDT).",
|
||||||
|
"not-reachable": "No es posible acceder al servidor GDT.",
|
||||||
|
"publisher": "Tu nuevo miembro referido ha pagado la cuota",
|
||||||
|
"raise": "Aumento",
|
||||||
|
"recruited-member": "Miembro invitado"
|
||||||
|
},
|
||||||
|
"language": "Idioma",
|
||||||
|
"link-load": "recargar el último enlace |recargar los últimos {n} enlaces | descargar más {n} enlaces",
|
||||||
|
"login": "iniciar sesión",
|
||||||
|
"math": {
|
||||||
|
"aprox": "~",
|
||||||
|
"asterisk": "*",
|
||||||
|
"equal": "=",
|
||||||
|
"minus": "−",
|
||||||
|
"pipe": "|"
|
||||||
|
},
|
||||||
|
"message": {
|
||||||
|
"activateEmail": "Tu cuenta aún no ha sido activada. Por favor revisa tu correo electrónico y haz clic en el enlace de activación o solicita uno nuevo enlace de activación a través de la página restablecer contraseña.",
|
||||||
|
"checkEmail": "Tu correo electrónico ha sido verificado con éxito. Puedes registrarte ahora.",
|
||||||
|
"email": "Te hemos enviado un correo electrónico.",
|
||||||
|
"errorTitle": "Atención!",
|
||||||
|
"register": "Ya estás registrado, por favor revisa tu correo electrónico y haz clic en el enlace de activación.",
|
||||||
|
"reset": "Tu contraseña ha sido cambiada.",
|
||||||
|
"title": "Gracias!",
|
||||||
|
"unsetPassword": "Tu contraseña aún no ha sido configurada. Por favor reinícialo."
|
||||||
|
},
|
||||||
|
"navigation": {
|
||||||
|
"admin_area": "Área de administración",
|
||||||
|
"community": "Comunidad",
|
||||||
|
"logout": "Salir",
|
||||||
|
"members_area": "Área de afiliados",
|
||||||
|
"overview": "Resumen",
|
||||||
|
"profile": "Mi Perfil",
|
||||||
|
"send": "Enviar",
|
||||||
|
"support": "Soporte",
|
||||||
|
"transactions": "Transacciones"
|
||||||
|
},
|
||||||
|
"qrCode": "Código QR",
|
||||||
|
"send_gdd": "Enviar GDD",
|
||||||
|
"send_per_link": "Enviar GDD mediante un enlace",
|
||||||
|
"session": {
|
||||||
|
"extend": "Permanecer en sesión iniciada",
|
||||||
|
"lightText": "Si no has realizado ninguna acción durante más de 10 minutos, se cerrará tu sesión por razones de seguridad.",
|
||||||
|
"logoutIn": "Cerrar sesión en ",
|
||||||
|
"warningText": "Aún estas?"
|
||||||
|
},
|
||||||
|
"settings": {
|
||||||
|
"language": {
|
||||||
|
"changeLanguage": "Cambiar idioma",
|
||||||
|
"de": "Deutsch",
|
||||||
|
"en": "English",
|
||||||
|
"es": "Español",
|
||||||
|
"success": "Tu idioma ha sido cambiado con éxito."
|
||||||
|
},
|
||||||
|
"name": {
|
||||||
|
"change-name": "Cambiar nombre",
|
||||||
|
"change-success": "Tu nombre ha sido cambiado con éxito."
|
||||||
|
},
|
||||||
|
"newsletter": {
|
||||||
|
"newsletter": "Informaciones por correo electrónico",
|
||||||
|
"newsletterFalse": "No recibirás informaciones por correo electrónico.",
|
||||||
|
"newsletterTrue": "Recibirás informaciones por correo electrónico."
|
||||||
|
},
|
||||||
|
"password": {
|
||||||
|
"change-password": "Cambiar contraseña",
|
||||||
|
"forgot_pwd": "Olvide la contraseña?",
|
||||||
|
"resend_subtitle": "Su enlace de activación ha caducado. Puedes solicitar uno nuevo aquí.",
|
||||||
|
"reset": "Restablecer contraseña",
|
||||||
|
"reset-password": {
|
||||||
|
"text": "Ahora introduce una nueva contraseña con la que quieras acceder a tu cuenta de Gradido en el futuro.."
|
||||||
|
},
|
||||||
|
"send_now": "Enviar",
|
||||||
|
"set": "Establecer contraseña",
|
||||||
|
"set-password": {
|
||||||
|
"text": "Ahora guarda tu nueva contraseña, que podrás utilizar para acceder a tu cuenta de Gradido en el futuro."
|
||||||
|
},
|
||||||
|
"subtitle": "Si has olvidado tu contraseña, puedes restablecerla aquí."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"signin": "Iniciar sesión",
|
||||||
|
"signup": "Registrarse",
|
||||||
|
"site": {
|
||||||
|
"forgotPassword": {
|
||||||
|
"heading": "Por favor, introduce la dirección de correo electrónico con la que estas registrado en Gradido."
|
||||||
|
},
|
||||||
|
"login": {
|
||||||
|
"heading": "Inicia sesión con tus datos de acceso. Manténlos seguros en todo momento!"
|
||||||
|
},
|
||||||
|
"resetPassword": {
|
||||||
|
"heading": "Por favor, introduce tu contraseña y repítela."
|
||||||
|
},
|
||||||
|
"signup": {
|
||||||
|
"agree": "Acepto la <a href='https://gradido.net/de/datenschutz/' target='_blank' >Política de privacidad</a>.",
|
||||||
|
"dont_match": "Las contraseñas no coinciden.",
|
||||||
|
"heading": "Regístrate introduciendo todos los datos completos y en los campos correctos.",
|
||||||
|
"lowercase": "Se requiere una letra minúscula.",
|
||||||
|
"minimum": "Al menos 8 caracteres.",
|
||||||
|
"no-whitespace": "Sin espacios ni tabulaciones.",
|
||||||
|
"one_number": "Se requiere un número.",
|
||||||
|
"special-char": "Caracteres especiales requeridos (por ejemplo, _ o &)",
|
||||||
|
"uppercase": "Letra mayúscula requerida."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"success": "Lo lograste",
|
||||||
|
"time": {
|
||||||
|
"days": "Días",
|
||||||
|
"hours": "Horas",
|
||||||
|
"minutes": "Minutos",
|
||||||
|
"month": "Mes",
|
||||||
|
"months": "Meses",
|
||||||
|
"seconds": "Segundos",
|
||||||
|
"years": "Año"
|
||||||
|
},
|
||||||
|
"transaction": {
|
||||||
|
"gdd-text": "Transacciones Gradido",
|
||||||
|
"gdt-text": "Transacciones GradidoTransform ",
|
||||||
|
"nullTransactions": "Todavía no tienes ninguna transacción en tu cuenta.",
|
||||||
|
"receiverDeleted": "La cuenta del destinatario ha sido eliminada.",
|
||||||
|
"receiverNotFound": "Destinatario no encontrado",
|
||||||
|
"show_all": "Ver todas las transacciones de <strong>{count}</strong>"
|
||||||
|
},
|
||||||
|
"transaction-link": {
|
||||||
|
"send_you": "te envía"
|
||||||
|
},
|
||||||
|
"via_link": "atraves de un enlace",
|
||||||
|
"welcome": "Bienvenido a la comunidad."
|
||||||
|
}
|
||||||
@ -11,6 +11,12 @@ const locales = [
|
|||||||
iso: 'de-DE',
|
iso: 'de-DE',
|
||||||
enabled: true,
|
enabled: true,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: 'Español',
|
||||||
|
code: 'es',
|
||||||
|
iso: 'es-ES',
|
||||||
|
enabled: true,
|
||||||
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
export default locales
|
export default locales
|
||||||
|
|||||||
@ -6,6 +6,7 @@ import { toastErrorSpy } from '@test/testSetup'
|
|||||||
|
|
||||||
const localVue = global.localVue
|
const localVue = global.localVue
|
||||||
|
|
||||||
|
const mockRouterReplace = jest.fn()
|
||||||
const windowScrollToMock = jest.fn()
|
const windowScrollToMock = jest.fn()
|
||||||
window.scrollTo = windowScrollToMock
|
window.scrollTo = windowScrollToMock
|
||||||
|
|
||||||
@ -39,6 +40,9 @@ describe('Transactions', () => {
|
|||||||
$apollo: {
|
$apollo: {
|
||||||
query: apolloMock,
|
query: apolloMock,
|
||||||
},
|
},
|
||||||
|
$router: {
|
||||||
|
replace: mockRouterReplace,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
const Wrapper = () => {
|
const Wrapper = () => {
|
||||||
|
|||||||
@ -1,7 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="pb-4">
|
<div class="pb-4">
|
||||||
<b-tabs v-model="tabIndex" content-class="" justified>
|
<b-tabs v-model="tabIndex" content-class="" justified>
|
||||||
<b-tab :title="`Gradido (${$n(balance, 'decimal')} GDD)`" class="px-4">
|
<b-tab
|
||||||
|
:title="`Gradido (${$n(balance, 'decimal')} GDD)`"
|
||||||
|
class="px-4"
|
||||||
|
@click="$router.replace('/transactions')"
|
||||||
|
>
|
||||||
<p class="tab-tex">{{ $t('transaction.gdd-text') }}</p>
|
<p class="tab-tex">{{ $t('transaction.gdd-text') }}</p>
|
||||||
|
|
||||||
<gdd-transaction-list
|
<gdd-transaction-list
|
||||||
@ -42,6 +46,7 @@ export default {
|
|||||||
GdtTransactionList,
|
GdtTransactionList,
|
||||||
},
|
},
|
||||||
props: {
|
props: {
|
||||||
|
gdt: { type: Boolean, default: false },
|
||||||
balance: { type: Number, default: 0 },
|
balance: { type: Number, default: 0 },
|
||||||
GdtBalance: { type: Number, default: 0 },
|
GdtBalance: { type: Number, default: 0 },
|
||||||
transactions: {
|
transactions: {
|
||||||
@ -77,6 +82,8 @@ export default {
|
|||||||
this.transactionsGdt = listGDTEntries.gdtEntries
|
this.transactionsGdt = listGDTEntries.gdtEntries
|
||||||
this.transactionGdtCount = listGDTEntries.count
|
this.transactionGdtCount = listGDTEntries.count
|
||||||
window.scrollTo(0, 0)
|
window.scrollTo(0, 0)
|
||||||
|
// eslint-disable-next-line no-unused-expressions
|
||||||
|
this.$route.path === '/transactions' ? this.$router.replace('/gdt') : ''
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
this.transactionGdtCount = -1
|
this.transactionGdtCount = -1
|
||||||
@ -94,10 +101,26 @@ export default {
|
|||||||
return this.$t('gdt.gdt')
|
return this.$t('gdt.gdt')
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
created() {
|
||||||
|
if (this.gdt) {
|
||||||
|
this.tabIndex = 1
|
||||||
|
this.updateGdt()
|
||||||
|
} else {
|
||||||
|
this.tabIndex = 0
|
||||||
|
}
|
||||||
|
},
|
||||||
watch: {
|
watch: {
|
||||||
currentPage() {
|
currentPage() {
|
||||||
this.updateGdt()
|
this.updateGdt()
|
||||||
},
|
},
|
||||||
|
gdt() {
|
||||||
|
if (this.gdt) {
|
||||||
|
this.tabIndex = 1
|
||||||
|
this.updateGdt()
|
||||||
|
} else {
|
||||||
|
this.tabIndex = 0
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@ -50,7 +50,7 @@ describe('router', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('has sixteen routes defined', () => {
|
it('has sixteen routes defined', () => {
|
||||||
expect(routes).toHaveLength(17)
|
expect(routes).toHaveLength(18)
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('overview', () => {
|
describe('overview', () => {
|
||||||
@ -108,6 +108,17 @@ describe('router', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('gdt', () => {
|
||||||
|
it('requires authorization', () => {
|
||||||
|
expect(routes.find((r) => r.path === '/gdt').meta.requiresAuth).toBeTruthy()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('loads the "GDT" page', async () => {
|
||||||
|
const component = await routes.find((r) => r.path === '/gdt').component()
|
||||||
|
expect(component.default.name).toBe('Transactions')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
describe('login', () => {
|
describe('login', () => {
|
||||||
it('loads the "Login" page', async () => {
|
it('loads the "Login" page', async () => {
|
||||||
const component = await routes.find((r) => r.path === '/login/:code?').component()
|
const component = await routes.find((r) => r.path === '/login/:code?').component()
|
||||||
|
|||||||
@ -34,6 +34,15 @@ const routes = [
|
|||||||
{
|
{
|
||||||
path: '/transactions',
|
path: '/transactions',
|
||||||
component: () => import('@/pages/Transactions.vue'),
|
component: () => import('@/pages/Transactions.vue'),
|
||||||
|
props: { gdt: false },
|
||||||
|
meta: {
|
||||||
|
requiresAuth: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/gdt',
|
||||||
|
component: () => import('@/pages/Transactions.vue'),
|
||||||
|
props: { gdt: true },
|
||||||
meta: {
|
meta: {
|
||||||
requiresAuth: true,
|
requiresAuth: true,
|
||||||
},
|
},
|
||||||
|
|||||||
@ -2156,17 +2156,6 @@
|
|||||||
jest-message-util "^24.9.0"
|
jest-message-util "^24.9.0"
|
||||||
jest-mock "^24.9.0"
|
jest-mock "^24.9.0"
|
||||||
|
|
||||||
"@jest/fake-timers@^25.1.0":
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-25.5.0.tgz#46352e00533c024c90c2bc2ad9f2959f7f114185"
|
|
||||||
integrity sha512-9y2+uGnESw/oyOI3eww9yaxdZyHq7XvprfP/eeoCsjqKYts2yRlsHS/SgjPDV8FyMfn2nbMy8YzUk6nyvdLOpQ==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
jest-message-util "^25.5.0"
|
|
||||||
jest-mock "^25.5.0"
|
|
||||||
jest-util "^25.5.0"
|
|
||||||
lolex "^5.0.0"
|
|
||||||
|
|
||||||
"@jest/fake-timers@^26.6.2":
|
"@jest/fake-timers@^26.6.2":
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.6.2.tgz#459c329bcf70cee4af4d7e3f3e67848123535aad"
|
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.6.2.tgz#459c329bcf70cee4af4d7e3f3e67848123535aad"
|
||||||
@ -2378,16 +2367,6 @@
|
|||||||
"@types/istanbul-reports" "^1.1.1"
|
"@types/istanbul-reports" "^1.1.1"
|
||||||
"@types/yargs" "^13.0.0"
|
"@types/yargs" "^13.0.0"
|
||||||
|
|
||||||
"@jest/types@^25.5.0":
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/@jest/types/-/types-25.5.0.tgz#4d6a4793f7b9599fc3680877b856a97dbccf2a9d"
|
|
||||||
integrity sha512-OXD0RgQ86Tu3MazKo8bnrkDRaDXXMGUqd+kTtLtK1Zb7CRzQcaSRPPPV37SvYTdevXEBVxe0HXylEjs8ibkmCw==
|
|
||||||
dependencies:
|
|
||||||
"@types/istanbul-lib-coverage" "^2.0.0"
|
|
||||||
"@types/istanbul-reports" "^1.1.1"
|
|
||||||
"@types/yargs" "^15.0.0"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
|
|
||||||
"@jest/types@^26.6.2":
|
"@jest/types@^26.6.2":
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.6.2.tgz#bef5a532030e1d88a2f5a6d933f84e97226ed48e"
|
resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.6.2.tgz#bef5a532030e1d88a2f5a6d933f84e97226ed48e"
|
||||||
@ -2482,11 +2461,6 @@
|
|||||||
string-width "^2.0.0"
|
string-width "^2.0.0"
|
||||||
strip-ansi "^5"
|
strip-ansi "^5"
|
||||||
|
|
||||||
"@tootallnate/once@1":
|
|
||||||
version "1.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82"
|
|
||||||
integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==
|
|
||||||
|
|
||||||
"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.14", "@types/babel__core@^7.1.7":
|
"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.14", "@types/babel__core@^7.1.7":
|
||||||
version "7.1.17"
|
version "7.1.17"
|
||||||
resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.17.tgz#f50ac9d20d64153b510578d84f9643f9a3afbe64"
|
resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.17.tgz#f50ac9d20d64153b510578d84f9643f9a3afbe64"
|
||||||
@ -3293,11 +3267,6 @@ acorn@^8.0.5:
|
|||||||
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.1.0.tgz#52311fd7037ae119cbb134309e901aa46295b3fe"
|
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.1.0.tgz#52311fd7037ae119cbb134309e901aa46295b3fe"
|
||||||
integrity sha512-LWCF/Wn0nfHOmJ9rzQApGnxnvgfROzGilS8936rqN/lfcYkY9MYZzdMqN+2NJ4SlTc+m5HiSa+kNfDtI64dwUA==
|
integrity sha512-LWCF/Wn0nfHOmJ9rzQApGnxnvgfROzGilS8936rqN/lfcYkY9MYZzdMqN+2NJ4SlTc+m5HiSa+kNfDtI64dwUA==
|
||||||
|
|
||||||
acorn@^8.2.4:
|
|
||||||
version "8.6.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.6.0.tgz#e3692ba0eb1a0c83eaa4f37f5fa7368dd7142895"
|
|
||||||
integrity sha512-U1riIR+lBSNi3IbxtaHOIKdH8sLFv3NYfNv8sg7ZsNhcfl4HF2++BfqqrNAxoCLQW1iiylOj76ecnaUxz+z9yw==
|
|
||||||
|
|
||||||
acorn@^8.5.0, acorn@^8.7.0:
|
acorn@^8.5.0, acorn@^8.7.0:
|
||||||
version "8.7.0"
|
version "8.7.0"
|
||||||
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.0.tgz#90951fde0f8f09df93549481e5fc141445b791cf"
|
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.0.tgz#90951fde0f8f09df93549481e5fc141445b791cf"
|
||||||
@ -3308,13 +3277,6 @@ address@^1.0.3:
|
|||||||
resolved "https://registry.yarnpkg.com/address/-/address-1.1.2.tgz#bf1116c9c758c51b7a933d296b72c221ed9428b6"
|
resolved "https://registry.yarnpkg.com/address/-/address-1.1.2.tgz#bf1116c9c758c51b7a933d296b72c221ed9428b6"
|
||||||
integrity sha512-aT6camzM4xEA54YVJYSqxz1kv4IHnQZRtThJJHhUMRExaU5spC7jX5ugSwTaTgJliIgs4VhZOk7htClvQ/LmRA==
|
integrity sha512-aT6camzM4xEA54YVJYSqxz1kv4IHnQZRtThJJHhUMRExaU5spC7jX5ugSwTaTgJliIgs4VhZOk7htClvQ/LmRA==
|
||||||
|
|
||||||
agent-base@6:
|
|
||||||
version "6.0.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77"
|
|
||||||
integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==
|
|
||||||
dependencies:
|
|
||||||
debug "4"
|
|
||||||
|
|
||||||
ajv-errors@^1.0.0:
|
ajv-errors@^1.0.0:
|
||||||
version "1.0.1"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/ajv-errors/-/ajv-errors-1.0.1.tgz#f35986aceb91afadec4102fbd85014950cefa64d"
|
resolved "https://registry.yarnpkg.com/ajv-errors/-/ajv-errors-1.0.1.tgz#f35986aceb91afadec4102fbd85014950cefa64d"
|
||||||
@ -4657,14 +4619,6 @@ chalk@^2.0.0, chalk@^2.0.1, chalk@^2.1.0, chalk@^2.3.0, chalk@^2.4.1, chalk@^2.4
|
|||||||
escape-string-regexp "^1.0.5"
|
escape-string-regexp "^1.0.5"
|
||||||
supports-color "^5.3.0"
|
supports-color "^5.3.0"
|
||||||
|
|
||||||
chalk@^3.0.0:
|
|
||||||
version "3.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4"
|
|
||||||
integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==
|
|
||||||
dependencies:
|
|
||||||
ansi-styles "^4.1.0"
|
|
||||||
supports-color "^7.1.0"
|
|
||||||
|
|
||||||
chalk@^4.0.0:
|
chalk@^4.0.0:
|
||||||
version "4.1.2"
|
version "4.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01"
|
resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01"
|
||||||
@ -4995,7 +4949,7 @@ colors@^1.1.2:
|
|||||||
resolved "https://registry.yarnpkg.com/colors/-/colors-1.4.0.tgz#c50491479d4c1bdaed2c9ced32cf7c7dc2360f78"
|
resolved "https://registry.yarnpkg.com/colors/-/colors-1.4.0.tgz#c50491479d4c1bdaed2c9ced32cf7c7dc2360f78"
|
||||||
integrity sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==
|
integrity sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==
|
||||||
|
|
||||||
combined-stream@^1.0.6, combined-stream@^1.0.8, combined-stream@~1.0.6:
|
combined-stream@^1.0.6, combined-stream@~1.0.6:
|
||||||
version "1.0.8"
|
version "1.0.8"
|
||||||
resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f"
|
resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f"
|
||||||
integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==
|
integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==
|
||||||
@ -5578,13 +5532,6 @@ debug@2.6.9, debug@^2.2.0, debug@^2.3.3, debug@^2.6.8, debug@^2.6.9:
|
|||||||
dependencies:
|
dependencies:
|
||||||
ms "2.0.0"
|
ms "2.0.0"
|
||||||
|
|
||||||
debug@4, debug@^4.1.0, debug@^4.3.1, debug@^4.3.2, debug@^4.3.3:
|
|
||||||
version "4.3.3"
|
|
||||||
resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664"
|
|
||||||
integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==
|
|
||||||
dependencies:
|
|
||||||
ms "2.1.2"
|
|
||||||
|
|
||||||
debug@^3.1.0, debug@^3.1.1, debug@^3.2.6:
|
debug@^3.1.0, debug@^3.1.1, debug@^3.2.6:
|
||||||
version "3.2.7"
|
version "3.2.7"
|
||||||
resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a"
|
resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a"
|
||||||
@ -5599,6 +5546,13 @@ debug@^4.0.1, debug@^4.1.1:
|
|||||||
dependencies:
|
dependencies:
|
||||||
ms "2.1.2"
|
ms "2.1.2"
|
||||||
|
|
||||||
|
debug@^4.1.0, debug@^4.3.1, debug@^4.3.2, debug@^4.3.3:
|
||||||
|
version "4.3.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664"
|
||||||
|
integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==
|
||||||
|
dependencies:
|
||||||
|
ms "2.1.2"
|
||||||
|
|
||||||
decamelize-keys@^1.1.0:
|
decamelize-keys@^1.1.0:
|
||||||
version "1.1.0"
|
version "1.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/decamelize-keys/-/decamelize-keys-1.1.0.tgz#d171a87933252807eb3cb61dc1c1445d078df2d9"
|
resolved "https://registry.yarnpkg.com/decamelize-keys/-/decamelize-keys-1.1.0.tgz#d171a87933252807eb3cb61dc1c1445d078df2d9"
|
||||||
@ -7162,15 +7116,6 @@ forever-agent@~0.6.1:
|
|||||||
resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91"
|
resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91"
|
||||||
integrity sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=
|
integrity sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=
|
||||||
|
|
||||||
form-data@^3.0.0:
|
|
||||||
version "3.0.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/form-data/-/form-data-3.0.1.tgz#ebd53791b78356a99af9a300d4282c4d5eb9755f"
|
|
||||||
integrity sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==
|
|
||||||
dependencies:
|
|
||||||
asynckit "^0.4.0"
|
|
||||||
combined-stream "^1.0.8"
|
|
||||||
mime-types "^2.1.12"
|
|
||||||
|
|
||||||
form-data@~2.3.2:
|
form-data@~2.3.2:
|
||||||
version "2.3.3"
|
version "2.3.3"
|
||||||
resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6"
|
resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6"
|
||||||
@ -7864,15 +7809,6 @@ http-parser-js@>=0.5.1:
|
|||||||
resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.3.tgz#01d2709c79d41698bb01d4decc5e9da4e4a033d9"
|
resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.3.tgz#01d2709c79d41698bb01d4decc5e9da4e4a033d9"
|
||||||
integrity sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==
|
integrity sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==
|
||||||
|
|
||||||
http-proxy-agent@^4.0.1:
|
|
||||||
version "4.0.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz#8a8c8ef7f5932ccf953c296ca8291b95aa74aa3a"
|
|
||||||
integrity sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==
|
|
||||||
dependencies:
|
|
||||||
"@tootallnate/once" "1"
|
|
||||||
agent-base "6"
|
|
||||||
debug "4"
|
|
||||||
|
|
||||||
http-proxy-middleware@0.19.1:
|
http-proxy-middleware@0.19.1:
|
||||||
version "0.19.1"
|
version "0.19.1"
|
||||||
resolved "https://registry.yarnpkg.com/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz#183c7dc4aa1479150306498c210cdaf96080a43a"
|
resolved "https://registry.yarnpkg.com/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz#183c7dc4aa1479150306498c210cdaf96080a43a"
|
||||||
@ -7906,14 +7842,6 @@ https-browserify@^1.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73"
|
resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73"
|
||||||
integrity sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=
|
integrity sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=
|
||||||
|
|
||||||
https-proxy-agent@^5.0.0:
|
|
||||||
version "5.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz#e2a90542abb68a762e0a0850f6c9edadfd8506b2"
|
|
||||||
integrity sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==
|
|
||||||
dependencies:
|
|
||||||
agent-base "6"
|
|
||||||
debug "4"
|
|
||||||
|
|
||||||
human-signals@^1.1.1:
|
human-signals@^1.1.1:
|
||||||
version "1.1.1"
|
version "1.1.1"
|
||||||
resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-1.1.1.tgz#c5b1cd14f50aeae09ab6c59fe63ba3395fe4dfa3"
|
resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-1.1.1.tgz#c5b1cd14f50aeae09ab6c59fe63ba3395fe4dfa3"
|
||||||
@ -8430,11 +8358,6 @@ is-potential-custom-element-name@^1.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.0.tgz#0c52e54bcca391bb2c494b21e8626d7336c6e397"
|
resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.0.tgz#0c52e54bcca391bb2c494b21e8626d7336c6e397"
|
||||||
integrity sha1-DFLlS8yjkbssSUsh6GJtczbG45c=
|
integrity sha1-DFLlS8yjkbssSUsh6GJtczbG45c=
|
||||||
|
|
||||||
is-potential-custom-element-name@^1.0.1:
|
|
||||||
version "1.0.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5"
|
|
||||||
integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==
|
|
||||||
|
|
||||||
is-regex@^1.0.4, is-regex@^1.1.1, is-regex@^1.1.2:
|
is-regex@^1.0.4, is-regex@^1.1.1, is-regex@^1.1.2:
|
||||||
version "1.1.2"
|
version "1.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.2.tgz#81c8ebde4db142f2cf1c53fc86d6a45788266251"
|
resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.2.tgz#81c8ebde4db142f2cf1c53fc86d6a45788266251"
|
||||||
@ -8849,16 +8772,6 @@ jest-environment-jsdom-fifteen@^1.0.2:
|
|||||||
jest-util "^24.0.0"
|
jest-util "^24.0.0"
|
||||||
jsdom "^15.2.1"
|
jsdom "^15.2.1"
|
||||||
|
|
||||||
jest-environment-jsdom-sixteen@^2.0.0:
|
|
||||||
version "2.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-environment-jsdom-sixteen/-/jest-environment-jsdom-sixteen-2.0.0.tgz#0f8c12663ccd9836d248574decffc575bfb091e1"
|
|
||||||
integrity sha512-BF+8P67aEJcd78TQzwSb9P4a73cArOWb5KgqI8eU6cHRWDIJdDRE8XTeZAmOuDSDhKpuEXjKkXwWB3GOJvqHJQ==
|
|
||||||
dependencies:
|
|
||||||
"@jest/fake-timers" "^25.1.0"
|
|
||||||
jest-mock "^25.1.0"
|
|
||||||
jest-util "^25.1.0"
|
|
||||||
jsdom "^16.2.1"
|
|
||||||
|
|
||||||
jest-environment-jsdom@^24.9.0:
|
jest-environment-jsdom@^24.9.0:
|
||||||
version "24.9.0"
|
version "24.9.0"
|
||||||
resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-24.9.0.tgz#4b0806c7fc94f95edb369a69cc2778eec2b7375b"
|
resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-24.9.0.tgz#4b0806c7fc94f95edb369a69cc2778eec2b7375b"
|
||||||
@ -9073,20 +8986,6 @@ jest-message-util@^24.9.0:
|
|||||||
slash "^2.0.0"
|
slash "^2.0.0"
|
||||||
stack-utils "^1.0.1"
|
stack-utils "^1.0.1"
|
||||||
|
|
||||||
jest-message-util@^25.5.0:
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-25.5.0.tgz#ea11d93204cc7ae97456e1d8716251185b8880ea"
|
|
||||||
integrity sha512-ezddz3YCT/LT0SKAmylVyWWIGYoKHOFOFXx3/nA4m794lfVUskMcwhip6vTgdVrOtYdjeQeis2ypzes9mZb4EA==
|
|
||||||
dependencies:
|
|
||||||
"@babel/code-frame" "^7.0.0"
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
"@types/stack-utils" "^1.0.1"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
graceful-fs "^4.2.4"
|
|
||||||
micromatch "^4.0.2"
|
|
||||||
slash "^3.0.0"
|
|
||||||
stack-utils "^1.0.1"
|
|
||||||
|
|
||||||
jest-message-util@^26.6.2:
|
jest-message-util@^26.6.2:
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.6.2.tgz#58173744ad6fc0506b5d21150b9be56ef001ca07"
|
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.6.2.tgz#58173744ad6fc0506b5d21150b9be56ef001ca07"
|
||||||
@ -9109,13 +9008,6 @@ jest-mock@^24.0.0, jest-mock@^24.9.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^24.9.0"
|
"@jest/types" "^24.9.0"
|
||||||
|
|
||||||
jest-mock@^25.1.0, jest-mock@^25.5.0:
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-25.5.0.tgz#a91a54dabd14e37ecd61665d6b6e06360a55387a"
|
|
||||||
integrity sha512-eXWuTV8mKzp/ovHc5+3USJMYsTBhyQ+5A1Mak35dey/RG8GlM4YWVylZuGgVXinaW6tpvk/RSecmF37FKUlpXA==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
|
|
||||||
jest-mock@^26.6.2:
|
jest-mock@^26.6.2:
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.6.2.tgz#d6cb712b041ed47fe0d9b6fc3474bc6543feb302"
|
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.6.2.tgz#d6cb712b041ed47fe0d9b6fc3474bc6543feb302"
|
||||||
@ -9392,17 +9284,6 @@ jest-util@^24.0.0, jest-util@^24.9.0:
|
|||||||
slash "^2.0.0"
|
slash "^2.0.0"
|
||||||
source-map "^0.6.0"
|
source-map "^0.6.0"
|
||||||
|
|
||||||
jest-util@^25.1.0, jest-util@^25.5.0:
|
|
||||||
version "25.5.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-25.5.0.tgz#31c63b5d6e901274d264a4fec849230aa3fa35b0"
|
|
||||||
integrity sha512-KVlX+WWg1zUTB9ktvhsg2PXZVdkI1NBevOJSkTKYAyXyH4QSvh+Lay/e/v+bmaFfrkfx43xD8QTfgobzlEXdIA==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^25.5.0"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
graceful-fs "^4.2.4"
|
|
||||||
is-ci "^2.0.0"
|
|
||||||
make-dir "^3.0.0"
|
|
||||||
|
|
||||||
jest-util@^26.6.2:
|
jest-util@^26.6.2:
|
||||||
version "26.6.2"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.6.2.tgz#907535dbe4d5a6cb4c47ac9b926f6af29576cbc1"
|
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.6.2.tgz#907535dbe4d5a6cb4c47ac9b926f6af29576cbc1"
|
||||||
@ -9655,39 +9536,6 @@ jsdom@^15.2.1:
|
|||||||
ws "^7.0.0"
|
ws "^7.0.0"
|
||||||
xml-name-validator "^3.0.0"
|
xml-name-validator "^3.0.0"
|
||||||
|
|
||||||
jsdom@^16.2.1:
|
|
||||||
version "16.7.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.7.0.tgz#918ae71965424b197c819f8183a754e18977b710"
|
|
||||||
integrity sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==
|
|
||||||
dependencies:
|
|
||||||
abab "^2.0.5"
|
|
||||||
acorn "^8.2.4"
|
|
||||||
acorn-globals "^6.0.0"
|
|
||||||
cssom "^0.4.4"
|
|
||||||
cssstyle "^2.3.0"
|
|
||||||
data-urls "^2.0.0"
|
|
||||||
decimal.js "^10.2.1"
|
|
||||||
domexception "^2.0.1"
|
|
||||||
escodegen "^2.0.0"
|
|
||||||
form-data "^3.0.0"
|
|
||||||
html-encoding-sniffer "^2.0.1"
|
|
||||||
http-proxy-agent "^4.0.1"
|
|
||||||
https-proxy-agent "^5.0.0"
|
|
||||||
is-potential-custom-element-name "^1.0.1"
|
|
||||||
nwsapi "^2.2.0"
|
|
||||||
parse5 "6.0.1"
|
|
||||||
saxes "^5.0.1"
|
|
||||||
symbol-tree "^3.2.4"
|
|
||||||
tough-cookie "^4.0.0"
|
|
||||||
w3c-hr-time "^1.0.2"
|
|
||||||
w3c-xmlserializer "^2.0.0"
|
|
||||||
webidl-conversions "^6.1.0"
|
|
||||||
whatwg-encoding "^1.0.5"
|
|
||||||
whatwg-mimetype "^2.3.0"
|
|
||||||
whatwg-url "^8.5.0"
|
|
||||||
ws "^7.4.6"
|
|
||||||
xml-name-validator "^3.0.0"
|
|
||||||
|
|
||||||
jsdom@^16.4.0:
|
jsdom@^16.4.0:
|
||||||
version "16.5.1"
|
version "16.5.1"
|
||||||
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.5.1.tgz#4ced6bbd7b77d67fb980e64d9e3e6fb900f97dd6"
|
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.5.1.tgz#4ced6bbd7b77d67fb980e64d9e3e6fb900f97dd6"
|
||||||
@ -10050,7 +9898,7 @@ lodash.uniq@^4.5.0:
|
|||||||
resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773"
|
resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773"
|
||||||
integrity sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=
|
integrity sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=
|
||||||
|
|
||||||
lodash@^4.17.11, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.17.3, lodash@^4.17.4, lodash@^4.2.0, lodash@^4.3.0, lodash@^4.7.0:
|
lodash@^4.17.11, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.17.3, lodash@^4.17.4, lodash@^4.2.0, lodash@^4.3.0:
|
||||||
version "4.17.21"
|
version "4.17.21"
|
||||||
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c"
|
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c"
|
||||||
integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==
|
integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==
|
||||||
@ -10067,13 +9915,6 @@ loglevel@^1.6.8:
|
|||||||
resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.7.1.tgz#005fde2f5e6e47068f935ff28573e125ef72f197"
|
resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.7.1.tgz#005fde2f5e6e47068f935ff28573e125ef72f197"
|
||||||
integrity sha512-Hesni4s5UkWkwCGJMQGAh71PaLUmKFM60dHvq0zi/vDhhrzuk+4GgNbTXJ12YYQJn6ZKBDNIjYcuQGKudvqrIw==
|
integrity sha512-Hesni4s5UkWkwCGJMQGAh71PaLUmKFM60dHvq0zi/vDhhrzuk+4GgNbTXJ12YYQJn6ZKBDNIjYcuQGKudvqrIw==
|
||||||
|
|
||||||
lolex@^5.0.0:
|
|
||||||
version "5.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/lolex/-/lolex-5.1.2.tgz#953694d098ce7c07bc5ed6d0e42bc6c0c6d5a367"
|
|
||||||
integrity sha512-h4hmjAvHTmd+25JSwrtTIuwbKdwg5NzZVRMLn9saij4SZaepCrTCxPr35H/3bjwfMJtN+t3CX8672UIkglz28A==
|
|
||||||
dependencies:
|
|
||||||
"@sinonjs/commons" "^1.7.0"
|
|
||||||
|
|
||||||
loose-envify@^1.0.0, loose-envify@^1.2.0:
|
loose-envify@^1.0.0, loose-envify@^1.2.0:
|
||||||
version "1.4.0"
|
version "1.4.0"
|
||||||
resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf"
|
resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf"
|
||||||
@ -13848,13 +13689,6 @@ tr46@^2.0.2:
|
|||||||
dependencies:
|
dependencies:
|
||||||
punycode "^2.1.1"
|
punycode "^2.1.1"
|
||||||
|
|
||||||
tr46@^2.1.0:
|
|
||||||
version "2.1.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/tr46/-/tr46-2.1.0.tgz#fa87aa81ca5d5941da8cbf1f9b749dc969a4e240"
|
|
||||||
integrity sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==
|
|
||||||
dependencies:
|
|
||||||
punycode "^2.1.1"
|
|
||||||
|
|
||||||
tr46@~0.0.3:
|
tr46@~0.0.3:
|
||||||
version "0.0.3"
|
version "0.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a"
|
resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a"
|
||||||
@ -14792,15 +14626,6 @@ whatwg-url@^8.0.0:
|
|||||||
tr46 "^2.0.2"
|
tr46 "^2.0.2"
|
||||||
webidl-conversions "^6.1.0"
|
webidl-conversions "^6.1.0"
|
||||||
|
|
||||||
whatwg-url@^8.5.0:
|
|
||||||
version "8.7.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.7.0.tgz#656a78e510ff8f3937bc0bcbe9f5c0ac35941b77"
|
|
||||||
integrity sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==
|
|
||||||
dependencies:
|
|
||||||
lodash "^4.7.0"
|
|
||||||
tr46 "^2.1.0"
|
|
||||||
webidl-conversions "^6.1.0"
|
|
||||||
|
|
||||||
which-boxed-primitive@^1.0.1, which-boxed-primitive@^1.0.2:
|
which-boxed-primitive@^1.0.1, which-boxed-primitive@^1.0.2:
|
||||||
version "1.0.2"
|
version "1.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6"
|
resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6"
|
||||||
@ -14923,7 +14748,7 @@ ws@^6.0.0, ws@^6.2.1:
|
|||||||
dependencies:
|
dependencies:
|
||||||
async-limiter "~1.0.0"
|
async-limiter "~1.0.0"
|
||||||
|
|
||||||
ws@^7.0.0, ws@^7.4.6:
|
ws@^7.0.0:
|
||||||
version "7.5.6"
|
version "7.5.6"
|
||||||
resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.6.tgz#e59fc509fb15ddfb65487ee9765c5a51dec5fe7b"
|
resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.6.tgz#e59fc509fb15ddfb65487ee9765c5a51dec5fe7b"
|
||||||
integrity sha512-6GLgCqo2cy2A2rjCNFlxQS6ZljG/coZfZXclldI8FB/1G3CCI36Zd8xy2HrFVACi8tfk5XrgLQEk+P0Tnz9UcA==
|
integrity sha512-6GLgCqo2cy2A2rjCNFlxQS6ZljG/coZfZXclldI8FB/1G3CCI36Zd8xy2HrFVACi8tfk5XrgLQEk+P0Tnz9UcA==
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user