feat(02-registration-dictionary-phrases): dictionary-backed registration text

Phase 2 complete:

- Seed registration dictionary phrases

- Update public and admin registration templates to use translations

- Document PAUL plan, apply, summary, and changelog
This commit is contained in:
2026-04-24 21:35:17 +02:00
parent 2cf4715914
commit 6ef8b0029d
13 changed files with 1033 additions and 189 deletions

View File

@@ -1,4 +1,12 @@
<h1>Konferencja - Rejestracja</h1>
{assign var=registrationYes value='registration_yes'|translate}
{assign var=registrationNo value='registration_no'|translate}
{assign var=registrationMissing value='registration_missing'|translate}
{assign var=registrationParticipationFull value='registration_participation_full'|translate}
{assign var=registrationParticipationLodging value='registration_participation_one_day_lodging'|translate}
{assign var=registrationParticipationNoLodging value='registration_participation_one_day_no_lodging'|translate}
{assign var=registrationDietStandardShort value='registration_diet_standard_short'|translate}
{assign var=registrationDietSpecialShort value='registration_diet_special_short'|translate}
{dropDownContainer title='Zgłoszenia Rejestracji'}
{assign var="display" value=""}
@@ -16,12 +24,12 @@
<th><div style="float:left; width:100%">Lp.<div class="sort"><a class="ascendingAct" href="#">&nbsp;</a><a class="descending" href="#">&nbsp;</a></div></div></th>
<th>Imię</th>
<th>Nazwisko</th>
<th>Dane uczestnika</th>
<th>Dane instytucji</th>
<th>Dane wystąpienia</th>
<th {$display}>Do zapłaty</th>
<th>Zgody</th>
<th {$display}>Status opłaty</th>
<th>{'registration_participant_data'|translate}</th>
<th>{'registration_institution_data'|translate}</th>
<th>{'registration_presentation_data'|translate}</th>
<th {$display}>{'registration_amount_information'|translate}</th>
<th>{'registration_consents_expressed'|translate}</th>
<th {$display}>{'registration_payment_status'|translate}</th>
<th class="noSort">&nbsp;</div></th>
</tr>
{assign var=x value=0}
@@ -45,53 +53,53 @@
Kod pocztowy: {$obj->getPostCode()}</br>
Miejscowość: {$obj->getCity()}</br>
NIP Instytucji: {$obj->getNip()}</br></td>
<td>Referat: {$obj->getReferat()|replace:1:'Tak'|replace:0:'Nie'|replace:2:'Nie'}</br>
Poster: {$obj->getPoster()|replace:1:'Tak'|replace:0:'Nie'|replace:2:'Nie'}
<p>Temat: {$obj->getMessage()|default:'brak'}</p>
<p>Autor: {$obj->getAutor()|default:'brak'}</p>
<p>Typ udziału: {$obj->getParticipationOption()|replace:'full':'cała konferencja'|replace:'one_day_lodging':'jeden dzień konferencji (z noclegiem)'|replace:'one_day_no_lodging':'jeden dzień konferencji (bez noclegu)'|default:'brak'}</p>
<p>Dni: {if $obj->getParticipationDays()}{$obj->getParticipationDays()}{elseif $obj->GetFeeOneDay()}{$obj->GetFeeOneDay()}{else}brak{/if}</p>
<p>Dieta: {$obj->getDiet()|replace:1:'standardowa'|replace:2:'specjalna'|default:'brak'} {if $obj->getDietSpecial()}- {$obj->getDietSpecial()}{/if}</p>
<td>Referat: {$obj->getReferat()|replace:1:$registrationYes|replace:0:$registrationNo|replace:2:$registrationNo}</br>
Poster: {$obj->getPoster()|replace:1:$registrationYes|replace:0:$registrationNo|replace:2:$registrationNo}
<p>{'registration_topic'|translate}: {$obj->getMessage()|default:$registrationMissing}</p>
<p>{'registration_author'|translate}: {$obj->getAutor()|default:$registrationMissing}</p>
<p>{'registration_participation_type'|translate}: {$obj->getParticipationOption()|replace:'full':$registrationParticipationFull|replace:'one_day_lodging':$registrationParticipationLodging|replace:'one_day_no_lodging':$registrationParticipationNoLodging|default:$registrationMissing}</p>
<p>{'registration_days'|translate}: {if $obj->getParticipationDays()}{$obj->getParticipationDays()}{elseif $obj->GetFeeOneDay()}{$obj->GetFeeOneDay()}{else}{$registrationMissing}{/if}</p>
<p>{'registration_diet'|translate}: {$obj->getDiet()|replace:1:$registrationDietStandardShort|replace:2:$registrationDietSpecialShort|default:$registrationMissing} {if $obj->getDietSpecial()}- {$obj->getDietSpecial()}{/if}</p>
</td>
<td {$display}>Wybrane opcje:</br>
<td {$display}>{'registration_selected_options'|translate}:</br>
{if $discPrice == 2 || $obj->getDateAdd() > '2024-10-11 00:00:00'}
Opłata zwykła (płatność <b>po 11.10.2024</b>)
{'registration_fee_normal_2026'|translate}
{else}
Opłata obniżona (płatność <b>do 11.10.2024</b>)
{'registration_fee_discount_2026'|translate}
{/if}
<ul>
{foreach $arrayObjParameters as $objParam}
{if in_array($objParam->GetId(),$arrayFee)}
{if $discPrice == 2 || $obj->getDateAdd() > '2024-10-11 00:00:00'}
<li>{$objParam->GetName()} {if $objParam->GetId() eq 5}({$obj->GetFeeOneDay()}){/if}</br>
Cena netto: {$objParam->GetPrice()|number_format:2:",":" "} PLN</br>
Cena brutto: {assign var="vat" value=$objParam->GetPrice()*1.23}{$vat|number_format:2:",":" "} PLN</br>
{'registration_net_price'|translate}: {$objParam->GetPrice()|number_format:2:",":" "} PLN</br>
{'registration_gross_price'|translate}: {assign var="vat" value=$objParam->GetPrice()*1.23}{$vat|number_format:2:",":" "} PLN</br>
</li>
{else}
<li>{$objParam->GetName()} {if $objParam->GetId() eq 5}({$obj->GetFeeOneDay()}){/if}</br>
Cena netto (bez VAT): {$objParam->GetPriceProm()|number_format:2:",":" "} PLN</br>
Cena brutto (z VAT): {assign var="vat" value=$objParam->GetPriceProm()*1.23}{$vat|number_format:2:",":" "} PLN</br>
{'registration_net_price_no_vat'|translate}: {$objParam->GetPriceProm()|number_format:2:",":" "} PLN</br>
{'registration_gross_price_vat'|translate}: {assign var="vat" value=$objParam->GetPriceProm()*1.23}{$vat|number_format:2:",":" "} PLN</br>
</li>
{/if}
{/if}
{/foreach}
<h3>Razem do zapłaty:</h3>
<h3>{'registration_total_to_pay'|translate}:</h3>
{assign var="resultPrice" value=$obj->getPrice()}
Cena netto: {$resultPrice|number_format:2:",":" "} PLN</br>
Cena brutto: {assign var="resultPriceVat" value=$resultPrice*1.23}{$resultPriceVat|number_format:2:",":" "} PLN</br>
{'registration_net_price'|translate}: {$resultPrice|number_format:2:",":" "} PLN</br>
{'registration_gross_price'|translate}: {assign var="resultPriceVat" value=$resultPrice*1.23}{$resultPriceVat|number_format:2:",":" "} PLN</br>
</ul>
</td>
<td>Zgoda przetwarzanie danych: {$obj->GetAgree1()|replace:1:'Tak'|replace:0:'Nie'} </br>
Zgoda przetwarzanie wizerunku: {$obj->GetAgree2()|replace:1:'Tak'|replace:0:'Nie'}
<td>{'registration_consent_data'|translate}: {$obj->GetAgree1()|replace:1:$registrationYes|replace:0:$registrationNo} </br>
{'registration_consent_image'|translate}: {$obj->GetAgree2()|replace:1:$registrationYes|replace:0:$registrationNo}
</td>
<td {$display}>{$obj->GetStatus()|replace:2:'Tak'|replace:1:'Nie'}</td>
<td {$display}>{$obj->GetStatus()|replace:2:$registrationYes|replace:1:$registrationNo}</td>
<td style="width:15px">
{*<a href="{url Calc=Edit id=$id}" class="edit">edytuj</a><a href="{url Calc=Delete id=$id}" class="delete">usuń</a>*}
<a href="{url Calc=RegEdit id=$id}" class="edit">edytuj</a>
<a href="{url Calc=RegDelete id=$id location=1}" onclick="{literal}if (confirm('Czy napewno usunąć ten element?')) { } else {return false;}{/literal}" class="delete">usuń</a>
<a href="{url Calc=RegEdit id=$id}" class="edit">{'registration_edit'|translate}</a>
<a href="{url Calc=RegDelete id=$id location=1}" onclick="{literal}if (confirm('Czy napewno usunąć ten element?')) { } else {return false;}{/literal}" class="delete">{'registration_delete'|translate}</a>
</td>
</tr>
{/foreach}

