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

Adding Yep Chat in Taktak #1

Draft
wants to merge 77 commits into
base: tt/develop
Choose a base branch
from
Draft

Conversation

nyinyithann
Copy link
Collaborator

This PR mainly about adding Yep Chat in Taktak.

This commit introduces a toolbar button that allows users to toggle the visibility of the chat side panel.  The button provides a visual cue by highlighting with a rounded background when the chat panel is active.
…nel can be toggled from the toolbar and displays AI chat alongside current web content.
…so it can be localized into different languages.
Deleted ChatContextObserver class and its dependencies to simplify codebase. Adjusted related headers and implementation files to reflect the removal, and corrected remaining references and comments accordingly.
Implemented different prompts for chat actions: summarize page, explain page, and fact check page. Updated function signatures and button click handlers to utilize the new action-specific prompts.
Previously, the full content was passed to the query without length restriction, which could cause issues. Now, the content is truncated to a maximum of 32768 tokens to ensure it adheres to the defined limit.
Replaced `div` elements with semantic `article` tags for better accessibility. Updated scroll behavior and appearance for smoother UX, adjusted padding and layout for consistency, and refined CSS rules to optimize styling across components. Improved scrollbar theming for a more modern look.
Refactored CSS styles for better alignment and consistency, including border addition and adjustments to line-height and H2 styling. TypeScript changes include exporting `conversationRecord` type, adding debug logging, and refactoring response handling with a new utility function in the HTML template for cleaner, reusable code.
Added a comment to properly credit the third-party/marked library, adhering to Chromium's recommended practices. This ensures compliance with attribution guidelines for third-party code.
Refined textarea height management to handle up to 10 lines dynamically, ensuring better usability by avoiding unnecessary scrollbars. Updated chat markdown lists with reduced padding and consistent list item spacing. Added custom scrollbar styling for improved visual consistency.
Added `disabled` states for UI elements like the input field and send button to prevent interactions during query submission or when input is invalid. Enhanced visual feedback through styles such as cursor change and reduced opacity for disabled elements. Fixed button behavior to avoid submitting empty queries.
Introduced support for passing parameters to chat actions, enabling more dynamic prompts for translation and social media. Added dropdown menus for selecting translation languages and social media platforms. Fixed a typo in the fact-check prompt and improved overall UI structure for better functionality.
Renamed variables for better readability and consistency, such as replacing `translateToSubItems_` with `translateToLanguages_`. Refactored social media post handling to use a unified `action-menu` component with event-driven logic. Added support for additional languages and cleaned up redundant menu elements.
The CSS and HTML structures for query prompts were refactored for better modularity and maintainability. Introduced `getQueryPromptSection` for improved query rendering and added a `resetToAutoHeight` method to streamline input field resizing. Removed unused imports and simplified the codebase for clarity, addressing minor issues in text handling and logging.
Introduced new color IDs and updated styling for the chat send button, providing improved visuals in both light and dark modes. Refactored CSS and HTML structure for better alignment, including a new icon design. Enhanced functionality by adding focus behavior to the input field after message submission.
nyinyithann pushed a commit that referenced this pull request Dec 27, 2024
The answers feature check in the history WebUI controller can be
safely removed, because #1 answers may be disabled for the profile
even if the answers feature itself is enabled. and chromium#2 when the
feature is disabled, the answer mojom fields fall back to default
values with the exception of the answer text which should be empty.

