-
Notifications
You must be signed in to change notification settings - Fork 700
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Parent component trigger function in child component #156
Comments
I have the same issue with a child component |
I'm a little confused on the goal there, but you could leverage one-way bindings to traverse data into the child component, without mutating the parent scope. |
can you give me an example how to solve it using one-way bindings? |
ah i think i misunderstood your question. To rephrase, you have a child component that is responsible for taking a picture that needs to be triggered by the parent component. Is this correct? If so, one way of doing it is the following: class CameraController {
constructor(CameraService) {
this._cameraService = CameraService;
}
$onChanges(changes) {
if (changes.buttonPressed.currentValue) {
this._takePicture();
}
}
_takePicture() {
this._cameraService
.takePicture()
.then(() => /* some code */)
.catch(err => /* handle err */)
.finally(() => this.resetButton());
}
}
export default Camera {
template: require('./camera.html'),
controller: CameraController,
controllerAs: 'vm',
bindings: {
buttonPressed: '<',
resetButton: '&'
}
}; parent.component.js class ParentController {
takePicture() {
this.buttonPressed = true;
}
resetButton() {
this.buttonPressed = false;
}
}
export default Parent {
template: require('./parent.html'),
controller: ParentController,
controllerAs: 'vm'
}; parent.html <div>
<camera-component
button-pressed="vm.buttonPressed"
reset-button="vm.resetButton()"
/>
<button ng-click="vm.takePicture()">Say Cheeze</button>
</div> also - confused on why the trigger can't exist within the child component |
In order to decouple the parent from child further, would this approach be considered in good style? class CameraController {
constructor(CameraService) {
this._cameraService = CameraService;
}
$onChanges(changes) {
if (changes.buttonPressed.currentValue) {
this._takePicture();
}
}
_takePicture() {
this._cameraService
.takePicture()
.then(() => /* some code */)
.catch(err => /* handle err */);
}
}
export default Camera {
template: require('./camera.html'),
controller: CameraController,
controllerAs: 'vm',
bindings: {
buttonPressed: '<',
}
}; parent.component.js class ParentController {
constructor($timeout) {
this.$timeout = $timeout;
this._buttonPressed = false;
}
get buttonPressed() {
return _buttonPressed;
}
set buttonPressed(value) {
const { $timeout } = this;
$timeout(() => {
this._buttonPressed = value;
if (this._buttonPressed) {
$timeout(() => {
this._buttonPressed = false;
});
}
});
}
takePicture() {
this.buttonPressed = true;
}
}
ParentController.$inject = ['$timeout'];
export default Parent {
template: require('./parent.html'),
controller: ParentController,
controllerAs: 'vm'
}; parent.html <div>
<camera-component button-pressed="vm.buttonPressed" />
<button ng-click="vm.takePicture()">Say Cheeze</button>
</div> Ultimately, we leave the resetting of the buttonPressed property to the parent controller. This still triggers the change in the child and now the child does not care about manipulating the state of its parent. |
I have a camera-component inside a parent-component. I want a make to snapshop from parent, but I can not find a way to do it.
The text was updated successfully, but these errors were encountered: