* Fri Sep 26 2025 Brian Read <brianr@koozali.org> 1.0-26.sme
- Fix remove logic, add in user name to rem panel re-format templates, add space to list panel [SME: 13168]
This commit is contained in:
		| @@ -46,10 +46,10 @@ | |||||||
| 'wrg_ERROR_WRONG_ACCT_TYPE' => 'The associated account shoult be a user or admin account.', | 'wrg_ERROR_WRONG_ACCT_TYPE' => 'The associated account shoult be a user or admin account.', | ||||||
| 'wrg_ERROR_OCCURED' => 'An error occured', | 'wrg_ERROR_OCCURED' => 'An error occured', | ||||||
| 'wrg_CLIENTS_ALREADY_CONFIGURED' => 'You can not alter the server ip, mask, private and public key as there are already some clients configured.', | 'wrg_CLIENTS_ALREADY_CONFIGURED' => 'You can not alter the server ip, mask, private and public key as there are already some clients configured.', | ||||||
| 'wrg_NO_CONF' => 'No configured client', | 'wrg_NO_CONF' => 'No configured clients', | ||||||
| 'wrg_INTERFACE' => 'Interface', | 'wrg_INTERFACE' => 'Interface', | ||||||
| 'wrg_CANCELLED' => 'Operation cancelled', | 'wrg_CANCELLED' => 'Operation cancelled', | ||||||
| 'wrg_SUCCESSFULLY_MODIFIED_CONF' => 'Client configuration successfully modified', | 'wrg_SUCCESSFULLY_MODIFIED_CONF' => 'Client configuration successfully modified', | ||||||
| 'wrg_SUCCESSFULLY_REMOVED_CONF' => 'Client successfully removed', | 'wrg_SUCCESSFULLY_REMOVED_CONF' => 'Client successfully removed', | ||||||
| 'wrg_SUCCESSFULLY_ADDED_CONF' => 'New client successfully added', | 'wrg_SUCCESSFULLY_ADDED_CONF' => 'New client successfully added', | ||||||
| 'wrg_SUCCESSFULLY_UPDATED_CONF' => 'Server configuration successfully modified', | 'wrg_SUCCESSFULLY_UPDATED_CONF' => 'Server configuration successfully modified', | ||||||
| @@ -1,73 +1,74 @@ | |||||||
| <div id='wrg_list'> | <div id='wrg_list'> | ||||||
|  |  | ||||||
|     <p><%=l 'wrg_DESC_MAIN_PAGE'%><br></p> |   <p><%= l 'wrg_DESC_MAIN_PAGE' %><br></p> | ||||||
|  |  | ||||||
| 	%= form_for 'wireguard' => (method => 'POST') => begin |   %= form_for 'wireguard' => (method => 'POST') => begin | ||||||
|     	    %=  hidden_field 'trt' => 'UPD' |     %= hidden_field 'trt' => 'UPD' | ||||||
| 	    <p><%=l 'wrg_LABEL_CONFIG'%><br><br></p> |     <p><%= l 'wrg_LABEL_CONFIG' %><br><br></p> | ||||||
| 	    %= submit_button l('wrg_EDIT_CONFIG'), class => 'action' |     %= submit_button l('wrg_EDIT_CONFIG'), class => 'action' | ||||||
| 	% end |   % end | ||||||
|  |  | ||||||
| 	<p><span class=label> |   <p><span class=label> | ||||||
| 	%=l 'wrg_INTERFACE' |       %= l 'wrg_INTERFACE' | ||||||
| 	</span> wg0<br></p> |     </span> wg0<br></p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |   <p><span class=label> | ||||||
| 	%=l 'wrg_LABEL_STATUS' |       %= l 'wrg_LABEL_STATUS' | ||||||
| 	</span> |     </span> | ||||||
| 	%= $wrg_datas->{sstatus} |     %= $wrg_datas->{sstatus} | ||||||
| 	<br></p> |     <br></p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |   <p><span class=label> | ||||||
| 	%=l 'wrg_PUBLIC_KEY' |       %= l 'wrg_PUBLIC_KEY' | ||||||
| 	</span> |     </span> | ||||||
| 	%= $wrg_datas->{wgpub} |     %= $wrg_datas->{wgpub} | ||||||
| 	<br></p> |     <br></p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |   <p><span class=label> | ||||||
| 	%=l 'wrg_IP' |       %= l 'wrg_IP' | ||||||
| 	</span> |     </span> | ||||||
| 	%= $wrg_datas->{wgip}.'/'.$wrg_datas->{wgmask} |     %= $wrg_datas->{wgip}.'/'.$wrg_datas->{wgmask} | ||||||
| 	<br></p> |     <br></p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |   <p><span class=label> | ||||||
| 	%=l 'wrg_PORT' |       %= l 'wrg_PORT' | ||||||
| 	</span> |     </span> | ||||||
| 	%= $wrg_datas->{wgport} |     %= $wrg_datas->{wgport} | ||||||
| 	<br></p> |     <br></p> | ||||||
|  |   <br /> | ||||||
|  |  | ||||||
| 	<table class="sme-border"><tbody> |   <table class="sme-border"><tbody> | ||||||
| 	<tr> |       <tr> | ||||||
|     	    <th class='sme-border'> |         <th class='sme-border'> | ||||||
|     	    %=l 'wrg_PUBLIC_KEY' |           %= l 'wrg_PUBLIC_KEY' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_INFO' |           %= l 'wrg_INFO' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_ENDPOINT' |           %= l 'wrg_ENDPOINT' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_VPN_IP' |           %= l 'wrg_VPN_IP' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_LATEST_HANDSHAKE' |           %= l 'wrg_LATEST_HANDSHAKE' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_RECEIVED' |           %= l 'wrg_RECEIVED' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_SENT' |           %= l 'wrg_SENT' | ||||||
|     	    </th><th class='sme-border'> |         </th><th class='sme-border'> | ||||||
|     	    %=l 'wrg_KEEPALIVE' |           %= l 'wrg_KEEPALIVE' | ||||||
|     	    </th> |         </th> | ||||||
|     	</tr> |       </tr> | ||||||
|  |  | ||||||
|     % if (scalar @$wgstatus > 0) { |       % if (scalar @$wgstatus > 0) { | ||||||
|     %    foreach my $list (@$wgstatus) { |         % foreach my $list (@$wgstatus) { | ||||||
|     %		#public-key | private-key | listen-port |persistent-keepalive |           % #public-key | private-key | listen-port |persistent-keepalive | ||||||
|     %		my @line = split(' ',$list); |           % my @line = split(' ',$list); | ||||||
|     %		next if $line[1] eq $wrg_datas->{wgpub}; |           % next if $line[1] eq $wrg_datas->{wgpub}; | ||||||
|     %		my ($ginfo, $user); |           % my ($ginfo, $user); | ||||||
|     %    	$ginfo = $c->get_wgs_info('info', "$line[3]"); |           % $ginfo = $c->get_wgs_info('info', "$line[3]"); | ||||||
|     %    	$user  = $c->get_wgs_info('user', "$line[3]"); |           % $user = $c->get_wgs_info('user', "$line[3]"); | ||||||
|     %    	use POSIX qw( strftime ); |           % use POSIX qw( strftime ); | ||||||
|     %    	my $dateR= ($line[4] ) ? strftime("%Y-%m-%d %H:%M:%S", localtime($line[4])) : " "; |           % my $dateR= ($line[4] ) ? strftime("%Y-%m-%d %H:%M:%S", localtime($line[4])) : " "; | ||||||
|         <tr> |           <tr> | ||||||
|             %= t td => (class => 'sme-border') => $line[0] |             %= t td => (class => 'sme-border') => $line[0] | ||||||
|             %= t td => (class => 'sme-border') => "$user : $ginfo" |             %= t td => (class => 'sme-border') => "$user : $ginfo" | ||||||
|             %= t td => (class => 'sme-border') => $line[2] |             %= t td => (class => 'sme-border') => $line[2] | ||||||
| @@ -76,55 +77,56 @@ | |||||||
|             %= t td => (class => 'sme-border') => $line[5] |             %= t td => (class => 'sme-border') => $line[5] | ||||||
|             %= t td => (class => 'sme-border') => $line[6] |             %= t td => (class => 'sme-border') => $line[6] | ||||||
|             %= t td => (class => 'sme-border') => $line[7] |             %= t td => (class => 'sme-border') => $line[7] | ||||||
|     	</tr> |           </tr> | ||||||
|     %    } |         % } | ||||||
|     %	} |       % } | ||||||
|     	</tbody></table> |   </tbody></table> | ||||||
|  |  | ||||||
|     %= form_for 'wireguard' => (method => 'POST') => begin |   %= form_for 'wireguard' => (method => 'POST') => begin | ||||||
| 	<hr class='sectionbar'/> |  | ||||||
| 	<p><%=l 'wrg_LABEL_CLIENTS'%><br><br></p> |  | ||||||
|         %= hidden_field 'trt' => 'NEW' |  | ||||||
| 	%= submit_button l('wrg_ADD_CLIENT'), class => 'action' |  | ||||||
|     % end |  | ||||||
|  |  | ||||||
|     %	if ( scalar @$wgconf == 0 ) { |  | ||||||
|     	    %=l 'wrg_NO_CONF' |  | ||||||
|     %	} else { |  | ||||||
| 	<table class="sme-border"><tbody> |  | ||||||
| 	<tr> |  | ||||||
|     	    <th class='sme-border'> |  | ||||||
|     	    %=l 'wrg_CONF_NAME' |  | ||||||
|     	    </th><th class='sme-border'> |  | ||||||
|     	    %=l 'wrg_USER' |  | ||||||
|     	    </th><th class='sme-border'> |  | ||||||
|     	    %=l 'wrg_INFO' |  | ||||||
|     	    </th><th class='sme-border'> |  | ||||||
|     	    %=l 'wrg_LABEL_STATUS' |  | ||||||
|     	    </th><th class='sme-border' colspan='3'> |  | ||||||
|     	    %=l 'ACTION' |  | ||||||
|     	    </th> |  | ||||||
|     	</tr> |  | ||||||
|     %    foreach my $conf (@$wgconf) { |  | ||||||
|     %    my $status = $c->l(uc($conf->prop('status') || 'enabled')); |  | ||||||
|         <tr> |  | ||||||
|             %= t td => (class => 'sme-border') => $conf->key |  | ||||||
|             %= t td => (class => 'sme-border') => $conf->prop('user') || '' |  | ||||||
|             %= t td => (class => 'sme-border') => $conf->prop('info') || '' |  | ||||||
|             %= t td => (class => 'sme-border') => $status |  | ||||||
|     %	    my $action =  |  | ||||||
|     % 		"<a href='wireguard2?CsrfDef=TOKEN&trt=QRC&Wgconf=" . $conf->key . "'>" . l('wrg_QRCODE') . "</a>";  |  | ||||||
|     	    <td class='sme-border'><%= $c->render_to_string(inline => $action) %></td> |  | ||||||
|     %	    $action =  |  | ||||||
|     % 		"<a href='wireguard2?CsrfDef=TOKEN&trt=MOD&Wgconf=" . $conf->key . "'>" . l('MODIFY') . "</a>";  |  | ||||||
|     	    <td class='sme-border'><%= $c->render_to_string(inline => $action) %></td> |  | ||||||
|     %	    $action =  |  | ||||||
|     % 		"<a href='wireguard2?CsrfDef=TOKEN&trt=REM&Wgconf=" . $conf->key . "'>" . l('REMOVE') . "</a>";  |  | ||||||
|     	    <td class='sme-border'><%= $c->render_to_string(inline => $action) %></td> |  | ||||||
|     	</tr> |  | ||||||
|     %    } |  | ||||||
|     	</tbody> |  | ||||||
|     	</table> |  | ||||||
|     %} |  | ||||||
|     <hr class='sectionbar'/> |     <hr class='sectionbar'/> | ||||||
| </div> |     <p><%= l 'wrg_LABEL_CLIENTS' %><br><br></p> | ||||||
|  |     %= hidden_field 'trt' => 'NEW' | ||||||
|  |     %= submit_button l('wrg_ADD_CLIENT'), class => 'action' | ||||||
|  |   % end | ||||||
|  |  | ||||||
|  |   % if ( scalar @$wgconf == 0 ) { | ||||||
|  |     %= l 'wrg_NO_CONF' | ||||||
|  |   % } else { | ||||||
|  |   <br /> | ||||||
|  |   <table class="sme-border"><tbody> | ||||||
|  |       <tr> | ||||||
|  |         <th class='sme-border'> | ||||||
|  |           %= l 'wrg_CONF_NAME' | ||||||
|  |         </th><th class='sme-border'> | ||||||
|  |           %= l 'wrg_USER' | ||||||
|  |         </th><th class='sme-border'> | ||||||
|  |           %= l 'wrg_INFO' | ||||||
|  |         </th><th class='sme-border'> | ||||||
|  |           %= l 'wrg_LABEL_STATUS' | ||||||
|  |         </th><th class='sme-border' colspan='3'> | ||||||
|  |           %= l 'ACTION' | ||||||
|  |         </th> | ||||||
|  |       </tr> | ||||||
|  |       % foreach my $conf (@$wgconf) { | ||||||
|  |         % my $status = $c->l(uc($conf->prop('status') || 'enabled')); | ||||||
|  |         <tr> | ||||||
|  |           %= t td => (class => 'sme-border') => $conf->key | ||||||
|  |           %= t td => (class => 'sme-border') => $conf->prop('user') || '' | ||||||
|  |           %= t td => (class => 'sme-border') => $conf->prop('info') || '' | ||||||
|  |           %= t td => (class => 'sme-border') => $status | ||||||
|  |           % my $action = | ||||||
|  |           % "<a href='wireguard2?CsrfDef=TOKEN&trt=QRC&Wgconf=" . $conf->key . "'>" . l('wrg_QRCODE') . "</a>"; | ||||||
|  |           <td class='sme-border'><%= $c->render_to_string(inline => $action) %></td> | ||||||
|  |           % $action = | ||||||
|  |           % "<a href='wireguard2?CsrfDef=TOKEN&trt=MOD&Wgconf=" . $conf->key . "'>" . l('MODIFY') . "</a>"; | ||||||
|  |           <td class='sme-border'><%= $c->render_to_string(inline => $action) %></td> | ||||||
|  |           % $action = | ||||||
|  |           % "<a href='wireguard2?CsrfDef=TOKEN&trt=REM&Wgconf=" . $conf->key . "'>" . l('REMOVE') . "</a>"; | ||||||
|  |           <td class='sme-border'><%= $c->render_to_string(inline => $action) %></td> | ||||||
|  |         </tr> | ||||||
|  |       % } | ||||||
|  |     </tbody> | ||||||
|  |   </table> | ||||||
|  |   % } | ||||||
|  |   <hr class='sectionbar'/> | ||||||
|  | </div> | ||||||
| @@ -1,94 +1,103 @@ | |||||||
|  |  | ||||||
|  | Mojolicious Template Code Formatter vmojofmt 0.1.9 | ||||||
|  | Input data: | ||||||
|  | Upload a file: | ||||||
|  | (none) | ||||||
|  | Remove empty lines from output | ||||||
|  | Formatted Output: | ||||||
|  | Output Syntax: | ||||||
|  |  | ||||||
| <div id='wrg_mod'> | <div id='wrg_mod'> | ||||||
|  |  | ||||||
|     %= form_for '/wireguard2' => (method => 'POST') => begin |   %= form_for '/wireguard2' => (method => 'POST') => begin | ||||||
| 	<p> |     <p> | ||||||
| 	%=l 'wrg_DESC_MODIFY_CLIENT_PAGE' |       %= l 'wrg_DESC_MODIFY_CLIENT_PAGE' | ||||||
| 	</p> |     </p> | ||||||
| 	<hr class='sectionbar'/> |     <hr class='sectionbar'/> | ||||||
|  |  | ||||||
| 	<p> |     <p> | ||||||
| 	%=l 'wrg_DESC_CONF_NAME' |       %= l 'wrg_DESC_CONF_NAME' | ||||||
| 	</p> |     </p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p><span class=label> | ||||||
| 	%=l 'wrg_CONF_NAME' |         %= l 'wrg_CONF_NAME' | ||||||
| 	</span> |       </span> | ||||||
| 	%= $wrg_datas->{wgconf} |       %= $wrg_datas->{wgconf} | ||||||
| 	<br></p> |       <br></p> | ||||||
|  |  | ||||||
| 	<p> |     <p> | ||||||
| 	%=l 'wrg_DESC_SELECT_ACCOUNT' |       %= l 'wrg_DESC_SELECT_ACCOUNT' | ||||||
| 	</p> |     </p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p><span class=label> | ||||||
| 	%=l 'wrg_SELECT_ACCOUNT' |         %= l 'wrg_SELECT_ACCOUNT' | ||||||
| 	</span><span class=data> |       </span><span class=data> | ||||||
| 	% param 'Account' => $wrg_datas->{account} unless param 'Account'; |         % param 'Account' => $wrg_datas->{account} unless param 'Account'; | ||||||
| 	%= select_field 'Account' => $c->get_existing_accounts(), class => 'input' |         %= select_field 'Account' => $c->get_existing_accounts(), class => 'input' | ||||||
| 	<br></span></p> |         <br></span></p> | ||||||
|  |  | ||||||
| 	<p> |     <p> | ||||||
| 	%=l 'wrg_DESC_INFO_ACC_WIREGUARD' |       %= l 'wrg_DESC_INFO_ACC_WIREGUARD' | ||||||
| 	</p> |     </p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p><span class=label> | ||||||
| 	%=l 'wrg_INFO_ACC_WIREGUARD' |         %= l 'wrg_INFO_ACC_WIREGUARD' | ||||||
| 	</span><span class=data> |       </span><span class=data> | ||||||
| 	% param 'Info' => $wrg_datas->{info} unless param 'Info'; |         % param 'Info' => $wrg_datas->{info} unless param 'Info'; | ||||||
| 	%=text_field 'Info' => size => '45', class => 'input' |         %= text_field 'Info' => size => '45', class => 'input' | ||||||
| 	<br></span></p> |         <br></span></p> | ||||||
| 	 |  | ||||||
| 	<p> |  | ||||||
| 	%=l 'wrg_DESC_PRIVATE' |  | ||||||
| 	</p> |  | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p> | ||||||
| 	%=l 'wrg_LABEL_PRIVATE' |       %= l 'wrg_DESC_PRIVATE' | ||||||
| 	</span><span class=data> |     </p> | ||||||
| 	% param 'Private' => $wrg_datas->{private} unless param 'Private'; |  | ||||||
| 	%=text_field 'Private' => size => '45', class => 'input' |  | ||||||
| 	<br></span></p> |  | ||||||
| 	 |  | ||||||
| 	<p> |  | ||||||
| 	%=l 'wrg_DESC_PUBLIC' |  | ||||||
| 	</p> |  | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p><span class=label> | ||||||
| 	%=l 'wrg_LABEL_PUBLIC' |         %= l 'wrg_LABEL_PRIVATE' | ||||||
| 	</span><span class=data> |       </span><span class=data> | ||||||
| 	% param 'Public' => $wrg_datas->{public} unless param 'Public'; |         % param 'Private' => $wrg_datas->{private} unless param 'Private'; | ||||||
| 	%=text_field 'Public' => size => '45', class => 'input' |         %= text_field 'Private' => size => '45', class => 'input' | ||||||
| 	<br></span></p> |         <br></span></p> | ||||||
| 	 |  | ||||||
| 	<p> |  | ||||||
| 	%=l 'wrg_DESC_STATUS' |  | ||||||
| 	</p> |  | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p> | ||||||
| 	%=l 'wrg_LABEL_STATUS' |       %= l 'wrg_DESC_PUBLIC' | ||||||
| 	</span><span class=data> |     </p> | ||||||
| 	% param 'Status' => $wrg_datas->{status} unless param 'Status'; |  | ||||||
| 	%= select_field 'Status' => [[ (l 'DISABLED') => 'disabled'], [ (l 'ENABLED') => 'enabled']], class => 'input' |  | ||||||
| 	<br></span></p> |  | ||||||
|  |  | ||||||
| 	<p> |     <p><span class=label> | ||||||
| 	%=l 'wrg_DESC_ALLOWEDIPS' |         %= l 'wrg_LABEL_PUBLIC' | ||||||
| 	</p> |       </span><span class=data> | ||||||
|  |         % param 'Public' => $wrg_datas->{public} unless param 'Public'; | ||||||
|  |         %= text_field 'Public' => size => '45', class => 'input' | ||||||
|  |         <br></span></p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |     <p> | ||||||
| 	%=l 'wrg_LABEL_ALLOWEDIPS' |       %= l 'wrg_DESC_STATUS' | ||||||
| 	</span><span class=data> |     </p> | ||||||
| 	% param 'Allowedips' => $wrg_datas->{allowedips} unless param 'Allowedips'; |  | ||||||
| 	%=text_field 'Allowedips' => size => '45', class => 'input' |  | ||||||
| 	<br></span></p> |  | ||||||
| 	 |  | ||||||
| 	<div class='center'> |  | ||||||
| 	%= submit_button l('MODIFY'), name => 'modify', class => 'action' |  | ||||||
| 	</div> |  | ||||||
|  |  | ||||||
| 	%= hidden_field 'trt' => $wrg_datas->{trt} |     <p><span class=label> | ||||||
|     	%= hidden_field 'Wgconf' => $wrg_datas->{wgconf} |         %= l 'wrg_LABEL_STATUS' | ||||||
| 	 |       </span><span class=data> | ||||||
|     % end |         % param 'Status' => $wrg_datas->{status} unless param 'Status'; | ||||||
|  |         %= select_field 'Status' => [[ (l 'DISABLED') => 'disabled'], [ (l 'ENABLED') => 'enabled']], class => 'input' | ||||||
|  |         <br></span></p> | ||||||
|  |  | ||||||
| </div> |     <p> | ||||||
|  |       %= l 'wrg_DESC_ALLOWEDIPS' | ||||||
|  |     </p> | ||||||
|  |  | ||||||
|  |     <p><span class=label> | ||||||
|  |         %= l 'wrg_LABEL_ALLOWEDIPS' | ||||||
|  |       </span><span class=data> | ||||||
|  |         % param 'Allowedips' => $wrg_datas->{allowedips} unless param 'Allowedips'; | ||||||
|  |         %= text_field 'Allowedips' => size => '45', class => 'input' | ||||||
|  |         <br></span></p> | ||||||
|  |  | ||||||
|  |     <div class='center'> | ||||||
|  |       %= submit_button l('MODIFY'), name => 'modify', class => 'action' | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     %= hidden_field 'trt' => $wrg_datas->{trt} | ||||||
|  |     %= hidden_field 'Wgconf' => $wrg_datas->{wgconf} | ||||||
|  |  | ||||||
|  |   % end | ||||||
|  |  | ||||||
|  | </div> | ||||||
| @@ -1,30 +1,38 @@ | |||||||
| <div id='wrg_rem'> | <div id='wrg_rem'> | ||||||
|  |  | ||||||
|     %= form_for '/wireguard2' => (method => 'POST') => begin |   %= form_for '/wireguard2' => (method => 'POST') => begin | ||||||
| 	<p> |     <p> | ||||||
| 	%=l 'wrg_DESC_REMOVE_CLIENT' |       %= l 'wrg_DESC_REMOVE_CLIENT' | ||||||
| 	</p> |     </p> | ||||||
|  |  | ||||||
| 	<p><br><span class=label> |     <p><span class=label> | ||||||
| 	%=l 'wrg_CONF_NAME' |         %= l 'wrg_USER' | ||||||
| 	</span> |       </span><span class=data> | ||||||
| 	%= $wrg_datas->{account} |         %= $wrg_datas->{account} | ||||||
| 	<br></p> |       </p> | ||||||
|  |  | ||||||
| 	<p><span class=label> |       <p><span class=label> | ||||||
| 	%=l 'COMMENT' |           %= l 'wrg_CONF_NAME' | ||||||
| 	</span> |         </span><span class=data> | ||||||
| 	%= $wrg_datas->{wgcomment} |           %= $wrg_datas->{wgconf} | ||||||
| 	<br></p> |         </span> | ||||||
|  |       </p> | ||||||
|  |  | ||||||
| <div class="center"> |       <p><span class=label> | ||||||
|   %= submit_button l('REMOVE'), name => 'remove', class => 'action left-btn' |           %= l 'COMMENT' | ||||||
|   %= submit_button l('CANCEL'), name => 'cancel', class => 'action center-btn' |         </span><span class=data> | ||||||
| </div> |           %= $wrg_datas->{wgcomment} | ||||||
|  |         </span> | ||||||
|  |       </p> | ||||||
|  |  | ||||||
|  |       <div class="center"> | ||||||
|  |         %= submit_button l('REMOVE'), name => 'remove', class => 'action left-btn' | ||||||
|  |         %= submit_button l('CANCEL'), name => 'cancel', class => 'action center-btn' | ||||||
|  |       </div> | ||||||
|  |  | ||||||
|  |       %= hidden_field 'trt' => $wrg_datas->{trt} | ||||||
|  |       %= hidden_field 'Wgconf' => $wrg_datas->{wgconf} | ||||||
|  |  | ||||||
| 	%= hidden_field 'trt' => $wrg_datas->{trt} |  | ||||||
|     	%= hidden_field 'Wgconf' => $wrg_datas->{account} |  | ||||||
| 	 |  | ||||||
|     % end |     % end | ||||||
|  |  | ||||||
| </div> |   </div> | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| %define release 25 | %define release 26 | ||||||
| %define version 1.0 | %define version 1.0 | ||||||
| %define debug_package %{nil} | %define debug_package %{nil} | ||||||
|  |  | ||||||
| @@ -61,6 +61,9 @@ fi | |||||||
|  |  | ||||||
|  |  | ||||||
| %changelog | %changelog | ||||||
|  | * Fri Sep 26 2025 Brian Read <brianr@koozali.org> 1.0-26.sme | ||||||
|  | - Fix remove logic, add in user name to rem panel re-format templates,  add space to list panel [SME: 13168] | ||||||
|  |  | ||||||
| * Thu Sep 25 2025 Brian Read <brianr@koozali.org> 1.0-25.sme | * Thu Sep 25 2025 Brian Read <brianr@koozali.org> 1.0-25.sme | ||||||
| - Sort outy Remove panel placement and operation of buttons [SME: 13168] | - Sort outy Remove panel placement and operation of buttons [SME: 13168] | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user