repository = $repository;
}
public function list(): string
{
$sortableColumns = ['id', 'status', 'color', 'o', 'apilo_status_id'];
$filterDefinitions = [
[
'key' => 'status',
'label' => 'Status',
'type' => 'text',
],
];
$listRequest = \admin\Support\TableListRequestFactory::fromRequest(
$filterDefinitions,
$sortableColumns,
'o'
);
$sortDir = $listRequest['sortDir'];
if (trim((string)\Shared\Helpers\Helpers::get('sort')) === '') {
$sortDir = 'ASC';
}
$result = $this->repository->listForAdmin(
$listRequest['filters'],
$listRequest['sortColumn'],
$sortDir,
$listRequest['page'],
$listRequest['perPage']
);
$apiloStatusList = $this->getApiloStatusList();
$rows = [];
$lp = ($listRequest['page'] - 1) * $listRequest['perPage'] + 1;
foreach ($result['items'] as $item) {
$id = (int)($item['id'] ?? 0);
$statusName = trim((string)($item['status'] ?? ''));
$color = trim((string)($item['color'] ?? ''));
$apiloStatusId = $item['apilo_status_id'] ?? null;
$apiloStatusLabel = '';
if ($apiloStatusId !== null && isset($apiloStatusList[$apiloStatusId])) {
$apiloStatusLabel = $apiloStatusList[$apiloStatusId];
}
$colorHtml = $color !== ''
? ' ' . htmlspecialchars($color, ENT_QUOTES, 'UTF-8')
: '-';
$rows[] = [
'lp' => $lp++ . '.',
'status' => '' . htmlspecialchars($statusName, ENT_QUOTES, 'UTF-8') . '',
'color' => $colorHtml,
'apilo_status' => htmlspecialchars($apiloStatusLabel, ENT_QUOTES, 'UTF-8'),
'_actions' => [
[
'label' => 'Edytuj',
'url' => '/admin/shop_statuses/edit/id=' . $id,
'class' => 'btn btn-xs btn-primary',
],
],
];
}
$total = (int)$result['total'];
$totalPages = max(1, (int)ceil($total / $listRequest['perPage']));
$viewModel = new PaginatedTableViewModel(
[
['key' => 'lp', 'label' => 'Lp.', 'class' => 'text-center', 'sortable' => false],
['key' => 'status', 'sort_key' => 'status', 'label' => 'Status', 'sortable' => true, 'raw' => true],
['key' => 'color', 'sort_key' => 'color', 'label' => 'Kolor', 'sortable' => true, 'raw' => true],
['key' => 'apilo_status', 'sort_key' => 'apilo_status_id', 'label' => 'Status Apilo', 'sortable' => true],
],
$rows,
$listRequest['viewFilters'],
[
'column' => $listRequest['sortColumn'],
'dir' => $sortDir,
],
[
'page' => $listRequest['page'],
'per_page' => $listRequest['perPage'],
'total' => $total,
'total_pages' => $totalPages,
],
array_merge($listRequest['queryFilters'], [
'sort' => $listRequest['sortColumn'],
'dir' => $sortDir,
'per_page' => $listRequest['perPage'],
]),
$listRequest['perPageOptions'],
$sortableColumns,
'/admin/shop_statuses/list/',
'Brak danych w tabeli.'
);
return \Shared\Tpl\Tpl::view('shop-statuses/view-list', [
'viewModel' => $viewModel,
]);
}
public function edit(): string
{
$status = $this->repository->find((int)\Shared\Helpers\Helpers::get('id'));
if ($status === null) {
\Shared\Helpers\Helpers::alert('Status nie zostal znaleziony.');
header('Location: /admin/shop_statuses/list/');
exit;
}
$apiloStatusList = $this->getApiloStatusList();
return \Shared\Tpl\Tpl::view('shop-statuses/status-edit', [
'form' => $this->buildFormViewModel($status, $apiloStatusList),
]);
}
public function save(): void
{
$legacyValues = \Shared\Helpers\Helpers::get('values');
if ($legacyValues) {
$values = json_decode((string)$legacyValues, true);
$response = [
'status' => 'error',
'msg' => 'Podczas zapisywania statusu wystapil blad. Prosze sprobowac ponownie.',
];
if (is_array($values)) {
$statusId = (int)($values['id'] ?? 0);
$id = $this->repository->save($statusId, $values);
if ($id !== null && $id >= 0) {
$response = [
'status' => 'ok',
'msg' => 'Status zostal zapisany.',
'id' => (int)$id,
];
}
}
echo json_encode($response);
exit;
}
$payload = $_POST;
$statusId = isset($payload['id']) && $payload['id'] !== '' ? (int)$payload['id'] : null;
if ($statusId === null) {
$statusId = (int)\Shared\Helpers\Helpers::get('id');
}
$id = $this->repository->save($statusId, $payload);
if ($id !== null && $id >= 0) {
echo json_encode([
'success' => true,
'id' => (int)$id,
'message' => 'Status zostal zapisany.',
]);
exit;
}
echo json_encode([
'success' => false,
'errors' => ['general' => 'Podczas zapisywania statusu wystapil blad.'],
]);
exit;
}
private function buildFormViewModel(array $status, array $apiloStatusList): FormEditViewModel
{
$id = (int)($status['id'] ?? 0);
$apiloOptions = ['' => '--- wybierz status apilo.com ---'];
foreach ($apiloStatusList as $apiloId => $apiloName) {
$apiloOptions[$apiloId] = $apiloName;
}
$data = [
'id' => $id,
'status' => (string)($status['status'] ?? ''),
'color' => (string)($status['color'] ?? ''),
'apilo_status_id' => $status['apilo_status_id'] ?? '',
];
$fields = [
FormField::hidden('id', $id),
FormField::text('status', [
'label' => 'Status',
'tab' => 'settings',
'readonly' => true,
]),
FormField::color('color', [
'label' => 'Kolor',
'tab' => 'settings',
]),
FormField::select('apilo_status_id', [
'label' => 'Status z Apilo',
'tab' => 'settings',
'options' => $apiloOptions,
]),
];
$tabs = [
new FormTab('settings', 'Ustawienia', 'fa-wrench'),
];
$actionUrl = '/admin/shop_statuses/save/id=' . $id;
$actions = [
FormAction::save($actionUrl, '/admin/shop_statuses/list/'),
FormAction::cancel('/admin/shop_statuses/list/'),
];
return new FormEditViewModel(
'status-edit',
'Edycja statusu zamowienia',
$data,
$fields,
$tabs,
$actions,
'POST',
$actionUrl,
'/admin/shop_statuses/list/',
true,
['id' => $id]
);
}
private function getApiloStatusList(): array
{
global $mdb;
$integrationsRepository = new IntegrationsRepository( $mdb );
$list = [];
$raw = @unserialize( $integrationsRepository -> getSetting( 'apilo', 'status-types-list' ) );
if (is_array($raw)) {
foreach ($raw as $apiloStatus) {
if (isset($apiloStatus['id'], $apiloStatus['name'])) {
$list[(int)$apiloStatus['id']] = (string)$apiloStatus['name'];
}
}
}
return $list;
}
}