-
-
Notifications
You must be signed in to change notification settings - Fork 92
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
Integrating Nuclia Widget #792
Draft
justdaksh
wants to merge
102
commits into
nuclia
Choose a base branch
from
nuclia_widget
base: nuclia
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Changes from all commits
Commits
Show all changes
102 commits
Select commit
Hold shift + click to select a range
99a154c
Integrating Nuclia Widget
justdaksh 520b294
removing redundant searchtester script
justdaksh b4533ea
Merged with main
justdaksh 26ba768
Merged with main
justdaksh e752db2
Revert "Merged with main"
justdaksh 2f72d6b
Merging with main
justdaksh 642e5e0
Resolved conflicts of widget with nuclia
justdaksh a6aca93
Updated nuclia_sync.yml
justdaksh aa591bf
Updated Environment varibles
justdaksh ae4d412
Merge branch 'nuclia_widget' of https://github.com/plone/training int…
justdaksh c20299a
Updating env varibale to upload job
justdaksh 00dda20
Functioning breadcrumbs,Debugging CI
justdaksh cdb9d41
Removed breadmaker.py && heading_to_breadcrumb_mapping.json
justdaksh 95037a4
Updated nuclia workflow
justdaksh 69e1658
Nuclia Sync: Updated docs
invalid-email-address adf5cbd
remove print statements
justdaksh 8262dda
Merge branch 'nuclia_widget' of https://github.com/plone/training int…
justdaksh 09683d9
Rerunning jobs for debugging
justdaksh dfc5dfe
Updating Commit Changes Run
justdaksh 38cd562
Nuclia Sync: Updated docs
invalid-email-address 930ebfe
Reverting to using JSON for breadcrumbs insted of metadata
justdaksh 323e5de
Merge branch 'nuclia_widget' of https://github.com/plone/training int…
justdaksh dd68adf
Nuclia Sync: Updated docs
invalid-email-address c0d8c37
Updated searchhtml
justdaksh 0572655
Merge branch 'nuclia_widget' of https://github.com/plone/training int…
justdaksh 7d30969
Nuclia Sync: Updated docs
invalid-email-address 4e53835
Using metadata,style changes
justdaksh adb5743
Updating workflow
justdaksh b5c5647
Added field parameter to upload script
justdaksh 28b2a20
Style Changes on results
justdaksh 6dc5fdc
title font-size change
justdaksh 5823c65
Merge branch 'main' into nuclia_widget
justdaksh 731c4d9
Merge branch 'refs/heads/main' into nuclia_widget
stevepiercy 1257b91
Merge remote-tracking branch 'origin/nuclia_widget' into nuclia_widget
stevepiercy 3373a37
Merge branch 'nuclia' into nuclia_widget
stevepiercy 3f214f7
refactor: volto customization for JS beginners
nileshgulia1 f044b3a
remove some chapters,fix grammer
nileshgulia1 9fb4a52
fix weather block
nileshgulia1 9adc25f
simplified installation docs
nileshgulia1 7811dfb
fix prerequisites
nileshgulia1 4d8b8aa
fix blank line
nileshgulia1 b82654d
fix code block
nileshgulia1 0a78266
initial commit
iRohitSingh e11dd6c
Merge branch 'main' into rafactor-volto-customization
claudiaifrim cca0c31
use correct command for pnpm workspaces
nileshgulia1 482f91a
amend more worspace hints
nileshgulia1 d91612d
pin matching Plone and Volto versions correctly
nileshgulia1 93bffda
Merge branch 'main' into rafactor-volto-customization
nileshgulia1 d9c8dcd
Apply suggestions from code review
nileshgulia1 6e843e8
refactor: apply leftover suggestions
nileshgulia1 a650478
replace occurances of <a> in links by md
nileshgulia1 722b66a
Merge branch 'main' into nuclia_widget
stevepiercy 0893762
Merge branch 'nuclia' into nuclia_widget
stevepiercy fb1ec8a
Merge branch 'nuclia' into nuclia_widget
stevepiercy fefecda
fix search page
ebrehault daa573a
Move search results inside the searchtext block, and wrap with a styl…
stevepiercy 85de850
Don't recreate the virtual environment, just delete it
stevepiercy dd1d1bd
Update Makefile
stevepiercy a0fad25
Merge pull request #865 from plone/make-use-sphinx-build-target
stevepiercy 1f2a61d
Merge branch 'main' into rafactor-volto-customization
nileshgulia1 a1fa751
some improvements in content
iRohitSingh 61f3100
fix all the things pointed by steve
iRohitSingh e050e90
fix: apply suggestions from @stevepiercy
nileshgulia1 19685d8
Merge pull request #860 from plone/rafactor-volto-customization
nileshgulia1 70f172b
update extending vlt training
danalvrz b566968
Merge branch 'main' into vlt-training
danalvrz 814ef3c
Merge branch 'main' into vlt-training
danalvrz b3f800c
Promote current trainings, use dash for directory
stevepiercy d895014
Fix errors with `numbered` option in `toctree` directive
stevepiercy 6c5c279
Fix errors with `numbered` option in `toctree` directive
stevepiercy 8250d6a
Populate meta information for teaching section, in hopes that the oth…
stevepiercy 89c2df3
what_vagrant_does.md is an orphan (not included in a toctree). We don…
stevepiercy 1f9dc3e
Fix broken references
stevepiercy bc7799f
Exclude files that are not included in a toctree, and are not referen…
stevepiercy 7e4f768
Clean up MyST syntax for toctree
stevepiercy d2f6442
Use proper lexer and syntax for selected lexer, wherever possible. JS…
stevepiercy 92c7c09
Document how to override build configuration options
stevepiercy bdcd5de
Merge pull request #871 from plone/tidy-up-training
stevepiercy 56f6e93
Fix RTD pull request previews
stevepiercy ee4564a
Include .github/workflows/rtd-pr-preview.yml as "docs"
stevepiercy 541386e
Merge pull request #874 from plone/fix-rtd-build-2
stevepiercy c03a2be
Fix spelling of Node.js
stevepiercy 4031b4d
Merge pull request #875 from plone/test-rtd-pr-build
stevepiercy ad51a2d
We r bad spelrz
stevepiercy f8baaa5
whoops, wrong project-slug
stevepiercy 78776f9
Merge pull request #876 from plone/rtd-pr-test-2
stevepiercy 3b1f032
It's a good thing that there are so many misspellings of Node.js to c…
stevepiercy 58755ad
Clearly I cant type
stevepiercy f4699a8
Merge pull request #877 from plone/rtd-pr-test-3
stevepiercy ff18b56
At this rate Node.js will be spelled correctly throughout the trainin…
stevepiercy 1f7bc9e
Merge pull request #878 from plone/rtd-pr-test-4
stevepiercy 9e48d47
Remove lesscpy from requirements.txt
stevepiercy 1c348e6
Merge pull request #879 from plone/update-reqs
stevepiercy fcffb53
Use no-tracking url of youtube
ksuess 68fd2cf
Merge pull request #882 from plone/privacy-youtube
stevepiercy f8e6d50
Merge branch 'main' into nuclia_widget
stevepiercy 6c11bbc
Change from secret to repo env.
stevepiercy 76aa8e3
Try another var
stevepiercy f6f0fda
This should do it, copied from build_deploy_staging.yml
stevepiercy c0e95e9
fix SDK call for deletion
ebrehault b89c046
typo
ebrehault 7346523
- Bump actions versions
stevepiercy File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
name: Nuclia Sync | ||
|
||
on: [push] | ||
jobs: | ||
sync: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- name: Check out code | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
|
||
- name: Set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: "3.10" | ||
|
||
- name: Install requirements | ||
run: | | ||
pip install -q -r requirements.txt | ||
|
||
- name: Run Nuclia Sync | ||
env: | ||
DEPLOY_NUCLIA_URL: ${{vars.DEPLOY_NUCLIA_URL}} | ||
DEPLOY_NUCLIA_TOKEN: ${{secrets.DEPLOY_NUCLIA_TOKEN}} | ||
run: | | ||
python3 upload.py | ||
|
||
- name: Check for changes in nuclia_sync.json | ||
id: check_changes | ||
run: | | ||
CHANGED_FILES=$(git diff --name-only ${{ github.event.before }} ${{ github.sha }}) | ||
echo "Changed files: $CHANGED_FILES" | ||
if echo "$CHANGED_FILES" | grep -q 'nuclia_sync.json'; then | ||
echo "::set-output name=changed::true" | ||
else | ||
echo "::set-output name=changed::false" | ||
fi | ||
|
||
- name: Commit changes | ||
if: steps.check_changes.outputs.changed == 'true' | ||
run: | | ||
git config --global user.name github-actions | ||
git config --global user.email github-actions@github.com | ||
git add . | ||
git commit -m "Nuclia Sync: Updated docs" | ||
git push | ||
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,206 @@ | ||
const { switchMap } = rxjs; | ||
const nucliaResult = document.querySelector("nuclia-search-results"); | ||
const shadowRoot = nucliaResult.shadowRoot; | ||
|
||
const nuclia = new window.NucliaSDK.Nuclia({ | ||
backend: "https://nuclia.cloud/api", | ||
zone: "europe-1", | ||
knowledgeBox: "62407006-2711-4631-9c03-761d156de289", | ||
}); | ||
justdaksh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
function createBreadcrumbs(resultTitleContainer,ContainerHash) { | ||
|
||
let ContainerHeading = resultTitleContainer.querySelector("div:nth-child(2)"); | ||
|
||
try { | ||
nuclia.db | ||
.getKnowledgeBox() | ||
.pipe( | ||
switchMap((knowledgeBox) => | ||
knowledgeBox.getResource(ContainerHash, [ | ||
"extra", | ||
]) | ||
) | ||
) | ||
.subscribe( | ||
(resource) => { | ||
insertBreadcrumbDiv(resource, ContainerHeading); | ||
}, | ||
(error) => { | ||
console.error("Error fetching resource:", error); | ||
} | ||
); | ||
} catch (error) { | ||
console.error("Error in createBreadcrumbs:", error); | ||
} | ||
} | ||
|
||
function insertBreadcrumbDiv(resource, ContainerHeading) { | ||
let array = resource.extra.metadata["breadcrumbs"]; | ||
if (!ContainerHeading.querySelector("div.breadcrumbs")) { | ||
let breadcrumbContainer = document.createElement("div"); | ||
breadcrumbContainer.className = "breadcrumbs"; | ||
for (let i = 0; i < array.length; i++) { | ||
let dict = array[i]; | ||
|
||
// Create a span element for each breadcrumb | ||
let breadcrumbSpan = document.createElement("span"); | ||
|
||
// Create a breadcrumb link or span based on whether it's the last breadcrumb | ||
if (i < array.length - 1) { | ||
let breadcrumbLink = document.createElement("a"); | ||
breadcrumbLink.href = dict.url; | ||
breadcrumbLink.textContent = dict.label; | ||
breadcrumbLink.classList.add("breadcrumb-link"); | ||
breadcrumbSpan.appendChild(breadcrumbLink); | ||
|
||
// Add a separator between breadcrumb links | ||
let separator = document.createTextNode(" > "); | ||
breadcrumbSpan.appendChild(separator); | ||
} else { | ||
// If it's the last breadcrumb, create a non-clickable span | ||
breadcrumbSpan.textContent = dict.label; | ||
breadcrumbSpan.classList.add("breadcrumb-last"); | ||
} | ||
|
||
breadcrumbContainer.appendChild(breadcrumbSpan); | ||
} | ||
ContainerHeading.insertAdjacentElement( | ||
"afterbegin", | ||
breadcrumbContainer | ||
); | ||
} | ||
} | ||
|
||
function isMatch(element) { | ||
return ( | ||
element && | ||
element.nodeName === "DIV" && | ||
element.classList && | ||
element.classList.contains("sw-result-row") && | ||
element.classList.length === 2 | ||
); | ||
} | ||
|
||
// Function to process added nodes within the shadow DOM | ||
function processAddedNodes(addedNodes) { | ||
addedNodes.forEach((addedNode) => { | ||
if (isMatch(addedNode)) { | ||
let resultTitleContainer = addedNode.querySelector('.result-title-container') | ||
let ContainerHash = addedNode.getAttribute('data-nuclia-rid'); | ||
if (ContainerHash.length == 32) { // To be removed when Null result issue get solved | ||
createBreadcrumbs(resultTitleContainer,ContainerHash); | ||
} | ||
} | ||
}); | ||
} | ||
|
||
function addBreadcrumbsToResults() { | ||
if (!nucliaResult) { | ||
console.error("Nuclia-search-result tag not found"); | ||
return; | ||
} | ||
let observer = new MutationObserver(callback); | ||
|
||
observer.observe(shadowRoot, { | ||
childList: true, | ||
subtree: true, | ||
}); | ||
} | ||
|
||
const callback = function (mutationsList, observer) { | ||
for (const mutation of mutationsList) { | ||
if (mutation.type === "childList") { | ||
processAddedNodes(mutation.addedNodes); | ||
} | ||
} | ||
}; | ||
|
||
const style = document.createElement('style'); | ||
style.textContent = ` | ||
:host { | ||
--pst-color-primary: #579aca; | ||
--color-on-hover: #0056b3; | ||
--color-of-separator: #777; | ||
--color-of-lastbreadcrumb: #CECECE; | ||
--size-of-title-m: 22px; | ||
} | ||
|
||
/* Breadcrumb container */ | ||
.breadcrumbs { | ||
margin: 10px 0; | ||
} | ||
|
||
/* Breadcrumb links */ | ||
.breadcrumbs a { | ||
font-size: var(--font-size-small); | ||
text-decoration: none; | ||
color: var(--pst-color-primary); | ||
transition: color 0.2s; | ||
} | ||
|
||
/* Style for the last breadcrumb */ | ||
.breadcrumbs span:last-child { | ||
font-size: var(--font-size-small); | ||
color: var(--color-of-lastbreadcrumb); | ||
} | ||
|
||
/* Separator between breadcrumbs */ | ||
.breadcrumbs .separator { | ||
font-size: var(--font-size-small); | ||
margin: 0 5px; | ||
color: var(--color-of-separator); | ||
} | ||
|
||
/* Hover effect for breadcrumb links */ | ||
.breadcrumbs a:hover { | ||
color: var(--color-on-hover); | ||
} | ||
|
||
/*Heading of the results*/ | ||
h3.ellipsis.title-m{ | ||
color: var(--pst-color-primary); | ||
font-size: var(--size-of-title-m); | ||
} | ||
|
||
/*Subheading of the results*/ | ||
.sw-paragraph-result { | ||
color: var(--pst-color-primary); | ||
} | ||
/*Gap between results*/ | ||
.results, .search-results { | ||
gap: var(--rhythm-7); | ||
} | ||
/*Gap between widget and answer generation*/ | ||
.sw-initial-answer { | ||
margin-top: var(--rhythm-3); | ||
} | ||
`; | ||
// Append the style element to the shadow DOM | ||
shadowRoot.appendChild(style); | ||
|
||
function handleThemeChange(mutationsList) { | ||
mutationsList.forEach((mutation) => { | ||
if (mutation.type === 'attributes' && mutation.attributeName === 'data-theme') { | ||
const newMode = htmlSelector.getAttribute('data-theme'); | ||
const nucliaSearchResults = document.querySelector('nuclia-search-results'); | ||
const nucliaSearchBar = document.querySelector('nuclia-search-bar'); | ||
const currentMode = nucliaSearchResults.getAttribute('mode'); | ||
|
||
if (newMode === 'dark' && currentMode !== 'dark') { | ||
nucliaSearchResults.setAttribute('mode', 'dark'); | ||
nucliaSearchBar.setAttribute('mode', 'dark'); | ||
} else if (newMode === 'light' && currentMode !== 'light') { | ||
nucliaSearchResults.setAttribute('mode', 'light'); | ||
nucliaSearchBar.setAttribute('mode', 'light'); | ||
} | ||
} | ||
}); | ||
} | ||
|
||
// Select the HTML element and configure the observer | ||
const htmlSelector = document.querySelector('html'); | ||
const observer = new MutationObserver(handleThemeChange); | ||
|
||
// Start observing changes in the data-theme attribute | ||
observer.observe(htmlSelector, { attributes: true, attributeFilter: ['data-theme'] }); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So everytime there is a commit on main, we run the job, which makes a commit on main.
It looks like an infinite loop :)
Maybe the job should have a condition like if the last changes are only about our 2 generated json files, we stop.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ebrehault I have put the check for
nuclia_sync.json
only. This should work, right?