@smallwebco/tinypivot-core 1.0.61 → 1.0.63

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,8 +5,12 @@
5
5
  import type { AIDataSource, AITableSchema } from '../types';
6
6
  /**
7
7
  * Build the system prompt for the AI Data Analyst
8
+ * @param dataSources - List of available data sources
9
+ * @param schemas - Map of table schemas (selected table schema)
10
+ * @param selectedSourceId - Currently selected data source ID
11
+ * @param allSchemas - Optional: ALL table schemas for enabling JOINs
8
12
  */
9
- export declare function buildSystemPrompt(dataSources: AIDataSource[], schemas: Map<string, AITableSchema>, selectedSourceId?: string): string;
13
+ export declare function buildSystemPrompt(dataSources: AIDataSource[], schemas: Map<string, AITableSchema>, selectedSourceId?: string, allSchemas?: AITableSchema[]): string;
10
14
  /**
11
15
  * Build a user message with additional context
12
16
  */
@@ -1 +1 @@
1
- {"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../src/ai/prompts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAkB,YAAY,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE3E;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,WAAW,EAAE,YAAY,EAAE,EAC3B,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,CAAC,EACnC,gBAAgB,CAAC,EAAE,MAAM,GACxB,MAAM,CAmER;AAmED;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE;IACR,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,GACA,MAAM,CAQR;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAiBtE;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,CA8CjF;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,OAAO,EAClB,OAAO,EAAE,MAAM,GACd,MAAM,CAUR;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAK3D"}
1
+ {"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../src/ai/prompts.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAkB,YAAY,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE3E;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAC/B,WAAW,EAAE,YAAY,EAAE,EAC3B,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,CAAC,EACnC,gBAAgB,CAAC,EAAE,MAAM,EACzB,UAAU,CAAC,EAAE,aAAa,EAAE,GAC3B,MAAM,CAiFR;AAiHD;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE;IACR,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,GACA,MAAM,CAQR;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAiBtE;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,CA8CjF;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,OAAO,EAClB,OAAO,EAAE,MAAM,GACd,MAAM,CAUR;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAK3D"}
@@ -1,11 +1,17 @@
1
1
  /**
2
2
  * Build the system prompt for the AI Data Analyst
3
+ * @param dataSources - List of available data sources
4
+ * @param schemas - Map of table schemas (selected table schema)
5
+ * @param selectedSourceId - Currently selected data source ID
6
+ * @param allSchemas - Optional: ALL table schemas for enabling JOINs
3
7
  */
4
- export function buildSystemPrompt(dataSources, schemas, selectedSourceId) {
8
+ export function buildSystemPrompt(dataSources, schemas, selectedSourceId, allSchemas) {
5
9
  const selectedSchema = selectedSourceId ? schemas.get(selectedSourceId) : undefined;
6
10
  const selectedSource = selectedSourceId
7
11
  ? dataSources.find(ds => ds.id === selectedSourceId)
8
12
  : undefined;
13
+ // Filter out the selected table from allSchemas to get "other tables"
14
+ const otherTables = allSchemas?.filter(s => s.table !== selectedSchema?.table) || [];
9
15
  return `You are a data analyst assistant. Your job is to translate user questions into SQL queries and return data results.
10
16
 
11
17
  ## CRITICAL: ALWAYS GENERATE A SQL QUERY
@@ -23,17 +29,28 @@ ${formatDataSourcesList(dataSources)}
23
29
 
24
30
  ${selectedSource && selectedSchema ? formatSelectedSchemaContext(selectedSource, selectedSchema) : '## No Data Source Selected\nPlease ask the user to select a data source first.'}
25
31
 
32
+ ${otherTables.length > 0 ? formatRelatedTablesContext(otherTables) : ''}
33
+
26
34
  ## Query Rules
27
35
  1. **READ-ONLY**: ONLY use SELECT. NEVER use INSERT, UPDATE, DELETE, DROP, ALTER, TRUNCATE, or any write operations.
28
- 2. **LIMIT RESULTS**: Always use LIMIT (default 100-1000 rows) to avoid overwhelming results.
29
- 3. **ONE TABLE**: Only query the currently selected table: \`${selectedSchema?.table || 'table_name'}\`
30
- 4. **BE SPECIFIC**: Select relevant columns, not SELECT * (unless showing sample data)
36
+ 2. **NO LIMIT**: Do NOT add LIMIT clauses unless the user explicitly asks for a limited number of results. Return all matching rows by default.
37
+ 3. **PRIMARY TABLE**: The main table is \`${selectedSchema?.table || 'table_name'}\`
38
+ 4. **JOINs ALLOWED**: You CAN JOIN with other tables listed in "Related Tables" when the user needs data from multiple tables.
39
+ 5. **BE SPECIFIC**: Select relevant columns, not SELECT * (unless showing sample data)
31
40
 
32
41
  ## Query Format
33
42
  Output queries in this EXACT format (the system auto-executes SQL blocks):
34
43
 
35
44
  \`\`\`sql
36
- SELECT column1, column2 FROM ${selectedSchema?.table || 'table_name'} WHERE condition LIMIT 100
45
+ SELECT column1, column2 FROM ${selectedSchema?.table || 'table_name'} WHERE condition
46
+ \`\`\`
47
+
48
+ For JOINs (when user needs data from related tables):
49
+ \`\`\`sql
50
+ SELECT p.column1, r.column2
51
+ FROM ${selectedSchema?.table || 'primary_table'} p
52
+ JOIN related_table r ON p.foreign_key = r.id
53
+ WHERE condition
37
54
  \`\`\`
38
55
 
39
56
  For complex analysis, use CTEs:
@@ -43,7 +60,7 @@ WITH summary AS (
43
60
  FROM ${selectedSchema?.table || 'table_name'}
44
61
  GROUP BY category
45
62
  )
46
- SELECT * FROM summary ORDER BY count DESC LIMIT 20
63
+ SELECT * FROM summary ORDER BY count DESC
47
64
  \`\`\`
48
65
 
49
66
  ## Response Format
@@ -56,7 +73,7 @@ Keep responses concise and insight-focused:
56
73
 
57
74
  Example response:
58
75
  "\`\`\`sql
59
- SELECT department, AVG(salary) as avg_salary FROM employees GROUP BY department ORDER BY avg_salary DESC LIMIT 10
76
+ SELECT department, AVG(salary) as avg_salary FROM employees GROUP BY department ORDER BY avg_salary DESC
60
77
  \`\`\`
61
78
 
62
79
  Engineering and Product teams have the highest average salaries at $145K and $138K respectively, while Support and Operations are at the lower end around $75K. This 2x salary gap may indicate market-driven compensation or role complexity differences.
@@ -112,6 +129,42 @@ ${formatColumnsTable(columnsWithDescriptions)}
112
129
  - For text searches, use ILIKE for case-insensitive matching
113
130
  - For date columns, use standard SQL date functions`;
114
131
  }
132
+ /**
133
+ * Format the context for related tables that can be JOINed
134
+ */
135
+ function formatRelatedTablesContext(tables) {
136
+ if (tables.length === 0)
137
+ return '';
138
+ const tablesSummary = tables.map((table) => {
139
+ // Show table name and key columns (likely join keys)
140
+ const keyColumns = table.columns
141
+ .filter(col => col.name === 'id'
142
+ || col.name.endsWith('_id')
143
+ || col.name.startsWith('id_')
144
+ || col.name === 'uuid')
145
+ .map(col => `\`${col.name}\``)
146
+ .join(', ');
147
+ const otherColumns = table.columns
148
+ .filter(col => col.name !== 'id'
149
+ && !col.name.endsWith('_id')
150
+ && !col.name.startsWith('id_')
151
+ && col.name !== 'uuid')
152
+ .slice(0, 5) // Show up to 5 other columns
153
+ .map(col => `\`${col.name}\` (${col.type})`)
154
+ .join(', ');
155
+ const moreCount = table.columns.length - (keyColumns ? keyColumns.split(',').length : 0) - 5;
156
+ const moreText = moreCount > 0 ? `, +${moreCount} more` : '';
157
+ return `- **\`${table.table}\`**
158
+ - Keys: ${keyColumns || 'none'}
159
+ - Columns: ${otherColumns}${moreText}`;
160
+ }).join('\n');
161
+ return `## Related Tables (Available for JOINs)
162
+ You can JOIN with these tables when the user needs additional data.
163
+ Look for foreign key relationships (columns ending in \`_id\`).
164
+
165
+ ${tablesSummary}
166
+ `;
167
+ }
115
168
  /**
116
169
  * Format columns as a readable table for the prompt
117
170
  */
@@ -1 +1 @@
1
- {"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../src/ai/prompts.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../src/ai/prompts.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@smallwebco/tinypivot-core",
3
3
  "type": "module",
4
- "version": "1.0.61",
4
+ "version": "1.0.63",
5
5
  "description": "Core logic for TinyPivot - framework agnostic utilities for AI-enabled data grids, pivot tables, and embedded analytics",
6
6
  "author": "Small Web, LLC",
7
7
  "license": "SEE LICENSE IN LICENSE.md",