View File

@@ -1,9 +1,17 @@
<h1>Edytuj zgłoszenie</h1>
<h1>Edytuj zgłoszenie</h1>
{assign var=registrationYes value='registration_yes'|translate}
{assign var=registrationNo value='registration_no'|translate}
{assign var=registrationMissing value='registration_missing'|translate}
{assign var=registrationParticipationFull value='registration_participation_full'|translate}
{assign var=registrationParticipationLodging value='registration_participation_one_day_lodging'|translate}
{assign var=registrationParticipationNoLodging value='registration_participation_one_day_no_lodging'|translate}
{assign var=registrationDietStandardShort value='registration_diet_standard_short'|translate}
{assign var=registrationDietSpecialShort value='registration_diet_special_short'|translate}
<script language="javascript" type="text/javascript">
urlStatic = '{$urlStatic}';
</script>
{assign var=id value=$obj->GetId()}
{assign var=id value=$obj->GetId()}
<form method="post" action="{url Calc='RegEdit' id=$obj->GetId()}" enctype="multipart/form-data">
{if isset($obj)}
<input type="hidden" name="id" value="{$obj->GetId()}" />
@@ -18,114 +26,105 @@ urlStatic = '{$urlStatic}';
<table width="100%" cellspacing="0" cellpadding="5" border="0" class="commonTable">
<tbody>
<tr>
<td>Dane uczestnika:</td>
<td>
Imię: {$objParticipant->getName()}</br>
Nazwisko: {$objParticipant->getSurname()}</br>
Tytuł/stop. naukowy:{$objParticipant->getDegree()}</br>
Stanowisko: {$objParticipant->getPosition()|default:'brak'}</br>
Telefon: {$objParticipant->getPhone()}</br>
Fax: {$objParticipant->getFax()|default:'brak'}</br>
Email: {$objParticipant->getEmail()}</br>
<td>{'registration_participant_data'|translate}:</td>
<td>
Imię: {$objParticipant->getName()}</br>
Nazwisko: {$objParticipant->getSurname()}</br>
Tytuł/stop. naukowy:{$objParticipant->getDegree()}</br>
Stanowisko: {$objParticipant->getPosition()|default:$registrationMissing}</br>
Telefon: {$objParticipant->getPhone()}</br>
Fax: {$objParticipant->getFax()|default:$registrationMissing}</br>
Email: {$objParticipant->getEmail()}</br>
</td>
</tr>
<tr>
<td>Dane instytucji::</td>
<td>{'registration_institution_data'|translate}:</td>
<td class="left">
Instytucja: {$objParticipant->getInstitution()|default:'brak'}</br>
Ulica i numer: {$objParticipant->getAddress()|default:'brak'}</br>
Kod pocztowy: {$objParticipant->getPostCode()|default:'brak'}</br>
Miejscowość: {$objParticipant->getCity()|default:'brak'}</br>
NIP Instytucji: {$objParticipant->getNip()|default:'brak'}</br>
</td>
</tr>
<tr>
<td>Dane wystąpienia:</td>
<td class="left">
Referat: {$objParticipant->getReferat()|default:'Nie'|replace:1:'Tak'|replace:2:'Nie'|replace:0:'Nie'}</br>
Poster: {$objParticipant->getPoster()|default:'Nie'|replace:1:'Tak'|replace:2:'Nie'|replace:0:'Nie'}
<p>Temat: {$objParticipant->getMessage()|default:'brak'}</p>
<p>Streszczenie: {$objParticipant->getMessageLong()|default:'brak'}</p>
<p>Autor: {$objParticipant->getAutor()|default:'brak'}</p>
</td>
</tr>
<tr>
<td>Udział i preferencje:</td>
<td class="left">
<p>Typ udziału: {$objParticipant->getParticipationOption()|replace:'full':'cała konferencja'|replace:'one_day_lodging':'jeden dzień konferencji (z noclegiem)'|replace:'one_day_no_lodging':'jeden dzień konferencji (bez noclegu)'|default:'brak'}</p>
<p>Dni: {if $objParticipant->getParticipationDays()}{$objParticipant->getParticipationDays()}{elseif $objParticipant->GetFeeOneDay()}{$objParticipant->GetFeeOneDay()}{else}brak{/if}</p>
<p>Dopłata do pokoju 1-osobowego: {$objParticipant->getFeeRoom1()|replace:1:'Tak'|replace:0:'Nie'|default:'Nie'}</p>
<p>Osoba towarzysząca/kierowca: {$objParticipant->getFeeRoomAddPerson()|replace:1:'Tak'|replace:0:'Nie'|default:'Nie'}</p>
<p>Dieta: {$objParticipant->getDiet()|replace:1:'standardowa'|replace:2:'specjalna'|default:'brak'} {if $objParticipant->getDietSpecial()}- {$objParticipant->getDietSpecial()}{/if}</p>
Instytucja: {$objParticipant->getInstitution()|default:$registrationMissing}</br>
Ulica i numer: {$objParticipant->getAddress()|default:$registrationMissing}</br>
Kod pocztowy: {$objParticipant->getPostCode()|default:$registrationMissing}</br>
Miejscowość: {$objParticipant->getCity()|default:$registrationMissing}</br>
NIP Instytucji: {$objParticipant->getNip()|default:$registrationMissing}</br>
</td>
</tr>
<tr>
<td>Informacja o kwocie do zapłaty:</td>
<td>{'registration_presentation_data'|translate}:</td>
<td class="left">
Wybrane opcje:</br>
{if $discPrice == 2}
Opłata zwykła (płatność <b>po 08.10.2021</b>)
{else}
Opłata obniżona (płatność <b>do 08.10.2021</b>)
{/if}
<ul>
{foreach $arrayObjParameters as $objParam}
{if in_array($objParam->GetId(),$arrayFee)}
{if $discPrice == 2}
<li>{$objParam->GetName()} {if $objParam->GetId() eq 5}({$objParticipant->GetFeeOneDay()}){/if}</br>
Cena netto: {$objParam->GetPrice()|number_format:2:",":" "} PLN</br>
Cena brutto: {assign var="vat" value=$objParam->GetPrice()*1.23}{$vat|number_format:2:",":" "} PLN</br>
</li>
{else}
<li>{$objParam->GetName()} {if $objParam->GetId() eq 5}({$objParticipant->GetFeeOneDay()}){/if}</br>
Cena netto (bez VAT): {$objParam->GetPriceProm()|number_format:2:",":" "} PLN</br>
Cena brutto (z VAT): {assign var="vat" value=$objParam->GetPriceProm()*1.23}{$vat|number_format:2:",":" "} PLN</br>
</li>
{/if}
{/if}
{/foreach}
<h3>Razem do zapłaty:</h3>
{assign var="resultPrice" value=$objParticipant->getPrice()}
Cena netto: {$resultPrice|number_format:2:",":" "} PLN</br>
Cena brutto: {assign var="resultPriceVat" value=$resultPrice*1.23}{$resultPriceVat|number_format:2:",":" "} PLN</br>
</ul>
</td>
</tr>
<tr>
<td>Wyrażono zgody</td>
<td class="left">
<p>Zgoda na przetwarzanie danych - {$objParticipant->getAgree1()|default:'Nie'|replace:1:'Tak'|replace:'on':'Tak'|replace:0:'Nie'}</p>
<p>Zgoda na przetwarzanie wizerunku - {$objParticipant->getAgree2()|default:'Nie'|replace:1:'Tak'|replace:'on':'Tak'|replace:0:'Nie'}</p>
</td>
Referat: {$objParticipant->getReferat()|default:$registrationNo|replace:1:$registrationYes|replace:2:$registrationNo|replace:0:$registrationNo}</br>
Poster: {$objParticipant->getPoster()|default:$registrationNo|replace:1:$registrationYes|replace:2:$registrationNo|replace:0:$registrationNo}
<p>{'registration_topic'|translate}: {$objParticipant->getMessage()|default:$registrationMissing}</p>
<p>{'registration_abstract'|translate}: {$objParticipant->getMessageLong()|default:$registrationMissing}</p>
<p>{'registration_author'|translate}: {$objParticipant->getAutor()|default:$registrationMissing}</p>
</td>
</tr>
<tr>
<td>Status opłaty: </td><td>
<select class="input" style="width: 100px;" name="payment_status">
<option value="1" {if $objParticipant->GetStatus() == 1}selected="selected"{/if}>nie opołacone</option>
<option value="2" {if $objParticipant->GetStatus() == 2}selected="selected"{/if}>opołacone</option>
</select>
</td>
</tr>
<td>{'registration_participation_preferences'|translate}:</td>
<td class="left">
<p>{'registration_participation_type'|translate}: {$objParticipant->getParticipationOption()|replace:'full':$registrationParticipationFull|replace:'one_day_lodging':$registrationParticipationLodging|replace:'one_day_no_lodging':$registrationParticipationNoLodging|default:$registrationMissing}</p>
<p>{'registration_days'|translate}: {if $objParticipant->getParticipationDays()}{$objParticipant->getParticipationDays()}{elseif $objParticipant->GetFeeOneDay()}{$objParticipant->GetFeeOneDay()}{else}{$registrationMissing}{/if}</p>
<p>{'registration_single_room_surcharge'|translate}: {$objParticipant->getFeeRoom1()|replace:1:$registrationYes|replace:0:$registrationNo|default:$registrationNo}</p>
<p>{'registration_accompanying_driver'|translate}: {$objParticipant->getFeeRoomAddPerson()|replace:1:$registrationYes|replace:0:$registrationNo|default:$registrationNo}</p>
<p>{'registration_diet'|translate}: {$objParticipant->getDiet()|replace:1:$registrationDietStandardShort|replace:2:$registrationDietSpecialShort|default:$registrationMissing} {if $objParticipant->getDietSpecial()}- {$objParticipant->getDietSpecial()}{/if}</p>
</td>
</tr>
<tr>
<td>{'registration_amount_information'|translate}:</td>
<td class="left">
{'registration_selected_options'|translate}:</br>
{if $discPrice == 2}
{'registration_fee_normal_2026'|translate}
{else}
{'registration_fee_discount_2026'|translate}
{/if}
<ul>
{foreach $arrayObjParameters as $objParam}
{if in_array($objParam->GetId(),$arrayFee)}
{if $discPrice == 2}
<li>{$objParam->GetName()} {if $objParam->GetId() eq 5}({$objParticipant->GetFeeOneDay()}){/if}</br>
{'registration_net_price'|translate}: {$objParam->GetPrice()|number_format:2:",":" "} PLN</br>
{'registration_gross_price'|translate}: {assign var="vat" value=$objParam->GetPrice()*1.23}{$vat|number_format:2:",":" "} PLN</br>
</li>
{else}
<li>{$objParam->GetName()} {if $objParam->GetId() eq 5}({$objParticipant->GetFeeOneDay()}){/if}</br>
{'registration_net_price_no_vat'|translate}: {$objParam->GetPriceProm()|number_format:2:",":" "} PLN</br>
{'registration_gross_price_vat'|translate}: {assign var="vat" value=$objParam->GetPriceProm()*1.23}{$vat|number_format:2:",":" "} PLN</br>
</li>
{/if}
{/if}
{/foreach}
<h3>{'registration_total_to_pay'|translate}:</h3>
{assign var="resultPrice" value=$objParticipant->getPrice()}
{'registration_net_price'|translate}: {$resultPrice|number_format:2:",":" "} PLN</br>
{'registration_gross_price'|translate}: {assign var="resultPriceVat" value=$resultPrice*1.23}{$resultPriceVat|number_format:2:",":" "} PLN</br>
</ul>
</td>
</tr>
<tr>
<td>{'registration_consents_expressed'|translate}</td>
<td class="left">
<p>{'registration_consent_data'|translate} - {$objParticipant->getAgree1()|default:$registrationNo|replace:1:$registrationYes|replace:'on':$registrationYes|replace:0:$registrationNo}</p>
<p>{'registration_consent_image'|translate} - {$objParticipant->getAgree2()|default:$registrationNo|replace:1:$registrationYes|replace:'on':$registrationYes|replace:0:$registrationNo}</p>
</td>
</tr>
<tr>
<td>{'registration_payment_status'|translate}: </td><td>
<select class="input" style="width: 100px;" name="payment_status">
<option value="1" {if $objParticipant->GetStatus() == 1}selected="selected"{/if}>{'registration_unpaid'|translate}</option>
<option value="2" {if $objParticipant->GetStatus() == 2}selected="selected"{/if}>{'registration_paid'|translate}</option>
</select>
</td>
</tr>
</tbody>
</table>
{/dropDownContainer}
</div>
</div>
</div>
<div class="cb"></div>
<div class="panelButtons">
<input type="button" value="Anuluj" class="cancel" onclick="document.location.href='{url Calc=Reg}';"/>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<input type="submit" value="Zapisz" name="doCategoryEdit"/>
</div>
<div class="panelButtons">
<input type="button" value="{'registration_cancel'|translate}" class="cancel" onclick="document.location.href='{url Calc=Reg}';"/>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<input type="submit" value="{'registration_save'|translate}" name="doCategoryEdit"/>
</div>
<input type="hidden" name="descriptionHidden" id="descriptionHidden" value="" />
<input type="hidden" name="shortnoteHidden" id="shortnoteHidden" value="" />
<input type="hidden" name="shortnoteHidden" id="shortnoteHidden" value="" />
</form>

View File

@@ -0,0 +1,226 @@
-- Dictionary phrase seed for XXXV Konferencja registration labels.
-- Safe to run more than once: each INSERT checks for an existing Polish key.
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_yes', 'pl', 'Tak'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_yes' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_no', 'pl', 'Nie'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_no' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_missing', 'pl', 'brak'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_missing' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_invoice_data', 'pl', 'Dane do wystawienia faktury'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_invoice_data' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participant_data', 'pl', 'Dane uczestnika'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participant_data' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_institution_data', 'pl', 'Dane instytucji'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_institution_data' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_presentation_data', 'pl', 'Dane wystąpienia'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_presentation_data' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_submit_talk', 'pl', 'Zgłaszam referat'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_submit_talk' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_submit_poster', 'pl', 'Zgłaszam poster'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_submit_poster' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_topic', 'pl', 'Temat'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_topic' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_abstract', 'pl', 'Streszczenie'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_abstract' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_author', 'pl', 'Autor'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_author' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_amount_information', 'pl', 'Informacja o kwocie do zapłaty'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_amount_information' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_selected_options', 'pl', 'Wybrane opcje'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_selected_options' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_fee_discount_2026', 'pl', 'Opłata obniżona (płatność do 03.10.2026)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_fee_discount_2026' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_fee_normal_2026', 'pl', 'Opłata zwykła (płatność po 03.10.2026)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_fee_normal_2026' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_net_price', 'pl', 'Cena netto'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_net_price' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_net_price_no_vat', 'pl', 'Cena netto (bez VAT)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_net_price_no_vat' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_gross_price', 'pl', 'Cena brutto'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_gross_price' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_gross_price_vat', 'pl', 'Cena brutto (z VAT)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_gross_price_vat' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_total_to_pay', 'pl', 'Razem do zapłaty'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_total_to_pay' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_full_conference_label', 'pl', 'Cała konferencja'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_full_conference_label' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_full_cta', 'pl', 'Biorę udział w całej konferencji'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_full_cta' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_one_day_lodging_cta', 'pl', 'Biorę udział w jednym dniu konferencji (z noclegiem)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_one_day_lodging_cta' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_one_day_no_lodging_cta', 'pl', 'Biorę udział w jednym dniu konferencji (bez noclegu)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_one_day_no_lodging_cta' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_full', 'pl', 'cała konferencja'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_full' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_one_day_lodging', 'pl', 'jeden dzień konferencji (z noclegiem)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_one_day_lodging' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_one_day_no_lodging', 'pl', 'jeden dzień konferencji (bez noclegu)'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_one_day_no_lodging' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_select_day', 'pl', 'Proszę zaznaczyć dzień'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_select_day' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_selected_presence_days', 'pl', 'Wskazane dni obecności'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_selected_presence_days' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_full_conference_presence', 'pl', 'Obecność podczas całej konferencji.'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_full_conference_presence' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_single_room_surcharge', 'pl', 'Dopłata do pokoju 1-osobowego'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_single_room_surcharge' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_accompanying_driver_fee', 'pl', 'Opłata za pobyt osoby towarzyszącej lub kierowcy w pokoju dwuosobowym'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_accompanying_driver_fee' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_accompanying_driver', 'pl', 'Osoba towarzysząca/kierowca'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_accompanying_driver' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_preferences', 'pl', 'Udział i preferencje'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_preferences' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet_preferences', 'pl', 'Preferencje żywieniowe'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet_preferences' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet_standard', 'pl', 'dieta standardowa'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet_standard' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet_special', 'pl', 'dieta specjalna'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet_special' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet_standard_short', 'pl', 'standardowa'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet_standard_short' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet_special_short', 'pl', 'specjalna'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet_special_short' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet_which', 'pl', 'Jaka?'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet_which' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_conference_price', 'pl', 'Cena za konferencję'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_conference_price' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_consents_expressed', 'pl', 'Wyrażono zgody'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_consents_expressed' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_consent_data', 'pl', 'Zgoda na przetwarzanie danych'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_consent_data' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_consent_image', 'pl', 'Zgoda na przetwarzanie wizerunku'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_consent_image' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_selected_participation_option', 'pl', 'Wybrana opcja udziału'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_selected_participation_option' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_participation_type', 'pl', 'Typ udziału'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_participation_type' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_days', 'pl', 'Dni'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_days' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_diet', 'pl', 'Dieta'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_diet' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_payment_status', 'pl', 'Status opłaty'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_payment_status' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_paid', 'pl', 'opłacone'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_paid' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_unpaid', 'pl', 'nie opłacone'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_unpaid' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_edit', 'pl', 'edytuj'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_edit' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_delete', 'pl', 'usuń'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_delete' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_cancel', 'pl', 'Anuluj'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_cancel' AND lang = 'pl');
INSERT INTO mf_dictionary (keyword, lang, replacement)
SELECT 'registration_save', 'pl', 'Zapisz'
WHERE NOT EXISTS (SELECT 1 FROM mf_dictionary WHERE keyword = 'registration_save' AND lang = 'pl');

