node_add_form.inc
3.47 KB
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
/**
* @file
*
* Plugin to provide a node_add_form context
*/
/**
* Plugins are described by creating a $plugin array which will be used
* by the system that includes this file.
*/
$plugin = array(
'title' => t('Node add form'),
'description' => t('A node add form.'),
'context' => 'ctools_context_create_node_add_form',
'edit form' => 'ctools_context_node_add_form_settings_form',
'defaults' => array('type' => ''),
'keyword' => 'node_add',
'context name' => 'node_add_form',
'convert list' => array('type' => t('Node type')),
'convert' => 'ctools_context_node_add_form_convert',
'placeholder form' => array(
'#type' => 'textfield',
'#description' => t('Enter the node type this context.'),
),
);
/**
* It's important to remember that $conf is optional here, because contexts
* are not always created from the UI.
*/
function ctools_context_create_node_add_form($empty, $data = NULL, $conf = FALSE) {
static $creating = FALSE;
$context = new ctools_context(array('form', 'node_add', 'node_form', 'node', 'entity:node'));
$context->plugin = 'node_add_form';
if ($empty || ($creating)) {
return $context;
}
$creating = TRUE;
if ($conf && (isset($data['types']) || isset($data['type']))) {
// Holdover from typo'd config.
$data = isset($data['types']) ? $data['types'] : $data['type'];
}
if (!empty($data)) {
$types = node_type_get_types();
$type = str_replace('-', '_', $data);
// Validate the node type exists.
if (isset($types[$type]) && node_access('create', $type)) {
// Initialize settings:
global $user;
$node = (object) array(
'uid' => $user->uid,
'name' => (isset($user->name) ? $user->name : ''),
'type' => $type,
'language' => LANGUAGE_NONE,
);
$form_id = $type . '_node_form';
$form_state = array(
'want form' => TRUE,
'build_info' => array(
'args' => array($node)
)
);
// Use module_load_include so that caches and stuff can know to load this.
form_load_include($form_state, 'inc', 'node', 'node.pages');
$form = drupal_build_form($form_id, $form_state);
// In a form, $data is the object being edited.
$context->data = $node;
$context->title = $types[$type]->name;
$context->argument = $type;
// These are specific pieces of data to this form.
// All forms should place the form here.
$context->form = $form;
$context->form_id = $form_id;
$context->form_title = t('Submit @name', array('@name' => $types[$type]->name));
$context->node_type = $type;
$context->restrictions['type'] = array($type);
$context->restrictions['form'] = array('form');
$creating = FALSE;
return $context;
}
}
$creating = FALSE;
}
function ctools_context_node_add_form_settings_form($form, &$form_state) {
$conf = $form_state['conf'];
$form['type'] = array(
'#title' => t('Node type'),
'#type' => 'select',
'#options' => node_type_get_names(),
'#default_value' => $conf['type'],
'#description' => t('Select the node type for this form.'),
);
return $form;
}
function ctools_context_node_add_form_settings_form_submit($form, &$form_state) {
$form_state['conf']['type'] = $form_state['values']['type'];
}
/**
* Convert a context into a string.
*/
function ctools_context_node_add_form_convert($context, $type) {
switch ($type) {
case 'type':
return $context->data->type;
}
}