nid = $expense->nid;
$n->uid = $expense->uid;
$n->organization_nid = $expense->organization_nid;
$n->project_nid = $expense->project_nid;
$n->task_nid = $expense->task_nid;
$n->ticket_nid = $expense->ticket_nid;
$n->type = 'stormexpense';
$rows[] = array(
l($expense->organization_title, 'node/'. $expense->organization_nid),
l($expense->project_title, 'node/'. $expense->project_nid),
l($expense->title, 'node/'. $expense->nid),
format_date($expense->expensedate, 'custom', 'Y-m-d'),
array('data' => sprintf('%.2f', $expense->total), 'align' => 'right'),
array(
'data' => storm_icon_edit_node($n, $_GET) .' '. storm_icon_delete_node($n, $_GET),
'class' => 'storm_list_operations',
),
);
}
$o = theme('table', $header, $rows);
$header = array(
array(
'data' => t('Amount'),
'style' => 'text-align: right;',
),
array(
'data' => variable_get('storm_tax1_name', 'VAT'),
'style' => 'text-align: right;',
),
array(
'data' => variable_get('storm_tax2_name', 'Tax 2'),
'style' => 'text-align: right;',
),
array(
'data' => t('Total'),
'style' => 'text-align: right;',
),
);
$rows = array();
$rows[] = array(
array(
'data' => sprintf('%.2f', $totals->t_amount),
'style' => 'text-align: right;',
),
array(
'data' => sprintf('%.2f', $totals->t_tax1),
'style' => 'text-align: right;',
),
array(
'data' => sprintf('%.2f', $totals->t_tax2),
'style' => 'text-align: right;',
),
array(
'data' => sprintf('%.2f', $totals->t_total),
'style' => 'text-align: right;',
),
);
$o .= theme('table', $header, $rows);
return $o;
}
function theme_stormexpense_view($node, $teaser = FALSE, $page = FALSE) {
drupal_add_css(drupal_get_path('module', 'storm') . '/storm-node.css', 'module');
$node = node_prepare($node, $teaser);
$l_pos = 1; // Used to increase the link position number (see issue 814820)
$node->content['links'] = array(
'#prefix' => '
',
'#weight' => -25,
);
// Code to create invoice auto_add link
if (module_exists('storminvoice') && user_access('Storm invoice: add')) {
$v = '';
$v .= ''. t('Invoice this item:') .'';
$v .= '';
$v .= '- '. l('Add to new invoice', 'storm/invoice/auto_add/new/'. $node->nid) .'
';
$v .= '- '. l('Add to existing invoice', 'storm/invoice/auto_add/existing/'. $node->nid) .'
';
$v .= '
';
$node->content['links']['auto_invoice'] = array(
'#prefix' => '',
'#suffix' => '',
'#value' => $v,
'#weight' => $l_pos++,
);
}
$node->content['group1'] = array(
'#prefix' => '',
'#suffix' => '
',
'#weight' => module_exists('content') ? content_extra_field_weight($node->type, 'group1') : -20,
);
$node->content['group1']['organization'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Organization'), l($node->organization_title, 'node/'. $node->organization_nid)),
'#weight' => 1,
);
$node->content['group1']['project'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Project'), l($node->project_title, 'node/'. $node->project_nid)),
'#weight' => 2,
);
$node->content['group1']['task'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Task'), l($node->task_title, 'node/'. $node->task_nid)),
'#weight' => 3,
);
$node->content['group1']['ticket'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Ticket'), l($node->ticket_title, 'node/'. $node->ticket_nid)),
'#weight' => 4,
);
$node->content['group2'] = array(
'#prefix' => '',
'#suffix' => '
',
'#weight' => module_exists('content') ? content_extra_field_weight($node->type, 'group2') : -19,
);
$node->content['group2']['expensedate'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Date'), format_date($node->expensedate, 'custom', 'Y-m-d')),
'#weight' => 1,
);
$node->content['group2']['provider'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Provider'), $node->provider_title),
'#weight' => 2,
);
$node->content['group3'] = array(
'#prefix' => '',
'#suffix' => '
',
'#weight' => module_exists('content') ? content_extra_field_weight($node->type, 'group3') : -18,
);
$node->content['group3']['amount'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Amount'), sprintf('%.2f', $node->amount)),
'#weight' => 1,
);
$node->content['group4'] = array(
'#prefix' => '',
'#suffix' => '
',
'#weight' => module_exists('content') ? content_extra_field_weight($node->type, 'group4') : -17,
);
if ($node->tax1) {
$node->content['group4']['tax1'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', variable_get('storm_tax1_name', 'VAT'), sprintf('%.2f', $node->tax1)),
'#weight' => 1,
);
}
if ($node->tax2) {
$node->content['group4']['tax2'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', variable_get('storm_tax2_name', 'Tax 2'), sprintf('%.2f', $node->tax2)),
'#weight' => 2,
);
}
if ($node->tax1 || $node->tax2) {
$node->content['group4']['total'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Total'), sprintf('%.2f', $node->total)),
'#weight' => 3,
);
}
$node->content['body_field'] = array(
'#prefix' => '',
'#suffix' => '
',
'#value' => theme('storm_view_item', t('Description'), $node->content['body']['#value']),
'#weight' => module_exists('content') ? content_extra_field_weight($node->type, 'body_field') : -16,
);
unset($node->content['body']);
return $node;
}
function theme_stormexpense_list_form_report_reports() {
$reports = array(
'std' => t('Standard'),
'for_organization' => t('For an organization'),
'for_organization_w_task' => t('For an org. with tasks'),
'for_project' => t('For a project'),
);
return $reports;
}
function theme_stormexpense_list_report($report, $language, $expenses) {
switch ($report) {
case 'std':
$header = array(
t('Organization', array(), $language),
t('Project', array(), $language),
t('Title', array(), $language),
t('Date', array(), $language),
t('Total', array(), $language));
$expenses_total = 0;
$rows = array();
foreach ($expenses as $expense) {
$rows[] = array(
check_plain($expense->organization_title),
check_plain($expense->project_title),
check_plain($expense->title),
format_date($expense->expensedate, 'custom', 'Y-m-d'),
array('data' => sprintf('%.2f', $expense->total), 'align' => 'right'),
);
$expenses_total += $expense->total;
}
$title = ''. t('Expenses report', array(), $language) .'
';
break;
case 'for_organization':
$organization = node_load($_SESSION['stormexpense_list_filter']['organization_nid']);
$header = array(
t('Project', array(), $language),
t('Title', array(), $language),
t('Date', array(), $language),
t('Total', array(), $language));
$expenses_total = 0;
foreach ($expenses as $expense) {
$rows[] = array(
check_plain($expense->project_title),
check_plain($expense->title),
format_date($expense->expensedate, 'custom', 'Y-m-d'),
array('data' => sprintf('%.2f', $expense->total), 'align' => 'right'),
);
$expenses_total += $expense->total;
}
$title = ''. t('Expenses report', array(), $language) .'
';
$title .= t('Organization : @organization', array('@organization' => $organization->fullname), $language) .'
';
break;
case 'for_organization_w_task':
$organization = node_load($_SESSION['stormexpense_list_filter']['organization_nid']);
$header = array(
t('Project', 'expense', array(), $language),
t('Task', 'expense', array(), $language),
t('Title', 'expense', array(), $language),
t('Date', 'expense', array(), $language),
t('Total', 'expense', array(), $language));
$total_duration = 0;
foreach ($expenses as $expense) {
$rows[] = array(
check_plain($expense->project_title),
check_plain($expense->task_title),
check_plain($expense->title),
format_date($expense->expensedate, 'custom', 'Y-m-d'),
array('data' => sprintf('%.2f', $expense->total), 'align' => 'right'),
);
$expenses_total += $expense->total;
}
$title = ''. t('Expenses report', array(), $language) .'
';
$title .= t('Organization : @organization', array('@organization' => $organization->fullname), $language) .'
';
break;
case 'for_project':
$organization = node_load($_SESSION['stormexpense_list_filter']['organization_nid']);
$project = node_load($_SESSION['stormexpense_list_filter']['project_nid']);
$header = array(
t('Task', 'expense', array(), $language),
t('Title', 'expense', array(), $language),
t('Date', 'expense', array(), $language),
t('Total', 'expense', array(), $language));
$total_duration = 0;
foreach ($expenses as $expense) {
$rows[] = array(
check_plain($expense->task_title),
check_plain($expense->title),
format_date($expense->expensedate, 'custom', 'Y-m-d'),
array('data' => sprintf('%.2f', $expense->total), 'align' => 'right'),
);
$expenses_total += $expense->total;
}
$title = ''. t('Expenses report', array(), $language) .'
';
$title .= t('Organization : @organization', array('@organization' => $organization->fullname), $language) .'
';
$title .= t('Project : @project', array('@project' => $project->title), $language) .'
';
break;
}
$footer = ''. t('Expenses total : %expenses_total' , array('%expenses_total' => format_plural($expenses_total, '1', '@count', array(), $language)), $language) .'
';
return theme('storm_list_report', $header, $rows, $title, $footer);
}