avoiding feature explosion - plugins

classic Classic list List threaded Threaded
1 message Options
Reply | Threaded
Open this post in threaded view
|

avoiding feature explosion - plugins

wvengen
Administrator
Hi,

I've got a number of features that I don't think all foodcoops will use. And they're really small. Something like membership fee, for example, I have currently implemented as a check that an ordergroup has paid at least a certain amount. Or a dropdown on each page to choose a language, which some coops might want, others not. Or an online banking option - with several possible providers.

Would it be possible to have plugins/extensions/addons offering these kind of features? In that way foodsoft core can remain clean and simple, and foodcoops can pick and choose what they need.

Is this easily possible in Ruby/Rails? I tend to think as Ruby being flexible enough - being able to modify existing classes, e.g. to add filters. Modifying views may be more complicated (jQuery-like dom manipulation, perhaps?). Does anyone have experience with this?


Apart from this general approach, there are two kinds of more contained plugins I'm thinking of:
  • Import plugins - so that different file formats can be imported. We have suppliers that send an excel sheet that does not easily map to the foodsoft csv format. We are already using this in branch multiimport [1].
    Since suppliers can be really specific to certain foodcoops, and may need to be updated often, I think it is useful not to require keeping them in the main repository.
  • Payment plugins - it has really helped us start to allow new members to pay using online banking. That lowered the barrier to attracting new members. I think it makes sense to introduce a simple plugin api for online banking providers. We are currently using mollie (branch onlinepay [2] - needs cleanup though), but consider switching.

- Willem

[1] https://github.com/foodcoop-adam/foodsoft/tree/multiimport
[2] https://github.com/foodcoop-adam/foodsoft/tree/onlinepay