Skip to content
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
feb056f
pdfChunks file updated for better text processing
Aayushjshah Sep 12, 2025
60bfdb9
comment fixes
Aayushjshah Sep 12, 2025
29508fa
comment fixes
Aayushjshah Sep 12, 2025
498c544
comment fixes
Aayushjshah Sep 12, 2025
5ab007e
comment fixes
Aayushjshah Sep 12, 2025
9f816a0
comment fixes
Aayushjshah Sep 12, 2025
2f497d0
comment fixes
Aayushjshah Sep 15, 2025
9dab216
Merge branch 'main' into feat/pdfIngestFix
Aayushjshah Sep 15, 2025
0c98b7a
removing old logic
Aayushjshah Sep 15, 2025
bb60269
removing old logic
Aayushjshah Sep 15, 2025
8ae7a74
Workflow route issue fix and removed logs (#847)
avirupsinha12 Sep 16, 2025
8a95be8
Fixed file content retrieval: used wrong format for names (#851)
SahilKumar000 Sep 16, 2025
ea7db16
Workflow Refresh Issue fixed (#860)
avirupsinha12 Sep 17, 2025
133adf8
fix/file-process: Now KB files images are processed (#861)
SahilKumar000 Sep 17, 2025
afcc971
feat(doc-preview): Added support for viewing xlxs,xls,csv (#834) (#865)
Ravishekhar7870 Sep 17, 2025
56a3b54
fix:model-selection (#866)
MayankBansal2004 Sep 17, 2025
d09b563
fix(citation preview): added back button in citation preview (#846) (…
rahul1841 Sep 17, 2025
94bd9a6
fix:temperorily disabled chunk citations for pdfs (#848) (#870)
Himanshvarma Sep 17, 2025
de50563
fix:title-generation (#852) (#872)
Ravishekhar7870 Sep 17, 2025
1840e06
User Management page (#631) (#871)
naSim087 Sep 17, 2025
328e78b
testing
Aayushjshah Sep 17, 2025
da77a8c
Fix/app exc (#877)
naSim087 Sep 18, 2025
da483b7
fix(docker-compose): add vespa‑deploy service and relax Microsoft cre…
shivamashtikar Sep 18, 2025
a296053
fix:replace z.instanceof(File) with z.any() for better compatibility …
naSim087 Sep 18, 2025
d5154f6
feat(docker): add GPU support and configurable metrics port (#884) (#…
shivamashtikar Sep 18, 2025
e5ff53d
Adding gemini for pdf processing
Aayushjshah Sep 18, 2025
394e3eb
chore: merge main into feat/pdfLayout
Aayushjshah Sep 18, 2025
600c959
chore: merge main into feat/pdfLayout
Aayushjshah Sep 18, 2025
845db22
chore: merge main into feat/pdfLayout
Aayushjshah Sep 18, 2025
70a95db
chore: splitting of large pdfs feat/pdfLayout
Aayushjshah Sep 19, 2025
64337f7
chore: splitting of large pdfs feat/pdfLayout
Aayushjshah Sep 19, 2025
d42feac
Merge branch 'main' into feat/pdfLayout
Aayushjshah Sep 19, 2025
03b1045
chore: splitting of large pdfs feat/pdfLayout
Aayushjshah Sep 19, 2025
b30386b
chore: splitting of large pdfs feat/pdfLayout
Aayushjshah Sep 19, 2025
bd43cd1
chore: splitting of large pdfs feat/pdfLayout
Aayushjshah Sep 19, 2025
bb78cd5
chore: splitting of large pdfs feat/pdfLayout
Aayushjshah Sep 19, 2025
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
64 changes: 64 additions & 0 deletions server/.spec-workflow/user-templates/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
# User Templates

This directory allows you to create custom templates that override the default Spec Workflow templates.

## How to Use Custom Templates

1. **Create your custom template file** in this directory with the exact same name as the default template you want to override:
- `requirements-template.md` - Override requirements document template
- `design-template.md` - Override design document template
- `tasks-template.md` - Override tasks document template
- `product-template.md` - Override product steering template
- `tech-template.md` - Override tech steering template
- `structure-template.md` - Override structure steering template

2. **Template Loading Priority**:
- The system first checks this `user-templates/` directory
- If a matching template is found here, it will be used
- Otherwise, the default template from `templates/` will be used

## Example Custom Template

To create a custom requirements template:

1. Create a file named `requirements-template.md` in this directory
2. Add your custom structure, for example:

```markdown
# Requirements Document

## Executive Summary
[Your custom section]

## Business Requirements
[Your custom structure]

## Technical Requirements
[Your custom fields]

## Custom Sections
[Add any sections specific to your workflow]
```

## Template Variables

Templates can include placeholders that will be replaced when documents are created:
- `{{projectName}}` - The name of your project
- `{{featureName}}` - The name of the feature being specified
- `{{date}}` - The current date
- `{{author}}` - The document author

## Best Practices

1. **Start from defaults**: Copy a default template from `../templates/` as a starting point
2. **Keep structure consistent**: Maintain similar section headers for tool compatibility
3. **Document changes**: Add comments explaining why sections were added/modified
4. **Version control**: Track your custom templates in version control
5. **Test thoroughly**: Ensure custom templates work with the spec workflow tools

## Notes

- Custom templates are project-specific and not included in the package distribution
- The `templates/` directory contains the default templates which are updated with each version
- Your custom templates in this directory are preserved during updates
- If a custom template has errors, the system will fall back to the default template
4 changes: 2 additions & 2 deletions server/integrations/dataSource/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ import {
} from "./errors"
import { describeImageWithllm } from "@/lib/describeImageWithllm"
import { promises as fsPromises } from "fs"
import { extractTextAndImagesWithChunksFromPDF } from "@/pdfChunks"
import { extractTextAndImagesWithChunksFromPDFviaGemini } from "@/lib/chunkPdfWithGemini"
import { extractTextAndImagesWithChunksFromDocx } from "@/docxChunks"
import { extractTextAndImagesWithChunksFromPptx } from "@/pptChunks"
import imageType from "image-type"
Expand Down Expand Up @@ -208,7 +208,7 @@ const processPdfContent = async (
try {
const docId = `dsf-${createId()}`
const { text_chunks, image_chunks, text_chunk_pos, image_chunk_pos } =
await extractTextAndImagesWithChunksFromPDF(pdfBuffer, docId, true)
await extractTextAndImagesWithChunksFromPDFviaGemini(pdfBuffer, docId)
if (text_chunks.length === 0 && image_chunks.length === 0) {
throw new ContentExtractionError(
"No chunks generated from PDF content",
Expand Down
5 changes: 2 additions & 3 deletions server/integrations/google/worker-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ import {
import * as XLSX from "xlsx"
import { extractTextAndImagesWithChunksFromDocx } from "@/docxChunks"
import { extractTextAndImagesWithChunksFromPptx } from "@/pptChunks"
import { extractTextAndImagesWithChunksFromPDF } from "@/pdfChunks"
import { extractTextAndImagesWithChunksFromPDFviaGemini } from "@/lib/chunkPdfWithGemini"

const Logger = getLogger(Subsystem.Integrations).child({ module: "google" })

Expand Down Expand Up @@ -49,10 +49,9 @@ const processPdfFile = async (
): Promise<string[]> => {
try {
// Handle non-spreadsheet files as before
const pdfResult = await extractTextAndImagesWithChunksFromPDF(
const pdfResult = await extractTextAndImagesWithChunksFromPDFviaGemini(
pdfBuffer,
attachmentId,
false, // Don't extract images for email attachments
)
return pdfResult.text_chunks.filter((v) => v.trim())
} catch (error) {
Expand Down
5 changes: 2 additions & 3 deletions server/integrations/microsoft/attachment-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import {
import * as XLSX from "xlsx"
import { extractTextAndImagesWithChunksFromDocx } from "@/docxChunks"
import { extractTextAndImagesWithChunksFromPptx } from "@/pptChunks"
import { extractTextAndImagesWithChunksFromPDF } from "@/pdfChunks"
import { extractTextAndImagesWithChunksFromPDFviaGemini } from "@/lib/chunkPdfWithGemini"
import { makeGraphApiCall, type MicrosoftGraphClient } from "./client"

const Logger = getLogger(Subsystem.Integrations).child({
Expand Down Expand Up @@ -48,10 +48,9 @@ const processPdfFile = async (
attachmentId: string,
): Promise<string[]> => {
try {
const pdfResult = await extractTextAndImagesWithChunksFromPDF(
const pdfResult = await extractTextAndImagesWithChunksFromPDFviaGemini(
pdfBuffer,
attachmentId,
false, // Don't extract images for email attachments
)
return pdfResult.text_chunks.filter((v) => v.trim())
} catch (error) {
Expand Down
Loading
Loading