本文整理匯總了PHP中singleton函數的典型用法代碼示例。如果您正苦於以下問題:PHP singleton函數的具體用法?PHP singleton怎麽用?PHP singleton使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了singleton函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: __construct
/**
* @param Controller $controller
* @param Job $job (optional)
*/
public function __construct($controller, $job = null)
{
if ($job) {
$fields = $job->getFields();
$required = $job->getValidator();
} else {
$fields = singleton('Job')->getFields();
$required = singleton('Job')->getValidator();
}
$fields->merge(new FieldList(new LiteralField('Conditions', $controller->TermsAndConditionsText), new HiddenField('BackURL', '', $controller->Link('thanks')), new HiddenField('EmailFrom', '', $controller->getJobEmailFromAddress()), new HiddenField('EmailSubject', '', $controller->getJobEmailSubject()), $jobId = new HiddenField('JobID')));
if ($job) {
$jobId->setValue($job->ID);
$actions = new FieldList(new FormAction('doEditJob', _t('Jobboard.EDITLISTING', 'Edit Listing')));
} else {
$actions = new FieldList(new FormAction('doAddJob', _t('JobBoard.CONFIRM', 'Confirm')));
}
parent::__construct($controller, 'AddJobForm', $fields, $actions, $required);
$this->setFormAction('JobBoardFormProcessor/doJobForm');
$this->setFormMethod('POST');
if ($job) {
$this->loadDataFrom($job);
} else {
$this->enableSpamProtection();
}
}
示例2: init
/**
* Loads the requirements, checks perms, etc. If an ID is in the URL, that becomes the
* current folder.
*/
public function init()
{
parent::init();
if (!Permission::check("ADMIN") && !Permission::check("CMS_ACCESS_BrowseFiles")) {
return Security::permissionFailure($this, _t('KickAssets.PERMISSIONFAIL', 'You do not have permission to access this section of the CMS.'));
}
Requirements::clear();
Requirements::css('kickassets/css/core.css');
Requirements::css('kickassets/css/kickassets.css');
Requirements::javascript('kickassets/javascript/jquery.js');
Requirements::javascript(THIRDPARTY_DIR . '/jquery-livequery/jquery.livequery.js');
Requirements::javascript('kickassets/javascript/apprise/apprise-1.5.full.js');
Requirements::javascript('kickassets/javascript/jquery.tooltip.js');
Requirements::css('kickassets/javascript/apprise/apprise.css');
Requirements::javascript('kickassets/javascript/kickassets_ui.js');
Requirements::javascript('kickassets/javascript/chosen/chosen.jquery.js');
Requirements::css('kickassets/javascript/chosen/chosen.css');
Requirements::javascript('kickassets/javascript/jquery.form.js');
Requirements::javascript('kickassets/javascript/kickassets.js');
Requirements::css('kickassets/css/kickassets_ui.css');
if ($this->getRequest()->param('ID')) {
$this->currentFolder = DataObject::get_by_id("Folder", (int) $this->getRequest()->param('ID'));
$this->currentPath = KickAssetUtil::relative_asset_dir($this->currentFolder->Filename);
} else {
$this->currentFolder = singleton('Folder');
$this->currentPath = false;
}
}
示例3: updateEditForm
public function updateEditForm($form)
{
$singl = singleton($this->owner->modelClass);
if ($singl->hasExtension('SoftDeletable')) {
/* @var $gridfield GridField */
$gridfield = $form->Fields()->dataFieldByName($this->owner->modelClass);
$config = $gridfield->getConfig();
$config->removeComponentsByType('GridFieldDeleteAction');
if ($this->owner->config()->softdelete_from_list) {
$config->addComponent(new GridFieldSoftDeleteAction());
}
$bulkManager = $config->getComponentByType('GridFieldBulkManager');
if ($bulkManager && $this->owner->config()->softdelete_from_bulk) {
$bulkManager->removeBulkAction('delete');
$bulkManager->addBulkAction('softDelete', 'delete (soft)', 'GridFieldBulkSoftDeleteEventHandler');
}
if ($this->filtersOnDeleted()) {
/* @var $cols GridFieldDataColumns */
$cols = $gridfield->getConfig()->getComponentByType('GridFieldDataColumns');
$displayedFields = $cols->getDisplayFields($gridfield);
$displayedFields['Deleted'] = 'Deleted';
$cols->setDisplayFields($displayedFields);
}
}
return $form;
}
示例4: SearchForm
/**
* Manipulate search form to add some grouping.
*
* @return void
*
* @author Sebastian Diel <sdiel@pixeltricks.de>
* @since 25.06.2014
*/
public function SearchForm()
{
$searchForm = parent::SearchForm();
$fields = $searchForm->Fields();
$order = singleton('SilvercartOrder');
$basicLabelField = new HeaderField('BasicLabelField', $order->fieldLabel('BasicData'));
$customerLabelField = new HeaderField('CustomerLabelField', $order->fieldLabel('CustomerData'));
$positionLabelField = new HeaderField('PositionLabelField', $order->fieldLabel('OrderPositionData'));
$miscLabelField = new HeaderField('MiscLabelField', $order->fieldLabel('MiscData'));
$origOrderStatusField = $fields->dataFieldByName('q[SilvercartOrderStatus__ID]');
$orderStatusField = new SilvercartMultiDropdownField('q[SilvercartOrderStatus__ID]', $origOrderStatusField->Title(), $origOrderStatusField->getSource());
$positionQuantityField = new TextField('q[OrderPositionQuantity]', $order->fieldLabel('OrderPositionQuantity'));
$positionIsLimitField = new CheckboxField('q[OrderPositionIsLimit]', $order->fieldLabel('OrderPositionIsLimit'));
$limitField = new TextField('q[SearchResultsLimit]', $order->fieldLabel('SearchResultsLimit'));
$fields->insertBefore($basicLabelField, 'q[OrderNumber]');
$fields->insertAfter($fields->dataFieldByName('q[Created]'), 'q[OrderNumber]');
$fields->insertAfter($orderStatusField, 'q[IsSeen]');
$fields->insertBefore($customerLabelField, 'q[Member__CustomerNumber]');
$fields->insertBefore($positionLabelField, 'q[SilvercartOrderPositions__ProductNumber]');
$fields->insertAfter($positionQuantityField, 'q[SilvercartOrderPositions__ProductNumber]');
$fields->insertAfter($positionIsLimitField, 'q[OrderPositionQuantity]');
$fields->insertAfter($miscLabelField, 'q[OrderPositionIsLimit]');
$fields->insertAfter($limitField, 'q[MiscLabelField]');
$fields->dataFieldByName('q[SilvercartOrderStatus__ID]')->setEmptyString(_t('SilvercartOrderSearchForm.PLEASECHOOSE'));
$fields->dataFieldByName('q[SilvercartPaymentMethod__ID]')->setEmptyString(_t('SilvercartOrderSearchForm.PLEASECHOOSE'));
$fields->dataFieldByName('q[SilvercartShippingMethod__ID]')->setEmptyString(_t('SilvercartOrderSearchForm.PLEASECHOOSE'));
$fields->dataFieldByName('q[SilvercartShippingAddress__SilvercartCountry__ID]')->setEmptyString(_t('SilvercartOrderSearchForm.PLEASECHOOSE'));
return $searchForm;
}
示例5: scaffoldFormField
public function scaffoldFormField($title = null, $params = null)
{
if (empty($this->object)) {
return null;
}
$relationName = substr($this->name, 0, -2);
$hasOneClass = $this->object->hasOneComponent($relationName);
if ($hasOneClass && singleton($hasOneClass) instanceof Image) {
$field = new UploadField($relationName, $title);
$field->getValidator()->setAllowedExtensions(array('jpg', 'jpeg', 'png', 'gif'));
} elseif ($hasOneClass && singleton($hasOneClass) instanceof File) {
$field = new UploadField($relationName, $title);
} else {
$titleField = singleton($hasOneClass)->hasField('Title') ? "Title" : "Name";
$list = DataList::create($hasOneClass);
// Don't scaffold a dropdown for large tables, as making the list concrete
// might exceed the available PHP memory in creating too many DataObject instances
if ($list->count() < 100) {
$field = new DropdownField($this->name, $title, $list->map('ID', $titleField));
$field->setEmptyString(' ');
} else {
$field = new NumericField($this->name, $title);
}
}
return $field;
}
示例6: updateWiki
/**
* Updates the database of a calitrix wiki from beta 1 to beta 2.
*
* @author Johannes Klose <exe@calitrix.de>
* @return void
**/
function updateWiki()
{
$tpl =& singleton('template');
$setPath = isset($this->post['set_dir']) ? trim($this->post['set_dir']) : '';
$dbFile = $setPath . '/dbconfig.php';
$setFile = $setPath . '/stdconfig.php';
if (!file_exists($dbFile) || !file_exists($setFile)) {
$tpl->assign('isError', true);
$tpl->assign('error', $this->lang['updateb1_config_failed']);
return false;
}
include $dbFile;
mysql_connect(DB_HOST, DB_USER, DB_PASS);
mysql_select_db(DB_NAME);
mysql_query('CREATE TABLE ' . DB_PREFIX . 'config(config_section VARCHAR(30) NOT NULL, config_item ' . 'VARCHAR(100) NOT NULL, config_value TEXT NOT NULL, PRIMARY KEY (config_section, config_item))');
mysql_query('UPDATE ' . DB_PREFIX . 'users SET user_access_mask = -1 WHERE user_access_mask = 0');
$cfg = $this->createConfigTable($setFile);
$cfg = $this->createConfigFile($cfg, $setFile);
if ($cfg === false) {
$tpl->assign('isError', true);
$tpl->assign('error', sprintf($this->lang['updateb1_update_failed'], mysql_error()));
return false;
}
$this->lockInstaller();
$tpl->assign('updated', true);
}
示例7: testHasDatabaseFieldOnDataObject
public function testHasDatabaseFieldOnDataObject()
{
$obj = singleton('CompositeDBFieldTest_DataObject');
$this->assertTrue($obj->hasDatabaseField('MyMoneyAmount'));
$this->assertTrue($obj->hasDatabaseField('MyMoneyCurrency'));
$this->assertFalse($obj->hasDatabaseField('MyMoney'));
}
示例8: getDisplayFields
/**
* Get the DisplayFields
*
* @return array
* @see GridFieldDataColumns::setDisplayFields
*/
public function getDisplayFields($gridField)
{
if (!$this->displayFields) {
return singleton($gridField->getModelClass())->summaryFields();
}
return $this->displayFields;
}
示例9: getCMSFields
/**
* Get the fieldset to display in the administration section
*/
function getCMSFields()
{
$templateSource = singleton("NewsletterAdmin")->templateSource();
$fields = new FieldSet(new TabSet("Root", new Tab(_t('NewsletterAdmin.NLSETTINGS', 'Newsletter Settings'), new TextField("Title", _t('NewsletterAdmin.NEWSLTYPE', 'Newsletter Type')), new TreeDropdownField('GroupID', _T('NewsletterAdmin.MAILINGGROUP', 'Mailing list group'), 'Group'), new TextField("FromEmail", _t('NewsletterAdmin.FROMEM', 'From email address')), new DropdownField("Template", _t('NewsletterAdmin.TEMPLATE', 'Template'), $templateSource))));
$this->extend('updateCMSFields', $fields);
return $fields;
}
示例10: process
public function process()
{
$object = $this->getDataObject();
if ($object) {
$object->onScheduledExecution();
// figure out what our rescheduled date should be
$timeStr = $object->ExecuteFree;
if ($object->ExecuteEvery) {
$executeInterval = $object->ExecuteInterval;
if (!$executeInterval || !is_numeric($executeInterval)) {
$executeInterval = 1;
}
$timeStr = '+' . $executeInterval . ' ' . $object->ExecuteEvery;
}
$next = strtotime($timeStr);
if ($next > time()) {
// in the future
$nextGen = date('Y-m-d H:i:s', $next);
$nextId = singleton('QueuedJobService')->queueJob(new ScheduledExecutionJob($object, $this->timesExecuted + 1), $nextGen);
$object->ScheduledJobID = $nextId;
$object->write();
}
}
$this->currentStep++;
$this->isComplete = true;
}
示例11: show_timeSheetItems
function show_timeSheetItems($template_name)
{
global $date_to_view;
$current_user =& singleton("current_user");
global $TPL;
$query = prepare("SELECT * \n FROM timeSheetItem \n LEFT JOIN timeSheet ON timeSheetItem.timeSheetID = timeSheet.timeSheetID\n LEFT JOIN project ON timeSheet.projectID = project.projectID\n WHERE dateTimeSheetItem='%s'\n AND timeSheet.personID=%d", date("Y-m-d", $date_to_view), $current_user->get_id());
$db = new db_alloc();
$db->query($query);
while ($db->next_record()) {
$timeSheetItem = new timeSheetItem();
$timeSheetItem->read_db_record($db);
$timeSheetItem->set_values();
if ($timeSheetItem->get_value("unit") == "Hour") {
$TPL["daily_hours_total"] += $timeSheetItem->get_value("timeSheetItemDuration");
}
$project = new project();
$project->read_db_record($db);
$project->set_values();
if ($project->get_value("projectShortName")) {
$TPL["item_description"] = $project->get_value("projectShortName");
} else {
$TPL["item_description"] = $project->get_value("projectName");
}
include_template($template_name);
}
}
示例12: create_gridfield_for
/**
* A simple Gridfield factory
* @param string $model
* @param string $relationname
* @param DataObject $reference
* @return GridField
*/
public static function create_gridfield_for($model, $relationname, $reference)
{
if ($relationname != null && ClassInfo::exists($model)) {
$config = GridFieldConfig_RelationEditor::create();
$config->addComponent($gridFieldForm = new GridFieldDetailForm());
if ($items = $reference->{$relationname}()) {
if (is_a($items, 'ManyManyList') && ClassInfo::exists('GridFieldManyRelationHandler')) {
$config->addComponent(new GridFieldManyRelationHandler(), 'GridFieldPaginator');
} else {
$sortable = singleton($model)->hasExtension('SortableDataExtension');
if ($sortable) {
$config->addComponent(new GridFieldSortableRows('SortOrder'));
}
}
$gridfield = GridField::create($relationname, $model, $items, $config);
$datacolumns = $gridfield->getConfig()->getComponentByType('GridFieldDataColumns');
$cfields = singleton($model)->summaryFields();
if (singleton($model)->hasExtension('CMSPublishableDataExtension') && !isset($cfields['PublishStatus'])) {
$cfields = array('PublishStatus' => 'PublishStatus') + $cfields;
}
$datacolumns->setDisplayFields($cfields);
return $gridfield;
} else {
throw new InvalidArgumentException("Couldn't find relation.");
}
} else {
throw new InvalidArgumentException("Couldn't create GridField because wrong parameters passed to the factory.");
}
}
示例13: installDatabase
/**
* Installs the database.
*
* @author Johannes Klose <exe@calitrix.de>
* @param bool $defaultPages Enables installation of default wiki pages if set to true
* @return void
**/
function installDatabase($defaultPages)
{
$tpl =& singleton('template');
include CWIKI_INSTALL_DIR . '/mysql.php';
include CWIKI_SET_DIR . '/dbconfig.php';
mysql_connect(DB_HOST, DB_USER, DB_PASS);
mysql_select_db(DB_NAME);
foreach ($struct as $tbl => $sql) {
if (!@mysql_query('CREATE TABLE ' . DB_PREFIX . $tbl . $sql)) {
return false;
}
}
if (count($tableConflict) > 0) {
$tpl->assign('isError', true);
$tpl->assign('error', sprintf($this->lang['install_conflict'], join(', ', $tableConflict)));
}
foreach ($data['groups'] as $sql) {
if (!@mysql_query('INSERT INTO ' . DB_PREFIX . 'groups' . $sql)) {
return false;
}
}
unset($data['groups']);
if ($defaultPages) {
foreach ($data as $tbl => $stmts) {
foreach ($stmts as $sql) {
if (!@mysql_query('INSERT INTO ' . DB_PREFIX . $tbl . $sql)) {
return false;
}
}
}
}
return $this->createConfigTable();
}
示例14: updateImportForm
function updateImportForm(Form $form)
{
/* @var $owner ModelAdmin */
$owner = $this->owner;
$class = $owner->modelClass;
// Overwrite model imports
$importerClasses = $owner->stat('model_importers');
if (is_null($importerClasses)) {
$models = $owner->getManagedModels();
foreach ($models as $modelName => $options) {
$importerClasses[$modelName] = 'ExcelBulkLoader';
}
$owner->set_stat('model_importers', $importerClasses);
}
$modelSNG = singleton($class);
$modelName = $modelSNG->i18n_singular_name();
$fields = $form->Fields();
$content = _t('ModelAdminExcelExtension.DownloadSample', '<div class="field"><a href="{link}">Download sample file</a></div>', array('link' => $owner->Link($class . '/downloadsample')));
$file = $fields->dataFieldByName('_CsvFile');
if ($file) {
$file->setDescription(ExcelImportExport::getValidExtensionsText());
$file->getValidator()->setAllowedExtensions(ExcelImportExport::getValidExtensions());
}
$fields->removeByName("SpecFor{$modelName}");
$fields->insertAfter('EmptyBeforeImport', new LiteralField("SampleFor{$modelName}", $content));
if (!$modelSNG->canDelete()) {
$fields->removeByName('EmptyBeforeImport');
}
$actions = $form->Actions();
$import = $actions->dataFieldByName('action_import');
if ($import) {
$import->setTitle(_t('ModelAdminExcelExtension.ImportExcel', "Import from Excel"));
}
}
示例15: scaffoldFormField
public function scaffoldFormField($title = null, $params = null)
{
if (empty($this->object)) {
return null;
}
$relationName = substr($this->name, 0, -2);
$hasOneClass = DataObject::getSchema()->hasOneComponent(get_class($this->object), $relationName);
if (empty($hasOneClass)) {
return null;
}
$hasOneSingleton = singleton($hasOneClass);
if ($hasOneSingleton instanceof File) {
$field = new UploadField($relationName, $title);
if ($hasOneSingleton instanceof Image) {
$field->setAllowedFileCategories('image/supported');
}
return $field;
}
// Build selector / numeric field
$titleField = $hasOneSingleton->hasField('Title') ? "Title" : "Name";
$list = DataList::create($hasOneClass);
// Don't scaffold a dropdown for large tables, as making the list concrete
// might exceed the available PHP memory in creating too many DataObject instances
if ($list->count() < 100) {
$field = new DropdownField($this->name, $title, $list->map('ID', $titleField));
$field->setEmptyString(' ');
} else {
$field = new NumericField($this->name, $title);
}
return $field;
}