PageRenderTime 44ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 0ms

/include/generic/SugarWidgets/SugarWidget.php

https://bitbucket.org/cviolette/sugarcrm
PHP | 111 lines | 44 code | 11 blank | 56 comment | 5 complexity | fa0def8d0108586cf8c82def4f8b9556 MD5 | raw file
Possible License(s): LGPL-2.1, MPL-2.0-no-copyleft-exception, BSD-3-Clause
  1. <?php
  2. if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
  3. /*********************************************************************************
  4. * SugarCRM Community Edition is a customer relationship management program developed by
  5. * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
  6. *
  7. * This program is free software; you can redistribute it and/or modify it under
  8. * the terms of the GNU Affero General Public License version 3 as published by the
  9. * Free Software Foundation with the addition of the following permission added
  10. * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
  11. * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
  12. * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
  13. *
  14. * This program is distributed in the hope that it will be useful, but WITHOUT
  15. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  16. * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
  17. * details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License along with
  20. * this program; if not, see http://www.gnu.org/licenses or write to the Free
  21. * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  22. * 02110-1301 USA.
  23. *
  24. * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
  25. * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
  26. *
  27. * The interactive user interfaces in modified source and object code versions
  28. * of this program must display Appropriate Legal Notices, as required under
  29. * Section 5 of the GNU Affero General Public License version 3.
  30. *
  31. * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
  32. * these Appropriate Legal Notices must retain the display of the "Powered by
  33. * SugarCRM" logo. If the display of the logo is not reasonably feasible for
  34. * technical reasons, the Appropriate Legal Notices must display the words
  35. * "Powered by SugarCRM".
  36. ********************************************************************************/
  37. //TODO move me out of generic
  38. /**
  39. * Generic Sugar widget
  40. * @api
  41. */
  42. class SugarWidget
  43. {
  44. var $layout_manager = null;
  45. var $widget_id;
  46. protected $form_value;
  47. protected $parent_bean;
  48. function SugarWidget(&$layout_manager)
  49. {
  50. $this->layout_manager = $layout_manager;
  51. }
  52. function display(&$layout_def)
  53. {
  54. return 'display class undefined';
  55. }
  56. /**
  57. * getSubpanelWidgetId
  58. * This is a utility function to return a widget's unique id
  59. * @return id String label of the widget's unique id
  60. */
  61. public function getWidgetId() {
  62. return $this->widget_id;
  63. }
  64. /**
  65. * setSubpanelWidgetId
  66. * This is a utility function to set the id for a widget
  67. * @param id String value to set the widget's unique id
  68. */
  69. public function setWidgetId($id='') {
  70. $this->widget_id = $id;
  71. }
  72. public function getDisplayName()
  73. {
  74. return $this->form_value;
  75. }
  76. function getParentBean()
  77. {
  78. return $this->parent_bean;
  79. }
  80. function setParentBean($parent_bean)
  81. {
  82. $this->parent_bean = $parent_bean;
  83. }
  84. /**
  85. * getTruncatedColumnAlias
  86. * This function ensures that a column alias is no more than 28 characters. Should the column_name
  87. * argument exceed 28 charcters, it creates an alias using the first 22 characters of the column_name
  88. * plus an md5 of the first 6 characters of the lowercased column_name value.
  89. *
  90. */
  91. protected function getTruncatedColumnAlias($column_name)
  92. {
  93. if(empty($column_name) || !is_string($column_name) || strlen($column_name) < 28)
  94. {
  95. return $column_name;
  96. }
  97. return strtoupper(substr($column_name,0,22) . substr(md5(strtolower($column_name)), 0, 6));
  98. }
  99. }
  100. ?>