update
This commit is contained in:
173
.paul/plans/20260519-0928-fix-cookie-injectscripts/PLAN.md
Normal file
173
.paul/plans/20260519-0928-fix-cookie-injectscripts/PLAN.md
Normal file
@@ -0,0 +1,173 @@
|
||||
---
|
||||
plan_id: 20260519-0928-fix-cookie-injectscripts
|
||||
title: Naprawa bledu injectScripts w Cookie Notice Pro
|
||||
storage: plan-first
|
||||
legacy_phase: null
|
||||
created: 2026-05-19T09:28:06+02:00
|
||||
status: applied
|
||||
type: execute
|
||||
autonomous: true
|
||||
delegation: auto
|
||||
files_modified:
|
||||
- wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js
|
||||
quality_radar: degraded
|
||||
---
|
||||
|
||||
<objective>
|
||||
## Goal
|
||||
Usunac blad JavaScript `Uncaught ReferenceError: injectScripts is not defined` wystepujacy po kliknieciu przycisku akceptacji cookies.
|
||||
|
||||
## Purpose
|
||||
Blad przerywa sciezke akceptacji cookies i moze blokowac poprawne zapisanie preferencji oraz aktualizacje Google Consent Mode.
|
||||
|
||||
## Output
|
||||
Zmodyfikowany plik `wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js` z lokalna, bezpieczna obsluga brakujacego `injectScripts()`.
|
||||
</objective>
|
||||
|
||||
<context>
|
||||
## Project Docs
|
||||
@.paul/PROJECT.md
|
||||
@.paul/STATE.md
|
||||
@.paul/config.md
|
||||
@.paul/codebase/impact_map.md
|
||||
@.paul/codebase/quality_risks.md
|
||||
@.paul/codebase/tooling_status.md
|
||||
|
||||
## Source Files
|
||||
@wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js
|
||||
@wp-content/mu-plugins/cookie-notice-pro/cookie-notice-pro.php
|
||||
</context>
|
||||
|
||||
<clarifications>
|
||||
- Brak dodatkowych wyjasnien wymaganych. Komunikat z konsoli wskazuje dokladny blad i plik.
|
||||
- Uzytkownik wskazal poprzednia instancje `c:\visual studio code\projekty\luxmedkrakow.pl\`; tam poprawka polegala na dodaniu `const injectScripts = () => {};` w `cookienoticepro.script.js`.
|
||||
- Porownanie sekcji `googleConsentModeHandler()` pokazalo, ze obsluga `analytics_storage` jest zgodna z referencja. Pelne kopiowanie skryptu nie jest zalecane, bo referencja zawiera inne roznice konfiguracyjne i dodatkowa obsluge `functionality_storage`/`personalization_storage`.
|
||||
</clarifications>
|
||||
|
||||
<impact_scan>
|
||||
## Quality Radar
|
||||
|
||||
**Status:** degraded
|
||||
**Tools:** codebase-memory-mcp dostepny, ale projekt nie jest widoczny w rejestrze MCP przy odczycie; `jscpd` i `ast-grep` sa disabled by policy.
|
||||
|
||||
## Affected Areas
|
||||
|
||||
- `wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js` - glowna logika banera cookies, preferencji i Google Consent Mode.
|
||||
- `wp-content/mu-plugins/cookie-notice-pro/cookie-notice-pro.php` - ladowanie skryptu i inicjalizacja `window.cookieNoticePro.init()` w stopce.
|
||||
- Publiczna strona WordPress - `mu-plugin` laduje sie globalnie.
|
||||
- Referencja: `c:\visual studio code\projekty\luxmedkrakow.pl\wp-content\mu-plugins\cookie-notice-pro\assets\cookienoticepro.script.js:401` zawiera sprawdzona poprawke `const injectScripts = () => {};`.
|
||||
- Referencyjna sekcja `analytics_storage` dziala tak samo jak w tej instancji; wymaganie analityki po odswiezeniu powinno byc zweryfikowane manualnie po przeniesieniu brakujacej funkcji.
|
||||
|
||||
## Duplicate / Hardcoded Risks
|
||||
|
||||
- Konfiguracja cookies i Google Consent Mode jest hardcoded w `cookienoticepro.script.js`; poprawka ma nie zmieniac wartosci konfiguracji.
|
||||
- Elementor i WordPress moga dodawac logike poza repozytorium; weryfikacja musi obejmowac zachowanie w przegladarce.
|
||||
|
||||
## Explicit Deferrals
|
||||
|
||||
- Pelne mapowanie repozytorium przez `$paul-map-codebase` odlozone, bo zakres poprawki jest waski i dotyczy jednego bledu runtime.
|
||||
- Nie wlaczamy `jscpd` ani `ast-grep`, bo sa wylaczone w `.paul/config.md`.
|
||||
- Nie kopiujemy calego pliku z `luxmedkrakow.pl`, bo zawiera inne roznice konfiguracji i logiki consent. Przenosimy tylko minimalna poprawke brakujacej funkcji.
|
||||
- Jesli po wdrozeniu minimalnej poprawki analityka nadal nie dziala po reloadzie, dopiero wtedy wykonac drugi, kontrolowany plan dla logiki Consent Mode zamiast podmieniac caly skrypt.
|
||||
</impact_scan>
|
||||
|
||||
<acceptance_criteria>
|
||||
|
||||
## AC-1: Klikniecie akceptacji nie powoduje ReferenceError
|
||||
```gherkin
|
||||
Given baner cookies jest widoczny i `showSettingsBtn` ma wartosc `true`
|
||||
When uzytkownik klika `#cookieAccept`
|
||||
Then konsola przegladarki nie pokazuje `Uncaught ReferenceError: injectScripts is not defined`
|
||||
And cookie zgody oraz preferencji sa nadal zapisywane
|
||||
```
|
||||
|
||||
## AC-2: Istniejaca obsluga Google Consent Mode zostaje zachowana
|
||||
```gherkin
|
||||
Given `enableGoogleConsentMode` ma wartosc `true`
|
||||
When uzytkownik akceptuje cookies albo wraca na strone z istniejaca zgoda
|
||||
Then `googleConsentModeHandler()` nadal wykonuje sie bez zmiany konfiguracji GTM ani wartosci zgody
|
||||
```
|
||||
|
||||
## AC-3: Analityka dziala po akceptacji zgody i odswiezeniu strony
|
||||
```gherkin
|
||||
Given uzytkownik zaakceptowal zgody cookies z wlaczona preferencja `analytics`
|
||||
When strona zostaje odswiezona
|
||||
Then zapisane `cnp_prefs` nadal zawiera `analytics`
|
||||
And Google Consent Mode ustawia `analytics_storage` na `granted`
|
||||
And tagi analityczne moga uruchomic sie przez GTM zgodnie z udzielona zgoda
|
||||
```
|
||||
|
||||
## AC-4: Panel preferencji nadal dziala
|
||||
```gherkin
|
||||
Given uzytkownik otwiera ustawienia cookies przez `#cookieSettings`, `#cookieReject` albo zminimalizowana ikone
|
||||
When wybiera preferencje i zatwierdza
|
||||
Then baner zapisuje wybrane preferencje i nie tworzy dodatkowych bledow JS
|
||||
```
|
||||
|
||||
</acceptance_criteria>
|
||||
|
||||
<tasks>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 1: Przenies minimalna poprawke injectScripts z poprzedniej instancji</name>
|
||||
<files>wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js</files>
|
||||
<action>
|
||||
Dodaj `const injectScripts = () => {};` w zakresie glownego IIFE, analogicznie do poprzedniej instancji `luxmedkrakow.pl`, najlepiej przed `changeRootVariables`. Nie kopiuj calego pliku referencyjnego i nie zmieniaj konfiguracji, tekstow, linkow ani logiki `googleConsentModeHandler()`.
|
||||
</action>
|
||||
<verify>rg -n "const injectScripts|function injectScripts|injectScripts\\(" wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js</verify>
|
||||
<done>Spelnia AC-1 i nie zmienia konfiguracji z AC-2 oraz AC-3.</done>
|
||||
</task>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 2: Zweryfikuj zachowanie analityki po reloadzie</name>
|
||||
<files>wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js</files>
|
||||
<action>
|
||||
Sprawdz, czy aktualna sciezka po zaakceptowaniu cookies zapisuje `analytics` w `cnp_prefs`, a po odswiezeniu strony `googleConsentModeHandler()` odczytuje te preferencje i ustawia `analytics_storage: granted`. Jezeli samo dodanie no-op `injectScripts` nie wystarczy, popraw tylko minimalny fragment odpowiedzialny za odczyt/zapis preferencji albo kolejnosc wywolania `googleConsentModeHandler()`. Nie zmieniaj nazw cookies ani konfiguracji GTM.
|
||||
</action>
|
||||
<verify>Manualnie: wyczysc `cnp_*`, zaakceptuj zgody, odswiez strone, sprawdz `cnp_prefs` i Consent Mode dla `analytics_storage`.</verify>
|
||||
<done>Spelnia AC-2 i AC-3 bez rozszerzania zakresu poza cookies/consent.</done>
|
||||
</task>
|
||||
|
||||
<task type="auto">
|
||||
<name>Task 3: Zweryfikuj brak regresji runtime</name>
|
||||
<files>wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js, wp-content/mu-plugins/cookie-notice-pro/cookie-notice-pro.php</files>
|
||||
<action>
|
||||
Sprawdz skladnie i sciezke inicjalizacji: PHP nadal laduje `cnp-script`, footer nadal wywoluje `window.cookieNoticePro.init()`, a JS nadal eksportuje `window.cookieNoticePro`.
|
||||
</action>
|
||||
<verify>php -l wp-content/mu-plugins/cookie-notice-pro/cookie-notice-pro.php; rg -n "window\\.cookieNoticePro|injectScripts|googleConsentModeHandler" wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js</verify>
|
||||
<done>Spelnia AC-2, AC-3 i potwierdza, ze poprawka nie narusza inicjalizacji pluginu.</done>
|
||||
</task>
|
||||
|
||||
</tasks>
|
||||
|
||||
<boundaries>
|
||||
## Do Not Change
|
||||
- Nie zmieniac `wp-config.php`.
|
||||
- Nie zmieniac `CNP_GTM_ID`.
|
||||
- Nie zmieniac wartosci cookie names: `cnp_consent`, `cnp_prefs`, `cnp_gconsent_ad_prefs`, `cnp_gconsent_analytics_storage`.
|
||||
- Nie przebudowywac wygladu banera ani tekstow prawnych.
|
||||
|
||||
## Scope Limits
|
||||
- Zakres obejmuje naprawe bledu `injectScripts is not defined`.
|
||||
- Pelna refaktoryzacja Cookie Notice Pro jest poza zakresem.
|
||||
- Integracje z dodatkowymi skryptami marketingowymi/analitycznymi sa poza zakresem, chyba ze istnieja juz w tym pliku.
|
||||
</boundaries>
|
||||
|
||||
<verification>
|
||||
- [ ] `rg -n "injectScripts" wp-content/mu-plugins/cookie-notice-pro/assets/cookienoticepro.script.js` pokazuje definicje i kontrolowane wywolania.
|
||||
- [ ] `php -l wp-content/mu-plugins/cookie-notice-pro/cookie-notice-pro.php` przechodzi.
|
||||
- [ ] Manualnie w przegladarce: wyczysc cookies `cnp_*`, odswiez strone, kliknij `Akceptuj`, sprawdz brak `ReferenceError`.
|
||||
- [ ] Manualnie w przegladarce: po kliknieciu `Akceptuj` odswiez strone i sprawdz, ze analityka ma zgode `analytics_storage: granted`.
|
||||
- [ ] Manualnie w przegladarce: otworz ustawienia cookies i zatwierdz preferencje, sprawdz brak nowych bledow JS.
|
||||
- [ ] Quality Radar relevant risks handled or deferred.
|
||||
</verification>
|
||||
|
||||
<success_criteria>
|
||||
- [ ] Wszystkie AC przechodza.
|
||||
- [ ] Weryfikacja wykonana lub brak mozliwosci weryfikacji opisany w SUMMARY.md.
|
||||
- [ ] `.paul/codebase/impact_map.md` i `.paul/codebase/tooling_status.md` zostaly odswiezone, jezeli w apply pojawia sie istotna zmiana zakresu.
|
||||
</success_criteria>
|
||||
|
||||
<output>
|
||||
SUMMARY.md path: `.paul/plans/20260519-0928-fix-cookie-injectscripts/SUMMARY.md`
|
||||
</output>
|
||||
Reference in New Issue
Block a user