Difference between revisions of "Bower"
From OpenEMR Project Wiki
Bradymiller (talk | contribs) |
Bradymiller (talk | contribs) |
||
Line 90: | Line 90: | ||
===jquery-ui-1-10-4=== | ===jquery-ui-1-10-4=== | ||
===jquery-ui-1-11-4=== | ===jquery-ui-1-11-4=== | ||
===jquery-validation-1-13-0 | ===jquery-validation-1-13-0=== | ||
===jscolor-1-4-5=== | ===jscolor-1-4-5=== |
Revision as of 07:26, 31 January 2017
Overview
End Goals
- Centralize and organize all front-end assets in one flexible path (ie. can move entire path to the assets without breaking scripts).
- Use bower to collect and organize the front-end assets.
- Migrate all the front-end assets(of which there are multiple versions of many of the front-end assets) to most current version.
- Ability to install all front assets via bower (if ever decide to not include them in the codebase).
- Centralize and organize all front-end assets in one flexible path (ie. can move entire path to the assets without breaking scripts).
More Details
- Assets that are collected via bower are stored at public/assets; note this location is flexible since we are not sure where we will be storing these in the future as migrate to MVC architecture.
- The path is set to a global ($GLOBALS['assets_static_relative']) here in the codebase(so the path will be easy to change in the future) and also would need to be changed in the .bowerrc file):
- https://github.com/openemr/openemr/commit/b63b0da6a5eae6f8051234bff104a06cb37db167
- (also see above commit for a example on using the global/path)
- Incorporating the versions in the paths of the libraries.
ignoredDependencies setting in .bowerrc file.
- Using "ignoredDependencies" in .bowerrc file to ignore sub-dependencies which makes things messy(would bring in paths without versions of which would be a redundant library).
- bootstrap
- datatables
- datatables.net-jqui
- datatables.net-scroller
- datatables.net
- jquery
- imagesloaded
- react
scripts that required hard-coded path to the assets
- These are scripts where was unable to use the globals path for the assets directory(thus if move the assets directory, then would need to adjust these scripts).
- acknowledge_license_cert.html
- setup.php
Add New Asset
Bower Method (preferred)
- Add entry to the bower.json file.
- 'bower install' command
- Remove .gitignore and .gitattributes files(if they are present) from the installed package.
- Remove test scripts or anything that may cause a vulnerability (such as example scripts that allow file uploading; note this is very unlikely to be the case, but good to check).
- Add to below list of assets (and document there if removed any files).
Manual Method (only if bower method is not supported by package)
- If there is no bower support and package is not a supported git repo, then will need to bring in manually into the manual-added-packages sub-directory. See below shortcut.js-2-01-B asset for example.
- Remove .gitignore and .gitattributes files(if they are present) from the installed package.
- Remove test scripts or anything that may cause a vulnerability (such as example scripts that allow file uploading; note this is very unlikely to be the case, but good to check).
- Add to below list of assets (and document there if removed any files).
Current Assets
AnythingSlider-1-9-4
angular-1-5-8 (plan to use for the new patient portal)
angular-sanitize-1-5-8 (plan to use for the new patient portal)
angular-summernote-0-8-1 (plan to use for the new patient portal)
backbone-1-3-3 (plan to use for the new patient portal)
bootstrap-3-3-4
bootstrap-rtl-3-3-4
bootstrap-combobox-1-1-7 (plan to use for the new patient portal)
Chart.js-2-1-3
checklist-model-0-10-0 (plan to use for the new patient portal)
datatables.net-1-10-13
datatables.net-bs-1-10-13
- This is the bootstrap styling for datatables-1-10-13.
datatables.net-dt-1-10-13
- This is the generic styling for datatables-1-10-13.
datatables.net-jqui-1-10-13
- This is the jquery-ui styling for datatables-1-10-13.
datatables.net-colreorder-1-3-2
- This is an extension for datatables-1-10-13.
datatables.net-colreorder-dt-1-3-2
- This is the generic styling for datatables.net-colreorder-dt-1-3-2.
datatables.net-scroller-1-4-2
- This is an extension for datatables-1-10-13.
datatables.net-scroller-jqui-1-4-2
- This is the jquery-ui styling for datatables.net-scroller-1-4-2.
emodal-1-2-65 (plan to use for the new patient portal)
eonasdan-bootstrap-datetimepicker-3-1-3 (plan to use for the new patient portal)
font-awesome-4-6-3
jquery-creditcardvalidator-1-1-0 (plan to use for the new patient portal)
jquery-datetimepicker-2-5-4 (plan to use for the forms code by matrix)
- Use the files in build directory (and do NOT use build/jquery.datetimepicker.min.js)
jquery.gritter-1-7-4
jquery-min-*
- Contain the jquery library files. This is brought in via bower by direct html download since the old versions are not available in repo (need to be built) and only 1 file is needed for these numerous different versions of jquery.
- jquery-min-1-10-2 is used by datatables.net-1-10-13
jquery-modern-blink-0-1-3
jquery-panelslider-0-1-1
jquery-ui-1-10-4
jquery-ui-1-11-4
jquery-validation-1-13-0
jscolor-1-4-5
- Need to keep this version until update where it is used (not compatible with more recent jscolor version).
jscolor-2-0-4
knockout-3-4-0
literallycanvas-0-4-13
moment-2-13-0
numeral-1-5-3 (requested by Matrix, but not used yet)
pure-0-5-0
qtip2-2-2-1
react-15-1-0
shortcut.js-2-01-B
- Not supported by bower, so brought in manually to the manual-added-packages sub-directory.
- In future, can likely bring this in via bower via http method.
summernote-0-8-2 (plan to use for the new patient portal)
underscore-1-8-3 (plan to use for the new patient portal)
undone.js-0-0-1
validate.js-0-10-0 (requested by Matrix, but not used yet)
Questions
- Development is ongoing for this project:
- Ideal directory for this stuff (this is why we have made it flexible so can easily change this in the future)
- Ideal syntax of the bower openemr package