false, ]; } /** * List of keys of the default fields we want to display on the builder. * * @since 2.0.0 * @return array */ public function default_fields() { return [ 'name', 'placeholder', 'tooltip', ]; } /** * If you want to force a particular attribute to a value, declare it here. * * @since 2.0.0 * @return array */ public function force_attributes() { return [ 'id' => 'site_title', 'required' => true, ]; } /** * Returns the list of additional fields specific to this type. * * @since 2.0.0 * @return array */ public function get_fields() { return [ 'auto_generate_site_title' => [ 'type' => 'toggle', 'title' => __('Auto-generate?', 'wp-multisite-waas'), 'desc' => __('Check this option to auto-generate this field based on the username of the customer.', 'wp-multisite-waas'), 'tooltip' => '', 'value' => 0, 'html_attr' => [ 'v-model' => 'auto_generate_site_title', ], ], ]; } /** * Returns the field/element actual field array to be used on the checkout form. * * @since 2.0.0 * * @param array $attributes Attributes saved on the editor form. * @return array An array of fields, not the field itself. */ public function to_fields_array($attributes) { /* * If we should auto-generate, add as hidden. */ if (isset($attributes['auto_generate_site_title']) && $attributes['auto_generate_site_title']) { return [ 'auto_generate_site_title' => [ 'type' => 'hidden', 'id' => 'auto_generate_site_title', 'value' => 'username', ], 'site_title' => [ 'type' => 'hidden', 'id' => 'site_title', 'html_attr' => [ 'v-bind:value' => 'username', ], ], ]; } return [ 'site_title' => [ 'type' => 'text', 'id' => 'site_title', 'required' => true, 'name' => $attributes['name'], 'placeholder' => $attributes['placeholder'], 'tooltip' => $attributes['tooltip'], 'wrapper_classes' => wu_get_isset($attributes, 'wrapper_element_classes', ''), 'classes' => wu_get_isset($attributes, 'element_classes', ''), 'value' => $this->get_value(), 'wrapper_html_attr' => [ 'style' => $this->calculate_style_attr(), ], ], ]; } }