* Added playwright and started writing e2e tests. * To make things easy, disabled other browsers while I get confortable. Added a login flow (assumes my dev env) * More tests on login page * Lots more testing code, trying to figure out auth code. * Ensure we don't track DBs inside config * Added a new date property for when chapters are added to a series which helps with OnDeck calculations. Changed a lot of heavy api calls to use IEnumerable to stream repsonse to UI. * Fixed OnDeck with a new field for when last chapter was added on Series. This is a streamlined way to query. Updated Reading List with NormalizedTitle, CoverImage, CoverImageLocked. * Implemented the ability to read a random item in the reading list and for the reading list to be intact for order. * Tweaked the style for webtoon to not span the whole width, but use max width * When we update a cover image just send an event so we don't need to have logic for when updates occur * Fixed a bad name for entity type on cover updates * Aligned the edit collection tag modal to align with new tab design * Rewrote code for picking the first file for metadata to ensure it always picks the correct file, esp if the first chapter of a series starts with a float (1.1) * Refactored setting LastChapterAdded to ensure we do it on the Series. * Updated Chapter updating in scan loop to avoid nested for loop and an additional loop. * Fixed a bug where locked person fields wouldn't persist between scans. * Updated Contributing to reflect how to view the swagger api
81 lines
2.2 KiB
JSON
81 lines
2.2 KiB
JSON
{
|
|
"name": "kavita-webui",
|
|
"version": "0.4.2",
|
|
"scripts": {
|
|
"ng": "ng",
|
|
"start": "ng serve",
|
|
"build": "ng build",
|
|
"prod": "ng build --configuration production",
|
|
"explore": "ng build --stats-json && webpack-bundle-analyzer dist/stats.json",
|
|
"test": "jest",
|
|
"test:watch": "jest --watch",
|
|
"test:coverage": "jest --coverage",
|
|
"lint": "ng lint",
|
|
"e2e": "ng e2e"
|
|
},
|
|
"private": true,
|
|
"dependencies": {
|
|
"@angular-slider/ngx-slider": "^2.0.3",
|
|
"@angular/animations": "~13.2.2",
|
|
"@angular/cdk": "^13.2.2",
|
|
"@angular/common": "~13.2.2",
|
|
"@angular/compiler": "~13.2.2",
|
|
"@angular/core": "~13.2.2",
|
|
"@angular/forms": "~13.2.2",
|
|
"@angular/localize": "~13.2.2",
|
|
"@angular/platform-browser": "~13.2.2",
|
|
"@angular/platform-browser-dynamic": "~13.2.2",
|
|
"@angular/router": "~13.2.2",
|
|
"@fortawesome/fontawesome-free": "^6.0.0",
|
|
"@microsoft/signalr": "^6.0.2",
|
|
"@ng-bootstrap/ng-bootstrap": "^12.0.0",
|
|
"@popperjs/core": "^2.11.2",
|
|
"@types/file-saver": "^2.0.5",
|
|
"bootstrap": "^5.1.2",
|
|
"bowser": "^2.11.0",
|
|
"file-saver": "^2.0.5",
|
|
"lazysizes": "^5.3.2",
|
|
"ng-circle-progress": "^1.6.0",
|
|
"ngx-color-picker": "^12.0.0",
|
|
"ngx-file-drop": "^13.0.0",
|
|
"ngx-toastr": "^14.2.1",
|
|
"rxjs": "~7.5.4",
|
|
"swiper": "^8.0.6",
|
|
"tslib": "^2.3.1",
|
|
"webpack-bundle-analyzer": "^4.5.0",
|
|
"zone.js": "~0.11.4"
|
|
},
|
|
"devDependencies": {
|
|
"@angular-devkit/build-angular": "~13.2.3",
|
|
"@angular/cli": "^13.2.3",
|
|
"@angular/compiler-cli": "~13.2.2",
|
|
"@playwright/test": "^1.20.2",
|
|
"@types/jest": "^27.4.0",
|
|
"@types/node": "^17.0.17",
|
|
"codelyzer": "^6.0.2",
|
|
"jest": "^27.5.1",
|
|
"jest-preset-angular": "^11.1.0",
|
|
"karma-coverage": "~2.2.0",
|
|
"playwright": "^1.20.2",
|
|
"protractor": "~7.0.0",
|
|
"ts-node": "~10.5.0",
|
|
"tslint": "^6.1.3",
|
|
"typescript": "~4.5.5"
|
|
},
|
|
"jest": {
|
|
"preset": "jest-preset-angular",
|
|
"setupFilesAfterEnv": [
|
|
"<rootDir>/setupJest.ts"
|
|
],
|
|
"testPathIgnorePatterns": [
|
|
"<rootDir>/node_modules/",
|
|
"<rootDir>/dist/"
|
|
],
|
|
"globals": {
|
|
"ts-jest": {
|
|
"tsConfig": "<rootDir>/tsconfig.spec.json",
|
|
"stringifyContentPathRegex": "\\.html$"
|
|
}
|
|
}
|
|
}
|
|
}
|