forked from TwistedInteractive/statusfield
/
extension.driver.php
81 lines (75 loc) · 2.12 KB
/
extension.driver.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<?php
Class extension_statusfield extends Extension
{
// About this extension:
public function about()
{
return array(
'name' => 'Field: Status',
'version' => '0.1',
'release-date' => '2010-10-20',
'author' => array(
'name' => 'Giel Berkers',
'website' => 'http://www.gielberkers.com',
'email' => 'info@gielberkers.com'),
'description' => 'Store the status and hold a history of previous statuses.'
);
}
// Set the delegates:
public function getSubscribedDelegates()
{
return array(
array(
'page' => '/backend/',
'delegate' => 'InitaliseAdminPageHead',
'callback' => 'initialiseHead'
),
);
}
public function initialiseHead($context)
{
$page = $context['parent']->Page;
if ($page instanceof ContentPublish && in_array($page->_context['page'], array('new', 'edit')))
{
Administration::instance()->Page->addScriptToHead(URL . '/extensions/statusfield/assets/statusfield.publish.js', 101, false);
Administration::instance()->Page->addStylesheetToHead(URL . '/extensions/statusfield/assets/statusfield.publish.css', 'screen', 101, false);
}
}
public function uninstall()
{
Symphony::Database()->query("DROP TABLE `tbl_fields_status`");
Symphony::Database()->query("DROP TABLE `tbl_fields_status_statuses`");
}
public function install()
{
Symphony::Database()->query("CREATE TABLE `tbl_fields_status` (
`id` int(11) unsigned NOT NULL auto_increment,
`field_id` int(11) unsigned NOT NULL,
`options` TEXT default NULL,
`valid_until` TINYTEXT default NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `field_id` (`field_id`)
)");
Symphony::Database()->query("CREATE TABLE `tbl_fields_status_statuses` (
`id` int(11) unsigned NOT NULL auto_increment,
`field_id` int(11) unsigned NOT NULL,
`entry_id` int(11) unsigned NOT NULL,
`date` DATE,
`status` TEXT,
`valid_until` DATE,
PRIMARY KEY (`id`)
)");
}
public function update()
{
try{
if(version_compare($previousVersion, '0.2', '<')){
Symphony::Database()->query(
"RENAME `tbl_fields_status_statusses` TO `tbl_fields_status_statuses`"
);
}
}
catch(Exception $e){
}
}
}