Bug: 381108241
Change-Id: I2c7bcd3bd38aab64263103cbea923ac1d25ad75a
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6116038
Commit-Queue: Moe Ahmadi <[email protected]>
Reviewed-by: John Lee <[email protected]>
Code-Coverage: [email protected] <[email protected]>
Cr-Commit-Position: refs/heads/main@{#1400350}
nyinyithann pushed a commit that referenced this pull request Jan 3, 2025
No change to logic. This flag is not currently in use, as we instead
opted to proceed with the SITE_BLOCK flag. This removes most references
to the switch, however we still need to leave the flag definition so
that downstream references can be safely cleaned up.

This is change #1/3.

Bug: 356234122
Test: autoninja -C out/Default system_webview_google_apk
Test: tools/autotest.py -C out/Default AwSupervisedUserTest
Change-Id: I8c1e84ccec844064fb6648d791776b1d2da00874
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6107741
Commit-Queue: Peter Pakkenberg <[email protected]>
Reviewed-by: Peter Pakkenberg <[email protected]>
Auto-Submit: Nate Fischer <[email protected]>
Cr-Commit-Position: refs/heads/main@{#1401748}
Nyi Nyi and others added 6 commits January 4, 2025 19:43
Introduce a character limit for chat input and display an error message when this limit is exceeded. Updated styles, UI logic, and string resources to enforce and visually represent the new constraint.
Introduced the ability to cancel ongoing queries across the chat API, backend, and user interface. Refactored several methods to manage query cancelation states and ensure smooth handling of page content extraction interruptions.
Added logic to handle incomplete or invalid JSON chunks by preserving and combining them to ensure proper processing. Enhanced logging for debugging invalid JSON segments in streamed responses.
Updated CSS to improve layout flexibility, spacing, and applied consistent styling for message containers. Removed redundant padding rules and simplified the empty state HTML by eliminating the `vertical-space` div.
Simplified invalid chunk handling by refactoring first and last chunk validation. Replaced inefficient operations with streamlined logic to improve readability and maintainability. Removed unused testing method from the class header.
nyinyithann pushed a commit that referenced this pull request Jan 9, 2025
… document.scripts()"

This reverts commit 14d9421.

Reason for revert: extensions_unittests failures started after this
CL on Linux UBSAN, see failed build at https://ci.chromium.org/ui/p/chromium/builders/ci/Linux%20UBSan%20Tests/2624/overview
Specific test failure:
https://luci-milo.appspot.com/ui/inv/build-8726283549253023857/test-results?q=ScriptContextSetTest.Lifecycle&sortby=&groupby=
Partial stack trace seems related to this CL:
../../v8/include/cppgc/member.h:258:43: runtime error: reference binding to null pointer of type 'blink::Element'
    #0 0x6285783a4e16 in operator* v8/include/cppgc/member.h:258:36
    #1 0x6285783a4e16 in blink::Document::UpdateBaseURL() third_party/blink/renderer/core/dom/document.cc:4597:52
    chromium#2 0x6285783a22db in blink::Document::Document(blink::DocumentInit const&, base::EnumSet<blink::DocumentClass, (blink::DocumentClass)0, (blink::DocumentClass)7>) third_party/blink/renderer/core/dom/document.cc:918:5
    chromium#3 0x6285764452e4 in blink::HTMLDocument::HTMLDocument(blink::DocumentInit const&, base::EnumSet<blink::DocumentClass, (blink::DocumentClass)0, (blink::DocumentClass)7>) third_party/blink/renderer/core/html/html_document.cc:67:7

Original change's description:
> SpeculationRules: Use Traversal<HTMLScriptElement> instead of document.scripts()
>
> It's possible to run Document::UpdateBaseURL() while processing the
> removal of elements (ContainerNode::RemovedFrom), but before the
> HTMLCollections (like document.scripts()) are invalidated (which
> happens in ContainerNode::ChildrenChanged after all removals are
> complete).
>
> Bug: 386547460
> Change-Id: Ifc8036887dad3b999e77b1a014b950b97a20484a
> Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6148370
> Reviewed-by: Jeremy Roman <[email protected]>
> Reviewed-by: Mason Freed <[email protected]>
> Commit-Queue: Adithya Srinivasan <[email protected]>
> Cr-Commit-Position: refs/heads/main@{#1403679}

Bug: 386547460
Change-Id: Ibfaa45470d3f303610fdf8ceb4048dc22ea3029f
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6158707
Commit-Queue: Justin Lulejian <[email protected]>
Bot-Commit: Rubber Stamper <[email protected]>
Owners-Override: Justin Lulejian <[email protected]>
Reviewed-by: Adithya Srinivasan <[email protected]>
Reviewed-by: Justin Lulejian <[email protected]>
Cr-Commit-Position: refs/heads/main@{#1403868}
Increase max prompt input length to 90,000 and introduce logic to hide the site info container when the current page's content is used as chat context. Clear extracted content cache in page handler to prevent stale data. Adjust HTML rendering to support the new site info visibility logic.
Updated chat API to handle structured message inputs and support conversation history. Refined prompts and fixed typo in fact-check prompt definition. Improved page content extraction logic and streamlined API communication with better context management.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant