feat(feedback): Add content improvement feedback system

Frontend (frontend/app.js):

- Add textarea for improvement feedback

- Add submit button with loading state

- Handle API response and display improved content

Backend (backend/copywriter.py):

- Add improve_copy() method using Cohere API

- Integrate retry mechanism for API calls

Backend (backend/main.py):

- Add /improve-content POST endpoint

- Implement error handling and return improved content with metadata

Testing:

- Verified feedback submission flow

- Confirmed improved content generation

- Tested error scenarios and loading states
This commit is contained in:
Michael Ikehi
2025-04-18 04:39:06 +01:00
parent 6fd7213076
commit af8f99dea3
13 changed files with 550 additions and 167 deletions
+316
View File
@@ -458,3 +458,319 @@
2025-04-17 08:08:22.724 | INFO | brand_style:update_style_guidelines:80 - Updated brand style guidelines
2025-04-17 08:10:36.577 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 08:10:36.577 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:14:52.646 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-17 09:14:52.646 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-17 09:15:06.876 | INFO | copywriter:generate_copy:118 - Generated content with 775 characters
2025-04-17 09:15:06.876 | INFO | copywriter:generate_copy:118 - Generated content with 775 characters
2025-04-17 09:15:07.331 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:15:07.331 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:15:45.897 | INFO | copywriter:improve_copy:221 - Improved content based on feedback
2025-04-17 09:15:45.897 | INFO | copywriter:improve_copy:221 - Improved content based on feedback
2025-04-17 09:21:39.757 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-17 09:21:39.757 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-17 09:21:55.770 | INFO | copywriter:generate_copy:118 - Generated content with 1778 characters
2025-04-17 09:21:55.770 | INFO | copywriter:generate_copy:118 - Generated content with 1778 characters
2025-04-17 09:21:56.229 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:21:56.229 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:23:23.199 | INFO | copywriter:improve_copy:221 - Improved content based on feedback
2025-04-17 09:23:23.199 | INFO | copywriter:improve_copy:221 - Improved content based on feedback
2025-04-17 09:24:27.186 | INFO | copywriter:generate_copy:118 - Generated content with 1353 characters
2025-04-17 09:24:27.186 | INFO | copywriter:generate_copy:118 - Generated content with 1353 characters
2025-04-17 09:24:33.304 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:24:33.304 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:25:18.277 | INFO | copywriter:improve_copy:221 - Improved content based on feedback
2025-04-17 09:25:18.277 | INFO | copywriter:improve_copy:221 - Improved content based on feedback
2025-04-17 09:27:47.580 | INFO | copywriter:generate_copy:118 - Generated content with 1316 characters
2025-04-17 09:27:47.580 | INFO | copywriter:generate_copy:118 - Generated content with 1316 characters
2025-04-17 09:27:48.175 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:27:48.175 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:28:28.798 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-17 09:28:28.798 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 00:48:00.063 | INFO | brand_style:update_style_guidelines:80 - Updated brand style guidelines
2025-04-18 00:48:00.063 | INFO | brand_style:update_style_guidelines:80 - Updated brand style guidelines
2025-04-18 01:00:14.884 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:00:14.884 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:00:18.898 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:00:18.898 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:00:22.903 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:00:22.903 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:00:22.904 | ERROR | main:generate_copy:157 - Error generating copy: RetryError[<Future at 0x115ae8a70 state=finished raised AttributeError>]
2025-04-18 01:00:22.904 | ERROR | main:generate_copy:157 - Error generating copy: RetryError[<Future at 0x115ae8a70 state=finished raised AttributeError>]
2025-04-18 01:02:05.000 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:02:05.000 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:02:09.006 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:02:09.006 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:02:13.014 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:02:13.014 | ERROR | copywriter:generate_copy:122 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:02:13.015 | ERROR | main:generate_copy:157 - Error generating copy: RetryError[<Future at 0x115cd30e0 state=finished raised AttributeError>]
2025-04-18 01:02:13.015 | ERROR | main:generate_copy:157 - Error generating copy: RetryError[<Future at 0x115cd30e0 state=finished raised AttributeError>]
2025-04-18 01:14:27.689 | ERROR | copywriter:generate_copy:94 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:14:27.689 | ERROR | copywriter:generate_copy:94 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:14:31.699 | ERROR | copywriter:generate_copy:94 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:14:31.699 | ERROR | copywriter:generate_copy:94 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:14:35.702 | ERROR | copywriter:generate_copy:94 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:14:35.702 | ERROR | copywriter:generate_copy:94 - Error generating copy: 'BrandStyleManager' object has no attribute '_get_content_format'
2025-04-18 01:14:35.703 | ERROR | main:generate_copy:133 - Error generating copy: RetryError[<Future at 0x114e7b5c0 state=finished raised AttributeError>]
2025-04-18 01:14:35.703 | ERROR | main:generate_copy:133 - Error generating copy: RetryError[<Future at 0x114e7b5c0 state=finished raised AttributeError>]
2025-04-18 01:17:10.288 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:17:10.288 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:17:16.813 | INFO | copywriter:generate_copy:90 - Generated content with 770 characters
2025-04-18 01:17:16.813 | INFO | copywriter:generate_copy:90 - Generated content with 770 characters
2025-04-18 01:17:17.285 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:17:17.285 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:18:21.877 | INFO | copywriter:generate_copy:90 - Generated content with 583 characters
2025-04-18 01:18:21.877 | INFO | copywriter:generate_copy:90 - Generated content with 583 characters
2025-04-18 01:18:22.645 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:18:22.645 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:18:52.465 | INFO | copywriter:generate_copy:90 - Generated content with 791 characters
2025-04-18 01:18:52.465 | INFO | copywriter:generate_copy:90 - Generated content with 791 characters
2025-04-18 01:18:52.905 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:18:52.905 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:20:01.008 | INFO | copywriter:generate_copy:90 - Generated content with 1695 characters
2025-04-18 01:20:01.008 | INFO | copywriter:generate_copy:90 - Generated content with 1695 characters
2025-04-18 01:20:01.566 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:20:01.566 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:20:26.004 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:20:26.004 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:34:03.153 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:34:03.153 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:34:22.102 | INFO | copywriter:generate_copy:90 - Generated content with 2004 characters
2025-04-18 01:34:22.102 | INFO | copywriter:generate_copy:90 - Generated content with 2004 characters
2025-04-18 01:34:22.524 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:34:22.524 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:35:24.984 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:35:24.984 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:35:41.564 | INFO | copywriter:generate_copy:90 - Generated content with 1635 characters
2025-04-18 01:35:41.564 | INFO | copywriter:generate_copy:90 - Generated content with 1635 characters
2025-04-18 01:35:42.025 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:35:42.025 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:36:43.029 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:36:43.029 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:36:51.487 | INFO | copywriter:generate_copy:90 - Generated content with 1163 characters
2025-04-18 01:36:51.487 | INFO | copywriter:generate_copy:90 - Generated content with 1163 characters
2025-04-18 01:36:51.866 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:36:51.866 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:37:35.913 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:37:35.913 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:38:04.403 | INFO | copywriter:generate_copy:90 - Generated content with 1374 characters
2025-04-18 01:38:04.403 | INFO | copywriter:generate_copy:90 - Generated content with 1374 characters
2025-04-18 01:38:05.011 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:38:05.011 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:38:44.318 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:38:44.318 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 01:39:14.512 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 01:39:14.512 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 01:39:48.781 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 01:39:48.781 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 01:40:08.963 | INFO | copywriter:generate_copy:90 - Generated content with 1831 characters
2025-04-18 01:40:08.963 | INFO | copywriter:generate_copy:90 - Generated content with 1831 characters
2025-04-18 01:40:09.921 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:40:09.921 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 01:44:03.287 | INFO | copywriter:improve_copy:193 - Improved content based on feedback
2025-04-18 01:44:03.287 | INFO | copywriter:improve_copy:193 - Improved content based on feedback
2025-04-18 01:44:55.624 | INFO | copywriter:improve_copy:193 - Improved content based on feedback
2025-04-18 01:44:55.624 | INFO | copywriter:improve_copy:193 - Improved content based on feedback
2025-04-18 02:07:19.823 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 02:07:19.823 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 02:07:27.541 | INFO | copywriter:generate_copy:90 - Generated content with 226 characters
2025-04-18 02:07:27.541 | INFO | copywriter:generate_copy:90 - Generated content with 226 characters
2025-04-18 02:07:28.463 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:07:28.463 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:08:38.495 | INFO | copywriter:generate_copy:90 - Generated content with 239 characters
2025-04-18 02:08:38.495 | INFO | copywriter:generate_copy:90 - Generated content with 239 characters
2025-04-18 02:08:38.965 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:08:38.965 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:09:04.045 | INFO | copywriter:generate_copy:90 - Generated content with 229 characters
2025-04-18 02:09:04.045 | INFO | copywriter:generate_copy:90 - Generated content with 229 characters
2025-04-18 02:09:04.476 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:09:04.476 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:09:33.639 | INFO | copywriter:generate_copy:90 - Generated content with 686 characters
2025-04-18 02:09:33.639 | INFO | copywriter:generate_copy:90 - Generated content with 686 characters
2025-04-18 02:09:34.290 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:09:34.290 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:10:29.627 | INFO | copywriter:generate_copy:90 - Generated content with 383 characters
2025-04-18 02:10:29.627 | INFO | copywriter:generate_copy:90 - Generated content with 383 characters
2025-04-18 02:10:30.087 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:10:30.087 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:19:13.085 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:19:13.085 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:19:22.542 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 02:19:22.542 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 02:19:22.543 | INFO | copywriter:generate_copy:90 - Generated content with 963 characters
2025-04-18 02:19:22.543 | INFO | copywriter:generate_copy:90 - Generated content with 963 characters
2025-04-18 02:20:37.281 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 02:20:37.281 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 02:20:37.283 | INFO | copywriter:generate_copy:90 - Generated content with 1278 characters
2025-04-18 02:20:37.283 | INFO | copywriter:generate_copy:90 - Generated content with 1278 characters
2025-04-18 02:21:03.210 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 02:21:03.210 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 02:21:03.212 | INFO | copywriter:generate_copy:90 - Generated content with 1099 characters
2025-04-18 02:21:03.212 | INFO | copywriter:generate_copy:90 - Generated content with 1099 characters
2025-04-18 02:26:17.803 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:26:17.803 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:26:25.385 | INFO | copywriter:generate_copy:90 - Generated content with 1128 characters
2025-04-18 02:26:25.385 | INFO | copywriter:generate_copy:90 - Generated content with 1128 characters
2025-04-18 02:26:25.823 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:26:25.823 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:28:15.335 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:28:15.335 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:28:24.861 | INFO | copywriter:generate_copy:90 - Generated content with 1197 characters
2025-04-18 02:28:24.861 | INFO | copywriter:generate_copy:90 - Generated content with 1197 characters
2025-04-18 02:28:25.253 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:28:25.253 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:29:27.025 | INFO | copywriter:generate_copy:90 - Generated content with 852 characters
2025-04-18 02:29:27.025 | INFO | copywriter:generate_copy:90 - Generated content with 852 characters
2025-04-18 02:29:27.561 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:29:27.561 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:30:18.629 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:30:18.629 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:30:31.984 | INFO | copywriter:generate_copy:90 - Generated content with 1280 characters
2025-04-18 02:30:31.984 | INFO | copywriter:generate_copy:90 - Generated content with 1280 characters
2025-04-18 02:30:32.533 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:30:32.533 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:50:52.050 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:50:52.050 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 02:51:08.753 | INFO | copywriter:generate_copy:90 - Generated content with 1621 characters
2025-04-18 02:51:08.753 | INFO | copywriter:generate_copy:90 - Generated content with 1621 characters
2025-04-18 02:51:09.188 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:51:09.188 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:54:25.384 | INFO | copywriter:generate_copy:90 - Generated content with 1304 characters
2025-04-18 02:54:25.384 | INFO | copywriter:generate_copy:90 - Generated content with 1304 characters
2025-04-18 02:54:26.186 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:54:26.186 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:54:46.982 | INFO | copywriter:generate_copy:90 - Generated content with 815 characters
2025-04-18 02:54:46.982 | INFO | copywriter:generate_copy:90 - Generated content with 815 characters
2025-04-18 02:54:47.508 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:54:47.508 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:55:50.883 | INFO | copywriter:generate_copy:90 - Generated content with 1827 characters
2025-04-18 02:55:50.883 | INFO | copywriter:generate_copy:90 - Generated content with 1827 characters
2025-04-18 02:55:51.314 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 02:55:51.314 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:02:34.882 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:02:34.882 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:02:55.595 | INFO | copywriter:generate_copy:90 - Generated content with 1571 characters
2025-04-18 03:02:55.595 | INFO | copywriter:generate_copy:90 - Generated content with 1571 characters
2025-04-18 03:02:57.531 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:02:57.531 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:11:46.772 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:11:46.772 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:12:00.197 | INFO | copywriter:generate_copy:90 - Generated content with 971 characters
2025-04-18 03:12:00.197 | INFO | copywriter:generate_copy:90 - Generated content with 971 characters
2025-04-18 03:12:00.621 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:12:00.621 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:14:42.619 | INFO | copywriter:generate_copy:90 - Generated content with 1146 characters
2025-04-18 03:14:42.619 | INFO | copywriter:generate_copy:90 - Generated content with 1146 characters
2025-04-18 03:14:43.225 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:14:43.225 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:29:08.562 | INFO | copywriter:generate_copy:90 - Generated content with 1423 characters
2025-04-18 03:29:08.562 | INFO | copywriter:generate_copy:90 - Generated content with 1423 characters
2025-04-18 03:29:09.128 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:29:09.128 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:30:04.797 | INFO | copywriter:generate_copy:90 - Generated content with 1475 characters
2025-04-18 03:30:04.797 | INFO | copywriter:generate_copy:90 - Generated content with 1475 characters
2025-04-18 03:30:05.244 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:30:05.244 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:43:52.883 | INFO | copywriter:generate_copy:90 - Generated content with 1123 characters
2025-04-18 03:43:52.883 | INFO | copywriter:generate_copy:90 - Generated content with 1123 characters
2025-04-18 03:44:41.387 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:44:41.387 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:45:23.813 | INFO | copywriter:generate_copy:90 - Generated content with 2004 characters
2025-04-18 03:45:23.813 | INFO | copywriter:generate_copy:90 - Generated content with 2004 characters
2025-04-18 03:45:24.224 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:45:24.224 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:46:06.815 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:46:06.815 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:46:23.745 | INFO | copywriter:generate_copy:90 - Generated content with 1750 characters
2025-04-18 03:46:23.745 | INFO | copywriter:generate_copy:90 - Generated content with 1750 characters
2025-04-18 03:46:50.243 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:46:50.243 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:49:53.371 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:49:53.371 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:50:01.024 | INFO | copywriter:generate_copy:90 - Generated content with 1182 characters
2025-04-18 03:50:01.024 | INFO | copywriter:generate_copy:90 - Generated content with 1182 characters
2025-04-18 03:50:01.557 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:50:01.557 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:52:18.453 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:52:18.453 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:52:25.589 | INFO | copywriter:generate_copy:90 - Generated content with 1040 characters
2025-04-18 03:52:25.589 | INFO | copywriter:generate_copy:90 - Generated content with 1040 characters
2025-04-18 03:52:26.378 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:52:26.378 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:53:03.190 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:53:03.190 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:53:09.327 | INFO | copywriter:generate_copy:90 - Generated content with 883 characters
2025-04-18 03:53:09.327 | INFO | copywriter:generate_copy:90 - Generated content with 883 characters
2025-04-18 03:53:09.798 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:53:09.798 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:54:12.575 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:54:12.575 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:54:29.054 | INFO | copywriter:generate_copy:90 - Generated content with 1439 characters
2025-04-18 03:54:29.054 | INFO | copywriter:generate_copy:90 - Generated content with 1439 characters
2025-04-18 03:54:29.441 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:54:29.441 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:55:16.974 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:55:16.974 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:55:26.092 | INFO | copywriter:generate_copy:90 - Generated content with 1243 characters
2025-04-18 03:55:26.092 | INFO | copywriter:generate_copy:90 - Generated content with 1243 characters
2025-04-18 03:55:26.505 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:55:26.505 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:56:15.753 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:56:15.753 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 03:56:24.050 | INFO | copywriter:generate_copy:90 - Generated content with 1189 characters
2025-04-18 03:56:24.050 | INFO | copywriter:generate_copy:90 - Generated content with 1189 characters
2025-04-18 03:56:53.669 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:56:53.669 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:59:44.352 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 03:59:44.352 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 03:59:44.355 | INFO | copywriter:generate_copy:90 - Generated content with 906 characters
2025-04-18 03:59:44.355 | INFO | copywriter:generate_copy:90 - Generated content with 906 characters
2025-04-18 03:59:45.100 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 03:59:45.100 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:00:08.827 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:00:08.827 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:00:21.413 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:00:21.413 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:00:21.413 | INFO | copywriter:generate_copy:90 - Generated content with 1350 characters
2025-04-18 04:00:21.413 | INFO | copywriter:generate_copy:90 - Generated content with 1350 characters
2025-04-18 04:00:21.848 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:00:21.848 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:01:23.133 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:01:23.133 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:01:23.138 | INFO | copywriter:generate_copy:90 - Generated content with 1525 characters
2025-04-18 04:01:23.138 | INFO | copywriter:generate_copy:90 - Generated content with 1525 characters
2025-04-18 04:01:23.727 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:01:23.727 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:02:32.346 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:02:32.346 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:03:46.372 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:03:46.372 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:05:53.862 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:05:53.862 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:06:28.073 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:06:28.073 | INFO | brand_style:update_style_guidelines:178 - Updated brand style guidelines
2025-04-18 04:10:51.448 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:10:51.448 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:11:15.704 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:11:15.704 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:11:15.705 | INFO | copywriter:generate_copy:90 - Generated content with 1647 characters
2025-04-18 04:11:15.705 | INFO | copywriter:generate_copy:90 - Generated content with 1647 characters
2025-04-18 04:11:16.128 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:11:16.128 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:19:51.595 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:19:51.595 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:20:10.910 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:20:10.910 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:20:10.910 | INFO | copywriter:generate_copy:90 - Generated content with 1248 characters
2025-04-18 04:20:10.910 | INFO | copywriter:generate_copy:90 - Generated content with 1248 characters
2025-04-18 04:20:11.454 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:20:11.454 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:21:29.147 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:21:29.147 | INFO | vector_store:search:212 - Found 3 matching documents for query
2025-04-18 04:21:59.320 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 04:21:59.320 | ERROR | copywriter:_call_llm_api:139 - Error calling Cohere API:
2025-04-18 04:22:36.137 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:22:36.137 | INFO | copywriter:_generate_headline_suggestions:188 - Generated 3 headline suggestions
2025-04-18 04:22:36.139 | INFO | copywriter:generate_copy:90 - Generated content with 3409 characters
2025-04-18 04:22:36.139 | INFO | copywriter:generate_copy:90 - Generated content with 3409 characters
2025-04-18 04:22:36.945 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store
2025-04-18 04:22:36.945 | INFO | vector_store:add_documents:131 - Added 1 documents to vector store