View File

@@ -0,0 +1,200 @@
<?php
/**
* One-off dictionary phrase seed for XXXV Konferencja registration labels.
*
* Usage:
* - Browser: /_rejestracja/sql/apply-2026-04-24-registration-dictionary-phrases.php?run=20260424
* - CLI: php apply-2026-04-24-registration-dictionary-phrases.php --run
*
* Remove this file from the server after a successful production run.
*/
ini_set('display_errors', 1);
error_reporting(E_ALL);
$phrases = array(
'registration_yes' => 'Tak',
'registration_no' => 'Nie',
'registration_missing' => 'brak',
'registration_invoice_data' => 'Dane do wystawienia faktury',
'registration_participant_data' => 'Dane uczestnika',
'registration_institution_data' => 'Dane instytucji',
'registration_presentation_data' => 'Dane wystąpienia',
'registration_submit_talk' => 'Zgłaszam referat',
'registration_submit_poster' => 'Zgłaszam poster',
'registration_topic' => 'Temat',
'registration_abstract' => 'Streszczenie',
'registration_author' => 'Autor',
'registration_amount_information' => 'Informacja o kwocie do zapłaty',
'registration_selected_options' => 'Wybrane opcje',
'registration_fee_discount_2026' => 'Opłata obniżona (płatność do 03.10.2026)',
'registration_fee_normal_2026' => 'Opłata zwykła (płatność po 03.10.2026)',
'registration_net_price' => 'Cena netto',
'registration_net_price_no_vat' => 'Cena netto (bez VAT)',
'registration_gross_price' => 'Cena brutto',
'registration_gross_price_vat' => 'Cena brutto (z VAT)',
'registration_total_to_pay' => 'Razem do zapłaty',
'registration_full_conference_label' => 'Cała konferencja',
'registration_participation_full_cta' => 'Biorę udział w całej konferencji',
'registration_participation_one_day_lodging_cta' => 'Biorę udział w jednym dniu konferencji (z noclegiem)',
'registration_participation_one_day_no_lodging_cta' => 'Biorę udział w jednym dniu konferencji (bez noclegu)',
'registration_participation_full' => 'cała konferencja',
'registration_participation_one_day_lodging' => 'jeden dzień konferencji (z noclegiem)',
'registration_participation_one_day_no_lodging' => 'jeden dzień konferencji (bez noclegu)',
'registration_select_day' => 'Proszę zaznaczyć dzień',
'registration_selected_presence_days' => 'Wskazane dni obecności',
'registration_full_conference_presence' => 'Obecność podczas całej konferencji.',
'registration_single_room_surcharge' => 'Dopłata do pokoju 1-osobowego',
'registration_accompanying_driver_fee' => 'Opłata za pobyt osoby towarzyszącej lub kierowcy w pokoju dwuosobowym',
'registration_accompanying_driver' => 'Osoba towarzysząca/kierowca',
'registration_participation_preferences' => 'Udział i preferencje',
'registration_diet_preferences' => 'Preferencje żywieniowe',
'registration_diet_standard' => 'dieta standardowa',
'registration_diet_special' => 'dieta specjalna',
'registration_diet_standard_short' => 'standardowa',
'registration_diet_special_short' => 'specjalna',
'registration_diet_which' => 'Jaka?',
'registration_conference_price' => 'Cena za konferencję',
'registration_consents_expressed' => 'Wyrażono zgody',
'registration_consent_data' => 'Zgoda na przetwarzanie danych',
'registration_consent_image' => 'Zgoda na przetwarzanie wizerunku',
'registration_selected_participation_option' => 'Wybrana opcja udziału',
'registration_participation_type' => 'Typ udziału',
'registration_days' => 'Dni',
'registration_diet' => 'Dieta',
'registration_payment_status' => 'Status opłaty',
'registration_paid' => 'opłacone',
'registration_unpaid' => 'nie opłacone',
'registration_edit' => 'edytuj',
'registration_delete' => 'usuń',
'registration_cancel' => 'Anuluj',
'registration_save' => 'Zapisz',
);
$isCli = PHP_SAPI === 'cli';
$approved = $isCli
? in_array('--run', $argv, true)
: (isset($_GET['run']) && $_GET['run'] === '20260424');
header_safe('Content-Type: text/plain; charset=utf-8');
if (!$approved) {
echo "DRY RUN ONLY\n";
echo "To apply dictionary seed, run with ?run=20260424 in browser or --run in CLI.\n";
echo "No database changes were made.\n";
exit;
}
$configPath = __DIR__ . '/../core/config/Strona/db.config.ini';
if (!is_file($configPath)) {
fail("Config file not found: " . $configPath);
}
$config = parse_ini_file($configPath, true);
if (!isset($config['db'])) {
fail("Missing [db] section in config.");
}
$dbConfig = $config['db'];
foreach (array('prodHost', 'prodUser', 'prodPass', 'prodDb') as $key) {
if (!array_key_exists($key, $dbConfig)) {
fail("Missing db config key: " . $key);
}
}
$mysqli = new mysqli(
$dbConfig['prodHost'],
$dbConfig['prodUser'],
$dbConfig['prodPass'],
$dbConfig['prodDb']
);
if ($mysqli->connect_errno) {
fail("MySQL connection failed: " . $mysqli->connect_error);
}
$mysqli->set_charset('utf8');
$langs = get_dictionary_langs($mysqli);
echo "Applying dictionary phrase seed...\n";
echo "Languages: " . implode(', ', $langs) . "\n";
$inserted = 0;
$skipped = 0;
foreach ($phrases as $keyword => $replacementPl) {
foreach ($langs as $lang) {
if (dictionary_phrase_exists($mysqli, $keyword, $lang)) {
$skipped++;
continue;
}
$replacement = $lang === 'pl' ? $replacementPl : $lang . '_' . $keyword;
insert_dictionary_phrase($mysqli, $keyword, $lang, $replacement);
$inserted++;
}
}
echo "Dictionary seed complete.\n";
echo "Inserted: " . $inserted . "\n";
echo "Skipped: " . $skipped . "\n";
$mysqli->close();
function get_dictionary_langs(mysqli $mysqli) {
$langs = array('pl');
$result = $mysqli->query("SELECT DISTINCT lang FROM mf_dictionary WHERE lang <> ''");
if (!$result) {
fail("Could not load dictionary languages: " . $mysqli->error);
}
while ($row = $result->fetch_assoc()) {
if (!in_array($row['lang'], $langs, true)) {
$langs[] = $row['lang'];
}
}
return $langs;
}
function dictionary_phrase_exists(mysqli $mysqli, $keyword, $lang) {
$stmt = $mysqli->prepare("SELECT COUNT(*) AS cnt FROM mf_dictionary WHERE keyword = ? AND lang = ?");
if (!$stmt) {
fail("Prepare failed: " . $mysqli->error);
}
$stmt->bind_param('ss', $keyword, $lang);
if (!$stmt->execute()) {
fail("Dictionary check failed: " . $stmt->error);
}
$result = $stmt->get_result();
$row = $result->fetch_assoc();
$stmt->close();
return isset($row['cnt']) && (int)$row['cnt'] > 0;
}
function insert_dictionary_phrase(mysqli $mysqli, $keyword, $lang, $replacement) {
$stmt = $mysqli->prepare("INSERT INTO mf_dictionary (keyword, lang, replacement) VALUES (?, ?, ?)");
if (!$stmt) {
fail("Prepare failed: " . $mysqli->error);
}
$stmt->bind_param('sss', $keyword, $lang, $replacement);
if (!$stmt->execute()) {
fail("Insert failed for " . $keyword . " / " . $lang . ": " . $stmt->error);
}
$stmt->close();
}
function fail($message) {
echo "ERROR: " . $message . "\n";
exit(1);
}
function header_safe($header) {
if (!headers_sent() && PHP_SAPI !== 'cli') {
header($header);
}
}

