gl-website-deployer/admin/phpMyAdmin/templates/export.twig
2024-11-19 08:02:04 +01:00

503 lines
23 KiB
Twig

<div class="container">
<h2 class="my-3">
{{ get_image('b_export', 'Export'|trans) }}
{% block title %}{% endblock %}
</h2>
{{ page_settings_error_html|raw }}
{{ page_settings_html|raw }}
{% block message %}{% endblock %}
{% if templates.is_enabled %}
<div class="card mb-3">
<div class="card-header">{% trans 'Export templates:' %}</div>
<div class="card-body row gy-3">
<form method="post" action="{{ url('/export/template/create') }}" class="col-12 col-md ajax">
<fieldset>
<legend>{% trans 'New template:' %}</legend>
<div class="row g-3 align-items-center">
<div class="col-auto">
<label for="templateName" class="col-form-label">{% trans 'Template name' %}</label>
</div>
<div class="col-auto">
<input class="form-control" type="text" name="templateName" id="templateName" maxlength="64" placeholder="{% trans 'Template name' %}" required>
</div>
<div class="col-auto">
<input class="btn btn-secondary" type="submit" name="createTemplate" id="createTemplate" value="{% trans 'Create' %}">
</div>
</div>
</fieldset>
</form>
<form method="post" id="existingTemplatesForm" class="col-12 col-md ajax">
<fieldset>
<legend>{% trans 'Existing templates:' %}</legend>
<div class="row g-3 align-items-center">
<div class="col-auto">
<label for="template" class="col-form-label">{% trans 'Template:' %}</label>
</div>
<div class="col-auto">
<select class="form-select" name="template" id="template" required>
<option value="">-- {% trans 'Select a template' %} --</option>
{% for template in templates.templates %}
<option value="{{ template.getId() }}"{{ template.getId() == templates.selected ? ' selected' }}>
{{ template.getName() }}
</option>
{% endfor %}
</select>
</div>
<div class="col-auto">
<input class="btn btn-secondary" type="submit" formaction="{{ url('/export/template/update') }}" name="updateTemplate" id="updateTemplate" value="{% trans 'Update' %}">
</div>
<div class="col-auto">
<input class="btn btn-secondary" type="submit" formaction="{{ url('/export/template/delete') }}" name="deleteTemplate" id="deleteTemplate" value="{% trans 'Delete' %}">
</div>
</div>
</fieldset>
</form>
</div>
</div>
{% endif %}
{% if sql_query is not empty %}
<div class="card mb-3">
<div class="card-header">
{# l10n: Title of the option on the Export page #}
{% trans 'SQL query:' %}
</div>
<div class="card-body">
<div id="sqlqueryform">
{# l10n: Button to show the SQL query on the export page #}
<input class="btn btn-secondary" type="submit" id="showsqlquery" value="{% trans 'Show SQL query' %}">
</div>
<div class="d-none"></div>
</div>
</div>
<div class="modal fade" id="showSqlQueryModal" tabindex="-1" aria-labelledby="showSqlQueryModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="showSqlQueryModalLabel">{% trans 'Loading' %}</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="{% trans 'Close' %}"></button>
</div>
<div class="modal-body">
<div id="export_sql_modal_content">
<code class="sql">
<pre id="sql_preview_query">{{ sql_query }}</pre>
</code>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">{% trans 'Close' %}</button>
</div>
</div>
</div>
</div>
{% endif %}
<form method="post" action="{{ url('/export') }}" name="dump" class="disableAjax">
{{ get_hidden_inputs(hidden_inputs) }}
{% if export_method != 'custom-no-form' %}
<div class="card mb-3" id="quick_or_custom">
<div class="card-header">{% trans 'Export method:' %}</div>
<div class="card-body">
<div class="form-check">
<input class="form-check-input" type="radio" name="quick_or_custom" value="quick" id="radio_quick_export"{{ export_method == 'quick' ? ' checked' }}>
<label class="form-check-label" for="radio_quick_export">{% trans 'Quick - display only the minimal options' %}</label>
</div>
<div class="form-check">
<input class="form-check-input" type="radio" name="quick_or_custom" value="custom" id="radio_custom_export"{{ export_method == 'custom' ? ' checked' }}>
<label class="form-check-label" for="radio_custom_export">{% trans 'Custom - display all possible options' %}</label>
</div>
</div>
</div>
{% endif %}
<div class="card mb-3" id="format">
<div class="card-header">{% trans 'Format:' %}</div>
<div class="card-body">
<select class="form-select" id="plugins" name="what" aria-label="{% trans 'File format to export' %}">
{% for option in plugins_choice %}
<option value="{{ option.name }}"{{ option.is_selected ? ' selected' }}>{{ option.text }}</option>
{% endfor %}
</select>
{% for option in plugins_choice %}
<input type="hidden" id="force_file_{{ option.name }}" value="{{ option.force_file ? 'true' : 'false' }}">
{% endfor %}
</div>
</div>
{% block selection_options %}{% endblock %}
{% if rows is not empty %}
<div class="card mb-3" id="rows">
<div class="card-header">{% trans 'Rows:' %}</div>
<div class="card-body">
<div class="form-check">
<input class="form-check-input" type="radio" name="allrows" value="1" id="radio_allrows_1"{{ rows.allrows is null or rows.allrows == 1 ? ' checked' }}>
<label class="form-check-label" for="radio_allrows_1">{% trans 'Dump all rows' %}</label>
</div>
<div class="form-check mb-2">
<input class="form-check-input" type="radio" name="allrows" value="0" id="radio_allrows_0"{{ rows.allrows is not null and rows.allrows == 0 ? ' checked' }}>
<label class="form-check-label" for="radio_allrows_0">{% trans 'Dump some row(s)' %}</label>
</div>
<ul class="list-group">
<li class="list-group-item">
<label class="form-label" for="limit_to">{% trans 'Number of rows:' %}</label>
<input class="form-control" type="text" id="limit_to" name="limit_to" size="5" value="
{%- if rows.limit_to is not null -%}
{{- rows.limit_to -}}
{%- elseif rows.unlim_num_rows is not empty and rows.unlim_num_rows != 0 -%}
{{- rows.unlim_num_rows -}}
{%- else %}
{{- rows.number_of_rows -}}
{%- endif -%}" onfocus="this.select()">
</li>
<li class="list-group-item">
<label class="form-label" for="limit_from">{% trans 'Row to begin at:' %}</label>
<input class="form-control" type="text" id="limit_from" name="limit_from" size="5" value="{{ rows.limit_from is not null ? rows.limit_from : 0 }}" onfocus="this.select()">
</li>
</ul>
</div>
</div>
{% endif %}
{% if has_save_dir %}
<div class="card mb-3 d-none" id="output_quick_export">
<div class="card-header">{% trans 'Output:' %}</div>
<div class="card-body">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" name="quick_export_onserver" value="saveit" id="checkbox_quick_dump_onserver"{{ export_is_checked ? ' checked' }}>
<label class="form-check-label" for="checkbox_quick_dump_onserver">
{{ 'Save on server in the directory <strong>%s</strong>'|trans|format(save_dir|e)|raw }}
</label>
</div>
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" name="quick_export_onserver_overwrite" value="saveitover" id="checkbox_quick_dump_onserver_overwrite"
{{- export_overwrite_is_checked ? ' checked' }}>
<label class="form-check-label" for="checkbox_quick_dump_onserver_overwrite">
{% trans 'Overwrite existing file(s)' %}
</label>
</div>
</div>
</div>
{% endif %}
<div class="modal fade" id="renameExportModal" tabindex="-1" aria-labelledby="renameExportModalLabel" aria-hidden="true">
<div class="modal-dialog modal-xl">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="renameExportModalLabel">{% trans 'Rename exported databases/tables/columns' %}</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="{% trans 'Close' %}"></button>
</div>
<div class="modal-body overflow-auto">
<table class="table align-middle mb-3" id="alias_data">
<thead>
<tr>
<th colspan="4">
{% trans 'Defined aliases' %}
</th>
</tr>
</thead>
<tbody>
{% for db, db_data in aliases %}
{% if db_data.alias is defined and db_data.alias is not null %}
<tr>
<th>{% trans %}Database{% context %}Alias{% endtrans %}</th>
<td>{{ db }}</td>
<td>
<input name="aliases[{{ db }}][alias]" value="{{ db_data.alias }}" type="text">
</td>
<td>
<button class="alias_remove btn btn-secondary">{% trans 'Remove' %}</button>
</td>
</tr>
{% endif %}
{% for table, table_data in db_data.tables ?? [] %}
{% if table_data.alias is defined and table_data.alias is not null %}
<tr>
<th>{% trans %}Table{% context %}Alias{% endtrans %}</th>
<td>{{ db }}.{{ table }}</td>
<td>
<input name="aliases[{{ db }}][tables][{{ table }}][alias]" value="{{ table_data.alias }}" type="text">
</td>
<td>
<button class="alias_remove btn btn-secondary">{% trans 'Remove' %}</button>
</td>
</tr>
{% endif %}
{% for column, column_name in table_data.columns ?? [] %}
<tr>
<th>{% trans %}Column{% context %}Alias{% endtrans %}</th>
<td>{{ db }}.{{ table }}.{{ column }}</td>
<td>
<input name="aliases[{{ db }}][tables][{{ table }}][colums][{{ column }}]" value="{{ column_name }}" type="text">
</td>
<td>
<button class="alias_remove btn btn-secondary">{% trans 'Remove' %}</button>
</td>
</tr>
{% endfor %}
{% endfor %}
{% endfor %}
</tbody>
{# Empty row for javascript manipulations. #}
<tfoot class="hide">
<tr>
<th></th>
<td></td>
<td>
<input name="aliases_new" value="" type="text">
</td>
<td>
<button class="alias_remove btn btn-secondary">{% trans 'Remove' %}</button>
</td>
</tr>
</tfoot>
</table>
<table class="table align-middle">
<thead>
<tr>
<th colspan="4">{% trans 'Define new aliases' %}</th>
</tr>
</thead>
<tr>
<td>
<label>{% trans 'Select database:' %}</label>
</td>
<td>
<select id="db_alias_select">
<option value=""></option>
</select>
</td>
<td>
<input id="db_alias_name" placeholder="{% trans 'New database name' %}" disabled="1">
</td>
<td>
<button id="db_alias_button" class="btn btn-secondary" disabled="1">{% trans 'Add' %}</button>
</td>
</tr>
<tr>
<td>
<label>{% trans 'Select table:' %}</label>
</td>
<td>
<select id="table_alias_select">
<option value=""></option>
</select>
</td>
<td>
<input id="table_alias_name" placeholder="{% trans 'New table name' %}" disabled="1">
</td>
<td>
<button id="table_alias_button" class="btn btn-secondary" disabled="1">{% trans 'Add' %}</button>
</td>
</tr>
<tr>
<td>
<label>{% trans 'Select column:' %}</label>
</td>
<td>
<select id="column_alias_select">
<option value=""></option>
</select>
</td>
<td>
<input id="column_alias_name" placeholder="{% trans 'New column name' %}" disabled="1">
</td>
<td>
<button id="column_alias_button" class="btn btn-secondary" disabled="1">{% trans 'Add' %}</button>
</td>
</tr>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" id="saveAndCloseBtn" data-bs-dismiss="modal">
{% trans 'Save & close' %}
</button>
</div>
</div>
</div>
</div>
<div class="card mb-3" id="output">
<div class="card-header">{% trans 'Output:' %}</div>
<ul class="list-group list-group-flush">
<li class="list-group-item">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" id="btn_alias_config"{{ has_aliases ? ' checked' }}>
<label class="form-check-label" for="btn_alias_config">{% trans 'Rename exported databases/tables/columns' %}</label>
</div>
</li>
{% if export_type != 'server' %}
<li class="list-group-item">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" name="lock_tables" value="something" id="checkbox_lock_tables"
{{- (not repopulate and is_checked_lock_tables) or lock_tables ? ' checked' }}>
<label class="form-check-label" for="checkbox_lock_tables">
{{ 'Use %s statement'|trans|format('<code>LOCK TABLES</code>')|raw }}
</label>
</div>
</li>
{% endif %}
<li class="list-group-item">
<div class="form-check">
<input class="form-check-input" type="radio" id="radio_view_as_text" name="output_format" value="astext"{{ repopulate or export_asfile == false ? ' checked' }}>
<label class="form-check-label" for="radio_view_as_text">{% trans 'View output as text' %}</label>
</div>
<div class="form-check mb-2">
<input class="form-check-input" type="radio" name="output_format" value="sendit" id="radio_dump_asfile"{{ not repopulate and is_checked_asfile ? ' checked' }}>
<label class="form-check-label" for="radio_dump_asfile">{% trans 'Save output to a file' %}</label>
</div>
<div class="hstack gap-3">
<div class="vr"></div>
<ul class="list-group" id="ul_save_asfile">
{% if has_save_dir %}
<li class="list-group-item">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" name="onserver" value="saveit" id="checkbox_dump_onserver"{{ is_checked_export ? ' checked' }}>
<label class="form-check-label" for="checkbox_dump_onserver">
{{ 'Save on server in the directory <strong>%s</strong>'|trans|format(save_dir|e)|raw }}
</label>
</div>
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" name="onserver_overwrite" value="saveitover" id="checkbox_dump_onserver_overwrite"
{{- is_checked_export_overwrite ? ' checked' }}>
<label class="form-check-label" for="checkbox_dump_onserver_overwrite">
{% trans 'Overwrite existing file(s)' %}
</label>
</div>
</li>
{% endif %}
<li class="list-group-item">
<div class="row g-3 align-items-center">
<div class="col-auto">
<label for="filename_template" class="col-form-label">
{% trans 'File name template:' %}
{{ show_hint('This value is interpreted using the \'strftime\' function, so you can use time formatting strings. Additionally the following transformations will happen: %s Other text will be kept as is. See the FAQ 6.27 for details.'|trans|format(filename_hint)) }}
</label>
</div>
<div class="col-auto">
<input type="text" class="form-control" name="filename_template" id="filename_template" value="{{ filename_template }}">
</div>
<div class="col-auto">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" name="remember_template" id="checkbox_remember_template"{{ is_checked_remember_file_template ? ' checked' }}>
<label class="form-check-label" for="checkbox_remember_template">
{% trans 'Use this for future exports' %}
</label>
</div>
</div>
</div>
</li>
{% if is_encoding_supported %}
<li class="list-group-item">
<div class="row">
<div class="col-auto">
<label for="select_charset" class="col-form-label">{% trans 'Character set of the file:' %}</label>
</div>
<div class="col-auto">
<select class="form-select" id="select_charset" name="charset">
{% for charset in encodings %}
<option value="{{ charset }}"
{{- (export_charset is empty and charset == 'utf-8') or charset == export_charset ? ' selected' }}>
{{- charset -}}
</option>
{% endfor %}
</select>
</div>
</div>
</li>
{% endif %}
{% if has_zip or has_gzip %}
<li class="list-group-item">
<div class="row">
<div class="col-auto">
<label for="compression" class="col-form-label">{% trans 'Compression:' %}</label>
</div>
<div class="col-auto">
<select class="form-select" id="compression" name="compression">
<option value="none">{% trans 'None' %}</option>
{% if has_zip %}
<option value="zip"
{{- selected_compression == 'zip' ? ' selected' }}>
{% trans 'zipped' %}
</option>
{% endif %}
{% if has_gzip %}
<option value="gzip"
{{- selected_compression == 'gzip' ? ' selected' }}>
{% trans 'gzipped' %}
</option>
{% endif %}
</select>
</div>
</div>
</li>
{% else %}
<input type="hidden" name="compression" value="{{ selected_compression }}">
{% endif %}
{% if export_type == 'server' or export_type == 'database' %}
<li class="list-group-item">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" role="switch" id="checkbox_as_separate_files" name="as_separate_files" value="{{ export_type }}"
{{- is_checked_as_separate_files ? ' checked' }}>
<label class="form-check-label" for="checkbox_as_separate_files">
{% if export_type == 'server' %}
{% trans 'Export databases as separate files' %}
{% elseif export_type == 'database' %}
{% trans 'Export tables as separate files' %}
{% endif %}
</label>
</div>
</li>
{% endif %}
</ul>
</div>
</li>
<li class="list-group-item">
<label for="maxsize" class="form-label">{% trans 'Skip tables larger than:' %}</label>
<input class="form-control" type="number" id="maxsize" name="maxsize" aria-describedby="maxsizeHelp">
<div id="maxsizeHelp" class="form-text">{% trans 'The size is measured in MiB.' %}</div>
</li>
</ul>
</div>
<div class="card mb-3" id="format_specific_opts">
<div class="card-header">{% trans 'Format-specific options:' %}</div>
<div class="card-body">
{{ options|raw }}
</div>
</div>
{% if can_convert_kanji %}
{# Japanese encoding setting #}
<div class="card mb-3" id="kanji_encoding">
<div class="card-header">{% trans 'Encoding Conversion:' %}</div>
<div class="card-body">
{% include 'encoding/kanji_encoding_form.twig' %}
</div>
</div>
{% endif %}
<div id="submit">
<input id="buttonGo" class="btn btn-primary" type="submit" value="{% trans 'Export' %}" data-exec-time-limit="{{ exec_time_limit }}">
</div>
</form>
</div>