Mikhail Chusavitin
f73e3d144d
Vendor mapping: wildcard ignore patterns, bulk CSV import, multi-lot qty
...
- Add glob pattern support (* and ?) for ignore rules stored in
qt_vendor_partnumber_seen (is_pattern flag, migration 041)
- Pattern matching applied in stock/competitor import, partnumber book
snapshot, and vendor mappings list (Go-side via NormalizeKey)
- BulkUpsertMappings: replace N+1 loop with two batch SQL upserts,
validating all lots in a single query (~1500 queries → 3-4)
- CSV import: multi-lot per PN via repeated rows, optional qty column
- CSV export: updated column format vendor;partnumber;lot_name;qty;description;ignore;notes
- UI: ignore patterns section with add/delete, import progress feedback
- Update bible-local/vendor-mapping.md with new CSV format
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-03-19 09:41:48 +03:00
Mikhail Chusavitin
f48615e8a9
Modularize Go files, extract JS to static, implement competitor pricelists
...
Go refactoring:
- Split handlers/pricing.go (2446→291 lines) into 5 focused files
- Split services/stock_import.go (1334→~400 lines) into stock_mappings.go + stock_parse.go
- Split services/sync/service.go (1290→~250 lines) into 3 files
JS extraction:
- Move all inline <script> blocks to web/static/js/ (6 files)
- Templates reduced: admin_pricing 2873→521, lot 1531→304, vendor_mappings 1063→169, etc.
Competitor pricelists (migrations 033-039):
- qt_competitors + partnumber_log_competitors tables
- Excel import with column mapping, dedup, bulk insert
- p/n→lot resolution via weighted_median, discount applied
- Unmapped p/ns written to qt_vendor_partnumber_seen
- Quote counts (unique/total) shown on /admin/competitors
- price_method="weighted_median", price_period_days=0 stored explicitly
Fix price_method/price_period_days for warehouse items:
- warehouse: weighted_avg, period=0
- competitor: weighted_median, period=0
- Removes misleading DB defaults (was: median/90)
Update bible: architecture.md, pricelist.md, history.md
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-03-13 07:44:10 +03:00
Mikhail Chusavitin
3f26a2935a
Refactor vendor mappings to canonical PN catalog
2026-03-07 23:11:42 +03:00
Mikhail Chusavitin
b2b2f4774c
Refactor scheduler and settings UI
2026-03-07 21:10:20 +03:00
Mikhail Chusavitin
04ce74ca1b
Refine vendor mapping CSV operations and ignore import flow
2026-02-27 16:49:39 +03:00
Mikhail Chusavitin
6f1de7a20e
Add vendor mappings CSV import modal and fix vendor rename save
2026-02-26 12:44:11 +03:00
a4457a0a28
Add partnumber book snapshots for QuoteForge integration
...
- Migrations 026-028: qt_partnumber_books + qt_partnumber_book_items
tables; is_primary_pn on lot_partnumbers; version VARCHAR(30);
description VARCHAR(10000) on items (required by QuoteForge sync)
- Service: CreateSnapshot expands bundles, filters empty lot_name and
ignored PNs, copies description, activates new book atomically,
applies GFS retention (7d/5w/12m/10y) with explicit item deletion
- Task type TaskTypePartnumberBookCreate; handlers ListPartnumberBooks
and CreatePartnumberBook; routes GET/POST /api/admin/pricing/partnumber-books
- UI: snapshot list + "Создать снапшот сопоставлений" button with
progress polling on /vendor-mappings page
- Bible: history, api, background-tasks, vendor-mapping updated
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-02-21 22:16:16 +03:00
Mikhail Chusavitin
c22328bf03
Implement global vendor mappings with bundle support and seen-based ignore
2026-02-18 19:54:07 +03:00