View File

@@ -52,7 +52,7 @@
</div>
<div class="cb"></div>
<div class="entry">
<div><h5 align="center">Dane do wystawienia faktury:</h5></div>
<div><h5 align="center">{translate word='registration_invoice_data'}:</h5></div>
</div>
<div class="entry">
<div class="label">{translate word='Instytucja'}:</div>
@@ -76,14 +76,14 @@
</div>
<div class="cb"></div>
<div class="entry">
<div class="label">Zgłaszam referat</div>
<div class="label">{translate word='registration_submit_talk'}</div>
<div class="value" title="s">
<label class="control control--radio">Tak
<label class="control control--radio">{translate word='registration_yes'}
<input type="radio" name="referat" class="referat" value="1" />
<div class="control__indicator"></div>
</label>
<label class="control control--radio">Nie
<label class="control control--radio">{translate word='registration_no'}
<input type="radio" name="referat" class="referat" value="2" />
<div class="control__indicator"></div>
</label>
@@ -91,14 +91,14 @@
</div>
<div class="cb"></div>
<div class="entry">
<div class="label">Zgłaszam poster</div>
<div class="label">{translate word='registration_submit_poster'}</div>
<div class="value" title="s">
<label class="control control--radio">Tak
<label class="control control--radio">{translate word='registration_yes'}
<input type="radio" name="poster" value="1" />
<div class="control__indicator"></div>
</label>
<label class="control control--radio">Nie
<label class="control control--radio">{translate word='registration_no'}
<input type="radio" name="poster" value="2" />
<div class="control__indicator"></div>
</label>
@@ -136,11 +136,11 @@
<div class="label">{translate word='Opłata'}: </div>
<div class="value">
<div class="confOption">
<label class="control control--radio">Opłata obniżona (płatność do 03.10.2026)
<label class="control control--radio">{translate word='registration_fee_discount_2026'}
<input type="radio" name="conference_fee_disc" id="conference_fee_disc" checked="true" class="conference_fee_disc" value="1" onclick="calculatePrice();"/>
<div class="control__indicator"></div>
</label>
<label class="control control--radio">Opłata zwykła (płatność po 03.10.2026)
<label class="control control--radio">{translate word='registration_fee_normal_2026'}
<input type="radio" name="conference_fee_disc" id="conference_fee_norm" class="conference_fee_disc" value="2" onclick="calculatePrice();"/>
<div class="control__indicator"></div>
</label>
@@ -148,7 +148,7 @@
</div>
</div>
<div class="entry">
<div class="label">Cała konferencja: </div>
<div class="label">{translate word='registration_full_conference_label'}: </div>
<div class="value">
<input type="hidden" name="participation_option" id="participation_option" value="full" />
<input type="hidden" name="one_day_lodging" id="one_day_lodging" value="0" />
@@ -160,24 +160,24 @@
$('#conference_2').hide(); calculatePrice();" />
<div class="control__indicator"></div>
</label>
<span>Biorę udział w całej konferencji</span>
<span>{translate word='registration_participation_full_cta'}</span>
</div>
<div style="width:100%; display:flex; flex-wrap:no-wrap; align-items:start; gap;10px; margin-bottom:30px;">
<label class="control control--radio">&nbsp;
<input type="radio" name="conference_fee" id="conference_fee_1_lodging" class="conference_fee" value="5" onclick="calculatePrice()" />
<div class="control__indicator"></div>
</label>
<span>Biorę udział w jednym dniu konferencji (z noclegiem)</span>
<span>{translate word='registration_participation_one_day_lodging_cta'}</span>
</div>
<div style="width:100%; display:flex; flex-wrap:no-wrap; align-items:start; gap;10px; margin-bottom:30px;">
<label class="control control--radio">&nbsp;
<input type="radio" name="conference_fee" id="conference_fee_1" class="conference_fee" value="5" onclick="calculatePrice()" />
<div class="control__indicator"></div>
</label>
<span>Biorę udział w jednym dniu konferencji (bez noclegu)</span>
<span>{translate word='registration_participation_one_day_no_lodging_cta'}</span>
</div>
<div class="show--day-select" id="one-day-lodging-days" style="display:none; width:100%; margin-bottom:30px; flex-direction:column; gap:10px;">
<span>Proszę zaznaczyć dzień:</span>
<span>{translate word='registration_select_day'}:</span>
<label class="control control--radio">3/4 listopada
<input type="radio" name="participation_days" value="3/4 listopada" />
<div class="control__indicator"></div>
@@ -188,7 +188,7 @@
</label>
</div>
<div class="show--day-select" id="one-day-no-lodging-days" style="display:none; width:100%; margin-bottom:30px; flex-direction:column; gap:10px;">
<span>Proszę zaznaczyć dzień:</span>
<span>{translate word='registration_select_day'}:</span>
<label class="control control--radio">3 listopada
<input type="radio" name="participation_days" value="3 listopada" />
<div class="control__indicator"></div>
@@ -303,11 +303,11 @@
{/literal}
</script>
<div class="confOptionContainer" id="conference_1">
<label class="control control--checkbox" > Dopłata do pokoju 1-osobowego
<label class="control control--checkbox" > {translate word='registration_single_room_surcharge'}
<input type="checkbox" name="fee_room1" class="price_plus_room" id="price_plus_room" data-theme="d" value="2" onchange="calculatePrice();" >
<div class="control__indicator"></div>
</label>
<label class="control control--checkbox" > Opłata za pobyt osoby towarzyszącej lub kierowcy w pokoju dwuosobowym
<label class="control control--checkbox" > {translate word='registration_accompanying_driver_fee'}
<input type="checkbox" name="fee_room_add_person" id="price_plus_person" data-theme="d" onclick="$('#price_plus_room').prop
("checked", true);" value="3" onchange="calculatePrice();" >
<div class="control__indicator"></div>
@@ -355,24 +355,24 @@
</div>
</div>
<div class="entry">
<div class="label">Preferencje żywieniowe:</div>
<div class="label">{translate word='registration_diet_preferences'}:</div>
<div class="value">
<label class="control control--radio">dieta standardowa
<label class="control control--radio">{translate word='registration_diet_standard'}
<input type="radio" name="diet" value="1" checked="checked" onclick="$('#diet_special_container').hide(); $('#diet_special').val('');" />
<div class="control__indicator"></div>
</label>
<label class="control control--radio">dieta specjalna
<label class="control control--radio">{translate word='registration_diet_special'}
<input type="radio" name="diet" value="2" onclick="$('#diet_special_container').show();" />
<div class="control__indicator"></div>
</label>
<div id="diet_special_container" style="display:none; margin-top:10px;">
<label for="diet_special">Jaka?</label>
<label for="diet_special">{translate word='registration_diet_which'}</label>
<input type="text" name="diet_special" id="diet_special" />
</div>
</div>
</div>
<div class="entry">
<div class="label">Cena za konferencję</div>
<div class="label">{translate word='registration_conference_price'}</div>
<div class="value"><p class="price_full_fee" style="margin: 0px;">&nbsp;</p></div>
</div>

