public function TwilioAdminForm::buildForm in Twilio 8
Form constructor.
Parameters
array $form: An associative array containing the structure of the form.
\Drupal\Core\Form\FormStateInterface $form_state: The current state of the form.
Return value
array The form structure.
Overrides ConfigFormBase::buildForm
File
- src/
Form/ TwilioAdminForm.php, line 50
Class
- TwilioAdminForm
- Admin form for Twilio config.
Namespace
Drupal\twilio\FormCode
public function buildForm(array $form, FormStateInterface $form_state) {
$form['account'] = [
'#type' => 'textfield',
'#required' => TRUE,
'#title' => $this
->t('Twilio Account SID'),
'#default_value' => $this
->config('twilio.settings')
->get('account'),
'#description' => $this
->t('Enter your Twilio account id'),
];
$form['token'] = [
'#type' => 'textfield',
'#required' => TRUE,
'#title' => $this
->t('Twilio Auth Token'),
'#default_value' => $this
->config('twilio.settings')
->get('token'),
'#description' => $this
->t('Enter your Twilio token id'),
];
$form['number'] = [
'#type' => 'textfield',
'#required' => TRUE,
'#title' => $this
->t('Twilio Phone Number'),
'#default_value' => $this
->config('twilio.settings')
->get('number'),
'#description' => $this
->t('Enter your Twilio phone number'),
];
$form['long_sms'] = [
'#type' => 'radios',
'#title' => $this
->t('Long SMS handling'),
'#description' => $this
->t('How would you like to handle SMS messages longer than 160 characters.'),
'#options' => [
$this
->t('Send multiple messages'),
$this
->t('Truncate message to 160 characters'),
],
'#default_value' => $this
->config('twilio.settings')
->get('long_sms'),
];
$form['registration_form'] = [
'#type' => 'radios',
'#title' => $this
->t('Show mobile fields during user registration'),
'#description' => $this
->t('Specify if the site should collect mobile information during registration.'),
'#options' => [
$this
->t('Disabled'),
$this
->t('Optional'),
$this
->t('Required'),
],
'#default_value' => $this
->config('twilio.settings')
->get('registration_form'),
];
$form['twilio_country_codes_container'] = [
'#tree' => TRUE,
'#type' => 'fieldset',
'#title' => $this
->t('Country codes'),
'#description' => $this
->t('Select the country codes you would like available, If none are selected all will be available.'),
'#collapsible' => TRUE,
'#collapsed' => TRUE,
];
$form['twilio_country_codes_container']['country_codes'] = [
'#type' => 'checkboxes',
'#options' => TwilioController::countryDialCodes(TRUE),
'#default_value' => $this
->config('twilio.settings')
->get('twilio_country_codes_container')['country_codes'],
];
// Expose the callback URLs to the user for convenience.
$form['twilio_callback_container'] = [
'#type' => 'fieldset',
'#title' => $this
->t('Module callbacks'),
'#description' => $this
->t('Enter these callback addresses into your Twilio phone number configuration on the Twilio dashboard to allow your site to respond to incoming voice calls and SMS messages.'),
];
// Initialize URL variables.
$voice_callback = $GLOBALS['base_url'] . '/twilio/voice';
$sms_callback = $GLOBALS['base_url'] . '/twilio/sms';
$form['twilio_callback_container']['voice_callback'] = [
'#type' => 'item',
'#title' => $this
->t('Voice request URL'),
'#markup' => '<p>' . $voice_callback . '</p>',
];
$form['twilio_callback_container']['sms_callback'] = [
'#type' => 'item',
'#title' => $this
->t('SMS request URL'),
'#markup' => '<p>' . $sms_callback . '</p>',
];
return parent::buildForm($form, $form_state);
}