Skip to content
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

Refactor: {{action}} helper usage #635

Open
wants to merge 51 commits into
base: staging
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
2313978
todos
DrumsnChocolate May 18, 2022
77c57cf
add checks for overrides of ModelSaveUtils, using the entity property…
DrumsnChocolate May 18, 2022
1d5bcbe
Merge branch 'master' into refactor/edit_destroy_controllers
DrumsnChocolate Aug 30, 2022
b7c24ac
Merge branch 'staging' into refactor/edit_destroy_controllers
DrumsnChocolate Aug 30, 2022
bc89493
got the activity destroy controller working properly, it seems :)
DrumsnChocolate Aug 30, 2022
50bfe4f
article comments now properly redirect. Took me a while to figure out…
DrumsnChocolate Aug 30, 2022
2aca33a
this is starting to look like something. not perfect, but it works fo…
DrumsnChocolate Aug 30, 2022
c4bfc9c
this should comprise the last of controllers that extend DestroyContr…
DrumsnChocolate Aug 30, 2022
a7237d6
debit collection show is currently broken, do not understand why. get…
DrumsnChocolate Aug 30, 2022
03adffb
starting to get a grip on how ember works, I think
DrumsnChocolate Sep 1, 2022
f5c771f
more progress, now also added cancel action to editcontroller, and re…
DrumsnChocolate Sep 3, 2022
cca8442
refactoring all usages of "Annuleren" LinkTo elements into buttons th…
DrumsnChocolate Sep 3, 2022
5393cfa
jslint
DrumsnChocolate Sep 3, 2022
2dd9e23
FINALLY figured out how to do a union of ObjectProxies
DrumsnChocolate Sep 3, 2022
8c407d5
moved thread save logic to model
DrumsnChocolate Sep 3, 2022
29e8f50
more stuff
DrumsnChocolate Sep 3, 2022
7c16a8f
fix debit collection controllers
DrumsnChocolate Sep 6, 2022
581e29d
going through the controllers alphabetically, decided to add some met…
DrumsnChocolate Sep 6, 2022
9e8dd3a
idk, changes from last time I worked on this
DrumsnChocolate Sep 19, 2022
56acba6
Merge branch 'staging' into refactor/edit_destroy_controllers
DrumsnChocolate Sep 19, 2022
b825372
fix js lint
DrumsnChocolate Sep 19, 2022
7aa8b6d
fix template lint
DrumsnChocolate Sep 19, 2022
115e24f
Merge branch 'master' into refactor/edit_destroy_controllers
DrumsnChocolate Sep 29, 2022
3d7a48e
I found a way to keep the model just the model, while also querying p…
DrumsnChocolate Sep 29, 2022
ab44d80
more changes
DrumsnChocolate Sep 30, 2022
fa693ba
more changes
DrumsnChocolate Sep 30, 2022
54813ae
typo
DrumsnChocolate Sep 30, 2022
f1c0727
better handling of transitions in destroycontrollers
DrumsnChocolate Sep 30, 2022
3a16484
I think I have had all new edit and destroy controllers
DrumsnChocolate Sep 30, 2022
e9d58e2
js lint fixes
DrumsnChocolate Sep 30, 2022
2e15f06
Merge branch 'staging' into refactor/edit_destroy_controllers
DrumsnChocolate Oct 23, 2022
f00b5d0
remove comment
DrumsnChocolate Oct 23, 2022
3ebeb38
start of refactoring action helper usage
DrumsnChocolate Oct 23, 2022
7e1342b
Merge branch 'staging' into refactor/action_helper_usage
DrumsnChocolate Dec 21, 2022
27a553a
Merge branch 'staging' into refactor/action_helper_usage
DrumsnChocolate Jan 15, 2023
9983ee3
remove preventdefaults
DrumsnChocolate Jan 27, 2023
5e081eb
Merge branch 'staging' into refactor/action_helper_usage
DrumsnChocolate May 7, 2023
f28249f
Merge branch 'staging' into refactor/action_helper_usage
DrumsnChocolate Nov 3, 2024
9380381
rewrite board room presence in octane
DrumsnChocolate Nov 3, 2024
1d3650b
use @action syntax on newPresence, and move permission check to template
DrumsnChocolate Nov 3, 2024
95344b9
use on, fn
DrumsnChocolate Nov 3, 2024
2d9f7a0
modal, sidebar
DrumsnChocolate Nov 3, 2024
3bb722a
rewrite privacy-modal to octane (afaik)
DrumsnChocolate Nov 3, 2024
a3d32a1
remove unused import
DrumsnChocolate Nov 3, 2024
2ea0d64
action helper in public-activity-card-small
DrumsnChocolate Nov 3, 2024
a90eb41
write open and closed question components in octane
DrumsnChocolate Nov 3, 2024
c64f6c4
fix lint
DrumsnChocolate Nov 3, 2024
8e9cde7
Merge branch 'staging' into refactor/action_helper_usage
DrumsnChocolate Nov 4, 2024
4f53b89
fix broken submit based on #896
DrumsnChocolate Nov 5, 2024
45d3aac
fix poll form
DrumsnChocolate Nov 5, 2024
26735a6
Merge branch 'staging' into refactor/action_helper_usage
DrumsnChocolate Nov 9, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
this is starting to look like something. not perfect, but it works fo…
…r now
  • Loading branch information
