203 lines
11 KiB
Twig
203 lines
11 KiB
Twig
<div class="container">
|
|
<h2 class="my-3">
|
|
{{ get_image('b_import', 'Import'|trans) }}
|
|
{% block title %}{% endblock %}
|
|
</h2>
|
|
|
|
{{ page_settings_error_html|raw }}
|
|
{{ page_settings_html|raw }}
|
|
|
|
<iframe id="import_upload_iframe" name="import_upload_iframe" width="1" height="1" class="hide"></iframe>
|
|
<div id="import_form_status" class="hide"></div>
|
|
<div id="importmain">
|
|
<img src="{{ image('ajax_clock_small.gif') }}" width="16" height="16" alt="ajax clock" class="hide">
|
|
|
|
<script type="text/javascript">
|
|
//<![CDATA[
|
|
{% include 'import/javascript.twig' with {'upload_id': upload_id, 'handler': handler} only %}
|
|
//]]>
|
|
</script>
|
|
|
|
<form id="import_file_form" action="{{ url('/import') }}" method="post" enctype="multipart/form-data" name="import" class="ajax"
|
|
{%- if handler != 'PhpMyAdmin\\Plugins\\Import\\Upload\\UploadNoplugin' %} target="import_upload_iframe"{% endif %}>
|
|
{{ get_hidden_inputs(hidden_inputs) }}
|
|
|
|
<div class="card mb-3">
|
|
<div class="card-header">{% trans 'File to import:' %}</div>
|
|
<div class="card-body">
|
|
{# We don't have show anything about compression, when no supported #}
|
|
{% if compressions is not empty %}
|
|
<p class="card-text">
|
|
{{ 'File may be compressed (%s) or uncompressed.'|trans|format(compressions|join(', ')) }}<br>
|
|
{% trans 'A compressed file\'s name must end in <strong>.[format].[compression]</strong>. Example: <strong>.sql.zip</strong>' %}
|
|
</p>
|
|
{% endif %}
|
|
|
|
{% if is_upload and upload_dir is not empty %}
|
|
{% set use_local_file_import = timeout_passed_global is not empty and local_import_file is not empty %}
|
|
<ul class="nav nav-pills mb-3" id="importFileTab" role="tablist">
|
|
<li class="nav-item" role="presentation">
|
|
<button class="nav-link{{ not use_local_file_import ? ' active' }}" id="uploadFileTab" data-bs-toggle="tab" data-bs-target="#uploadFile" type="button" role="tab" aria-controls="uploadFile" aria-selected="{{ not use_local_file_import ? 'true' : 'false' }}">{% trans 'Upload a file' %}</button>
|
|
</li>
|
|
<li class="nav-item" role="presentation">
|
|
<button class="nav-link{{ use_local_file_import ? ' active' }}" id="localFileTab" data-bs-toggle="tab" data-bs-target="#localFile" type="button" role="tab" aria-controls="localFile" aria-selected="{{ use_local_file_import ? 'true' : 'false' }}">{% trans 'Select file to import' %}</button>
|
|
</li>
|
|
</ul>
|
|
<div class="tab-content mb-3" id="importFileTabContent">
|
|
<div class="tab-pane fade{{ not use_local_file_import ? ' show active' }}" id="uploadFile" role="tabpanel" aria-labelledby="uploadFileTab">
|
|
<input type="hidden" name="MAX_FILE_SIZE" value="{{ max_upload_size }}">
|
|
<div class="mb-3">
|
|
<label class="form-label" for="input_import_file">{% trans 'Browse your computer:' %} <small>{{ formatted_maximum_upload_size }}</small></label>
|
|
<input class="form-control" type="file" name="import_file" id="input_import_file">
|
|
</div>
|
|
<div id="upload_form_status" class="hide"></div>
|
|
<div id="upload_form_status_info" class="hide"></div>
|
|
<p class="card-text">{% trans 'You may also drag and drop a file on any page.' %}</p>
|
|
</div>
|
|
|
|
<div class="tab-pane fade{{ use_local_file_import ? ' show active' }}" id="localFile" role="tabpanel" aria-labelledby="localFileTab">
|
|
{% if local_files is same as(false) %}
|
|
{{ 'The directory you set for upload work cannot be reached.'|trans|error }}
|
|
{% elseif local_files is not empty %}
|
|
<label class="form-label" for="select_local_import_file">{{ 'Select from the web server upload directory [strong]%s[/strong]:'|trans|format(user_upload_dir)|sanitize }}</label>
|
|
<select class="form-select" size="1" name="local_import_file" id="select_local_import_file">
|
|
<option value=""></option>
|
|
{{ local_files|raw }}
|
|
</select>
|
|
{% else %}
|
|
<div class="alert alert-info" role="alert">
|
|
{% trans 'There are no files to import!' %}
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
{% elseif is_upload %}
|
|
<input type="hidden" name="MAX_FILE_SIZE" value="{{ max_upload_size }}">
|
|
<div class="mb-3">
|
|
<label class="form-label" for="input_import_file">{% trans 'Browse your computer:' %} <small>{{ formatted_maximum_upload_size }}</small></label>
|
|
<input class="form-control" type="file" name="import_file" id="input_import_file">
|
|
</div>
|
|
<div id="upload_form_status" class="hide"></div>
|
|
<div id="upload_form_status_info" class="hide"></div>
|
|
<p class="card-text">{% trans 'You may also drag and drop a file on any page.' %}</p>
|
|
{% elseif upload_dir is not empty %}
|
|
{% if local_files is same as(false) %}
|
|
{{ 'The directory you set for upload work cannot be reached.'|trans|error }}
|
|
{% elseif local_files is not empty %}
|
|
<div class="mb-3">
|
|
<label class="form-label" for="select_local_import_file">{{ 'Select from the web server upload directory [strong]%s[/strong]:'|trans|format(user_upload_dir)|sanitize }}</label>
|
|
<select class="form-select" size="1" name="local_import_file" id="select_local_import_file">
|
|
<option value=""></option>
|
|
{{ local_files|raw }}
|
|
</select>
|
|
</div>
|
|
{% else %}
|
|
<div class="alert alert-info" role="alert">
|
|
{% trans 'There are no files to import!' %}
|
|
</div>
|
|
{% endif %}
|
|
{% else %}
|
|
{{ 'File uploads are not allowed on this server.'|trans|notice }}
|
|
{% endif %}
|
|
|
|
<label class="form-label" for="charset_of_file">{% trans 'Character set of the file:' %}</label>
|
|
{% if is_encoding_supported %}
|
|
<select class="form-select" id="charset_of_file" name="charset_of_file" size="1">
|
|
{% for charset in encodings %}
|
|
<option value="{{ charset }}"{% if (import_charset is empty and charset == 'utf-8') or charset == import_charset %} selected{% endif %}>
|
|
{{- charset -}}
|
|
</option>
|
|
{% endfor %}
|
|
</select>
|
|
{% else %}
|
|
<select class="form-select" lang="en" dir="ltr" name="charset_of_file" id="charset_of_file">
|
|
<option value=""></option>
|
|
{% for charset in charsets %}
|
|
<option value="{{ charset.getName() }}" title="{{ charset.getDescription() }}"{{ charset.getName() == 'utf8' ? ' selected' }}>
|
|
{{- charset.getName() -}}
|
|
</option>
|
|
{% endfor %}
|
|
</select>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card mb-3">
|
|
<div class="card-header">{% trans 'Partial import:' %}</div>
|
|
<div class="card-body">
|
|
{% if timeout_passed is defined and timeout_passed %}
|
|
<input type="hidden" name="skip" value="{{ offset }}">
|
|
<div class="alert alert-info" role="alert">
|
|
{{ 'Previous import timed out, after resubmitting will continue from position %d.'|trans|format(offset) }}
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div class="form-check form-switch mb-3">
|
|
<input class="form-check-input" type="checkbox" role="switch" name="allow_interrupt" value="yes" id="checkbox_allow_interrupt"{{ is_allow_interrupt_checked|raw }} aria-describedby="allowInterruptHelp">
|
|
<label class="form-check-label" for="checkbox_allow_interrupt">
|
|
{% trans 'Allow the interruption of an import in case the script detects it is close to the PHP timeout limit.' %}
|
|
</label>
|
|
<div id="allowInterruptHelp" class="form-text">{% trans 'This might be a good way to import large files, however it can break transactions.' %}</div>
|
|
</div>
|
|
|
|
{% if not (timeout_passed is defined and timeout_passed) %}
|
|
<label class="form-label" for="text_skip_queries">{% trans 'Skip this number of queries (for SQL) starting from the first one:' %}</label>
|
|
<input class="form-control" type="number" name="skip_queries" value="{{ skip_queries_default|raw }}" id="text_skip_queries" min="0">
|
|
{% else %}
|
|
{# If timeout has passed, do not show the Skip dialog to avoid the risk of someone entering a value here that would interfere with "skip" #}
|
|
<input type="hidden" name="skip_queries" value="{{ skip_queries_default|raw }}" id="text_skip_queries">
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card mb-3">
|
|
<div class="card-header">{% trans 'Other options' %}</div>
|
|
<div class="card-body">
|
|
<input type="hidden" name="fk_checks" value="0">
|
|
<div class="form-check form-switch">
|
|
<input class="form-check-input" type="checkbox" role="switch" name="fk_checks" id="fk_checks" value="1"{{ is_foreign_key_check ? ' checked' }}>
|
|
<label class="form-check-label" for="fk_checks">{% trans 'Enable foreign key checks' %}</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card mb-3">
|
|
<div class="card-header">{% trans 'Format' %}</div>
|
|
<div class="card-body">
|
|
<select class="form-select" id="plugins" name="format" aria-label="{% trans 'Format' %}">
|
|
{% 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="true">
|
|
{% endfor %}
|
|
|
|
<div id="import_notification"></div>
|
|
</div>
|
|
</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>
|
|
|
|
{# Japanese encoding setting #}
|
|
{% if can_convert_kanji %}
|
|
<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 'Import' %}">
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|