This repository has been archived on 2025-06-21. You can view files and clone it, but you cannot make any changes to it's state, such as pushing and creating new issues, pull requests or comments.
suitedesk/modules/storm/storminvoice/storminvoice.views.inc

461 lines
12 KiB
PHP

<?php
/**
* @file
* Functions to expose SuiteDesk Invoice module data to the views module
*/
function storminvoice_views_data() {
// Invoice core fields
$data['storminvoice']['table']['group'] = t('SuiteDesk Invoice');
$data['storminvoice']['table']['join'] = array(
'node' => array(
'left_field' => 'vid',
'field' => 'vid',
),
);
$data['storminvoice']['number'] = array(
'title' => t('Number'),
'help' => t('SuiteDesk Invoice Number'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['reference'] = array(
'title' => t('Reference'),
'help' => t('SuiteDesk Invoice Reference'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_string',
),
'argument' => array(
'handler' => 'views_handler_argument_string',
),
);
$data['storminvoice']['organization_nid'] = array(
'title' => t('Organization'),
'help' => t('Invoice -> Organization'),
'relationship' => array(
'base' => 'node',
'field' => 'nid',
'handler' => 'views_handler_relationship',
'label' => t('Invoice -> Organization'),
),
);
$data['storminvoice']['organization_title'] = array(
'title' => t('Organization'),
'help' => t('SuiteDesk Invoice Organization (title only)'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_string',
),
'argument' => array(
'handler' => 'views_handler_argument_string',
),
);
$data['storminvoice']['project_nid'] = array(
'title' => t('Project'),
'help' => t('Invoice -> Project'),
'relationship' => array(
'base' => 'node',
'field' => 'nid',
'handler' => 'views_handler_relationship',
'label' => t('Invoice -> Project'),
),
);
$data['storminvoice']['project_title'] = array(
'title' => t('Project'),
'help' => t('SuiteDesk Invoice Project (title only)'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_string',
),
'argument' => array(
'handler' => 'views_handler_argument_string',
),
);
$data['storminvoice']['requestdate'] = array(
'title' => t('Request date'),
'help' => t('SuiteDesk Invoice Request Date'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'views_handler_field_date',
),
'sort' => array(
'handler' => 'views_handler_sort_date',
),
'filter' => array(
'handler' => 'views_handler_filter_date',
),
);
$data['storminvoice']['duedate'] = array(
'title' => t('Due date'),
'help' => t('SuiteDesk Invoice Due Date'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'views_handler_field_date',
),
'sort' => array(
'handler' => 'views_handler_sort_date',
),
'filter' => array(
'handler' => 'views_handler_filter_date',
),
);
$data['storminvoice']['paymentdate'] = array(
'title' => t('Payment date'),
'help' => t('SuiteDesk Invoice Payment Date'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'views_handler_field_date',
),
'sort' => array(
'handler' => 'views_handler_sort_date',
),
'filter' => array(
'handler' => 'views_handler_filter_date',
),
);
$data['storminvoice']['amount'] = array(
'title' => t('Amount'),
'help' => t('SuiteDesk Invoice Amount'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['tax1'] = array(
'title' => t('Tax 1'),
'help' => t('SuiteDesk Invoice Tax 1'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['tax2'] = array(
'title' => t('Tax 2'),
'help' => t('SuiteDesk Invoice Tax 2'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['total'] = array(
'title' => t('Total'),
'help' => t('SuiteDesk Invoice Total'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['totalcustomercurr'] = array(
'title' => t('Total in customer currency'),
'help' => t('SuiteDesk Invoice Total in Customer Currency'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['taxexempt'] = array(
'title' => t('Tax exempt'),
'help' => t('SuiteDesk Invoice Tax Exempt'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['invoice_status'] = array(
'title' => t('Invoice status'),
'help' => t('SuiteDesk Invoice Status'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'storminvoice_handler_field_invoice_status'
),
'filter' => array(
'handler' => 'storminvoice_handler_filter_invoice_status',
),
);
// Invoice items
$data['storminvoice_items']['table']['group'] = t('SuiteDesk Invoice Item');
$data['storminvoice_items']['table']['join'] = array(
'node' => array(
'left_field' => 'nid',
'field' => 'invoice_nid',
),
);
$data['storminvoice_items']['invoice_nid'] = array(
'title' => t('Invoice'),
'help' => t('Invoiceitem -> Invoice'),
'relationship' => array(
'base' => 'node',
'field' => 'nid',
'handler' => 'views_handler_relationship',
'label' => t('Invoiceitem -> Invoice'),
),
);
$data['storminvoice_items']['weight'] = array(
'title' => t('Weight'),
'help' => t('SuiteDesk Invoiceitem Weight'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice_items']['amount'] = array(
'title' => t('Amount'),
'help' => t('SuiteDesk Invoiceitem Amount'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice_items']['tax1percent'] = array(
'title' => t('Tax 1 Percent'),
'help' => t('SuiteDesk Invoiceitem Tax 1 Percent'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice_items']['tax2percent'] = array(
'title' => t('Tax 2 Percent'),
'help' => t('SuiteDesk Invoiceitem Tax 2 Percent'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice_items']['tax1'] = array(
'title' => t('Tax 1'),
'help' => t('SuiteDesk Invoiceitem Tax 1'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice_items']['tax2'] = array(
'title' => t('Tax 2'),
'help' => t('SuiteDesk Invoiceitem Tax 2'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice_items']['total'] = array(
'title' => t('Total'),
'help' => t('SuiteDesk Invoiceitem Total'),
'field' => array(
'click sortable' => TRUE,
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
);
$data['storminvoice']['operation'] = array(
'field' => array(
'title' => t('Edit/Delete link'),
'help' => t('Provide a simple link to edit and delete the node.'),
'handler' => 'storm_handler_field_operation',
'type' => 'storminvoice',
),
);
return $data;
}
function storminvoice_views_handlers() {
return array(
'info' => array(
'path' => drupal_get_path('module', 'storminvoice'),
),
'handlers' => array(
'storm_handler_filter_attributes_domain' => array(
'parent' => 'views_handler_filter_in_operator',
'path' => drupal_get_path('module', 'storm'),
),
'storm_handler_field_operation' => array(
'parent' => 'views_handler_field_node_link',
'path' => drupal_get_path('module', 'storm'),
),
'storminvoice_handler_field_invoice_status' => array(
'parent' => 'views_handler_field',
),
'storminvoice_handler_filter_invoice_status' => array(
'parent' => 'views_handler_filter_in_operator',
),
),
);
}
function storminvoice_date_api_fields($field) {
$values = array(
'sql_type' => DATE_UNIX,
'tz_handling' => 'site',
'timezone_field' => '',
'offset_field' => '',
'related_fields' => array(),
'granularity' => array('year', 'month', 'day'),
);
switch ($field) {
case 'storminvoice.paymentdate':
case 'storminvoice.duedate':
case 'storminvoice.requestdate':
return $values;
}
}
function storminvoice_date_api_tables() {
return array('storminvoice');
}