DrumsnChocolate committed Aug 30, 2022
commit 2aca33a583ce601f246daf2cbb8915ad085a3759
10 changes: 10 additions & 0 deletions app/controllers/application/destroy.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,16 @@ export default class DestroyController extends EditController {
this.modelSaveUtil.destroyModel(this.model);
}

onError(error) {
// todo: somehow incorporate the error into the message maybe? could be useful if users can show us the error message
this.errorMessage = 'Er ging iets fout bij het verwijderen.'
this.errorMessage += error
}

transition() {
this.replaceRoute(...arguments)
}

submit = undefined;

}
8 changes: 6 additions & 2 deletions app/controllers/application/edit.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,9 @@ import { inject as service } from '@ember/service';
import { tracked } from '@glimmer/tracking';

export default class EditController extends Controller {
@service('flash-notice') flashNotice;
@service flashNotice;

@tracked errorMessage = null;

successMessage = 'Wijzigen gelukt!';
successTransitionTarget = null;
@tracked successTransitionModel = null;
Expand All @@ -22,4 +21,9 @@ export default class EditController extends Controller {
submit() {
this.modelSaveUtil.saveModel(this.model);
}

onError(error) {
// todo: somehow incorporate the error into the message maybe? could be useful if users can show us the error message
this.errorMessage = 'Er ging iets fout bij het opslaan van je wijzigingen.'
}
}
35 changes: 16 additions & 19 deletions app/controllers/form/responses/destroy.js
Original file line number Diff line number Diff line change
@@ -1,22 +1,19 @@
import { inject as service } from '@ember/service';
import { action } from '@ember/object';
import DestroyController from 'amber-ui/controllers/application/destroy';

export default DestroyController.extend({
store: service(),
successMessage: 'Je inschrijving is verwijderd.',
successTransitionTarget: 'activities.index',
actions: {
destroy() {
this.set('form', this.model.form);
this._super(...arguments);
},
onSuccess() {
this._super(...arguments);
// Reload form to update fields as 'currentUserResponseCompleted', 'currentUserResponseId' and 'amountOfResponses'
this.store.peekRecord('form/form', this.form.id).reload();
},
onError() {
this.set('errorMessage', 'Er ging iets fout bij het verwijderen');
},
},
});
export default class DestroyFormResponseController extends DestroyController {
@service store;
successMessage = 'Je inschrijving is verwijderd.';
successTransitionTarget = 'activities.index';

@action
async destroyModel() {
this.form = await this.model.form;
super.destroyModel();
}
onSuccess(model) {
this.form.reload();
this.modelSaveUtil.redirect(model);
}
}
33 changes: 20 additions & 13 deletions app/utils/model-save.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,27 +10,34 @@ export default class ModelSaveUtil {
}
}

transition(target, model) {
const transition_args = model ? [target, model] : [target]
if (this.entity.transition) {
this.entity.transition(...transition_args);
} else {
this.entity.transitionToRoute(...transition_args);
}
}

redirect(model) {
const targetModel = this.entity?.successTransitionModel ?? model;
if (!isNone(this.entity?.successTransitionTarget)) {
this.transition(
this.entity.successTransitionTarget,
targetModel,
);
}
}

onSuccess(model) {
// Show notice
this.sendSuccess();
// todo: make sure that all subclasses of the edit controller correctly implement onsuccess, and don't call sendsuccess unnecessarily
if (this.entity?.onSuccess) {
this.entity.onSuccess();
this.entity.onSuccess(model);
} else {
// Redirect
const targetModel = this.entity?.successTransitionModel ?? model;
if (!isNone(this.entity?.successTransitionTarget)) {
if (isNone(targetModel)) {
// In destroy routes, targetModel is undefined
this.entity.transitionToRoute(this.entity.successTransitionTarget);
} else {
this.entity.transitionToRoute(
this.entity.successTransitionTarget,
targetModel,
);
}
}
this.redirect(model)
}
}

Expand Down