-
Notifications
You must be signed in to change notification settings - Fork 85
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
Naming the css units class? #4
Comments
Why not call it Another option is to provide direct function in order to have a lightweight syntax: let px (value : float) : ICssUnit = unbox ((unbox<string>value) + "px")
// Usage
px 2.0 The problem is that we lose the overload support for conciseness. In the future, when dotnet/fsharp#6805 is available, it should be possible to do: type System.Int32 with
static member inline toPixel (value : int) =
(unbox<string> value + "px")
let inline pixel (value : ^a) =
(^a : (static member inline toPixel: ^a -> string) (value))
let size = pixel 2 // this gives 2 + "px" -> "2px" A possible workaround is: type ToPixel = ToPixel with
static member inline ($) (ToPixel, value: int ) = unbox<string> value + "px"
static member inline ($) (ToPixel, value: float) = unbox<string> value + "px"
let inline pixel value = ToPixel $ value
let pixelFromInt = pixel 2
let prixelFromFloat = pixel 2. But this version generates a much more verbose JavaScript: import { union } from "fable-library/Reflection.js";
import { declare, Union } from "fable-library/Types.js";
export const ToPixel = declare(function DragAndDrop_ToPixel(tag, name, ...fields) {
Union.call(this, tag, name, ...fields);
}, Union);
export function ToPixel$reflection() {
return union("DragAndDrop.ToPixel", [], ToPixel, () => ["ToPixel"]);
}
export const pixelFromInt = (() => {
const arg0 = new ToPixel(0, "ToPixel");
return 2 + "px";
})();
export const prixelFromFloat = (() => {
const arg0$$1 = new ToPixel(0, "ToPixel");
return 2 + "px";
})(); It's possible to limit the verbosity by not inlining the import { union } from "fable-library/Reflection.js";
import { declare, Union } from "fable-library/Types.js";
export const ToPixel = declare(function DragAndDrop_ToPixel(tag, name, ...fields) {
Union.call(this, tag, name, ...fields);
}, Union);
export function ToPixel$reflection() {
return union("DragAndDrop.ToPixel", [], ToPixel, () => ["ToPixel"]);
}
export function ToPixel$$$op_Dollar$$Z45FE3DAA(_arg1, value) {
return value + "px";
}
export function ToPixel$$$op_Dollar$$49846331(_arg2, value$$1) {
return value$$1 + "px";
}
export const pixelFromInt = ToPixel$$$op_Dollar$$Z45FE3DAA(new ToPixel(0, "ToPixel"), 2);
export const prixelFromFloat = ToPixel$$$op_Dollar$$49846331(new ToPixel(0, "ToPixel"), 2); Side note: Also, because you use This an interesting usage in order to reduce bundle size and have a small optimisation. (unbox<string> 2) + "px"
// generates: 2 + "px";
string 2 + "px"
// genertes: int32ToString(2) + "px"; I just wanted to note this behaviour as it's becoming an implementation detail of Feliz now. So using |
Another implementation possible is: type Utilities = Utilities with
static member inline toPixel (value: int ) = unbox<string> value + "px"
static member inline toPixel (value: float) = unbox<string> value + "px"
let inline call (_:^Utilities) value = ((^Utilities or ^a) : (static member inline toPixel: ^a -> string) (value))
let inline pixel value = call Utilities value
let pixelFromInt = pixel 2
let prixelFromFlaot = pixel 2.2 This generates: import { union } from "fable-library/Reflection.js";
import { declare, Union } from "fable-library/Types.js";
export const Utilities = declare(function DragAndDrop_Utilities(tag, name, ...fields) {
Union.call(this, tag, name, ...fields);
}, Union);
export function Utilities$reflection() {
return union("DragAndDrop.Utilities", [], Utilities, () => ["Utilities"]);
}
export const pixelFromInt = (() => {
const _arg1 = new Utilities(0, "Utilities");
return 2 + "px";
})();
export const prixelFromFlaot = (() => {
const _arg1$$1 = new Utilities(0, "Utilities");
return 2.2 + "px";
})(); |
Thanks @MangelMaxime for the suggestions, I cannot use Also although I like an overloaded Alright, I think I will keep it as is for now, thanks again for the input Maxime ❤️ |
Ah yes right. Perhaps
I am not convinced with
Indeed, but we can have a separate library with this syntax in it as Feliz seems easier to extends. :) If I prefer that this syntax perhaps I will work on it. Will first wait to Feliz to bo done :) |
I thought of |
Would dotnet/fsharp#6807 help with this? I think then you could |
@NatElkins I think that when it will be available yes it should help because I have also linked this PR for #2 (comment) And the problem is similar I think. |
@NatElkins Actually at this point I wouldn't recommend opening types such as |
I am not what to call the helper class that contains the different CSS units like
px
andrem
. I have now called itlength
, implemented like this:and you can use it like this:
but I am not sure if
length
is a good name for it, what do you think @MangelMaxime?The text was updated successfully, but these errors were encountered: