Files
Phraseanet/templates/web/admin/task-manager/task-editor/task.html.twig
Jean-Yves Gaulier b00cd16251 task record mover ok to test
- better sample
- twig cs
#time 1.5d
2015-05-20 20:05:37 +02:00

169 lines
6.2 KiB
Twig

<div id="taskBody">
{% block css %}{% endblock %}
<div>
<form
name="task-edit"
method="POST"
action="{{ path('admin_tasks_task_save', {'task' : task.getId()}) }}"
class="form-inline no-ajax"
>
{% if form.vars.errors|length > 0 %}
{{ form_errors(form) }}
{% endif %}
{{ form_rest(form) }}
<a href="{{ path('admin_tasks_list') }}">{{ 'Cancel' | trans }}</a>
<button type="submit" class="btn btn-success btn-trigger " id="taskSaveButton">
{{ "Save" | trans }}
</button>
</form>
<div>
{{ 'admin::tasks: Nombre de crashes :' | trans }} <span id="crash-counter">{{ task.getCrashed() }}</span>
<button class="btn btn-success" id="taskResetCrashCounterButton">
{{ 'admin::tasks: reinitialiser el compteur de crashes' | trans }}
</button>
</div>
</div>
<div id="taskTabs">
<ul>
<li><a href="#taskXmlTab">{{ 'boutton::vue xml' | trans }}</a></li>
<li><a href="#taskGuiTab">{{ 'boutton::vue graphique' | trans }}</a></li>
</ul>
<div id="taskGuiTab" >
<form id="graphicForm" name="graphicForm" class="form-horizontal" onsubmit="return(false);" method="post">
{% block form %}{% endblock %}
</form>
</div>
<div id="taskXmlTab">
{% block xml_settings %}
<form onsubmit="return(false);" name="fxml" method="post">
<textarea nowrap id="txtareaxml" style="white-space:pre; width:100%; height:250px" name="txtareaxml" >{{task.getSettings()}}</textarea>
</form>
{% endblock %}
</div>
</div>
{% block javascript %}
<script type="text/javascript">
function taskFillGraphic(xml) { };
</script>
{% endblock %}
</div>
<script type="text/javascript">
$(document).ready(function(){
$("#taskTabs").tabs({
create: function(event, ui) {
$("#taskTabs").tabs({ active: 1 });
}
,
beforeActivate: function(event, ui) {
switch($(ui.newPanel).attr("id"))
{
case "taskGuiTab":
var validated = false;
// click on gui tab : fill the gui from xml, then switch to the gui view
$.ajax({
"url" : "{{ path('admin_tasks_validate_xml') }}",
"data" : $("#txtareaxml").val(),
"processData" : false,
"dataType" : "text",
"type" : "POST",
"async" : false,
success : function(data) {
var x = $("#txtareaxml").val();
try {
taskFillGraphic(x);
validated = true;
} catch(e) {
// todo add notification
console.log(e);
}
},
error:function(jqXHR, textStatus, errorThrown) {
// todo add notification
}
});
return validated;
break;
case "taskXmlTab":
xmlFromForm();
break;
}
}
});
$("#taskResetCrashCounterButton").click(function()
{
$.ajax({
"url" : "{{ path('admin_tasks_task_reset', {'task' : task.getId()}) }}",
"dataType" : "json",
"type" : "POST",
success:function(data) {
if(!data.success) {
//todo add notification and loader
} else {
$("#crash-counter").html("0");
}
}
});
});
function xmlFromForm(callback) {
var formData = $("#graphicForm").serializeArray();
formData.push({"name":"xml", "value":$("#txtareaxml").val()});
$.ajax({ url: "{{ path('admin_tasks_xml_from_form', {'task' : task.getId()}) }}"
, data: formData
, dataType:'text'
, type:"POST"
, success:function(data) {
$("#txtareaxml").val(data);
if (typeof callback === 'function') {
callback(data);
}
}
, error:function(jqXHR, textStatus, errorThrown) {
console.log(jqXHR.responseText);
// todo add a notification message
}
});
}
$("form[name='task-edit']").on('submit', function()
{
xmlFromForm(function (data) {
$("form[name='task-edit'] input[name='settings']").val(data);
formData = $("form[name='task-edit']").serializeArray();
$.ajax({
url: "{{ path('admin_tasks_task_save', { 'task' : task.getID() }) }}"
, data: formData
, dataType:'json'
, type:"POST"
, async:false
, success:function(data) {
if (data.success) {
loadRightAjax("{{ path('admin_tasks_list') }}");
} else {
if (window.console) {
console.log(data.message);
}
alert("{{ 'An error occured' | trans | e('js') }}" + data.message);
}
}
, error:function(jqXHR, textStatus, errorThrown) {
alert("Erreur XML:\n\n" + jqXHR.responseText);
}
});
});
return false;
});
});
</script>