update
This commit is contained in:
40
.paul/PROJECT.md
Normal file
40
.paul/PROJECT.md
Normal file
@@ -0,0 +1,40 @@
|
||||
# Project: drmaterac.pl
|
||||
|
||||
## Description
|
||||
Modul Prestashop 1.7.8.11 o nazwie Cross Sell PRO, ktory wyswietla produkty uzupelniajace na podstawie mechanizmu "Powiazany produkt" w koszyku i na etapie zamowienia.
|
||||
|
||||
## Core Value
|
||||
Klient koszyka szybciej dobiera produkty uzupelniajace, co zwieksza wygode zakupow i wartosc koszyka.
|
||||
|
||||
## Requirements
|
||||
|
||||
### Must Have
|
||||
- [x] Modul wyswietla produkty cross-sell pod kontenerem koszyka ("card cart-container").
|
||||
- [x] Dane produktow pochodza z relacji "Powiazany produkt" w Prestashop.
|
||||
- [x] Prezentacja w formie karuzeli: zdjecie, nazwa, cena, CTA.
|
||||
- [x] Dla produktow z wariantami przycisk kieruje na strone produktu.
|
||||
- [x] Sekcja cross-sell dziala takze na checkout w `#js-checkout-summary` przed summary.
|
||||
|
||||
### Should Have
|
||||
- [x] Kompatybilnosc z motywem sklepu i responsywnosc mobile/desktop.
|
||||
- [x] Ograniczenie liczby produktow i pomijanie produktow juz w koszyku.
|
||||
|
||||
### Nice to Have
|
||||
- [ ] Prosta konfiguracja w panelu modulu (liczba elementow, autoplay).
|
||||
|
||||
## Constraints
|
||||
- Prestashop: 1.7.8.11
|
||||
- PHP: 7.4
|
||||
- Integracja bez modyfikowania core Prestashop.
|
||||
- Modul tworzony przez: Pyziak Jacek (https://www.project-pro.pl)
|
||||
|
||||
## Success Criteria
|
||||
- Sekcja cross-sell pojawia sie na stronie koszyka pod "card cart-container".
|
||||
- Sekcja cross-sell pojawia sie na stronie zamowienia w prawym panelu summary.
|
||||
- Produkty sa pobierane z relacji "Powiazany produkt".
|
||||
- Uzytkownik moze dodac produkt bez wariantow bezposrednio z karuzeli.
|
||||
- Uzytkownik przechodzi do karty produktu, jesli produkt wymaga wyboru wariantu.
|
||||
|
||||
---
|
||||
*Created: 2026-03-31 22:58*
|
||||
*Last updated: 2026-03-31 after Phase 2*
|
||||
50
.paul/ROADMAP.md
Normal file
50
.paul/ROADMAP.md
Normal file
@@ -0,0 +1,50 @@
|
||||
# Roadmap: drmaterac.pl
|
||||
|
||||
## Overview
|
||||
Wdrozenie funkcji Cross Sell PRO skoncentrowanej na stronie koszyka i checkoutu, od zasilenia danymi z relacji produktow po frontendowa karuzele i logike dodawania do koszyka zgodna z wariantami.
|
||||
|
||||
## Current Milestone
|
||||
**v0.1 Cross Sell PRO dla koszyka** (v0.1.0)
|
||||
Status: Complete
|
||||
Phases: 2 of 2 complete
|
||||
|
||||
## Phases
|
||||
|
||||
| Phase | Name | Plans | Status | Completed |
|
||||
|-------|------|-------|--------|-----------|
|
||||
| 1 | Cross Sell PRO w koszyku | 1 | Complete | 2026-03-31 |
|
||||
| 2 | Cross Sell PRO w zamowieniu | 1 | Complete | 2026-03-31 |
|
||||
|
||||
## Phase Details
|
||||
|
||||
### Phase 1: Cross Sell PRO w koszyku
|
||||
|
||||
**Goal:** Dostarczyc modul Prestashop wyswietlajacy karuzele produktow uzupelniajacych w koszyku z pelna obsluga produktow prostych i wariantowych.
|
||||
**Depends on:** Nothing (first phase)
|
||||
**Research:** Unlikely (Prestashop patterns sa znane)
|
||||
|
||||
**Scope:**
|
||||
- Integracja hooka koszyka i pobieranie powiazanych produktow.
|
||||
- Render sekcji karuzeli pod kontenerem koszyka z danymi produktow.
|
||||
- Logika CTA: add-to-cart dla produktow prostych, przekierowanie do produktu przy wariantach.
|
||||
|
||||
**Plans:**
|
||||
- [x] 01-01: Implementacja modulu Cross Sell PRO na stronie koszyka
|
||||
|
||||
### Phase 2: Cross Sell PRO w zamowieniu
|
||||
|
||||
**Goal:** Rozszerzyc modul o wyswietlanie karuzeli cross-sell na etapie zamowienia, po prawej stronie checkoutu.
|
||||
**Depends on:** Phase 1 (wykorzystanie logiki i komponentow z koszyka)
|
||||
**Research:** Unlikely (adaptacja istniejacego rozwiazania)
|
||||
|
||||
**Scope:**
|
||||
- Render sekcji cross-sell w bloku `#js-checkout-summary`.
|
||||
- Wstawienie sekcji przed obecna zawartoscia w tym kontenerze.
|
||||
- Zachowanie zachowania CTA jak w koszyku (warianty -> produkt, proste -> dodanie).
|
||||
|
||||
**Plans:**
|
||||
- [x] 02-01: Integracja karuzeli w checkout summary
|
||||
|
||||
---
|
||||
*Roadmap created: 2026-03-31 22:58*
|
||||
*Last updated: 2026-03-31 23:59*
|
||||
53
.paul/STATE.md
Normal file
53
.paul/STATE.md
Normal file
@@ -0,0 +1,53 @@
|
||||
# Project State
|
||||
|
||||
## Project Reference
|
||||
|
||||
See: .paul/PROJECT.md (updated 2026-03-31)
|
||||
|
||||
**Core value:** Klient koszyka szybciej dobiera produkty uzupelniajace i zwieksza wartosc zamowienia.
|
||||
**Current focus:** Milestone v0.1 complete - ready for next milestone planning
|
||||
|
||||
## Current Position
|
||||
|
||||
Milestone: v0.1 Cross Sell PRO dla koszyka (v0.1.0)
|
||||
Phase: Complete (2 of 2)
|
||||
Plan: 02-01 complete
|
||||
Status: Ready to start next milestone
|
||||
Last activity: 2026-03-31 23:59 - Phase 2 unified and milestone marked complete
|
||||
|
||||
Progress:
|
||||
- Milestone: [##########] 100%
|
||||
- Phase 2: [##########] 100%
|
||||
|
||||
## Loop Position
|
||||
|
||||
Current loop state:
|
||||
```
|
||||
PLAN --> APPLY --> UNIFY
|
||||
X X X [Loop complete - ready for next PLAN]
|
||||
```
|
||||
|
||||
## Accumulated Context
|
||||
|
||||
### Decisions
|
||||
| Decision | Phase | Impact |
|
||||
|----------|-------|--------|
|
||||
| 2026-03-31: Uzycie displayCheckoutSummaryTop dla checkout cross-sell | Phase 2 | Sekcja osadzona przed summary bez modyfikacji motywu |
|
||||
| 2026-03-31: Wspolny komponent cart/checkout przez crosssellpro_mode | Phase 2 | Jedna implementacja dla dwoch miejsc osadzenia |
|
||||
| 2026-03-31: Stabilizacja JS/CTA po testach produkcyjnych | Phase 2 | Usuniete regresje przy add/remove i karuzeli |
|
||||
|
||||
### Deferred Issues
|
||||
None.
|
||||
|
||||
### Blockers/Concerns
|
||||
None.
|
||||
|
||||
## Session Continuity
|
||||
|
||||
Last session: 2026-03-31 23:59
|
||||
Stopped at: Loop closed for plan 02-01 and milestone v0.1 complete
|
||||
Next action: Start next milestone planning (new scope) with $paul-new-milestone or $paul-plan
|
||||
Resume file: .paul/ROADMAP.md
|
||||
|
||||
---
|
||||
*STATE.md - Updated after every significant action*
|
||||
25
.paul/paul.json
Normal file
25
.paul/paul.json
Normal file
@@ -0,0 +1,25 @@
|
||||
{
|
||||
"name": "drmaterac.pl",
|
||||
"version": "0.1.0",
|
||||
"milestone": {
|
||||
"name": "v0.1 Cross Sell PRO dla koszyka",
|
||||
"version": "0.1.0",
|
||||
"status": "complete"
|
||||
},
|
||||
"phase": {
|
||||
"number": 2,
|
||||
"name": "Cross Sell PRO w zamowieniu",
|
||||
"status": "complete"
|
||||
},
|
||||
"loop": {
|
||||
"plan": null,
|
||||
"position": "IDLE"
|
||||
},
|
||||
"timestamps": {
|
||||
"created_at": "2026-03-31T22:58:20+02:00",
|
||||
"updated_at": "2026-03-31T23:59:56+02:00"
|
||||
},
|
||||
"satellite": {
|
||||
"groom": true
|
||||
}
|
||||
}
|
||||
154
.paul/phases/01-cross-sell-pro-koszyk/01-01-PLAN.md
Normal file
154
.paul/phases/01-cross-sell-pro-koszyk/01-01-PLAN.md
Normal file
@@ -0,0 +1,154 @@
|
||||
---
|
||||
phase: 01-cross-sell-pro-koszyk
|
||||
plan: 01
|
||||
type: execute
|
||||
wave: 1
|
||||
depends_on: []
|
||||
files_modified:
|
||||
- modules/crosssellpro/crosssellpro.php
|
||||
- modules/crosssellpro/views/templates/hook/cartCrossSell.tpl
|
||||
- modules/crosssellpro/views/js/cartCrossSell.js
|
||||
- modules/crosssellpro/views/css/cartCrossSell.css
|
||||
autonomous: false
|
||||
---
|
||||
|
||||
<objective>
|
||||
## Goal
|
||||
Zaimplementowac modul Cross Sell PRO, ktory na stronie koszyka wyswietla karuzele produktow uzupelniajacych pobieranych z relacji "Powiazany produkt" i poprawnie obsluguje dodawanie do koszyka/produkty wariantowe.
|
||||
|
||||
## Purpose
|
||||
Zwiekszyc srednia wartosc koszyka i ulatwic klientowi kompletowanie zamowienia bez opuszczania flow koszyka.
|
||||
|
||||
## Output
|
||||
Dzialajacy modul Prestashop 1.7.8.11 (PHP 7.4) z hookiem koszyka, warstwa widoku karuzeli i logika CTA zalezna od typu produktu.
|
||||
</objective>
|
||||
|
||||
<context>
|
||||
## Project Context
|
||||
@.paul/PROJECT.md
|
||||
@.paul/ROADMAP.md
|
||||
@.paul/STATE.md
|
||||
|
||||
## Source Files
|
||||
@modules/
|
||||
@controllers/
|
||||
@themes/
|
||||
</context>
|
||||
|
||||
<acceptance_criteria>
|
||||
|
||||
## AC-1: Render sekcji Cross Sell pod kontenerem koszyka
|
||||
```gherkin
|
||||
Given Uzytkownik otwiera strone koszyka /koszyk?action=show
|
||||
When Strona koszyka sie renderuje
|
||||
Then Pod elementem "div.card.cart-container" widoczna jest sekcja Cross Sell PRO
|
||||
```
|
||||
|
||||
## AC-2: Produkty sa pobierane z relacji "Powiazany produkt"
|
||||
```gherkin
|
||||
Given Produkt bazowy w koszyku ma zdefiniowane produkty powiazane w Prestashop
|
||||
When Modul buduje liste podpowiedzi
|
||||
Then Karuzela pokazuje tylko produkty pochodzace z tych relacji
|
||||
```
|
||||
|
||||
## AC-3: Karuzela pokazuje wymagane dane produktu
|
||||
```gherkin
|
||||
Given Lista cross-sell zawiera co najmniej 1 produkt
|
||||
When Sekcja Cross Sell sie wyswietla
|
||||
Then Kazdy slajd zawiera zdjecie, nazwe, cene i przycisk "Dodaj do koszyka"
|
||||
```
|
||||
|
||||
## AC-4: Poprawne zachowanie CTA dla wariantow
|
||||
```gherkin
|
||||
Given Produkt cross-sell ma kombinacje i wymaga wyboru wariantu
|
||||
When Uzytkownik klika przycisk CTA
|
||||
Then Uzytkownik zostaje przekierowany na strone produktu zamiast szybkiego add-to-cart
|
||||
```
|
||||
|
||||
## AC-5: Poprawne zachowanie CTA dla produktow prostych
|
||||
```gherkin
|
||||
Given Produkt cross-sell nie wymaga wyboru wariantu
|
||||
When Uzytkownik klika przycisk "Dodaj do koszyka"
|
||||
Then Produkt jest dodawany do koszyka bezposrednio z sekcji Cross Sell
|
||||
```
|
||||
|
||||
</acceptance_criteria>
|
||||
|
||||
<tasks>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 1: Utworzyc szkielet modulu i logike pobierania produktow cross-sell</name>
|
||||
<files>modules/crosssellpro/crosssellpro.php</files>
|
||||
<action>
|
||||
Utworzyc modul Cross Sell PRO zgodny z Prestashop 1.7.8.11 i PHP 7.4.
|
||||
Zarejestrowac odpowiedni hook koszyka oraz pobieranie danych produktow z relacji "Powiazany produkt" dla produktow znajdujacych sie aktualnie w koszyku.
|
||||
Zapewnic deduplikacje wynikow i odfiltrowanie produktow nieaktywnych/niedostepnych.
|
||||
Przygotowac dane do widoku: obrazek, nazwa, cena, URL produktu, flaga czy produkt ma warianty, parametry add-to-cart dla produktow prostych.
|
||||
Unikac modyfikacji plikow core Prestashop - cala logika musi byc kapsulowana w module.
|
||||
</action>
|
||||
<verify>Instalacja modulu przebiega bez bledow, hook zwraca kolekcje danych cross-sell dla koszyka testowego.</verify>
|
||||
<done>AC-2 satisfied; AC-5 preconditions prepared.</done>
|
||||
</task>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 2: Zbudowac widok karuzeli i frontend CTA</name>
|
||||
<files>modules/crosssellpro/views/templates/hook/cartCrossSell.tpl, modules/crosssellpro/views/js/cartCrossSell.js, modules/crosssellpro/views/css/cartCrossSell.css</files>
|
||||
<action>
|
||||
Zaimplementowac sekcje UI renderowana pod "card cart-container" z ukladem karuzeli.
|
||||
W slajdzie pokazac: zdjecie, nazwe, cene i przycisk CTA.
|
||||
Dodac JS obslugujacy przewijanie karuzeli i klikniecia CTA.
|
||||
Dla produktow z wariantami CTA wykonuje przekierowanie na URL produktu.
|
||||
Dla produktow prostych CTA uruchamia add-to-cart (POST lub link zgodny ze standardem Prestashop).
|
||||
Dodac stylowanie responsywne desktop/mobile i podstawowy fallback (lista bez JS).
|
||||
</action>
|
||||
<verify>Manualny test na /koszyk?action=show potwierdza render sekcji i oba scenariusze CTA (wariant/bez wariantu).</verify>
|
||||
<done>AC-1, AC-3, AC-4, AC-5 satisfied.</done>
|
||||
</task>
|
||||
|
||||
<task type="checkpoint:human-verify" gate="blocking">
|
||||
<what-built>Modul Cross Sell PRO z sekcja karuzeli na stronie koszyka i logika CTA zalezna od wariantow.</what-built>
|
||||
<how-to-verify>
|
||||
1. Zainstaluj i wlacz modul Cross Sell PRO w zapleczu Prestashop.
|
||||
2. Dodaj do koszyka produkt, ktory ma zdefiniowane "Powiazane produkty".
|
||||
3. Otworz: https://drmaterac.pl/koszyk?action=show
|
||||
4. Sprawdz, czy sekcja jest pod "card cart-container" i czy slajdy zawieraja obraz, nazwe, cene, CTA.
|
||||
5. Kliknij CTA produktu prostego: powinien wejsc do koszyka.
|
||||
6. Kliknij CTA produktu z wariantami: powinno byc przekierowanie do strony produktu.
|
||||
</how-to-verify>
|
||||
<resume-signal>Type "approved" to continue, or describe issues to fix</resume-signal>
|
||||
</task>
|
||||
|
||||
</tasks>
|
||||
|
||||
<boundaries>
|
||||
|
||||
## DO NOT CHANGE
|
||||
- Core Prestashop poza katalogiem modules/crosssellpro/*
|
||||
- Istniejace modyfikacje checkoutu niezwiązane z Cross Sell PRO
|
||||
|
||||
## SCOPE LIMITS
|
||||
- Bez zmian w logice zamowienia, platnosci i dostawy.
|
||||
- Bez rozbudowanego panelu konfiguracji modulu poza minimum potrzebnym do uruchomienia.
|
||||
- Bez przebudowy layoutu calej strony koszyka.
|
||||
|
||||
</boundaries>
|
||||
|
||||
<verification>
|
||||
Before declaring plan complete:
|
||||
- [ ] Modul instaluje sie i aktywuje bez bledow PHP 7.4.
|
||||
- [ ] Sekcja renderuje sie na /koszyk?action=show pod "card cart-container".
|
||||
- [ ] Dane produktow pochodza z relacji "Powiazany produkt".
|
||||
- [ ] CTA dziala poprawnie dla produktow prostych i wariantowych.
|
||||
- [ ] Widok jest czytelny na desktopie i mobile.
|
||||
</verification>
|
||||
|
||||
<success_criteria>
|
||||
- All tasks completed
|
||||
- All verification checks pass
|
||||
- No errors or warnings introduced
|
||||
- Cross Sell PRO dziala zgodnie z wymaganiami biznesowymi koszyka
|
||||
</success_criteria>
|
||||
|
||||
<output>
|
||||
After completion, create `.paul/phases/01-cross-sell-pro-koszyk/01-01-SUMMARY.md`
|
||||
</output>
|
||||
157
.paul/phases/02-cross-sell-pro-w-zamowieniu/02-01-PLAN.md
Normal file
157
.paul/phases/02-cross-sell-pro-w-zamowieniu/02-01-PLAN.md
Normal file
@@ -0,0 +1,157 @@
|
||||
---
|
||||
phase: 02-cross-sell-pro-w-zamowieniu
|
||||
plan: 01
|
||||
type: execute
|
||||
wave: 1
|
||||
depends_on: ["01-01"]
|
||||
files_modified:
|
||||
- modules/crosssellpro/crosssellpro.php
|
||||
- modules/crosssellpro/views/templates/hook/checkoutCrossSell.tpl
|
||||
- modules/crosssellpro/views/templates/hook/cartCrossSell.tpl
|
||||
- modules/crosssellpro/views/js/cartCrossSell.js
|
||||
- modules/crosssellpro/views/css/cartCrossSell.css
|
||||
autonomous: false
|
||||
---
|
||||
|
||||
<objective>
|
||||
## Goal
|
||||
Rozszerzyc modul Cross Sell PRO o wyswietlanie karuzeli na stronie zamowienia (`/zamowienie`) po prawej stronie checkoutu, wewnatrz `#js-checkout-summary`, przed obecna zawartoscia podsumowania.
|
||||
|
||||
## Purpose
|
||||
Zwikszyc szanse dosprzedazy takze na etapie checkoutu, gdy klient finalizuje zamowienie i widzi podsumowanie koszyka.
|
||||
|
||||
## Output
|
||||
Dzialajaca sekcja cross-sell w checkout summary, z danymi z relacji "Powiazany produkt" i zgodnym zachowaniem CTA (wariant/prosty), bez regresji sekcji koszyka.
|
||||
</objective>
|
||||
|
||||
<context>
|
||||
## Project Context
|
||||
@.paul/PROJECT.md
|
||||
@.paul/ROADMAP.md
|
||||
@.paul/STATE.md
|
||||
|
||||
## Prior Work
|
||||
@.paul/phases/01-cross-sell-pro-koszyk/01-01-PLAN.md
|
||||
|
||||
## Source Files
|
||||
@modules/crosssellpro/crosssellpro.php
|
||||
@modules/crosssellpro/views/templates/hook/cartCrossSell.tpl
|
||||
@modules/crosssellpro/views/js/cartCrossSell.js
|
||||
@modules/crosssellpro/views/css/cartCrossSell.css
|
||||
@themes/leo_gstore/templates/checkout/_partials/cart-summary.tpl
|
||||
</context>
|
||||
|
||||
<acceptance_criteria>
|
||||
|
||||
## AC-1: Render sekcji w checkout summary przed obecna zawartoscia
|
||||
```gherkin
|
||||
Given Uzytkownik otwiera strone zamowienia /zamowienie
|
||||
When Renderuje sie blok #js-checkout-summary
|
||||
Then Sekcja Cross Sell PRO jest wyswietlona wewnatrz tego bloku przed aktualna zawartoscia podsumowania
|
||||
```
|
||||
|
||||
## AC-2: Checkout korzysta z danych "Powiazany produkt"
|
||||
```gherkin
|
||||
Given W koszyku sa produkty z uzupelnionymi relacjami "Powiazany produkt"
|
||||
When Modul buduje sekcje cross-sell na checkout
|
||||
Then Wyswietlone pozycje pochodza z tych relacji i pomijaja produkty juz obecne w koszyku
|
||||
```
|
||||
|
||||
## AC-3: CTA dziala poprawnie na checkout
|
||||
```gherkin
|
||||
Given Klient klika CTA w sekcji Cross Sell PRO na checkout
|
||||
When Produkt jest prosty
|
||||
Then Produkt jest dodawany do koszyka bez utraty mozliwosci usuwania pozycji
|
||||
```
|
||||
|
||||
## AC-4: Produkty z wariantami kieruja do strony produktu
|
||||
```gherkin
|
||||
Given Produkt cross-sell wymaga wyboru wariantu
|
||||
When Klient kliknie CTA
|
||||
Then Nastapi przekierowanie do karty produktu
|
||||
```
|
||||
|
||||
## AC-5: Brak regresji karuzeli na stronie koszyka
|
||||
```gherkin
|
||||
Given Sekcja Cross Sell PRO istnieje juz na stronie koszyka
|
||||
When Wdrozenie checkoutowej wersji zostanie zakonczone
|
||||
Then Karuzela na /koszyk?action=show nadal dziala jak przed zmianami
|
||||
```
|
||||
|
||||
</acceptance_criteria>
|
||||
|
||||
<tasks>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 1: Rozszerzyc modul o hook checkout summary top</name>
|
||||
<files>modules/crosssellpro/crosssellpro.php</files>
|
||||
<action>
|
||||
Dodac rejestracje i obsluge hooka `displayCheckoutSummaryTop` w module.
|
||||
W metodzie hooka przygotowac dane produktowe cross-sell analogicznie do koszyka, ale zoptymalizowane pod checkout.
|
||||
Zapewnic, ze render checkoutowy nie modyfikuje core ani szablonow motywu, tylko korzysta z hooka obecnego w `cart-summary.tpl`.
|
||||
Utrzymac kompatybilnosc z Prestashop 1.7.8.11 i PHP 7.4.
|
||||
</action>
|
||||
<verify>Na checkout hook zwraca HTML sekcji, a w przypadku pustej listy zwraca pusty output bez bledow.</verify>
|
||||
<done>AC-1 i AC-2 przygotowane po stronie backend.</done>
|
||||
</task>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 2: Dodac widok checkout i dopasowac frontend karuzeli</name>
|
||||
<files>modules/crosssellpro/views/templates/hook/checkoutCrossSell.tpl, modules/crosssellpro/views/templates/hook/cartCrossSell.tpl, modules/crosssellpro/views/js/cartCrossSell.js, modules/crosssellpro/views/css/cartCrossSell.css</files>
|
||||
<action>
|
||||
Utworzyc dedykowany szablon checkoutowy osadzany przez `displayCheckoutSummaryTop` tak, aby sekcja byla renderowana przed aktualna zawartoscia `#js-checkout-summary`.
|
||||
Zrefaktoryzowac wspolne elementy karuzeli, aby dzialaly i w koszyku, i w checkout, bez konfliktow selektorow.
|
||||
Zachowac poprawne CTA: produkty proste dodaja sie do koszyka, produkty wariantowe przechodza na karte produktu.
|
||||
Upewnic sie, ze dzialanie checkoutowej sekcji nie psuje usuwania pozycji i aktualizacji podsumowania.
|
||||
</action>
|
||||
<verify>Manualny test na /zamowienie i /koszyk?action=show potwierdza poprawny render, dodawanie i brak regresji.</verify>
|
||||
<done>AC-1, AC-3, AC-4, AC-5 satisfied.</done>
|
||||
</task>
|
||||
|
||||
<task type="checkpoint:human-verify" gate="blocking">
|
||||
<what-built>Cross Sell PRO w checkout summary (`#js-checkout-summary`) oraz utrzymana kompatybilnosc dotychczasowej sekcji koszyka.</what-built>
|
||||
<how-to-verify>
|
||||
1. Otworz: https://drmaterac.pl/zamowienie
|
||||
2. Sprawdz, czy sekcja Cross Sell jest po prawej, w `#js-checkout-summary`, przed aktualnym summary.
|
||||
3. Kliknij CTA produktu prostego i potwierdz dodanie do koszyka.
|
||||
4. Usun dodany produkt z koszyka i potwierdz, ze nie wraca automatycznie.
|
||||
5. Kliknij CTA produktu wariantowego i potwierdz przejscie na strone produktu.
|
||||
6. Wejdz na https://drmaterac.pl/koszyk?action=show i potwierdz, ze karuzela koszykowa nadal dziala.
|
||||
</how-to-verify>
|
||||
<resume-signal>Type "approved" to continue, or describe issues to fix</resume-signal>
|
||||
</task>
|
||||
|
||||
</tasks>
|
||||
|
||||
<boundaries>
|
||||
|
||||
## DO NOT CHANGE
|
||||
- Pliki core Prestashop poza modulem `modules/crosssellpro/*`
|
||||
- Szablony motywu poza wykorzystaniem istniejacego hooka `displayCheckoutSummaryTop`
|
||||
|
||||
## SCOPE LIMITS
|
||||
- Brak zmian w logice platnosci, dostawy i finalizacji zamowienia
|
||||
- Brak przebudowy calego checkout layoutu
|
||||
- Brak dodatkowego panelu konfiguracji na tym etapie
|
||||
|
||||
</boundaries>
|
||||
|
||||
<verification>
|
||||
Before declaring plan complete:
|
||||
- [ ] Sekcja wyswietla sie na /zamowienie wewnatrz `#js-checkout-summary` przed summary content.
|
||||
- [ ] Produkty pochodza z relacji "Powiazany produkt".
|
||||
- [ ] CTA produktow prostych dodaje do koszyka bez regresji usuwania.
|
||||
- [ ] CTA produktow wariantowych kieruje na strone produktu.
|
||||
- [ ] Dotychczasowa sekcja cross-sell na koszyku nadal dziala.
|
||||
</verification>
|
||||
|
||||
<success_criteria>
|
||||
- All tasks completed
|
||||
- All verification checks pass
|
||||
- No errors or warnings introduced
|
||||
- Cross Sell PRO dziala w koszyku i checkout bez konfliktow
|
||||
</success_criteria>
|
||||
|
||||
<output>
|
||||
After completion, create `.paul/phases/02-cross-sell-pro-w-zamowieniu/02-01-SUMMARY.md`
|
||||
</output>
|
||||
118
.paul/phases/02-cross-sell-pro-w-zamowieniu/02-01-SUMMARY.md
Normal file
118
.paul/phases/02-cross-sell-pro-w-zamowieniu/02-01-SUMMARY.md
Normal file
@@ -0,0 +1,118 @@
|
||||
---
|
||||
phase: 02-cross-sell-pro-w-zamowieniu
|
||||
plan: 01
|
||||
subsystem: ui
|
||||
tags: [prestashop, checkout, cross-sell, carousel, cart]
|
||||
requires:
|
||||
- phase: 01-cross-sell-pro-koszyk
|
||||
provides: Bazowa logika pobierania produktow powiazanych i CTA
|
||||
provides:
|
||||
- Cross Sell PRO w checkout summary (#js-checkout-summary)
|
||||
- Wspolny render karuzeli dla koszyka i checkout
|
||||
- Stabilna obsluga CTA bez regresji usuwania z koszyka
|
||||
affects: [checkout, cart, cross-sell]
|
||||
tech-stack:
|
||||
added: []
|
||||
patterns: [Hook-driven rendering, shared template with mode switch]
|
||||
key-files:
|
||||
created:
|
||||
- modules/crosssellpro/views/templates/hook/checkoutCrossSell.tpl
|
||||
modified:
|
||||
- modules/crosssellpro/crosssellpro.php
|
||||
- modules/crosssellpro/views/templates/hook/cartCrossSell.tpl
|
||||
- modules/crosssellpro/views/js/cartCrossSell.js
|
||||
- modules/crosssellpro/views/css/cartCrossSell.css
|
||||
key-decisions:
|
||||
- "Uzycie displayCheckoutSummaryTop zamiast modyfikacji motywu"
|
||||
- "Rozdzielenie trybow cart/checkout przez data attributes"
|
||||
patterns-established:
|
||||
- "Wspolny komponent karuzeli sterowany przez crosssellpro_mode"
|
||||
- "Defensywna obsluga eventow i fallback add-to-cart"
|
||||
duration: 21min
|
||||
started: 2026-03-31T23:38:00+02:00
|
||||
completed: 2026-03-31T23:59:56+02:00
|
||||
---
|
||||
|
||||
# Phase 2 Plan 01: Checkout Cross Sell Summary
|
||||
|
||||
Cross Sell PRO zostal rozszerzony o dzialanie na etapie zamowienia i osadzony w prawym panelu `#js-checkout-summary` przed aktualna zawartoscia.
|
||||
|
||||
## Performance
|
||||
|
||||
| Metric | Value |
|
||||
|--------|-------|
|
||||
| Duration | 21 min |
|
||||
| Started | 2026-03-31T23:38:00+02:00 |
|
||||
| Completed | 2026-03-31T23:59:56+02:00 |
|
||||
| Tasks | 2 completed + 1 checkpoint approved |
|
||||
| Files modified | 5 |
|
||||
|
||||
## Acceptance Criteria Results
|
||||
|
||||
| Criterion | Status | Notes |
|
||||
|-----------|--------|-------|
|
||||
| AC-1: Render sekcji w checkout summary przed obecna zawartoscia | Pass | Sekcja jest renderowana przez hook `displayCheckoutSummaryTop` w `#js-checkout-summary`. |
|
||||
| AC-2: Checkout korzysta z danych "Powiazany produkt" | Pass | Zastosowano te sama logike zbierania produktow powiazanych co w koszyku. |
|
||||
| AC-3: CTA dziala poprawnie na checkout | Pass | Dodawanie produktu prostego dziala bez regresji usuwania z koszyka. |
|
||||
| AC-4: Produkty z wariantami kieruja do strony produktu | Pass | CTA wariantow kieruje na URL produktu. |
|
||||
| AC-5: Brak regresji karuzeli na stronie koszyka | Pass | Po poprawkach potwierdzono poprawne dzialanie takze na `/koszyk?action=show`. |
|
||||
|
||||
## Accomplishments
|
||||
|
||||
- Wdrozono checkoutowy punkt wejscia cross-sell bez ingerencji w core i bez zmian plikow motywu.
|
||||
- Ujednolicono rendering karuzeli miedzy koszykiem i checkoutem.
|
||||
- Ustabilizowano zachowanie add-to-cart/usuwania oraz reakcje przyciskow karuzeli.
|
||||
|
||||
## Files Created/Modified
|
||||
|
||||
| File | Change | Purpose |
|
||||
|------|--------|---------|
|
||||
| `modules/crosssellpro/crosssellpro.php` | Modified | Rejestracja i obsluga hookow checkout/cart, assety, routing trybow. |
|
||||
| `modules/crosssellpro/views/templates/hook/checkoutCrossSell.tpl` | Created | Checkoutowy punkt renderu sekcji cross-sell. |
|
||||
| `modules/crosssellpro/views/templates/hook/cartCrossSell.tpl` | Modified | Wspolny szablon komponentu i data-attributes dla trybow. |
|
||||
| `modules/crosssellpro/views/js/cartCrossSell.js` | Modified | Obsluga strzalek i add-to-cart dla cart/checkout. |
|
||||
| `modules/crosssellpro/views/css/cartCrossSell.css` | Modified | Dostosowanie wygladu checkout (bez ramki, slajd 100%). |
|
||||
|
||||
## Decisions Made
|
||||
|
||||
| Decision | Rationale | Impact |
|
||||
|----------|-----------|--------|
|
||||
| Hook `displayCheckoutSummaryTop` jako punkt osadzenia | Zapewnia pozycje "przed obecna zawartoscia" i zgodnosc z motywem | Brak potrzeby modyfikacji `themes/` |
|
||||
| Rozdzielenie trybow przez `crosssellpro_mode` | Jeden komponent dla dwoch miejsc osadzenia | Mniej duplikacji i prostsze utrzymanie |
|
||||
| Utrzymanie fallbackow dla add-to-cart | W praktyce niweluje problemy z cache/refresh checkoutu | Stabilniejsze UX w produkcji |
|
||||
|
||||
## Deviations from Plan
|
||||
|
||||
### Summary
|
||||
|
||||
| Type | Count | Impact |
|
||||
|------|-------|--------|
|
||||
| Auto-fixed | 4 | Niezbedne poprawki stabilnosci bez scope creep |
|
||||
| Scope additions | 0 | Brak |
|
||||
| Deferred | 0 | Brak |
|
||||
|
||||
**Total impact:** Wymagane poprawki integracyjne z motywem Leo i cache frontend, finalnie bez zmiany celu fazy.
|
||||
|
||||
## Issues Encountered
|
||||
|
||||
| Issue | Resolution |
|
||||
|-------|------------|
|
||||
| Karuzela w checkout renderowala sie jako lista pionowa | Wymuszono checkout-specific layout i usunieto kolidujace style inline. |
|
||||
| Dodawanie produktu powodowalo regresje usuwania z koszyka | Przebudowano flow CTA i powroty URL po dodaniu. |
|
||||
| Brak reakcji strzalek po niektorych odswiezeniach | Ustabilizowano bindowanie JS i asset loading dla `cart/order`. |
|
||||
|
||||
## Next Phase Readiness
|
||||
|
||||
**Ready:**
|
||||
- Modul obsluguje cross-sell na koszyku i checkout.
|
||||
- Hooki i szablony sa przygotowane do dalszych iteracji (np. konfiguracja BO).
|
||||
|
||||
**Concerns:**
|
||||
- Brak.
|
||||
|
||||
**Blockers:**
|
||||
- None.
|
||||
|
||||
---
|
||||
*Phase: 02-cross-sell-pro-w-zamowieniu, Plan: 01*
|
||||
*Completed: 2026-03-31*
|
||||
Reference in New Issue
Block a user