mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 10:23:17 +00:00
PHRAS-2978 #comment update feedback expiration date #time 6h
This commit is contained in:
@@ -600,6 +600,38 @@ class PushController extends Controller
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function updateExpirationAction(Request $request)
|
||||||
|
{
|
||||||
|
$ret = [
|
||||||
|
'success' => false,
|
||||||
|
'message' => $this->app->trans('Unable to save the expiration date')
|
||||||
|
];
|
||||||
|
if (is_null($request->request->get('date'))) {
|
||||||
|
$ret['message'] = $this->app->trans('The provided date is null!');
|
||||||
|
return $this->app->json($ret);
|
||||||
|
}
|
||||||
|
$repository = $this->app['repo.baskets'];
|
||||||
|
$manager = $this->getEntityManager();
|
||||||
|
$manager->beginTransaction();
|
||||||
|
try {
|
||||||
|
$basket = $repository->findUserBasket($request->request->get('basket_id'), $this->app->getAuthenticatedUser(), true);
|
||||||
|
$date = new \DateTime($request->request->get('date'));
|
||||||
|
$validation = $basket->getValidation();
|
||||||
|
if (is_null($validation)) {
|
||||||
|
return $this->app->json($ret);
|
||||||
|
}
|
||||||
|
$validation->setExpires($date);
|
||||||
|
$manager->persist($validation);
|
||||||
|
$manager->flush();
|
||||||
|
$manager->commit();
|
||||||
|
$ret['message'] = $this->app->trans('Expiration date successfully updated!');
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$ret['message'] = $e->getMessage();
|
||||||
|
$manager->rollback();
|
||||||
|
}
|
||||||
|
return $this->app->json($ret);
|
||||||
|
}
|
||||||
|
|
||||||
private function formatUser(User $user)
|
private function formatUser(User $user)
|
||||||
{
|
{
|
||||||
$subtitle = array_filter([$user->getJob(), $user->getCompany()]);
|
$subtitle = array_filter([$user->getJob(), $user->getCompany()]);
|
||||||
@@ -734,4 +766,5 @@ class PushController extends Controller
|
|||||||
{
|
{
|
||||||
return $this->app['random.medium'];
|
return $this->app['random.medium'];
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -59,6 +59,9 @@ class Push implements ControllerProviderInterface, ServiceProviderInterface
|
|||||||
$controllers->post('/validate/', 'controller.prod.push:validateAction')
|
$controllers->post('/validate/', 'controller.prod.push:validateAction')
|
||||||
->bind('prod_push_validate');
|
->bind('prod_push_validate');
|
||||||
|
|
||||||
|
$controllers->post('/update-expiration/', 'controller.prod.push:updateExpirationAction')
|
||||||
|
->bind('prod_push_do_update_expiration');
|
||||||
|
|
||||||
$controllers->get('/user/{usr_id}/', 'controller.prod.push:getUserAction')
|
$controllers->get('/user/{usr_id}/', 'controller.prod.push:getUserAction')
|
||||||
->assert('usr_id', '\d+');
|
->assert('usr_id', '\d+');
|
||||||
|
|
||||||
|
@@ -11,7 +11,11 @@
|
|||||||
<span class="expiredDate">
|
<span class="expiredDate">
|
||||||
{% if basket.getValidation() %}
|
{% if basket.getValidation() %}
|
||||||
{% set dateExpired = app['date-formatter'].getPrettyString(basket.getValidation().getExpires()) %}
|
{% set dateExpired = app['date-formatter'].getPrettyString(basket.getValidation().getExpires()) %}
|
||||||
{{ 'workzone:feedback:expiration' | trans }} : {{ dateExpired }}
|
{% if date(dateExpired) < date() %}
|
||||||
|
<span>{{ 'workzone:feedback:expiration-closed' | trans }} :</span>
|
||||||
|
{% else %}
|
||||||
|
<span>{{ 'workzone:feedback:expiration-open' | trans }} :</span>
|
||||||
|
{% endif %} {{ dateExpired }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</span>
|
</span>
|
||||||
<div style="margin:5px 0;max-height:160px;overflow:hidden;text-overflow:ellipsis;">
|
<div style="margin:5px 0;max-height:160px;overflow:hidden;text-overflow:ellipsis;">
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
|
<script src="https://rawgithub.com/trentrichardson/jQuery-Timepicker-Addon/master/jquery-ui-timepicker-addon.js"></script>
|
||||||
<div>
|
<div>
|
||||||
<button class="tools-accordion">Actions</button>
|
<button class="tools-accordion">Actions</button>
|
||||||
<div class="tools-panel">
|
<div class="tools-panel">
|
||||||
@@ -101,13 +101,19 @@
|
|||||||
|
|
||||||
{% set dateExpired = app['date-formatter'].getPrettyString(basket.getValidation().getExpires()) %}
|
{% set dateExpired = app['date-formatter'].getPrettyString(basket.getValidation().getExpires()) %}
|
||||||
<div class="expiredDate">
|
<div class="expiredDate">
|
||||||
<span>{{ 'workzone:feedback:expiration' | trans }} :</span>
|
{% if date(dateExpired) < date() %}
|
||||||
|
<span>{{ 'workzone:feedback:expiration-closed' | trans }} :</span>
|
||||||
|
{% else %}
|
||||||
|
<span>{{ 'workzone:feedback:expiration-open' | trans }} :</span>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
<form class="update-feed-validation">
|
<form class="update-feed-validation">
|
||||||
<input type="hidden" name="feedback-id" value={{ basket.getValidation().getId}} />
|
<input type="hidden" name="feedbackId" value={{ basket.getId}} />
|
||||||
<input type="hidden" name="feedback-deadline-format" class="alternate" />
|
<input type="hidden" name="feedbackDate" class="alternate" />
|
||||||
<input type="text" class="btn datepicker" name="feedback-deadline" value="{{ dateExpired }}">
|
<input type="text" class="btn feed-datepicker" name="feedback-deadline" value="{{ dateExpired }}">
|
||||||
<button type="submit" class="submit" title="{{ 'workzone:feedback:update' | trans }}"><i class="fa fa-save"></i></button>
|
<button type="submit" class="submit" title="{{ 'workzone:feedback:update' | trans }}"><i class="fa fa-save"></i></button>
|
||||||
</form>
|
</form>
|
||||||
|
<p class="message text-right" style="opacity: 0;transition: all 0.2s; color: green; display: block; ">{{ 'prod:workzone:basket:updated-message' | trans }}</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@@ -135,7 +141,24 @@
|
|||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
$( ".update-feed-validation" ).on( "submit", function( event ) {
|
$( ".update-feed-validation" ).on( "submit", function( event ) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
console.log( $( this ).serialize() );
|
var formData = $(this).serializeArray();
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
type: 'POST',
|
||||||
|
url: '/prod/push/update-expiration/',
|
||||||
|
data: {
|
||||||
|
basket_id: formData[0].value,
|
||||||
|
date: formData[1].value
|
||||||
|
},
|
||||||
|
beforeSend: function() {
|
||||||
|
console.log(formData[0].value);
|
||||||
|
console.log(formData[1].value);
|
||||||
|
},
|
||||||
|
success: function (data) {
|
||||||
|
$('.message').css('opacity',1);
|
||||||
|
setTimeout(function(){ $('.message').css('opacity',0); }, 2000);
|
||||||
|
},
|
||||||
|
});
|
||||||
});
|
});
|
||||||
$( function() {
|
$( function() {
|
||||||
$.datepicker.regional['default'] = {
|
$.datepicker.regional['default'] = {
|
||||||
@@ -149,11 +172,12 @@
|
|||||||
dayNamesMin: [ "D","L","M","M","J","V","S" ],
|
dayNamesMin: [ "D","L","M","M","J","V","S" ],
|
||||||
dateFormat: "d MM yy",
|
dateFormat: "d MM yy",
|
||||||
altField: ".alternate",
|
altField: ".alternate",
|
||||||
altFormat: "yy-mm-dd"
|
altFormat: "yy-mm-dd",
|
||||||
|
minDate: 0
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
$( ".datepicker" ).datepicker( $.datepicker.regional[ 'default' ]);
|
$( ".feed-datepicker" ).datepicker( $.datepicker.regional[ 'default' ]);
|
||||||
})
|
})
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
Reference in New Issue
Block a user