You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
@kball@gakimball@zurbrandon@zurbchris It's important that a resolution is reached regarding the customizer. The team might already be implementing a solution, in which case I placed some useful JSON files at the bottom of this comment. We are running into regular issues due to a lack of communication. The customizer depends on the following:
gulpfile.js (and the .js files within the gulp directory)
scss/foundation.scss
scss/settings/settings.scss
*.js within the js folder (just the file names need to remain the same)
There are two possible resolutions.
Whenever these files are modified, the customizer is tested and updated appropriately before release
The customizer is rebuilt using a "build up" approach which will reduce the dependencies
Lets examine these resolutions separately.
Option 1: Communication, testing and updating the customizer before releases
The issues that have broken the customizer recently are:
Adding require('child_process').execSync to deploy.js
This is a problem because all require statements are replaced with new relative file paths that point to the node_modules directory for the most recent build. This replace does not have the ability to take into account native modules vs modules within a node_modules directory. Adding native modules is not a problem if I (or the maintainer) are made aware before release. The fix was a single line of code.
Replacing minifyCss with cssnano
This is a problem because gulp deploy:custom depended on minifyCss, and was not updated. The fix was just to replace the reference to minifyCss with cssnano.
This is a change in the way scss is included, and the customizer needs to be updated to resolve this.
I am happy to maintain the customizer, and perform all the necessary updates before a new release
However, it is unclear to me what solution ZURB wants to pursue.
Option 2: Rebuilding the customizer with a "Build up" approach
If the customizer were rewritten to use a build up approach, some of the problems above could be avoided. Lets look at which files would be built up, and what would remain the same. Files to build up
gulpfile.js (build destinations)
foundation.scss
Files to edit
settings.scss
Files to remove
js files not included in the input submission
What can we draw from this "Build Up" approach
Any changes to the gulpfile in the foundation.scss repository would not necessitate code changes in the customizer.
Any changes to the foundation.scss file would not necessitate code changes in the customizer
Changes to the way components are @included, .js filenames, settings lines, would still require changes to the customizer
Conclusions
The build up approach can reduce the need for communication, and prevent some of these issues. I would be happy to build this out for ZURB. Given that Foundation is open source, I would be open to donating my time to this project. If that is what you would like to do, please let me know and I will begin. If that is not your desired course of action, I included the most pertinent JSON to rebuilding the app entirely. This JSON basically contains the mappings between the input values, and each of the files that would be either built up, or edited.
Regardless of your decision, please communicate with me before the next release if a solution has not yet been built out. I know you guys don't like seeing the customizer break, neither do the customers, and neither do I. If you communicate with me before the release I can do all of the testing necessary to ensure that we have a smooth upgrade on the customizer page. I would be happy to donate time before every release to maintain the customizer in its current state. This would require the least amount of time and effort out of all the solutions. The main requirement boils down to communication. I certainly want to give the team at ZURB the means to proceed with the course of action they think best, so if there are any questions please let me know and I will do my best to help.
It's important that a resolution is reached regarding the customizer.
I agree. I've been working on improving foundation-cli. I had mentioned to another member that it would be cool if foundation-cli could hook into customizer is some way.
@kball @gakimball @zurbrandon @zurbchris It's important that a resolution is reached regarding the customizer. The team might already be implementing a solution, in which case I placed some useful JSON files at the bottom of this comment. We are running into regular issues due to a lack of communication. The customizer depends on the following:
gulpfile.js
(and the .js files within the gulp directory)scss/foundation.scss
scss/settings/settings.scss
*.js
within the js folder (just the file names need to remain the same)There are two possible resolutions.
Lets examine these resolutions separately.
Option 1: Communication, testing and updating the customizer before releases
The issues that have broken the customizer recently are:
require('child_process').execSync
to deploy.jsThis is a problem because all require statements are replaced with new relative file paths that point to the node_modules directory for the most recent build. This replace does not have the ability to take into account native modules vs modules within a node_modules directory. Adding native modules is not a problem if I (or the maintainer) are made aware before release. The fix was a single line of code.
This is a problem because gulp deploy:custom depended on minifyCss, and was not updated. The fix was just to replace the reference to minifyCss with cssnano.
This is a change in the way scss is included, and the customizer needs to be updated to resolve this.
I am happy to maintain the customizer, and perform all the necessary updates before a new release
However, it is unclear to me what solution ZURB wants to pursue.
Option 2: Rebuilding the customizer with a "Build up" approach
If the customizer were rewritten to use a build up approach, some of the problems above could be avoided. Lets look at which files would be built up, and what would remain the same.
Files to build up
gulpfile.js
(build destinations)foundation.scss
Files to edit
settings.scss
Files to remove
js
files not included in the input submissionWhat can we draw from this "Build Up" approach
Conclusions
The build up approach can reduce the need for communication, and prevent some of these issues. I would be happy to build this out for ZURB. Given that Foundation is open source, I would be open to donating my time to this project. If that is what you would like to do, please let me know and I will begin. If that is not your desired course of action, I included the most pertinent JSON to rebuilding the app entirely. This JSON basically contains the mappings between the input values, and each of the files that would be either built up, or edited.
Regardless of your decision, please communicate with me before the next release if a solution has not yet been built out. I know you guys don't like seeing the customizer break, neither do the customers, and neither do I. If you communicate with me before the release I can do all of the testing necessary to ensure that we have a smooth upgrade on the customizer page. I would be happy to donate time before every release to maintain the customizer in its current state. This would require the least amount of time and effort out of all the solutions. The main requirement boils down to communication. I certainly want to give the team at ZURB the means to proceed with the course of action they think best, so if there are any questions please let me know and I will do my best to help.
Input values from html form submission
Mappings from values to scss includes
Mappings of input values to javascript files
Values from input settings fields
Mappings from settings values to text in settings.scss for replacement
Mappings from inputs, to the text that would be used to replace a given setting (used to construct new setting)
Mappings from input setting values to the prefixes used for these settings (used to construct new settings)
Mappings from settings input values to setting suffixes (used to construct new settings)
The text was updated successfully, but these errors were encountered: