Fix SingleSelect styling, added add to campaign documentation

This commit is contained in:
Christopher Joe 2016-08-17 12:13:55 +12:00 committed by Ingo Schommer
parent b9624994ac
commit a9bdf33ca8
8 changed files with 71 additions and 29 deletions

View File

@ -2,6 +2,7 @@ import React from 'react';
import { Modal } from 'react-bootstrap-4'; import { Modal } from 'react-bootstrap-4';
import SilverStripeComponent from 'lib/SilverStripeComponent'; import SilverStripeComponent from 'lib/SilverStripeComponent';
import FormBuilder from 'components/FormBuilder/FormBuilder'; import FormBuilder from 'components/FormBuilder/FormBuilder';
import i18n from 'i18n';
class AddToCampaignModal extends SilverStripeComponent { class AddToCampaignModal extends SilverStripeComponent {
constructor(props) { constructor(props) {
@ -46,9 +47,17 @@ class AddToCampaignModal extends SilverStripeComponent {
} }
getBody() { getBody() {
const schemaUrl = `${this.props.schemaUrl}/${this.props.fileId}`; // if no schema defined, then lets use existing children instead
if (!this.props.schemaUrl) {
return <FormBuilder schemaUrl={schemaUrl} handleSubmit={this.handleSubmit} />; return this.props.children;
}
return (
<FormBuilder
schemaUrl={this.props.schemaUrl}
handleSubmit={this.handleSubmit}
handleAction={this.props.handleAction}
/>
);
} }
getResponse() { getResponse() {
@ -86,7 +95,6 @@ class AddToCampaignModal extends SilverStripeComponent {
<Modal <Modal
show={this.props.show} show={this.props.show}
onHide={this.props.handleHide} onHide={this.props.handleHide}
container={document.getElementsByClassName('cms-container')[0]}
> >
<Modal.Header closeButton> <Modal.Header closeButton>
<Modal.Title>{this.props.title}</Modal.Title> <Modal.Title>{this.props.title}</Modal.Title>
@ -101,11 +109,16 @@ class AddToCampaignModal extends SilverStripeComponent {
} }
AddToCampaignModal.propTypes = { AddToCampaignModal.propTypes = {
show: React.PropTypes.bool.isRequired, show: React.PropTypes.bool,
title: React.PropTypes.string, title: React.PropTypes.string,
handleHide: React.PropTypes.func, handleHide: React.PropTypes.func,
schemaUrl: React.PropTypes.string, schemaUrl: React.PropTypes.string,
handleSubmit: React.PropTypes.func, handleSubmit: React.PropTypes.func,
}; };
AddToCampaignModal.defaultProps = {
show: false,
title: i18n._t('Campaigns.AddToCampaign', 'Add to campaign'),
};
export default AddToCampaignModal; export default AddToCampaignModal;

View File

@ -0,0 +1,29 @@
# AddToCampaignModal
This is a Modal component to help Add a target object to Campaigns (ChangeSets)
## Props
### title (string)
The title that will appear for the Modal, defaults to "Add to campaign".
### show (bool)
Tells the modal when to show and hide from the interface.
### handleHide (func)
Event handler when the modal is sending a hide request, this assumes the value of `show` that is passed will be changed when conditions are met.
### schemaUrl (string)
The url to call which is passed to the `FormBuilder` Component as a prop.
### handleSubmit (func)
Event handler when the form in the Modal is submitted.
### handleAction (func)
Event handler passed to the `FormBuilder` Component as a prop.

View File

@ -1,7 +1,7 @@
import React from 'react'; import React from 'react';
import SilverStripeComponent from 'lib/SilverStripeComponent'; import SilverStripeComponent from 'lib/SilverStripeComponent';
function fieldHolderWrapper(Field) { function fieldHolder(Field) {
class FieldHolder extends SilverStripeComponent { class FieldHolder extends SilverStripeComponent {
render() { render() {
@ -39,4 +39,4 @@ function fieldHolderWrapper(Field) {
return FieldHolder; return FieldHolder;
} }
export default fieldHolderWrapper; export default fieldHolder;

View File

@ -6,14 +6,6 @@ This component will be moved to Framweork or CMS when dependency injection is im
## PropTypes ## PropTypes
### actions
Actions the component can dispatch. This should include but is not limited to:
#### setSchema
An action to call when the response from fetching schema data is returned. This would normally be a simple action to set the store's `schema` key to the returned data.
### createFn (func) ### createFn (func)
Gives container components a chance to access a form component before it's constructed. Use this as an opportunity to pass a custom click handler to to a field for example. Gives container components a chance to access a form component before it's constructed. Use this as an opportunity to pass a custom click handler to to a field for example.
@ -22,10 +14,10 @@ Gives container components a chance to access a form component before it's const
The schema URL where the form will be scaffolded from e.g. '/admin/pages/schema/1'. The schema URL where the form will be scaffolded from e.g. '/admin/pages/schema/1'.
### schema ### handleSubmit (func)
JSON schema representing the form. Used as the blueprint for generating the form.
### onSubmit (func)
Event handler passed to the Form Component as a prop. Event handler passed to the Form Component as a prop.
### handleAction (func)
Event handler when a form action is clicked on, allows preventing submit and know which action was clicked on.

View File

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import SilverStripeComponent from 'lib/SilverStripeComponent'; import SilverStripeComponent from 'lib/SilverStripeComponent';
//import fieldHolder from 'components/FieldHolder/FieldHolder'; import fieldHolder from 'components/FieldHolder/FieldHolder';
import i18n from 'i18n'; import i18n from 'i18n';
class SingleSelectField extends SilverStripeComponent { class SingleSelectField extends SilverStripeComponent {
@ -45,10 +45,10 @@ class SingleSelectField extends SilverStripeComponent {
getSelectField() { getSelectField() {
const options = this.props.source || []; const options = this.props.source || [];
if (this.props.hasEmptyDefault) { if (this.props.data.hasEmptyDefault) {
options.unshift({ options.unshift({
value: '', value: '',
title: this.props.emptyString, title: this.props.data.emptyString,
disabled: false, disabled: false,
}); });
} }
@ -109,13 +109,20 @@ SingleSelectField.propTypes = {
title: React.PropTypes.string, title: React.PropTypes.string,
disabled: React.PropTypes.bool, disabled: React.PropTypes.bool,
})), })),
hasEmptyDefault: React.PropTypes.bool, data: React.PropTypes.oneOfType([
emptyString: React.PropTypes.string, React.PropTypes.array,
React.PropTypes.shape({
hasEmptyDefault: React.PropTypes.bool,
emptyString: React.PropTypes.string,
}),
]),
}; };
SingleSelectField.defaultProps = { SingleSelectField.defaultProps = {
source: [], source: [],
emptyString: i18n._t('Boolean.ANY', 'Any'), data: {
emptyString: i18n._t('Boolean.ANY', 'Any'),
},
}; };
export default SingleSelectField; export default fieldHolder(SingleSelectField);

View File

@ -34,10 +34,10 @@
@import "../components/PopoverField/PopoverField"; @import "../components/PopoverField/PopoverField";
@import "../components/GridField/GridField"; @import "../components/GridField/GridField";
@import "../components/HiddenField/HiddenField"; @import "../components/HiddenField/HiddenField";
@import "../components/SingleSelectField/SingleSelectField";
@import "../components/Label/Label"; @import "../components/Label/Label";
@import "../components/Preview/Preview"; @import "../components/Preview/Preview";
@import "../components/Toolbar/Toolbar"; @import "../components/Toolbar/Toolbar";
@import "../components/Form/Form";
@import "../components/Tabs/Tabs"; @import "../components/Tabs/Tabs";
@import "../components/Form/Form"; @import "../components/Form/Form";

View File

@ -176,7 +176,7 @@ class AddToCampaignHandler {
$inChangeSets = array_unique(ChangeSetItem::get_for_object($object)->column('ChangeSetID')); $inChangeSets = array_unique(ChangeSetItem::get_for_object($object)->column('ChangeSetID'));
$changeSets = $this->getAvailableChangeSets()->map(); $changeSets = $this->getAvailableChangeSets()->map();
$campaignDropdown = DropdownField::create('Campaign', '', $changeSets); $campaignDropdown = DropdownField::create('Campaign', _t('Campaigns.CampaignTitle', 'Campaigns'), $changeSets);
$campaignDropdown->setEmptyString(_t('Campaigns.AddToCampaign', 'Select a Campaign')); $campaignDropdown->setEmptyString(_t('Campaigns.AddToCampaign', 'Select a Campaign'));
$campaignDropdown->addExtraClass('noborder'); $campaignDropdown->addExtraClass('noborder');
$campaignDropdown->setDisabledItems($inChangeSets); $campaignDropdown->setDisabledItems($inChangeSets);

View File

@ -106,6 +106,7 @@ en:
MENUTITLE: Campaigns MENUTITLE: Campaigns
Campaigns: Campaigns:
AddToCampaign: 'Add To Campaign' AddToCampaign: 'Add To Campaign'
CampaignTitle: 'Campaign'
ChangePasswordEmail_ss: ChangePasswordEmail_ss:
CHANGEPASSWORDFOREMAIL: 'The password for account with email address {email} has been changed. If you didn\''t change your password please change your password using the link below' CHANGEPASSWORDFOREMAIL: 'The password for account with email address {email} has been changed. If you didn\''t change your password please change your password using the link below'
CHANGEPASSWORDTEXT1: 'You changed your password for' CHANGEPASSWORDTEXT1: 'You changed your password for'