Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ability to click on the affected URLs of a pattern and see which URLs have been affected #1038

Open
wants to merge 26 commits into
base: dev
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
933852b
Add 'Show Affected URLs' button and configure click handler
Kirandawadi Sep 17, 2024
b9d2385
Add necessary files for 'Affected URLs' page
Kirandawadi Sep 17, 2024
e89eaa1
Add DataTables features to the page
Kirandawadi Sep 19, 2024
194929a
Affected URLs page for excluded patterns working properly
Kirandawadi Sep 23, 2024
b15410e
add view affected urls button to title patterns and document-type pat…
Kirandawadi Sep 25, 2024
7a279fc
finalise the affected urls page for all the pattern types
Kirandawadi Sep 25, 2024
e736d2c
Refactor AffectedURLsListView into pattern-specific views
Kirandawadi Sep 26, 2024
242d414
remove unnecessary comments and format code
Kirandawadi Sep 26, 2024
32ed7f8
add integrity check to contents loaded from CDN
Kirandawadi Sep 26, 2024
74e074a
remove unnecessary css declarations
Kirandawadi Sep 26, 2024
dad63b0
remove ordering functionality from second row of the datatable
Kirandawadi Sep 27, 2024
11959fc
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Sep 27, 2024
e68b50e
fix issues shown by flake8
Kirandawadi Sep 27, 2024
c545b8c
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Sep 27, 2024
4205c1d
added include-pattern functionality; fixed candidate-urls-api (inclus…
Kirandawadi Sep 28, 2024
42cdda0
remove 'add pattern' button from unnecessary pages
Kirandawadi Oct 10, 2024
6b21213
add serializer class to affected urls functionalities
Kirandawadi Oct 11, 2024
9d666b2
add datatables reload() feature to skip unnecessary ui modifications
Kirandawadi Oct 11, 2024
6ec4943
fix ajax issues of datatable
Kirandawadi Oct 12, 2024
37bdb7c
add 'include pattern' feature on right mouse click
Kirandawadi Oct 19, 2024
1056ac9
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Oct 21, 2024
525e6a2
fix flake8 issues
Kirandawadi Oct 21, 2024
597252c
add checks to see if include pattern already exists
Kirandawadi Oct 21, 2024
4fd628b
fix 'exclude' column of 'Candidate URLs' page
Kirandawadi Oct 25, 2024
1179641
fix 'affected urls' count
Kirandawadi Oct 25, 2024
000153c
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Oct 25, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
added include-pattern functionality; fixed candidate-urls-api (inclus…
…ion added)
  • Loading branch information
Kirandawadi committed Sep 28, 2024
commit 4205c1d9659f1308592a1de77740d976840bcb3a
9 changes: 6 additions & 3 deletions sde_collections/models/candidate_url.py
Original file line number Diff line number Diff line change
@@ -6,21 +6,24 @@

from .collection import Collection
from .collection_choice_fields import Divisions, DocumentTypes
from .pattern import ExcludePattern, TitlePattern
from .pattern import ExcludePattern, IncludePattern, TitlePattern


class CandidateURLQuerySet(models.QuerySet):
def with_exclusion_status(self):
def with_exclusion_and_inclusion_status(self):
return self.annotate(
excluded=models.Exists(
ExcludePattern.candidate_urls.through.objects.filter(candidateurl=models.OuterRef("pk"))
),
included=models.Exists(
IncludePattern.candidate_urls.through.objects.filter(candidateurl=models.OuterRef("pk"))
)
)


class CandidateURLManager(models.Manager):
def get_queryset(self):
return CandidateURLQuerySet(self.model, using=self._db).with_exclusion_status()
return CandidateURLQuerySet(self.model, using=self._db).with_exclusion_and_inclusion_status()


class CandidateURL(models.Model):
28 changes: 26 additions & 2 deletions sde_collections/views.py
Original file line number Diff line number Diff line change
@@ -254,6 +254,30 @@ class ExcludePatternAffectedURLsListView(BaseAffectedURLsListView):
pattern_model = ExcludePattern
pattern_type = "Exclude"

def get_queryset(self):
self.pattern = self.pattern_model.objects.get(id=self.kwargs["id"])
queryset = self.pattern.matched_urls()

# Subquery to get the match_pattern and id of the IncludePattern
include_pattern_subquery = IncludePattern.objects.filter(
candidate_urls=models.OuterRef("pk")
).values('match_pattern', 'id')[:1]

# Annotate with inclusion status, match_pattern, and id of the IncludePattern
queryset = queryset.annotate(
included=models.Exists(include_pattern_subquery),
included_by_pattern=models.Subquery(
include_pattern_subquery.values('match_pattern'),
output_field=models.CharField()
),
match_pattern_id=models.Subquery(
include_pattern_subquery.values('id'),
output_field=models.IntegerField()
)
)

return queryset


class IncludePatternAffectedURLsListView(BaseAffectedURLsListView):
pattern_model = IncludePattern
@@ -362,8 +386,8 @@ def get(self, request, *args, **kwargs):
def get_queryset(self):
queryset = (
CandidateURL.objects.filter(collection__config_folder=self.config_folder)
.with_exclusion_status()
.filter(excluded=False)
.with_exclusion_and_inclusion_status()
.filter(models.Q(excluded=False) | models.Q(included=True))
)
return queryset

64 changes: 64 additions & 0 deletions sde_indexing_helper/static/css/affected_urls.css
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These are a lot of additional CSS rules on top of existing ones. Are these all required/used?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Refactored the affected_urls.css to only use required CSS declarations.

Original file line number Diff line number Diff line change
@@ -55,6 +55,20 @@
padding: 11px 15px;
}

.addPattern {
background-color: #0066CA !important;
border-color: #0066CA !important;
color: #fff !important;
}

#match_pattern_input {
background: #3F4A58;
border-radius: 4px;
}

.asterik {
color: #C3001A;
}
.customizeColumns {
margin-left: 10px !important;
}
@@ -63,6 +77,14 @@
background-image: none;
}

.form-control {
color: white;
}

.form-control:focus {
color: white;
}

.dt-container div.dt-length label {
display: none;
}
@@ -175,3 +197,45 @@ body {
color: #f5f5f5;
/* Hover effect for links */
}

/* Optional styles for the Include URL button */
.include-url-btn {
background-color: transparent;
border: none;
font-size: 2rem;
cursor: pointer;
}

.modalTitle {
font-size: 24px;
font-weight: 600;
line-height: 36px;
letter-spacing: -0.03em;
}

#hideShowColumnsModal {
position: fixed;
top: 0;
right: 0 !important;
left: unset !important;
background: #FFFFFF;
width: 30vw;
z-index: 2000;
}

.modalFooter {
position: sticky;
bottom: 0;
position: sticky;
bottom: 0;
padding: 10px 0;
background: #FFFFFF;
}

.modal-body .bmd-label-static {
top: -20px !important;
}

.modal-header {
margin-bottom: 40px;
}
Loading