Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

[Waiting for JsBarcode 4] New options from element #107

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

lindell
Copy link
Owner

@lindell lindell commented Sep 28, 2016

Will allow barcode specific options to be specified through html parameters.

This does also force the use of some-option when you want to specify someOption which will break backwards compatibility.

Scheduled for JsBarcode 4 release.

@@ -1,25 +1,25 @@
import optionsFromStrings from "./optionsFromStrings.js";
import defaults from "../options/defaults.js";

function getOptionsFromElement(element){
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As a suggestion:

function getOptionsFromElement(element) {
	const options = {};
	const attributes = element.attributes;

	for (let i = 0; i < attributes.length; i++) {
		const match = attributes[i].name
			.match(/(jsbarcode|data)-([A-Za-z0-9-]+)/i);

		if (match) {
			// Transforms foo-bar to fooBar
			const property = match[2].replace(/-[a-zA-Z]/, (val) => val[1].toUpperCase());
			options[property] = attributes[i].value;
		}
	}

	// Since all attributes are string they need to be converted to integers
	return optionsFromStrings(options);
}

@SanichKotikov
Copy link
Collaborator

SanichKotikov commented May 17, 2017

If I understand right, you forgot about conversion of flat option into boolean, in optionsFromStrings. It might looks like this:

const INT_OPTIONS = [
	"width",
	"height",
	"textMargin",
	"fontSize",
	"margin",
	"marginTop",
	"marginBottom",
	"marginLeft",
	"marginRight"
];

const BOOL_OPTIONS = [
	"displayValue",
	"flat"
];

// Convert string to integers/booleans where it should be
function optionsFromStrings(options) {
	Object.keys(options).forEach(key => {
		if (typeof options[key] === "string") { // not sure about this
			if (INT_OPTIONS.indexOf(key) !== -1) {
				options[key] = parseInt(options[key], 10);
			} else if (BOOL_OPTIONS.indexOf(key) !== -1) {
				options[key] = options[key] === "true";
			}
		}
	});
	return options;
}

export default optionsFromStrings;

@lindell
Copy link
Owner Author

lindell commented May 18, 2017

@SanichKotikov Indeed flat should be converted. But doing it that way would violate some important design principles. Primarly the dependency inversion principle. This means that every time an option is added to a barcode symbology the main library has to be updated which should be avoided.

But as you noted this is still an option that should be addressed. Maybe by allowing the symbologies to specify its options and the datatype to allow the main part of the library to convert it.

@SanichKotikov
Copy link
Collaborator

SanichKotikov commented May 18, 2017

I see. Good point about DI principle. I have a crazy idea https://jsfiddle.net/o6cbz9na/1/. If you need to add a new option, you will do it only in OPTIONS constant. :)

@lindell
Copy link
Owner Author

lindell commented May 19, 2017

That's all good! But the problem still remains that new (barcode specific) options does need to be edited in to work.

This implementation is much nicer for the library options and should probably be implemented for those 😄

@SanichKotikov
Copy link
Collaborator

@lindell just a thought: why don't we apply flat automatically if displayValue = false?

@garygreen
Copy link

@lindell any news on this? It fixes a lot of stuff for options, desperately need it!! 😄

@lindell
Copy link
Owner Author

lindell commented Jul 5, 2017

@garygreen I think I will realease the this when #171 i done which is hopefully pretty soon.

But what do you want to do exactly? There is probably a pretty easy workaraound that is just not as pretty.

@garygreen
Copy link

Probably is an easy workaround, I guess I'll have to initialise the barcodes manually - still would like to give options in a <svg> element

@lindell
Copy link
Owner Author

lindell commented Jul 5, 2017

@garygreen You can already, with all options except the barcode specific ones. So basically the flat option for some of the EAN barcodes.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants