Skip to content

Commit

Permalink
Update: Tree picker node component to support child nodes
Browse files Browse the repository at this point in the history
  • Loading branch information
pphminions committed Nov 22, 2016
1 parent 09d9e7e commit e75c7aa
Show file tree
Hide file tree
Showing 8 changed files with 8,295 additions and 9,163 deletions.
17,398 changes: 8,259 additions & 9,139 deletions dist/adslot-ui-main-ugly.js

Large diffs are not rendered by default.

38 changes: 17 additions & 21 deletions dist/adslot-ui-main.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion dist/adslot-ui.css

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion src/components/Main.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ class AppComponent extends React.Component {
treePickerPureSubtree: [],
selectedNodes: [
{ id: '2', label: 'Norfolk Island', path: [{ id: '11', label: 'AU' }], type: '', isSelectable: false },
{ id: '3', label: 'Queensland', path: [{ id: '12', label: 'AU' }], type: '' },
{ id: '3', label: 'Queensland', path: [{ id: '12', label: 'AU' }], type: '', isChildNode: true },
],
searchBarString: '',
};
Expand Down
2 changes: 1 addition & 1 deletion src/components/adslotUi/TreePickerNodeComponent.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ const TreePickerNodeComponent = ({
const labelCellProps = expanderElement ? { onClick: expandNodeBound } : {};

return (
<div className={`${baseClass}`}>
<div className={node.isChildNode ? `${baseClass} child-node` : `${baseClass}`}>
<GridRow dts={`${_.kebabCase(itemType)}-${node.id}`}>
{selected ?
<GridCell classSuffixes={['button']} dts="button-remove">
Expand Down
1 change: 1 addition & 0 deletions src/helpers/propTypes/TreePickerPropTypes.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { SvgSymbol } from 'alexandria-adslot';
export default {
node: PropTypes.shape({
id: PropTypes.string.isRequired,
isChildNode: PropTypes.bool,
isExpandable: PropTypes.bool,
label: PropTypes.string.isRequired,
path: PropTypes.arrayOf(
Expand Down
6 changes: 6 additions & 0 deletions src/styles/adslotUi/TreePickerNode.scss
Original file line number Diff line number Diff line change
Expand Up @@ -34,3 +34,9 @@
}
}
}

.child-node {
.grid-component-row {
padding-left: 30px;
}
}
9 changes: 9 additions & 0 deletions test/components/adslotUi/TreePickerNodeComponentTest.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,15 @@ describe('TreePickerNodeComponent', () => {
expect(valueCellElement).to.be.a('null');
});

it('should have the child node class for child nodes', () => {
const node = _.clone(cbrNode);
node.isChildNode = true;
const props = { itemType, node };
const component = shallow(<TreePickerNodeComponent {...props} />);

expect(component.prop('className')).to.equal('treepickernode-component child-node');
});

it('should fire expandNode when clicking on the `expand` cell', () => {
const nodes = [];
const expandNode = (node) => nodes.push(node);
Expand Down

0 comments on commit e75c7aa

Please sign in to comment.