View File

@@ -1,4 +1,12 @@
<div style="text-align: left;">
{assign var=registrationYes value='registration_yes'|translate}
{assign var=registrationNo value='registration_no'|translate}
{assign var=registrationMissing value='registration_missing'|translate}
{assign var=registrationParticipationFull value='registration_participation_full'|translate}
{assign var=registrationParticipationLodging value='registration_participation_one_day_lodging'|translate}
{assign var=registrationParticipationNoLodging value='registration_participation_one_day_no_lodging'|translate}
{assign var=registrationDietStandard value='registration_diet_standard'|translate}
{assign var=registrationDietSpecial value='registration_diet_special'|translate}
<h2>Dziękujemy za rejestrację na II Kongres Surowcowy</h2>
<p><b>Termin: 36 listopada 2025 r.</b></p>
<p><b>Miejsce kongresu: Krynica-Zdrój</b></p>
@@ -11,45 +19,45 @@
<!-- Dane uczestnika -->
<div class="divTableFormRow">
<div class="divTableFormCell"><h3>Dane uczestnika:</h3>
<div class="divTableFormCell"><h3>{'registration_participant_data'|translate}:</h3>
Imię: {$objParticipant->getName()}<br>
Nazwisko: {$objParticipant->getSurname()}<br>
Tytuł/stop. naukowy: {$objParticipant->getDegree()}<br>
Stanowisko: {$objParticipant->getPosition()|default:'brak'}<br>
Stanowisko: {$objParticipant->getPosition()|default:$registrationMissing}<br>
Telefon: {$objParticipant->getPhone()}<br>
Fax: {$objParticipant->getFax()|default:'brak'}<br>
Fax: {$objParticipant->getFax()|default:$registrationMissing}<br>
Email: {$objParticipant->getEmail()}<br>
</div>
</div>
<!-- Dane instytucji -->
<div class="divTableFormRow">
<div class="divTableFormCell"><h3>Dane instytucji:</h3>
Instytucja: {$objParticipant->getInstitution()|default:'brak'}<br>
Ulica i numer: {$objParticipant->getAddress()|default:'brak'}<br>
Kod pocztowy: {$objParticipant->getPostCode()|default:'brak'}<br>
Miejscowość: {$objParticipant->getCity()|default:'brak'}<br>
NIP Instytucji: {$objParticipant->getNip()|default:'brak'}<br>
<div class="divTableFormCell"><h3>{'registration_institution_data'|translate}:</h3>
Instytucja: {$objParticipant->getInstitution()|default:$registrationMissing}<br>
Ulica i numer: {$objParticipant->getAddress()|default:$registrationMissing}<br>
Kod pocztowy: {$objParticipant->getPostCode()|default:$registrationMissing}<br>
Miejscowość: {$objParticipant->getCity()|default:$registrationMissing}<br>
NIP Instytucji: {$objParticipant->getNip()|default:$registrationMissing}<br>
</div>
</div>
<!-- Wystąpienie -->
<div class="divTableFormRow">
<div class="divTableFormCell"><h3>Dane wystąpienia:</h3>
Referat: {$objParticipant->getReferat()|replace:1:'Tak'|replace:2:'Nie'|replace:0:'Nie'}<br>
Poster: {$objParticipant->getPoster()|replace:1:'Tak'|replace:2:'Nie'|replace:0:'Nie'}<br>
<p>Tytuł referatu/posteru: {$objParticipant->getMessage()|default:'brak'}</p>
<p>Autor: {$objParticipant->getAutor()|default:'brak'}</p>
<div class="divTableFormCell"><h3>{'registration_presentation_data'|translate}:</h3>
Referat: {$objParticipant->getReferat()|replace:1:$registrationYes|replace:2:$registrationNo|replace:0:$registrationNo}<br>
Poster: {$objParticipant->getPoster()|replace:1:$registrationYes|replace:2:$registrationNo|replace:0:$registrationNo}<br>
<p>Tytuł referatu/posteru: {$objParticipant->getMessage()|default:$registrationMissing}</p>
<p>{'registration_author'|translate}: {$objParticipant->getAutor()|default:$registrationMissing}</p>
</div>
</div>
<!-- Informacja o kwocie -->
<div class="divTableFormRow">
<div class="divTableFormCell"><h3>Informacja o kwocie do zapłaty:</h3>
<div class="divTableFormCell"><h3>{'registration_amount_information'|translate}:</h3>
{if $discPrice == 2}
Opłata zwykła (płatność <b>po 03.10.2026</b>)
{'registration_fee_normal_2026'|translate}
{else}
Opłata obniżona (płatność <b>do 03.10.2026</b>)
{'registration_fee_discount_2026'|translate}
{/if}
<ul>
{foreach $arrayObjParameters as $objParam}
@@ -60,14 +68,14 @@
{if $discPrice == 2}
{assign var="netto" value=$objParam->GetPrice()}
Cena netto: {$netto|number_format:2:",":" "} PLN<br>
{'registration_net_price'|translate}: {$netto|number_format:2:",":" "} PLN<br>
{else}
{assign var="netto" value=$objParam->GetPriceProm()}
Cena netto (bez VAT): {$netto|number_format:2:",":" "} PLN<br>
{'registration_net_price_no_vat'|translate}: {$netto|number_format:2:",":" "} PLN<br>
{/if}
{assign var="vat" value=$netto * 1.23}
Cena brutto: {$vat|number_format:2:",":" "} PLN<br>
{'registration_gross_price'|translate}: {$vat|number_format:2:",":" "} PLN<br>
</li>
{/if}
{/foreach}
@@ -75,11 +83,11 @@
<h3>Razem do zapłaty:</h3>
<h3>{'registration_total_to_pay'|translate}:</h3>
{assign var="resultPrice" value=$objParticipant->getPrice()}
Cena netto: {$resultPrice|number_format:2:",":" "} PLN<br>
{'registration_net_price'|translate}: {$resultPrice|number_format:2:",":" "} PLN<br>
{assign var="resultPriceVat" value=$resultPrice * 1.23}
Cena brutto: {$resultPriceVat|number_format:2:",":" "} PLN<br>
{'registration_gross_price'|translate}: {$resultPriceVat|number_format:2:",":" "} PLN<br>
<p><b>{'klauzula_ceny'|translate}</b></p>
</div>
@@ -87,25 +95,25 @@
<!-- Zgody -->
<div class="divTableFormRow">
<div class="divTableFormCell"><h3>Wyrażono zgody:</h3>
<p>Zgoda na przetwarzanie danych {$objParticipant->getAgree1()|replace:1:'Tak'|replace:'on':'Tak'|replace:0:'Nie'}</p>
<p>Zgoda na przetwarzanie wizerunku {$objParticipant->getAgree2()|replace:1:'Tak'|replace:'on':'Tak'|replace:0:'Nie'}</p>
<div class="divTableFormCell"><h3>{'registration_consents_expressed'|translate}:</h3>
<p>{'registration_consent_data'|translate} - {$objParticipant->getAgree1()|replace:1:$registrationYes|replace:'on':$registrationYes|replace:0:$registrationNo}</p>
<p>{'registration_consent_image'|translate} - {$objParticipant->getAgree2()|replace:1:$registrationYes|replace:'on':$registrationYes|replace:0:$registrationNo}</p>
</div>
</div>
<div class="divTableFormRow">
<div class="divTableFormCell"><h3>Wybrana opcja udziału:</h3>
<p><b>Typ udziału:</b> {$objParticipant->getParticipationOption()|replace:'full':'cała konferencja'|replace:'one_day_lodging':'jeden dzień konferencji (z noclegiem)'|replace:'one_day_no_lodging':'jeden dzień konferencji (bez noclegu)'|default:'cała konferencja'}</p>
<div class="divTableFormCell"><h3>{'registration_selected_participation_option'|translate}:</h3>
<p><b>{'registration_participation_type'|translate}:</b> {$objParticipant->getParticipationOption()|replace:'full':$registrationParticipationFull|replace:'one_day_lodging':$registrationParticipationLodging|replace:'one_day_no_lodging':$registrationParticipationNoLodging|default:$registrationParticipationFull}</p>
{if $days}
<p><b>Wskazane dni obecności:</b> {$days}</p>
<p><b>{'registration_selected_presence_days'|translate}:</b> {$days}</p>
{elseif $objParticipant->getParticipationDays()}
<p><b>Wskazane dni obecności:</b> {$objParticipant->getParticipationDays()}</p>
<p><b>{'registration_selected_presence_days'|translate}:</b> {$objParticipant->getParticipationDays()}</p>
{else}
<p><b>Obecność podczas całej konferencji.</b></p>
<p><b>{'registration_full_conference_presence'|translate}</b></p>
{/if}
<p><b>Dopłata do pokoju 1-osobowego:</b> {$objParticipant->getFeeRoom1()|replace:1:'Tak'|replace:0:'Nie'|default:'Nie'}</p>
<p><b>Osoba towarzysząca/kierowca:</b> {$objParticipant->getFeeRoomAddPerson()|replace:1:'Tak'|replace:0:'Nie'|default:'Nie'}</p>
<p><b>Preferencje żywieniowe:</b> {$objParticipant->getDiet()|replace:1:'dieta standardowa'|replace:2:'dieta specjalna'|default:'dieta standardowa'} {if $objParticipant->getDietSpecial()}- {$objParticipant->getDietSpecial()}{/if}</p>
<p><b>{'registration_single_room_surcharge'|translate}:</b> {$objParticipant->getFeeRoom1()|replace:1:$registrationYes|replace:0:$registrationNo|default:$registrationNo}</p>
<p><b>{'registration_accompanying_driver'|translate}:</b> {$objParticipant->getFeeRoomAddPerson()|replace:1:$registrationYes|replace:0:$registrationNo|default:$registrationNo}</p>
<p><b>{'registration_diet_preferences'|translate}:</b> {$objParticipant->getDiet()|replace:1:$registrationDietStandard|replace:2:$registrationDietSpecial|default:$registrationDietStandard} {if $objParticipant->getDietSpecial()}- {$objParticipant->getDietSpecial()}{/if}</p>
</div>
</div>