mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-07-09 03:04:19 -04:00
Misc Stuff (#2917)
Co-authored-by: Robbie Davis <robbie@therobbiedavis.com> Co-authored-by: Fesaa <77553571+Fesaa@users.noreply.github.com>
This commit is contained in:
parent
3c9565468a
commit
315a6cca7e
175
.github/workflows/release-workflow.yml
vendored
175
.github/workflows/release-workflow.yml
vendored
@ -1,175 +0,0 @@
|
|||||||
name: Stable Workflow
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: ['release/**']
|
|
||||||
pull_request:
|
|
||||||
branches: [ 'develop' ]
|
|
||||||
types: [ closed ]
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
debug:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Debug Info
|
|
||||||
run: |
|
|
||||||
echo "Event Name: ${{ github.event_name }}"
|
|
||||||
echo "Ref: ${{ github.ref }}"
|
|
||||||
echo "Not Contains Release: ${{ !contains(github.head_ref, 'release') }}"
|
|
||||||
echo "Matches Develop: ${{ github.ref == 'refs/heads/develop' }}"
|
|
||||||
if_merged:
|
|
||||||
if: github.event.pull_request.merged == true && contains(github.head_ref, 'release')
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- run: |
|
|
||||||
echo The PR was merged
|
|
||||||
build:
|
|
||||||
name: Upload Kavita.Common for Version Bump
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: github.event.pull_request.merged == true && contains(github.head_ref, 'release')
|
|
||||||
steps:
|
|
||||||
- name: Checkout Repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
|
|
||||||
- uses: actions/upload-artifact@v4
|
|
||||||
with:
|
|
||||||
name: csproj
|
|
||||||
path: Kavita.Common/Kavita.Common.csproj
|
|
||||||
|
|
||||||
stable:
|
|
||||||
name: Build Stable and Nightly Docker if Release
|
|
||||||
needs: [ build ]
|
|
||||||
if: github.event.pull_request.merged == true && contains(github.head_ref, 'release')
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
permissions:
|
|
||||||
packages: write
|
|
||||||
contents: read
|
|
||||||
steps:
|
|
||||||
- name: Find Current Pull Request
|
|
||||||
uses: jwalton/gh-find-current-pr@v1
|
|
||||||
id: findPr
|
|
||||||
with:
|
|
||||||
state: all
|
|
||||||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Parse PR body
|
|
||||||
id: parse-body
|
|
||||||
run: |
|
|
||||||
body="Read full changelog: https://github.com/Kareadita/Kavita/releases/latest"
|
|
||||||
|
|
||||||
echo $body
|
|
||||||
echo "BODY=$body" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
- name: Check Out Repo
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
ref: develop
|
|
||||||
|
|
||||||
- name: NodeJS to Compile WebUI
|
|
||||||
uses: actions/setup-node@v4
|
|
||||||
with:
|
|
||||||
node-version: 20
|
|
||||||
- run: |
|
|
||||||
|
|
||||||
cd UI/Web || exit
|
|
||||||
echo 'Installing web dependencies'
|
|
||||||
npm ci
|
|
||||||
|
|
||||||
echo 'Building UI'
|
|
||||||
npm run prod
|
|
||||||
|
|
||||||
echo 'Copying back to Kavita wwwroot'
|
|
||||||
rsync -a dist/ ../../API/wwwroot/
|
|
||||||
|
|
||||||
cd ../ || exit
|
|
||||||
|
|
||||||
- name: Get csproj Version
|
|
||||||
uses: kzrnm/get-net-sdk-project-versions-action@v2
|
|
||||||
id: get-version
|
|
||||||
with:
|
|
||||||
proj-path: Kavita.Common/Kavita.Common.csproj
|
|
||||||
|
|
||||||
- name: Echo csproj version
|
|
||||||
run: echo "${{steps.get-version.outputs.assembly-version}}"
|
|
||||||
|
|
||||||
- name: Parse Version
|
|
||||||
run: |
|
|
||||||
version='${{steps.get-version.outputs.assembly-version}}'
|
|
||||||
newVersion=${version%.*}
|
|
||||||
echo $newVersion
|
|
||||||
echo "VERSION=$newVersion" >> $GITHUB_OUTPUT
|
|
||||||
id: parse-version
|
|
||||||
|
|
||||||
- name: Compile dotnet app
|
|
||||||
uses: actions/setup-dotnet@v4
|
|
||||||
with:
|
|
||||||
dotnet-version: 8.0.x
|
|
||||||
- name: Install Swashbuckle CLI
|
|
||||||
run: dotnet tool install -g --version 6.5.0 Swashbuckle.AspNetCore.Cli
|
|
||||||
|
|
||||||
- run: ./monorepo-build.sh
|
|
||||||
|
|
||||||
- name: Login to Docker Hub
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKER_HUB_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }}
|
|
||||||
|
|
||||||
- name: Login to GitHub Container Registry
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.actor }}
|
|
||||||
password: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v3
|
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
id: buildx
|
|
||||||
uses: docker/setup-buildx-action@v3
|
|
||||||
|
|
||||||
- name: Build and push stable
|
|
||||||
id: docker_build_stable
|
|
||||||
uses: docker/build-push-action@v5
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
|
||||||
push: true
|
|
||||||
tags: jvmilazz0/kavita:latest, jvmilazz0/kavita:${{ steps.parse-version.outputs.VERSION }}, ghcr.io/kareadita/kavita:latest, ghcr.io/kareadita/kavita:${{ steps.parse-version.outputs.VERSION }}
|
|
||||||
|
|
||||||
- name: Build and push nightly
|
|
||||||
id: docker_build_nightly
|
|
||||||
uses: docker/build-push-action@v5
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
|
||||||
push: true
|
|
||||||
tags: jvmilazz0/kavita:nightly, jvmilazz0/kavita:nightly-${{ steps.parse-version.outputs.VERSION }}, ghcr.io/kareadita/kavita:nightly, ghcr.io/kareadita/kavita:nightly-${{ steps.parse-version.outputs.VERSION }}
|
|
||||||
|
|
||||||
- name: Image digest
|
|
||||||
run: echo ${{ steps.docker_build_stable.outputs.digest }}
|
|
||||||
|
|
||||||
- name: Image digest
|
|
||||||
run: echo ${{ steps.docker_build_nightly.outputs.digest }}
|
|
||||||
|
|
||||||
- name: Notify Discord
|
|
||||||
uses: rjstone/discord-webhook-notify@v1
|
|
||||||
with:
|
|
||||||
severity: info
|
|
||||||
description: v${{steps.get-version.outputs.assembly-version}} - ${{ steps.findPr.outputs.title }}
|
|
||||||
details: '${{ steps.findPr.outputs.body }}'
|
|
||||||
text: <@&939225192553644133> A new stable build has been released.
|
|
||||||
webhookUrl: ${{ secrets.DISCORD_DOCKER_UPDATE_URL }}
|
|
||||||
|
|
||||||
- name: Notify Discord
|
|
||||||
uses: rjstone/discord-webhook-notify@v1
|
|
||||||
with:
|
|
||||||
severity: info
|
|
||||||
description: v${{steps.get-version.outputs.assembly-version}} - ${{ steps.findPr.outputs.title }}
|
|
||||||
details: '${{ steps.findPr.outputs.body }}'
|
|
||||||
text: <@&939225459156217917> <@&939225350775406643> A new nightly build has been released for docker.
|
|
||||||
webhookUrl: ${{ secrets.DISCORD_DOCKER_UPDATE_URL }}
|
|
@ -33,5 +33,9 @@ public enum SortField
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Kavita+ Only - External Average Rating
|
/// Kavita+ Only - External Average Rating
|
||||||
/// </summary>
|
/// </summary>
|
||||||
AverageRating = 8
|
AverageRating = 8,
|
||||||
|
/// <summary>
|
||||||
|
/// Randomise the order
|
||||||
|
/// </summary>
|
||||||
|
Random = 9
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using API.DTOs.Filtering;
|
using API.DTOs.Filtering;
|
||||||
using API.Entities;
|
using API.Entities;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
|
||||||
namespace API.Extensions.QueryExtensions.Filtering;
|
namespace API.Extensions.QueryExtensions.Filtering;
|
||||||
#nullable enable
|
#nullable enable
|
||||||
@ -39,6 +40,7 @@ public static class BookmarkSort
|
|||||||
SortField.ReadProgress => query.DoOrderBy(s => s.Series.Progress.Where(p => p.SeriesId == s.Series.Id).Select(p => p.LastModified).Max(), sortOptions),
|
SortField.ReadProgress => query.DoOrderBy(s => s.Series.Progress.Where(p => p.SeriesId == s.Series.Id).Select(p => p.LastModified).Max(), sortOptions),
|
||||||
SortField.AverageRating => query.DoOrderBy(s => s.Series.ExternalSeriesMetadata.ExternalRatings
|
SortField.AverageRating => query.DoOrderBy(s => s.Series.ExternalSeriesMetadata.ExternalRatings
|
||||||
.Where(p => p.SeriesId == s.Series.Id).Average(p => p.AverageScore), sortOptions),
|
.Where(p => p.SeriesId == s.Series.Id).Average(p => p.AverageScore), sortOptions),
|
||||||
|
SortField.Random => query.DoOrderBy(s => EF.Functions.Random(), sortOptions),
|
||||||
_ => query
|
_ => query
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using API.DTOs.Filtering;
|
using API.DTOs.Filtering;
|
||||||
using API.Entities;
|
using API.Entities;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
|
||||||
namespace API.Extensions.QueryExtensions.Filtering;
|
namespace API.Extensions.QueryExtensions.Filtering;
|
||||||
#nullable enable
|
#nullable enable
|
||||||
@ -35,6 +36,7 @@ public static class SeriesSort
|
|||||||
.Max(), sortOptions),
|
.Max(), sortOptions),
|
||||||
SortField.AverageRating => query.DoOrderBy(s => s.ExternalSeriesMetadata.ExternalRatings
|
SortField.AverageRating => query.DoOrderBy(s => s.ExternalSeriesMetadata.ExternalRatings
|
||||||
.Where(p => p.SeriesId == s.Id).Average(p => p.AverageScore), sortOptions),
|
.Where(p => p.SeriesId == s.Id).Average(p => p.AverageScore), sortOptions),
|
||||||
|
SortField.Random => query.DoOrderBy(s => EF.Functions.Random(), sortOptions),
|
||||||
_ => query
|
_ => query
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -24,7 +24,8 @@ export enum SortField {
|
|||||||
/**
|
/**
|
||||||
* Kavita+ only
|
* Kavita+ only
|
||||||
*/
|
*/
|
||||||
AverageRating = 8
|
AverageRating = 8,
|
||||||
|
Random = 9
|
||||||
}
|
}
|
||||||
|
|
||||||
export const allSortFields = Object.keys(SortField)
|
export const allSortFields = Object.keys(SortField)
|
||||||
|
@ -29,6 +29,8 @@ export class SortFieldPipe implements PipeTransform {
|
|||||||
return this.translocoService.translate('sort-field-pipe.read-progress');
|
return this.translocoService.translate('sort-field-pipe.read-progress');
|
||||||
case SortField.AverageRating:
|
case SortField.AverageRating:
|
||||||
return this.translocoService.translate('sort-field-pipe.average-rating');
|
return this.translocoService.translate('sort-field-pipe.average-rating');
|
||||||
|
case SortField.Random:
|
||||||
|
return this.translocoService.translate('sort-field-pipe.random');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
.content-wrapper {
|
.content-wrapper {
|
||||||
padding: 0 5px 0;
|
padding: 0 5px 0;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
height: calc(100vh - 56px);
|
height: calc(var(--vh)*100 - 56px);
|
||||||
|
|
||||||
&.closed {
|
&.closed {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
|
@ -99,7 +99,7 @@ form {
|
|||||||
|
|
||||||
.dropdown {
|
.dropdown {
|
||||||
width: 100vw;
|
width: 100vw;
|
||||||
height: calc(100vh - 56px); //header offset
|
height: calc(var(--vh)*100 - 56px); //header offset
|
||||||
background: var(--dropdown-overlay-color);
|
background: var(--dropdown-overlay-color);
|
||||||
position: fixed;
|
position: fixed;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
|
@ -1745,7 +1745,8 @@
|
|||||||
"time-to-read": "Time to Read",
|
"time-to-read": "Time to Read",
|
||||||
"release-year": "Release Year",
|
"release-year": "Release Year",
|
||||||
"read-progress": "Last Read",
|
"read-progress": "Last Read",
|
||||||
"average-rating": "Average Rating"
|
"average-rating": "Average Rating",
|
||||||
|
"random": "Random"
|
||||||
},
|
},
|
||||||
|
|
||||||
"edit-series-modal": {
|
"edit-series-modal": {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user