diff --git a/404.html b/404.html index ff1cf80a..5edd0c16 100644 --- a/404.html +++ b/404.html @@ -6,13 +6,13 @@ Page Not Found | Shuffle.js - +
Skip to main content

Page Not Found

We could not find what you were looking for.

Please contact the owner of the site that linked you to the original URL and let them know their link is broken.

- + \ No newline at end of file diff --git a/assets/js/9ed00105.227fece3.js b/assets/js/9ed00105.227fece3.js new file mode 100644 index 00000000..7b76a49f --- /dev/null +++ b/assets/js/9ed00105.227fece3.js @@ -0,0 +1 @@ +"use strict";(globalThis.webpackChunkshuffle_docs=globalThis.webpackChunkshuffle_docs||[]).push([[4],{876:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>c});var l=n(2784);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);t&&(l=l.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,l)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(l=0;l=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var u=l.createContext({}),s=function(e){var t=l.useContext(u),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},d=function(e){var t=s(e.components);return l.createElement(u.Provider,{value:t},e.children)},p="mdxType",m={inlineCode:"code",wrapper:function(e){var t=e.children;return l.createElement(l.Fragment,{},t)}},f=l.forwardRef((function(e,t){var n=e.components,i=e.mdxType,r=e.originalType,u=e.parentName,d=a(e,["components","mdxType","originalType","parentName"]),p=s(n),f=i,c=p["".concat(u,".").concat(f)]||p[f]||m[f]||r;return n?l.createElement(c,o(o({ref:t},d),{},{components:n})):l.createElement(c,o({ref:t},d))}));function c(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var r=n.length,o=new Array(r);o[0]=f;var a={};for(var u in t)hasOwnProperty.call(t,u)&&(a[u]=t[u]);a.originalType=e,a[p]="string"==typeof e?e:i,o[1]=a;for(var s=2;s{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>o,default:()=>m,frontMatter:()=>r,metadata:()=>a,toc:()=>s});var l=n(8427),i=(n(2784),n(876));const r={sidebar_position:4},o="Configuring Shuffle",a={unversionedId:"configuration",id:"configuration",title:"Configuring Shuffle",description:"Here are the options you can change, as well as their defaults. The Shuffle.options property contains all the defaults.",source:"@site/docs/configuration.md",sourceDirName:".",slug:"/configuration",permalink:"/Shuffle/docs/configuration",draft:!1,editUrl:"https://github.com/Vestride/Shuffle/tree/main/apps/website/docs/docs/configuration.md",tags:[],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4},sidebar:"tutorialSidebar",previous:{title:"How column widths work",permalink:"/Shuffle/docs/column-widths"},next:{title:"Filters",permalink:"/Shuffle/docs/filters"}},u={},s=[{value:"Options",id:"options",level:2},{value:"buffer number",id:"buffer-number",level:3},{value:"columnThreshold number",id:"columnthreshold-number",level:3},{value:"columnWidth number | (conatinerWidth: number) => number",id:"columnwidth-number--conatinerwidth-number--number",level:3},{value:"delimiter string | null",id:"delimiter-string--null",level:3},{value:"easing string",id:"easing-string",level:3},{value:"filterMode Shuffle.FilterMode",id:"filtermode-shufflefiltermode",level:3},{value:"group string",id:"group-string",level:3},{value:"gutterWidth number | (conatinerWidth: number) => number",id:"gutterwidth-number--conatinerwidth-number--number",level:3},{value:"initialSort SortOptions | null",id:"initialsort-sortoptions--null",level:3},{value:"isCentered boolean",id:"iscentered-boolean",level:3},{value:"isRTL boolean",id:"isrtl-boolean",level:3},{value:"itemSelector string",id:"itemselector-string",level:3},{value:"roundTransforms boolean",id:"roundtransforms-boolean",level:3},{value:"sizer HTMLElement | string | null",id:"sizer-htmlelement--string--null",level:3},{value:"speed number",id:"speed-number",level:3},{value:"staggerAmount number",id:"staggeramount-number",level:3},{value:"staggerAmountMax number",id:"staggeramountmax-number",level:3},{value:"useTransforms boolean",id:"usetransforms-boolean",level:3},{value:"Sorting object",id:"sorting-object",level:2},{value:"by (element: HTMLElement) => any",id:"by-element-htmlelement--any",level:3},{value:"compare (a: Shuffle.ShuffleItem, b: Shuffle.ShuffleItem) => number",id:"compare-a-shuffleshuffleitem-b-shuffleshuffleitem--number",level:3},{value:"key keyof Shuffle.ShuffleItem",id:"key-keyof-shuffleshuffleitem",level:3},{value:"randomize boolean",id:"randomize-boolean",level:3},{value:"reverse boolean",id:"reverse-boolean",level:3}],d={toc:s},p="wrapper";function m(e){let{components:t,...n}=e;return(0,i.kt)(p,(0,l.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"configuring-shuffle"},"Configuring Shuffle"),(0,i.kt)("p",null,"Here are the options you can change, as well as their defaults. The ",(0,i.kt)("inlineCode",{parentName:"p"},"Shuffle.options")," property contains all the defaults."),(0,i.kt)("p",null,"No options ",(0,i.kt)("em",{parentName:"p"},"need")," to be specified, but ",(0,i.kt)("inlineCode",{parentName:"p"},"itemSelector")," should be used. Other common options to change are ",(0,i.kt)("inlineCode",{parentName:"p"},"speed")," and ",(0,i.kt)("inlineCode",{parentName:"p"},"sizer"),"."),(0,i.kt)("h2",{id:"options"},"Options"),(0,i.kt)("h3",{id:"buffer-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"buffer")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0")),(0,i.kt)("p",null,"Useful for percentage based heights when they might not always be exactly the same (in pixels)."),(0,i.kt)("h3",{id:"columnthreshold-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"columnThreshold")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0.01")),(0,i.kt)("p",null,"Reading the width of elements isn't precise enough and can cause columns to jump between values."),(0,i.kt)("h3",{id:"columnwidth-number--conatinerwidth-number--number"},(0,i.kt)("inlineCode",{parentName:"h3"},"columnWidth")," ","[number | (conatinerWidth: number) => number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0")),(0,i.kt)("p",null,"A static number or function that returns a number which determines how wide the columns are (in pixels)."),(0,i.kt)("h3",{id:"delimiter-string--null"},(0,i.kt)("inlineCode",{parentName:"h3"},"delimiter")," ","[string | null]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Set a delimiter to parse the ",(0,i.kt)("inlineCode",{parentName:"p"},"data-groups")," attribute with using ",(0,i.kt)("inlineCode",{parentName:"p"},"String.prototype.split()"),", instead of using ",(0,i.kt)("inlineCode",{parentName:"p"},"JSON.parse()"),". For example, if your HTML was ",(0,i.kt)("inlineCode",{parentName:"p"},'data-groups="nature,city"'),", you could set ",(0,i.kt)("inlineCode",{parentName:"p"},"delimiter: ','"),"."),(0,i.kt)("h3",{id:"easing-string"},(0,i.kt)("inlineCode",{parentName:"h3"},"easing")," ","[string]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"'cubic-bezier(0.4, 0.0, 0.2, 1)'")),(0,i.kt)("p",null,"CSS easing function to use."),(0,i.kt)("h3",{id:"filtermode-shufflefiltermode"},(0,i.kt)("inlineCode",{parentName:"h3"},"filterMode")," ","[Shuffle.FilterMode]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"Shuffle.FilterMode.ANY")),(0,i.kt)("p",null,"Affects using an array with filter. e.g. ",(0,i.kt)("inlineCode",{parentName:"p"},"filter(['one', 'two'])"),'. With "any", the element passes the test if any of its groups are in the array. With "all", the element only passes if all groups are in the array.'),(0,i.kt)("h3",{id:"group-string"},(0,i.kt)("inlineCode",{parentName:"h3"},"group")," ","[string]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"Shuffle.ALL_ITEMS")," (",(0,i.kt)("inlineCode",{parentName:"p"},'"all"'),")"),(0,i.kt)("p",null,"Initial filter group."),(0,i.kt)("h3",{id:"gutterwidth-number--conatinerwidth-number--number"},(0,i.kt)("inlineCode",{parentName:"h3"},"gutterWidth")," ","[number | (conatinerWidth: number) => number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0")),(0,i.kt)("p",null,"A static number or function that determines how wide the gutters between columns are (in pixels)."),(0,i.kt)("h3",{id:"initialsort-sortoptions--null"},(0,i.kt)("inlineCode",{parentName:"h3"},"initialSort")," ","[SortOptions | null]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Shuffle can be initialized with a sort object. It is the same object given to the sort method."),(0,i.kt)("h3",{id:"iscentered-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"isCentered")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Whether to center grid items in the row with the leftover space."),(0,i.kt)("h3",{id:"isrtl-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"isRTL")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Whether to align grid items to the right in the row."),(0,i.kt)("h3",{id:"itemselector-string"},(0,i.kt)("inlineCode",{parentName:"h3"},"itemSelector")," ","[string]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"'*'")),(0,i.kt)("p",null,"Query selector to find Shuffle items. e.g. '.picture-item'."),(0,i.kt)("h3",{id:"roundtransforms-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"roundTransforms")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"true")),(0,i.kt)("p",null,"Whether to round pixel values used in translate(x, y). This usually avoids blurriness."),(0,i.kt)("h3",{id:"sizer-htmlelement--string--null"},(0,i.kt)("inlineCode",{parentName:"h3"},"sizer")," ","[HTMLElement | string | null]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Element or selector string. Use an element to determine the size of columns and gutters."),(0,i.kt)("h3",{id:"speed-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"speed")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"250")),(0,i.kt)("p",null,"Transition/animation speed (milliseconds)."),(0,i.kt)("h3",{id:"staggeramount-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"staggerAmount")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"15")),(0,i.kt)("p",null,"Transition delay offset for each item in milliseconds."),(0,i.kt)("h3",{id:"staggeramountmax-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"staggerAmountMax")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"150")),(0,i.kt)("p",null,"Maximum stagger delay in milliseconds. This caps the stagger amount so that it does not exceed the given value. Since the transition delay is incremented for each item in the grid, this is useful for large grids of items."),(0,i.kt)("h3",{id:"usetransforms-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"useTransforms")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Whether to use absolute positioning instead of transforms."),(0,i.kt)("h2",{id:"sorting-object"},"Sorting object"),(0,i.kt)("h3",{id:"by-element-htmlelement--any"},(0,i.kt)("inlineCode",{parentName:"h3"},"by")," ","[(element: HTMLElement) => any]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Sorting function which gives you the element each shuffle item is using by default."),(0,i.kt)("p",null,"Returning ",(0,i.kt)("inlineCode",{parentName:"p"},"undefined")," from the ",(0,i.kt)("inlineCode",{parentName:"p"},"by")," function will reset the order to DOM order."),(0,i.kt)("h3",{id:"compare-a-shuffleshuffleitem-b-shuffleshuffleitem--number"},(0,i.kt)("inlineCode",{parentName:"h3"},"compare")," ","[(a: Shuffle.ShuffleItem, b: Shuffle.ShuffleItem) => number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Instead of using the simple ",(0,i.kt)("inlineCode",{parentName:"p"},"by")," function, you can use the ",(0,i.kt)("inlineCode",{parentName:"p"},"compare")," function provide a completely custom sorting function."),(0,i.kt)("admonition",{type:"tip"},(0,i.kt)("p",{parentName:"admonition"},"See ",(0,i.kt)("a",{parentName:"p",href:"/Shuffle/docs/sorting#advanced-sorting"},"Advanced sorting")," for usage.")),(0,i.kt)("h3",{id:"key-keyof-shuffleshuffleitem"},(0,i.kt)("inlineCode",{parentName:"h3"},"key")," ","[keyof Shuffle.ShuffleItem]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"'element'")),(0,i.kt)("p",null,"Determines which property of the ",(0,i.kt)("inlineCode",{parentName:"p"},"ShuffleItem")," instance is passed to the ",(0,i.kt)("inlineCode",{parentName:"p"},"by")," function."),(0,i.kt)("h3",{id:"randomize-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"randomize")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"If true, this will skip the sorting and return a randomized order in the array."),(0,i.kt)("h3",{id:"reverse-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"reverse")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Use array.reverse() to reverse the results of your sort."))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/9ed00105.f1b91c89.js b/assets/js/9ed00105.f1b91c89.js deleted file mode 100644 index 9821db5d..00000000 --- a/assets/js/9ed00105.f1b91c89.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(globalThis.webpackChunkshuffle_docs=globalThis.webpackChunkshuffle_docs||[]).push([[4],{876:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>h});var l=n(2784);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);t&&(l=l.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,l)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(l=0;l=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var u=l.createContext({}),s=function(e){var t=l.useContext(u),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},d=function(e){var t=s(e.components);return l.createElement(u.Provider,{value:t},e.children)},m="mdxType",p={inlineCode:"code",wrapper:function(e){var t=e.children;return l.createElement(l.Fragment,{},t)}},f=l.forwardRef((function(e,t){var n=e.components,i=e.mdxType,r=e.originalType,u=e.parentName,d=a(e,["components","mdxType","originalType","parentName"]),m=s(n),f=i,h=m["".concat(u,".").concat(f)]||m[f]||p[f]||r;return n?l.createElement(h,o(o({ref:t},d),{},{components:n})):l.createElement(h,o({ref:t},d))}));function h(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var r=n.length,o=new Array(r);o[0]=f;var a={};for(var u in t)hasOwnProperty.call(t,u)&&(a[u]=t[u]);a.originalType=e,a[m]="string"==typeof e?e:i,o[1]=a;for(var s=2;s{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>o,default:()=>p,frontMatter:()=>r,metadata:()=>a,toc:()=>s});var l=n(8427),i=(n(2784),n(876));const r={sidebar_position:4},o="Configuring Shuffle",a={unversionedId:"configuration",id:"configuration",title:"Configuring Shuffle",description:"Here are the options you can change, as well as their defaults. The Shuffle.options property contains all the defaults.",source:"@site/docs/configuration.md",sourceDirName:".",slug:"/configuration",permalink:"/Shuffle/docs/configuration",draft:!1,editUrl:"https://github.com/Vestride/Shuffle/tree/main/apps/website/docs/docs/configuration.md",tags:[],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4},sidebar:"tutorialSidebar",previous:{title:"How column widths work",permalink:"/Shuffle/docs/column-widths"},next:{title:"Filters",permalink:"/Shuffle/docs/filters"}},u={},s=[{value:"Options",id:"options",level:2},{value:"buffer number",id:"buffer-number",level:3},{value:"columnThreshold number",id:"columnthreshold-number",level:3},{value:"columnWidth number | (conatinerWidth: number) => number",id:"columnwidth-number--conatinerwidth-number--number",level:3},{value:"delimiter string | null",id:"delimiter-string--null",level:3},{value:"easing string",id:"easing-string",level:3},{value:"filterMode Shuffle.FilterMode",id:"filtermode-shufflefiltermode",level:3},{value:"group string",id:"group-string",level:3},{value:"gutterWidth number | (conatinerWidth: number) => number",id:"gutterwidth-number--conatinerwidth-number--number",level:3},{value:"initialSort SortOptions | null",id:"initialsort-sortoptions--null",level:3},{value:"isCentered boolean",id:"iscentered-boolean",level:3},{value:"isRTL boolean",id:"isrtl-boolean",level:3},{value:"itemSelector string",id:"itemselector-string",level:3},{value:"roundTransforms boolean",id:"roundtransforms-boolean",level:3},{value:"sizer HTMLElement | string | null",id:"sizer-htmlelement--string--null",level:3},{value:"speed number",id:"speed-number",level:3},{value:"staggerAmount number",id:"staggeramount-number",level:3},{value:"staggerAmountMax number",id:"staggeramountmax-number",level:3},{value:"useTransforms boolean",id:"usetransforms-boolean",level:3},{value:"Sorting object",id:"sorting-object",level:2},{value:"by (element: HTMLElement) => any",id:"by-element-htmlelement--any",level:3},{value:"compare (a: Shuffle.ShuffleItem, b: Shuffle.ShuffleItem) => number",id:"compare-a-shuffleshuffleitem-b-shuffleshuffleitem--number",level:3},{value:"key keyof Shuffle.ShuffleItem",id:"key-keyof-shuffleshuffleitem",level:3},{value:"randomize boolean",id:"randomize-boolean",level:3},{value:"reverse boolean",id:"reverse-boolean",level:3}],d={toc:s},m="wrapper";function p(e){let{components:t,...n}=e;return(0,i.kt)(m,(0,l.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"configuring-shuffle"},"Configuring Shuffle"),(0,i.kt)("p",null,"Here are the options you can change, as well as their defaults. The ",(0,i.kt)("inlineCode",{parentName:"p"},"Shuffle.options")," property contains all the defaults."),(0,i.kt)("p",null,"No options ",(0,i.kt)("em",{parentName:"p"},"need")," to be specified, but ",(0,i.kt)("inlineCode",{parentName:"p"},"itemSelector")," should be used. Other common options to change are ",(0,i.kt)("inlineCode",{parentName:"p"},"speed")," and ",(0,i.kt)("inlineCode",{parentName:"p"},"sizer"),"."),(0,i.kt)("h2",{id:"options"},"Options"),(0,i.kt)("h3",{id:"buffer-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"buffer")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0")),(0,i.kt)("p",null,"Useful for percentage based heights when they might not always be exactly the same (in pixels)."),(0,i.kt)("h3",{id:"columnthreshold-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"columnThreshold")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0.01")),(0,i.kt)("p",null,"Reading the width of elements isn't precise enough and can cause columns to jump between values."),(0,i.kt)("h3",{id:"columnwidth-number--conatinerwidth-number--number"},(0,i.kt)("inlineCode",{parentName:"h3"},"columnWidth")," ","[number | (conatinerWidth: number) => number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0")),(0,i.kt)("p",null,"A static number or function that returns a number which determines how wide the columns are (in pixels)."),(0,i.kt)("h3",{id:"delimiter-string--null"},(0,i.kt)("inlineCode",{parentName:"h3"},"delimiter")," ","[string | null]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"A static number or function that returns a number which determines how wide the columns are (in pixels)."),(0,i.kt)("h3",{id:"easing-string"},(0,i.kt)("inlineCode",{parentName:"h3"},"easing")," ","[string]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"'cubic-bezier(0.4, 0.0, 0.2, 1)'")),(0,i.kt)("p",null,"CSS easing function to use."),(0,i.kt)("h3",{id:"filtermode-shufflefiltermode"},(0,i.kt)("inlineCode",{parentName:"h3"},"filterMode")," ","[Shuffle.FilterMode]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"Shuffle.FilterMode.ANY")),(0,i.kt)("p",null,"Affects using an array with filter. e.g. ",(0,i.kt)("inlineCode",{parentName:"p"},"filter(['one', 'two'])"),'. With "any", the element passes the test if any of its groups are in the array. With "all", the element only passes if all groups are in the array.'),(0,i.kt)("h3",{id:"group-string"},(0,i.kt)("inlineCode",{parentName:"h3"},"group")," ","[string]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"Shuffle.ALL_ITEMS")," (",(0,i.kt)("inlineCode",{parentName:"p"},'"all"'),")"),(0,i.kt)("p",null,"Initial filter group."),(0,i.kt)("h3",{id:"gutterwidth-number--conatinerwidth-number--number"},(0,i.kt)("inlineCode",{parentName:"h3"},"gutterWidth")," ","[number | (conatinerWidth: number) => number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"0")),(0,i.kt)("p",null,"A static number or function that determines how wide the gutters between columns are (in pixels)."),(0,i.kt)("h3",{id:"initialsort-sortoptions--null"},(0,i.kt)("inlineCode",{parentName:"h3"},"initialSort")," ","[SortOptions | null]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Shuffle can be initialized with a sort object. It is the same object given to the sort method."),(0,i.kt)("h3",{id:"iscentered-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"isCentered")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Whether to center grid items in the row with the leftover space."),(0,i.kt)("h3",{id:"isrtl-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"isRTL")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Whether to align grid items to the right in the row."),(0,i.kt)("h3",{id:"itemselector-string"},(0,i.kt)("inlineCode",{parentName:"h3"},"itemSelector")," ","[string]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"'*'")),(0,i.kt)("p",null,"Query selector to find Shuffle items. e.g. '.picture-item'."),(0,i.kt)("h3",{id:"roundtransforms-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"roundTransforms")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"true")),(0,i.kt)("p",null,"Whether to round pixel values used in translate(x, y). This usually avoids blurriness."),(0,i.kt)("h3",{id:"sizer-htmlelement--string--null"},(0,i.kt)("inlineCode",{parentName:"h3"},"sizer")," ","[HTMLElement | string | null]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Element or selector string. Use an element to determine the size of columns and gutters."),(0,i.kt)("h3",{id:"speed-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"speed")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"250")),(0,i.kt)("p",null,"Transition/animation speed (milliseconds)."),(0,i.kt)("h3",{id:"staggeramount-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"staggerAmount")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"15")),(0,i.kt)("p",null,"Transition delay offset for each item in milliseconds."),(0,i.kt)("h3",{id:"staggeramountmax-number"},(0,i.kt)("inlineCode",{parentName:"h3"},"staggerAmountMax")," ","[number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"150")),(0,i.kt)("p",null,"Maximum stagger delay in milliseconds. This caps the stagger amount so that it does not exceed the given value. Since the transition delay is incremented for each item in the grid, this is useful for large grids of items."),(0,i.kt)("h3",{id:"usetransforms-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"useTransforms")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Whether to use absolute positioning instead of transforms."),(0,i.kt)("h2",{id:"sorting-object"},"Sorting object"),(0,i.kt)("h3",{id:"by-element-htmlelement--any"},(0,i.kt)("inlineCode",{parentName:"h3"},"by")," ","[(element: HTMLElement) => any]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Sorting function which gives you the element each shuffle item is using by default."),(0,i.kt)("p",null,"Returning ",(0,i.kt)("inlineCode",{parentName:"p"},"undefined")," from the ",(0,i.kt)("inlineCode",{parentName:"p"},"by")," function will reset the order to DOM order."),(0,i.kt)("h3",{id:"compare-a-shuffleshuffleitem-b-shuffleshuffleitem--number"},(0,i.kt)("inlineCode",{parentName:"h3"},"compare")," ","[(a: Shuffle.ShuffleItem, b: Shuffle.ShuffleItem) => number]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"null")),(0,i.kt)("p",null,"Instead of using the simple ",(0,i.kt)("inlineCode",{parentName:"p"},"by")," function, you can use the ",(0,i.kt)("inlineCode",{parentName:"p"},"compare")," function provide a completely custom sorting function."),(0,i.kt)("admonition",{type:"tip"},(0,i.kt)("p",{parentName:"admonition"},"See ",(0,i.kt)("a",{parentName:"p",href:"/Shuffle/docs/sorting#advanced-sorting"},"Advanced sorting")," for usage.")),(0,i.kt)("h3",{id:"key-keyof-shuffleshuffleitem"},(0,i.kt)("inlineCode",{parentName:"h3"},"key")," ","[keyof Shuffle.ShuffleItem]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"'element'")),(0,i.kt)("p",null,"Determines which property of the ",(0,i.kt)("inlineCode",{parentName:"p"},"ShuffleItem")," instance is passed to the ",(0,i.kt)("inlineCode",{parentName:"p"},"by")," function."),(0,i.kt)("h3",{id:"randomize-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"randomize")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"If true, this will skip the sorting and return a randomized order in the array."),(0,i.kt)("h3",{id:"reverse-boolean"},(0,i.kt)("inlineCode",{parentName:"h3"},"reverse")," ","[boolean]"),(0,i.kt)("p",null,"Default: ",(0,i.kt)("inlineCode",{parentName:"p"},"false")),(0,i.kt)("p",null,"Use array.reverse() to reverse the results of your sort."))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/runtime~main.8dfd011c.js b/assets/js/runtime~main.aa48c8c6.js similarity index 61% rename from assets/js/runtime~main.8dfd011c.js rename to assets/js/runtime~main.aa48c8c6.js index 4571e334..97674285 100644 --- a/assets/js/runtime~main.8dfd011c.js +++ b/assets/js/runtime~main.aa48c8c6.js @@ -1 +1 @@ -(()=>{"use strict";var e,t,r,a,d,o={},f={};function n(e){var t=f[e];if(void 0!==t)return t.exports;var r=f[e]={id:e,loaded:!1,exports:{}};return o[e].call(r.exports,r,r.exports,n),r.loaded=!0,r.exports}n.m=o,n.c=f,e=[],n.O=(t,r,a,d)=>{if(!r){var o=1/0;for(l=0;l=d)&&Object.keys(n.O).every((e=>n.O[e](r[c])))?r.splice(c--,1):(f=!1,d0&&e[l-1][2]>d;l--)e[l]=e[l-1];e[l]=[r,a,d]},n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,n.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var d=Object.create(null);n.r(d);var o={};t=t||[null,r({}),r([]),r(r)];for(var f=2&a&&e;"object"==typeof f&&!~t.indexOf(f);f=r(f))Object.getOwnPropertyNames(f).forEach((t=>o[t]=()=>e[t]));return o.default=()=>e,n.d(d,o),d},n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce(((t,r)=>(n.f[r](e,t),t)),[])),n.u=e=>"assets/js/"+({4:"9ed00105",53:"935f2afb",54:"9dd8a0d2",80:"9beb87c2",92:"6ff629d8",141:"d700bc26",162:"d589d3a7",192:"4777fd9a",202:"aa72d29b",207:"5fbc5cf1",211:"1ffdd7de",241:"164760aa",261:"828b0528",315:"2261bd48",456:"3475e39f",514:"1be78505",599:"e2d55573",879:"41eae919",918:"17896441",924:"e6a2d45a",943:"c4de80f8",947:"9348edec"}[e]||e)+"."+{4:"f1b91c89",6:"74d32451",53:"93ad64f9",54:"6ba1b4ce",80:"5587538e",92:"7588639d",141:"446e0646",162:"069c3b3b",192:"e31efd8d",202:"bad6b817",207:"4c44b453",211:"b9d8716d",241:"70a41558",261:"ab1698e8",315:"43398a4e",456:"106e4a1c",514:"9f24e08c",599:"fc48f741",879:"d6ef93bb",918:"b2d96756",924:"e3a617b3",943:"f221503f",947:"18fbe722"}[e]+".js",n.miniCssF=e=>{},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},d="shuffle-docs:",n.l=(e,t,r,o)=>{if(a[e])a[e].push(t);else{var f,c;if(void 0!==r)for(var i=document.getElementsByTagName("script"),l=0;l{f.onerror=f.onload=null,clearTimeout(b);var d=a[e];if(delete a[e],f.parentNode&&f.parentNode.removeChild(f),d&&d.forEach((e=>e(r))),t)return t(r)},b=setTimeout(s.bind(null,void 0,{type:"timeout",target:f}),12e4);f.onerror=s.bind(null,f.onerror),f.onload=s.bind(null,f.onload),c&&document.head.appendChild(f)}},n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.p="/Shuffle/",n.gca=function(e){return e={17896441:"918","9ed00105":"4","935f2afb":"53","9dd8a0d2":"54","9beb87c2":"80","6ff629d8":"92",d700bc26:"141",d589d3a7:"162","4777fd9a":"192",aa72d29b:"202","5fbc5cf1":"207","1ffdd7de":"211","164760aa":"241","828b0528":"261","2261bd48":"315","3475e39f":"456","1be78505":"514",e2d55573:"599","41eae919":"879",e6a2d45a:"924",c4de80f8:"943","9348edec":"947"}[e]||e,n.p+n.u(e)},(()=>{var e={303:0,532:0};n.f.j=(t,r)=>{var a=n.o(e,t)?e[t]:void 0;if(0!==a)if(a)r.push(a[2]);else if(/^(303|532)$/.test(t))e[t]=0;else{var d=new Promise(((r,d)=>a=e[t]=[r,d]));r.push(a[2]=d);var o=n.p+n.u(t),f=new Error;n.l(o,(r=>{if(n.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var d=r&&("load"===r.type?"missing":r.type),o=r&&r.target&&r.target.src;f.message="Loading chunk "+t+" failed.\n("+d+": "+o+")",f.name="ChunkLoadError",f.type=d,f.request=o,a[1](f)}}),"chunk-"+t,t)}},n.O.j=t=>0===e[t];var t=(t,r)=>{var a,d,[o,f,c]=r,i=0;if(o.some((t=>0!==e[t]))){for(a in f)n.o(f,a)&&(n.m[a]=f[a]);if(c)var l=c(n)}for(t&&t(r);i{"use strict";var e,t,r,a,o,d={},f={};function n(e){var t=f[e];if(void 0!==t)return t.exports;var r=f[e]={id:e,loaded:!1,exports:{}};return d[e].call(r.exports,r,r.exports,n),r.loaded=!0,r.exports}n.m=d,n.c=f,e=[],n.O=(t,r,a,o)=>{if(!r){var d=1/0;for(l=0;l=o)&&Object.keys(n.O).every((e=>n.O[e](r[c])))?r.splice(c--,1):(f=!1,o0&&e[l-1][2]>o;l--)e[l]=e[l-1];e[l]=[r,a,o]},n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,n.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var o=Object.create(null);n.r(o);var d={};t=t||[null,r({}),r([]),r(r)];for(var f=2&a&&e;"object"==typeof f&&!~t.indexOf(f);f=r(f))Object.getOwnPropertyNames(f).forEach((t=>d[t]=()=>e[t]));return d.default=()=>e,n.d(o,d),o},n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce(((t,r)=>(n.f[r](e,t),t)),[])),n.u=e=>"assets/js/"+({4:"9ed00105",53:"935f2afb",54:"9dd8a0d2",80:"9beb87c2",92:"6ff629d8",141:"d700bc26",162:"d589d3a7",192:"4777fd9a",202:"aa72d29b",207:"5fbc5cf1",211:"1ffdd7de",241:"164760aa",261:"828b0528",315:"2261bd48",456:"3475e39f",514:"1be78505",599:"e2d55573",879:"41eae919",918:"17896441",924:"e6a2d45a",943:"c4de80f8",947:"9348edec"}[e]||e)+"."+{4:"227fece3",6:"74d32451",53:"93ad64f9",54:"6ba1b4ce",80:"5587538e",92:"7588639d",141:"446e0646",162:"069c3b3b",192:"e31efd8d",202:"bad6b817",207:"4c44b453",211:"b9d8716d",241:"70a41558",261:"ab1698e8",315:"43398a4e",456:"106e4a1c",514:"9f24e08c",599:"fc48f741",879:"d6ef93bb",918:"b2d96756",924:"e3a617b3",943:"f221503f",947:"18fbe722"}[e]+".js",n.miniCssF=e=>{},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},o="shuffle-docs:",n.l=(e,t,r,d)=>{if(a[e])a[e].push(t);else{var f,c;if(void 0!==r)for(var i=document.getElementsByTagName("script"),l=0;l{f.onerror=f.onload=null,clearTimeout(b);var o=a[e];if(delete a[e],f.parentNode&&f.parentNode.removeChild(f),o&&o.forEach((e=>e(r))),t)return t(r)},b=setTimeout(s.bind(null,void 0,{type:"timeout",target:f}),12e4);f.onerror=s.bind(null,f.onerror),f.onload=s.bind(null,f.onload),c&&document.head.appendChild(f)}},n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.p="/Shuffle/",n.gca=function(e){return e={17896441:"918","9ed00105":"4","935f2afb":"53","9dd8a0d2":"54","9beb87c2":"80","6ff629d8":"92",d700bc26:"141",d589d3a7:"162","4777fd9a":"192",aa72d29b:"202","5fbc5cf1":"207","1ffdd7de":"211","164760aa":"241","828b0528":"261","2261bd48":"315","3475e39f":"456","1be78505":"514",e2d55573:"599","41eae919":"879",e6a2d45a:"924",c4de80f8:"943","9348edec":"947"}[e]||e,n.p+n.u(e)},(()=>{var e={303:0,532:0};n.f.j=(t,r)=>{var a=n.o(e,t)?e[t]:void 0;if(0!==a)if(a)r.push(a[2]);else if(/^(303|532)$/.test(t))e[t]=0;else{var o=new Promise(((r,o)=>a=e[t]=[r,o]));r.push(a[2]=o);var d=n.p+n.u(t),f=new Error;n.l(d,(r=>{if(n.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var o=r&&("load"===r.type?"missing":r.type),d=r&&r.target&&r.target.src;f.message="Loading chunk "+t+" failed.\n("+o+": "+d+")",f.name="ChunkLoadError",f.type=o,f.request=d,a[1](f)}}),"chunk-"+t,t)}},n.O.j=t=>0===e[t];var t=(t,r)=>{var a,o,[d,f,c]=r,i=0;if(d.some((t=>0!==e[t]))){for(a in f)n.o(f,a)&&(n.m[a]=f[a]);if(c)var l=c(n)}for(t&&t(r);iAdding and removing items | Shuffle.js - +

Adding and removing items

You can add and remove elements from shuffle after it has been created. This also works for infinite scrolling.

Adding elements

Wherever you add the element in the DOM is where it will show up in the grid (assuming you’re using the default sort-by-dom-order). With this in mind, you can append, prepend, or insert elements wherever you need to get them to show up in the right order.

/**
* Create some DOM elements, append them to the shuffle container, then notify
* shuffle about the new items. You could also insert the HTML as a string.
*/
onAppendBoxes() {
const elements = this._getArrayOfElementsToAdd();

elements.forEach((element) => {
this.shuffle.element.appendChild(element);
});

// Tell shuffle elements have been appended.
// It expects an array of elements as the parameter.
this.shuffle.add(elements);
}

Removing elements

Shuffle will animate the element away and then remove it from the DOM once it's finished. It will then emit the Shuffle.EventType.REMOVED event with the array of elements in event.collection.

this.shuffle.remove([element1, element2]);
tip
- + \ No newline at end of file diff --git a/docs/advanced-filters.html b/docs/advanced-filters.html index 438d3b38..166c482b 100644 --- a/docs/advanced-filters.html +++ b/docs/advanced-filters.html @@ -6,13 +6,13 @@ Advanced filters | Shuffle.js - +

Advanced filters

By passing a function to filter, you can fully customize filtering items. Shuffle will iterate over each item and give your function the element and the shuffle instance. Return true to keep the element or false to hide it.

Example

// Filters elements with a data-title attribute with less than 10 characters
shuffleInstance.filter((element) => element.dataset.title.length < 10);

Searching

// Add an event listener for key presses.
document.querySelector('.js-shuffle-search').addEventListener('keyup', handleSearchKeyup);

// Filter the shuffle instance by items with a title that matches the search input.
function handleSearchKeyup(event) {
const searchText = event.target.value.toLowerCase();

shuffleInstance.filter((element, shuffle) => {
const titleElement = element.querySelector('.picture-item__title');
const titleText = titleElement.textContent.toLowerCase().trim();

return titleText.includes(searchText);
});
}

In this example, when the user presses a key in the input, we call filter on shuffle with a callback function. Inside the callback function, we return whether the current shuffle item contains the search text.

tip
- + \ No newline at end of file diff --git a/docs/alternatives.html b/docs/alternatives.html index 4163948b..f45cf805 100644 --- a/docs/alternatives.html +++ b/docs/alternatives.html @@ -6,13 +6,13 @@ Alternatives | Shuffle.js - +

Alternatives

Shuffle won't fit every use case. There are also features I am not interested in implementing because of the level of effort it would take to write or they exist in other libraries.

Shuffle likely will not grow much farther than the current feature set. If you need something with drag and drop, filling in gaps, more layout modes, etc., I suggest looking into packery or isotope.

- + \ No newline at end of file diff --git a/docs/api.html b/docs/api.html index 078c1270..793dce31 100644 --- a/docs/api.html +++ b/docs/api.html @@ -6,13 +6,13 @@ API | Shuffle.js - +

API

A list of the methods available to you and what they do.

filter(category?, sortObject?)

Filters all the shuffle items and then sorts them.

  • category can be a string, array of strings, or a function. Learn more in filters.
  • The sortObject is optional, defaulting to the last-used sort object.

sort(sortObject?)

Sorts the currently filtered shuffle items.

Calling sort with an empty object will reset the elements to DOM order.

See the SortOptions for the available properties.

update(options?)

Repositions everything. Useful for when dimensions (like the window size) change.

You may provide an options object containing the following properties:

  • recalculateSizes: Whether to recalculate column, gutter, and container widths again. Defaults to true.
  • force: By default, update does nothing if the instance is disabled. Setting this to true forces the update to happen regardless.

layout()

Use this instead of update() if you don't need the columns and gutters updated. Maybe an image inside shuffle loaded (and now has a height), which means calculations could be off.

add(newItems)

New items have been appended to the shuffle container. newItems is an array of elements.

disable()

Disables Shuffle from updating dimensions and layout on resize.

enable(isUpdateLayout?)

Enables Shuffle again. If you pass false as the first parameter, you can tell Shuffle to skip the layout recalculation.

remove(elements)

Remove one or more shuffle items. elements is an array containing one or more elements.

getItemByElement(element)

Retrieve a ShuffleItem by its element.

destroy()

Destroys Shuffle, removes events, styles, classes, and references.

- + \ No newline at end of file diff --git a/docs/changelog.html b/docs/changelog.html index 12fc7ee8..87b5bf16 100644 --- a/docs/changelog.html +++ b/docs/changelog.html @@ -6,13 +6,13 @@ Changelog (abbreviated) | Shuffle.js - +

Changelog (abbreviated)

For a more detailed changelog, visit the latest releases on GitHub.

  • v6.1.0 2022-07-07 - Add sideEffects: false and exports-map to the package.json.
  • v6.0.0 2022-02-14 - Drop IE 11, remove misspelled delimeter option, remove matches-selector package.
  • v5.4.1 2021-05-29 - Add sortedItems property. Fix getComputedStyle bug for Chrome on Windows.
  • v5.3.0 2021-03-23 - Add isRTL option.
  • v5.2.3 2019-08-29 - Add missing inherited methods from TinyEmitter to TypeScript definitions.
  • v5.2.2 2019-06-03 - Update TypeScript definitions.
  • v5.2.1 2018-12-01 - Change `index.d.ts` to use `export default Shuffle` (#214). Upgrade dev dependencies.
  • v5.2.0 2018-08-19 - Lazily test whether the browser's getComputedStyle includes padding. This allows the bundled file to be imported in node for server side rendering.
  • v5.1.2 2018-03-26 - Fix misspelled delimiter option. Both "delimiter" and "delimeter" will continue to work for v5.
  • v5.1.1 2018-03-02 - Fix new item animation when there is an active filter.
  • v5.1.0 2018-02-20 - Add compare option to sorter. Add es build to package and "module" field to package.json.
  • v5.0.3 2017-10-30 - Fix rounding error.
  • v5.0.2 2017-09-23 - Update type definitions. Upgrade dev dependencies.
  • v5.0.1 2017-07-18 - Add roundTransforms option.
  • v5.0.0 2017-07-18 - Change global export from shuffle to Shuffle. Remove bower support. Expect ES6 environment. Make Shuffle instances Event Emitters instead of dispatching CustomEvent.
  • v4.2.0 2017-05-10 - Replace webpack build with rollup. Replace jshint and jscs with eslint. Add filterMode option.
  • v4.1.1 2017-03-21 - the before styles for a ShuffleItem were not applied if the item didn’t move.
  • v4.1.0 2017-01-30 - Use webpack-2 to bundle Shuffle.
  • v4.0.2 2016-09-15 - Update custom-event-polyfill dependency.
  • v4.0.1 2016-07-30 - Fix delimiter option.
  • v4.0.0 2016-04-20 - Rewrite in ES6 with babel. Remove jQuery and Modernizr dependencies. Remove support for IE<11. Docs improvements. Switch to gulp build system with webpack.
  • v3.1.0 2015-03-23 - Allow zero speed option (#64) and cancel previous animations instead of ignoring new ones (#69). Handle non-integer columns better (#46)
  • v3.0.4 2015-02-16 - Publish to NPM.
  • v3.0.2 2015-01-21 - Remove from jQuery plugins directory.
  • v3.0.1 2014-12-29 - Add CommonJS support.
  • v3.0.0 2014-10-06 - Refactored with improvements, added unit tests, more documentation. Removed some triggered events.
  • v2.1.2 2014-06-01 - Use window.jQuery instead of window.$ to work better with noConflict. Fixed #25.
  • v2.1.1 2014-04-16 - Fix items with zero opacity overlapping visible ones in IE<10.
  • v2.1.0 2014-04-12 - Register with bower as shufflejs.
  • 2014-04-10 - Add AMD support.
  • 2014-04-08 - Separate Modernizr into its own file and custom Shuffle build.
  • 2014-03-08 - Add Bootstrap 3 demo. Fixed issue with percentage width items.
  • 2013-10-04 - Moved some Shuffle instance properties to constants. Converted from 4 to 2 space indentation. Added events enum and pulled out some strings to constants.
  • 2013-08-30 - Added animate-in demo.
  • v2.0.0 2013-07-05 - Shuffle 2.0 with masonry, adding and removing, and more.
  • 2012-11-03 - Replaced layout system with masonry. Items can now be different sizes! Added addtional examples.
  • 2012-10-24 - Better handling of grid item dimensions. Added a minimal markup page.
  • 2012-09-20 - Added destroy method
  • 2012-09-18 - Added sorting ability and made plugin responsive. Updated to Modernizr 2.6.2
  • 2012-07-21 - Rewrote plugin in more object oriented structure. Added custom events. Updated to Modernizr 2.6.1
  • 2012-07-03 - Removed dependency on the css file and now apply the css with javascript
- + \ No newline at end of file diff --git a/docs/column-widths.html b/docs/column-widths.html index 90132a41..d57fe749 100644 --- a/docs/column-widths.html +++ b/docs/column-widths.html @@ -6,13 +6,13 @@ How column widths work | Shuffle.js - +

How column widths work

There are 4 options for defining the width of the columns:

  1. Use a sizer element. This is the easiest way to specify column and gutter widths. Add the sizer element and make it 1 column wide. Shuffle will measure the width and margin-left of this sizer element each time the grid resizes. This is awesome for responsive or fluid grids where the width of a column is a percentage.

    const shuffleInstance = new Shuffle(element, {
    itemSelector: '.picture-item',
    sizer: '.js-shuffle-sizer',
    });
  2. Use a function. When a function is used, its first parameter will be the width of the shuffle element. You need to return the column width for shuffle to use (in pixels).

    const shuffleInstance = new Shuffle(element, {
    itemSelector: '.picture-item',
    columnWidth: (containerWidth) => 0.18 * containerWidth,
    });
  3. A number. This will explicitly set the column width to your number (in pixels).

    const shuffleInstance = new Shuffle(element, {
    itemSelector: '.picture-item',
    columnWidth: 200,
    });
  4. By default, shuffle will use the width of the first item to calculate the column width.

    const shuffleInstance = new Shuffle(element, {
    itemSelector: '.picture-item',
    });
- + \ No newline at end of file diff --git a/docs/configuration.html b/docs/configuration.html index b9e4b1f5..bec7006b 100644 --- a/docs/configuration.html +++ b/docs/configuration.html @@ -6,13 +6,13 @@ Configuring Shuffle | Shuffle.js - +
-

Configuring Shuffle

Here are the options you can change, as well as their defaults. The Shuffle.options property contains all the defaults.

No options need to be specified, but itemSelector should be used. Other common options to change are speed and sizer.

Options

buffer [number]

Default: 0

Useful for percentage based heights when they might not always be exactly the same (in pixels).

columnThreshold [number]

Default: 0.01

Reading the width of elements isn't precise enough and can cause columns to jump between values.

columnWidth [number | (conatinerWidth: number) => number]

Default: 0

A static number or function that returns a number which determines how wide the columns are (in pixels).

delimiter [string | null]

Default: null

A static number or function that returns a number which determines how wide the columns are (in pixels).

easing [string]

Default: 'cubic-bezier(0.4, 0.0, 0.2, 1)'

CSS easing function to use.

filterMode [Shuffle.FilterMode]

Default: Shuffle.FilterMode.ANY

Affects using an array with filter. e.g. filter(['one', 'two']). With "any", the element passes the test if any of its groups are in the array. With "all", the element only passes if all groups are in the array.

group [string]

Default: Shuffle.ALL_ITEMS ("all")

Initial filter group.

gutterWidth [number | (conatinerWidth: number) => number]

Default: 0

A static number or function that determines how wide the gutters between columns are (in pixels).

initialSort [SortOptions | null]

Default: null

Shuffle can be initialized with a sort object. It is the same object given to the sort method.

isCentered [boolean]

Default: false

Whether to center grid items in the row with the leftover space.

isRTL [boolean]

Default: false

Whether to align grid items to the right in the row.

itemSelector [string]

Default: '*'

Query selector to find Shuffle items. e.g. '.picture-item'.

roundTransforms [boolean]

Default: true

Whether to round pixel values used in translate(x, y). This usually avoids blurriness.

sizer [HTMLElement | string | null]

Default: null

Element or selector string. Use an element to determine the size of columns and gutters.

speed [number]

Default: 250

Transition/animation speed (milliseconds).

staggerAmount [number]

Default: 15

Transition delay offset for each item in milliseconds.

staggerAmountMax [number]

Default: 150

Maximum stagger delay in milliseconds. This caps the stagger amount so that it does not exceed the given value. Since the transition delay is incremented for each item in the grid, this is useful for large grids of items.

useTransforms [boolean]

Default: false

Whether to use absolute positioning instead of transforms.

Sorting object

by [(element: HTMLElement) => any]

Default: null

Sorting function which gives you the element each shuffle item is using by default.

Returning undefined from the by function will reset the order to DOM order.

compare [(a: Shuffle.ShuffleItem, b: Shuffle.ShuffleItem) => number]

Default: null

Instead of using the simple by function, you can use the compare function provide a completely custom sorting function.

tip

See Advanced sorting for usage.

key [keyof Shuffle.ShuffleItem]

Default: 'element'

Determines which property of the ShuffleItem instance is passed to the by function.

randomize [boolean]

Default: false

If true, this will skip the sorting and return a randomized order in the array.

reverse [boolean]

Default: false

Use array.reverse() to reverse the results of your sort.

- +

Configuring Shuffle

Here are the options you can change, as well as their defaults. The Shuffle.options property contains all the defaults.

No options need to be specified, but itemSelector should be used. Other common options to change are speed and sizer.

Options

buffer [number]

Default: 0

Useful for percentage based heights when they might not always be exactly the same (in pixels).

columnThreshold [number]

Default: 0.01

Reading the width of elements isn't precise enough and can cause columns to jump between values.

columnWidth [number | (conatinerWidth: number) => number]

Default: 0

A static number or function that returns a number which determines how wide the columns are (in pixels).

delimiter [string | null]

Default: null

Set a delimiter to parse the data-groups attribute with using String.prototype.split(), instead of using JSON.parse(). For example, if your HTML was data-groups="nature,city", you could set delimiter: ','.

easing [string]

Default: 'cubic-bezier(0.4, 0.0, 0.2, 1)'

CSS easing function to use.

filterMode [Shuffle.FilterMode]

Default: Shuffle.FilterMode.ANY

Affects using an array with filter. e.g. filter(['one', 'two']). With "any", the element passes the test if any of its groups are in the array. With "all", the element only passes if all groups are in the array.

group [string]

Default: Shuffle.ALL_ITEMS ("all")

Initial filter group.

gutterWidth [number | (conatinerWidth: number) => number]

Default: 0

A static number or function that determines how wide the gutters between columns are (in pixels).

initialSort [SortOptions | null]

Default: null

Shuffle can be initialized with a sort object. It is the same object given to the sort method.

isCentered [boolean]

Default: false

Whether to center grid items in the row with the leftover space.

isRTL [boolean]

Default: false

Whether to align grid items to the right in the row.

itemSelector [string]

Default: '*'

Query selector to find Shuffle items. e.g. '.picture-item'.

roundTransforms [boolean]

Default: true

Whether to round pixel values used in translate(x, y). This usually avoids blurriness.

sizer [HTMLElement | string | null]

Default: null

Element or selector string. Use an element to determine the size of columns and gutters.

speed [number]

Default: 250

Transition/animation speed (milliseconds).

staggerAmount [number]

Default: 15

Transition delay offset for each item in milliseconds.

staggerAmountMax [number]

Default: 150

Maximum stagger delay in milliseconds. This caps the stagger amount so that it does not exceed the given value. Since the transition delay is incremented for each item in the grid, this is useful for large grids of items.

useTransforms [boolean]

Default: false

Whether to use absolute positioning instead of transforms.

Sorting object

by [(element: HTMLElement) => any]

Default: null

Sorting function which gives you the element each shuffle item is using by default.

Returning undefined from the by function will reset the order to DOM order.

compare [(a: Shuffle.ShuffleItem, b: Shuffle.ShuffleItem) => number]

Default: null

Instead of using the simple by function, you can use the compare function provide a completely custom sorting function.

tip

See Advanced sorting for usage.

key [keyof Shuffle.ShuffleItem]

Default: 'element'

Determines which property of the ShuffleItem instance is passed to the by function.

randomize [boolean]

Default: false

If true, this will skip the sorting and return a randomized order in the array.

reverse [boolean]

Default: false

Use array.reverse() to reverse the results of your sort.

+ \ No newline at end of file diff --git a/docs/custom-styles.html b/docs/custom-styles.html index 462590fb..1c76220d 100644 --- a/docs/custom-styles.html +++ b/docs/custom-styles.html @@ -6,13 +6,13 @@ Custom styles | Shuffle.js - +

Custom styles

You can customize the default styles which are applied to Shuffle items upon initialization, before layout, after layout, before hiding, and after hidden.

Here are the defaults:

ShuffleItem.Css = {
INITIAL: {
position: 'absolute',
top: 0,
visibility: 'visible',
willChange: 'transform',
},
DIRECTION: {
ltr: {
left: 0,
},
rtl: {
right: 0,
},
},
VISIBLE: {
before: {
opacity: 1,
visibility: 'visible',
},
after: {
transitionDelay: '',
},
},
HIDDEN: {
before: {
opacity: 0,
},
after: {
visibility: 'hidden',
transitionDelay: '',
},
},
};

ShuffleItem.Scale = {
VISIBLE: 1,
HIDDEN: 0.001,
};

If you wanted to add a 50% red background to every item when they initialize, you could do this:

Shuffle.ShuffleItem.Css.INITIAL.backgroundColor = 'rgba(255, 0, 0, 0.5)';

To set the text color to teal after the item has finished moving:

Shuffle.ShuffleItem.Css.VISIBLE.after.color = 'teal';

You can also customize the scaling effect with visible or hidden items.

Shuffle.ShuffleItem.Scale.HIDDEN = 0.5;
- + \ No newline at end of file diff --git a/docs/demos.html b/docs/demos.html index 7b6e01b3..12dba473 100644 --- a/docs/demos.html +++ b/docs/demos.html @@ -6,13 +6,13 @@ List of demos | Shuffle.js - + - + \ No newline at end of file diff --git a/docs/events.html b/docs/events.html index 508dcc39..7f64211a 100644 --- a/docs/events.html +++ b/docs/events.html @@ -6,13 +6,13 @@ Events | Shuffle.js - +

Events

Shuffle is a subclass of TinyEmitter. It emits an event when a layout happens and when elements are removed. The event names are Shuffle.EventType.LAYOUT and Shuffle.EventType.REMOVED.

Get notified when a layout happens

shuffleInstance.on(Shuffle.EventType.LAYOUT, () => {
console.log('Things finished moving!');
});

Do something when an item is removed

shuffleInstance.on(Shuffle.EventType.REMOVED, (data) => {
console.log(this, data, data.collection, data.shuffle);
});
tip

Check out the homepage demo. It adds these events and logs them to the console.

- + \ No newline at end of file diff --git a/docs/faqs.html b/docs/faqs.html index e54f3b97..cdc17954 100644 --- a/docs/faqs.html +++ b/docs/faqs.html @@ -6,13 +6,13 @@ FAQs | Shuffle.js - +

FAQs

Why Does Shuffle leave empty spaces?

The algorithm used to place items does not keep track of empty space nor try to fill them. If you require this functionality, I suggest packery.

Why are images overlapping?

If the size of your items are dependent on images, they can overlap if shuffle is initialized before all the images have loaded. Check out this demo to see how to fix it.

What’s the difference between Shuffle and Isotope?

Isotope:

  • more layout modes
  • more options
  • community of users
  • commercial use requires a license

Shuffle:

  • robust filtering
  • slightly smaller
  • responsive by default
  • sizer element (which packery also has)

They are very similar, but I think Shuffle's filtering and sorting are easier to customize, which is the main reason I created this library. Isotope has a much larger community, is battle-tested, and has many stackoverflow answers.

Padding isn’t working on the shuffle element

The padding is ignored by Shuffle because it creates complexities with absolute positioning the shuffle-items when they have a percentage width as well as setting the height of the shuffle container because of box-sizing. To fix this, wrap the shuffle element in another element which has the padding on it.

Can I center the layout?

Yes. Use the isCentered option.

It’s not working with Boostrap 4

Bootstrap 4 uses flexbox for grids, so your main shuffle container element must be a .row and the items inside the row (shuffle items) should all be columns. See the Bootstrap 4 grid demo.


Didn't find an answer?

Try browsing the CodePen collection or searching the issues on GitHub.

- + \ No newline at end of file diff --git a/docs/filters.html b/docs/filters.html index f48c0002..c2511299 100644 --- a/docs/filters.html +++ b/docs/filters.html @@ -6,13 +6,13 @@ Filters | Shuffle.js - +

Filters

Filter by a group

Use the filter() method. If, for example, you wanted to show only items that match "space", you would do this:

shuffleInstance.filter('space');

Filter by multiple groups

Show multiple groups at once by using an array.

shuffleInstance.filter(['space', 'nature']);

By default, this will show items that match space or nature. To show only groups that match space and nature, set the filterMode option to Shuffle.FilterMode.ALL.

Show all items

To go back to having no items filtered, you can call filter() without a parameter, or use Shuffle.ALL_ITEMS (which by default is the string "all").

shuffleInstance.filter(Shuffle.ALL_ITEMS); // or .filter()

Overrides

You can override both Shuffle.ALL_ITEMS and Shuffle.FILTER_ATTRIBUTE_KEY if you want.

// Defaults
Shuffle.ALL_ITEMS = 'all';
Shuffle.FILTER_ATTRIBUTE_KEY = 'groups';

// You can change them to something else.
Shuffle.ALL_ITEMS = 'any';
Shuffle.FILTER_ATTRIBUTE_KEY = 'categories';

Then you would have to use data-categories attribute on your items instead of data-groups.

- + \ No newline at end of file diff --git a/docs/getting-started.html b/docs/getting-started.html index e849b507..3aca9628 100644 --- a/docs/getting-started.html +++ b/docs/getting-started.html @@ -6,13 +6,13 @@ Getting started | Shuffle.js - +

Getting started

HTML markup

Shuffle operates on a group of items, giving you the ability to filter or sort them.

<div id="photo-gallery">
<div class="picture-item"></div>
<div class="picture-item"></div>
<div class="picture-item"></div>
<div class="picture-item"></div>
</div>

The easiest way to use Shuffle is to add a data-groups attribute to each of the items in your grid as a valid JSON array of strings.

<figure class="picture-item" data-groups='["nature","city"]'>
<img src="central-park.jpg" alt="Aerial view of Central Park" />
<figcaption>Looking down on central park and the surrounding builds from the Rockefellar Center</figcaption>
</figure>

Alternatively, you can set the delimiter option to a comma (delimiter: ',') and the data-groups attribute will be split on that character.

<figure class="picture-item" data-groups="nature,city">
<img src="central-park.jpg" alt="Aerial view of Central Park" />
<figcaption>Looking down on central park and the surrounding builds from the Rockefellar Center</figcaption>
</figure>

If you were using Bootstrap v4 grids, you could use the col-* classes like this.

<div class="row" id="photo-gallery">
<figure class="col-3 picture-item" data-groups='["animal"]'>
<div class="aspect">
<img src="crocodile.jpg" alt="A close, profile view of a crocodile looking directly into the camera" />
</div>
<figcaption>Crocodile</figcaption>
</figure>
<figure class="col-3 picture-item" data-groups='["city"]'>
<div class="aspect">
<img src="crossroads.jpg" alt="A multi-level highway stack interchange in Puxi, Shanghai" />
</div>
<figcaption>Crossroads</figcaption>
</figure>
<figure class="col-3 picture-item" data-groups='["nature","city"]'>
<div class="aspect">
<img
src="central-park.jpg"
alt="Looking down on central park and the surrounding builds from the Rockefellar Center"
/>
</div>
<figcaption>Central Park</figcaption>
</figure>
<div class="col-1 js-shuffle-sizer"></div>
</div>

JavaScript

Once the markup is ready, initialize Shuffle by giving it the container element and an optional options object.

const Shuffle = window.Shuffle; // Assumes you're using the UMD version of Shuffle (for example, from unpkg.com).
const element = document.getElementById('photo-gallery');
const sizer = element.querySelector('.js-shuffle-sizer');

const shuffleInstance = new Shuffle(element, {
itemSelector: '.picture-item',
sizer: sizer, // could also be a selector: '.js-shuffle-sizer'
});
- + \ No newline at end of file diff --git a/docs/install.html b/docs/install.html index a3ea22cb..a99c86eb 100644 --- a/docs/install.html +++ b/docs/install.html @@ -6,13 +6,13 @@ Installation | Shuffle.js - + - + \ No newline at end of file diff --git a/docs/sorting.html b/docs/sorting.html index e8ebfc70..c25daa01 100644 --- a/docs/sorting.html +++ b/docs/sorting.html @@ -6,13 +6,13 @@ Sorting | Shuffle.js - +

Sorting

You can order the elements with a function you supply. In the demo above, each item has a data-date-created and data-title attribute which are used for sorting.

<figure class="picture-item" data-groups='["city"]' data-date-created="2016-06-09" data-title="Crossroads"></figure>

<select class="sort-options">
<option value="">Default</option>
<option value="title">Title</option>
<option value="date-created">Date Created</option>
</select>
addSorting() {
document.querySelector('.sort-options').addEventListener('change', this._handleSortChange.bind(this));
}

_handleSortChange(event) {
const value = event.target.value;

function sortByDate(element) {
return element.dataset.created;
}

function sortByTitle(element) {
return element.dataset.title.toLowerCase();
}

let options;
if (value === 'date-created') {
options = {
reverse: true,
by: sortByDate,
};
} else if (value === 'title') {
options = {
by: sortByTitle,
};
} else {
options = {};
}

this.shuffle.sort(options);
}

The options object can contain three properties:

  • reverse: a boolean which will reverse the resulting order.
  • by: a function with an element as the parameter. Above, we’re returning the value of the data-date-created or data-title attribute.
  • randomize: Make the order random.

Returning undefined from the by function will reset the order to DOM order.

Calling sort with an empty object will reset the elements to DOM order.

tip

Check out the homepage demo.

Filter and sort

You can filter and sort at the same time by passing a sort object, which has the same shape as the sort function above, as the second parameter.

shuffleInstance.filter('space', {
by: (element) => {
return element.dataset.title.toLowerCase();
},
});

Advanced sorting

You can provide the entire sort compare function if you need more control.

The parameters (a, b) are ShuffleItem instances and you'll probably only use the element property. The reverse option still works with the compare function if you need it.

For example, if you wanted to sort by the first group in data-groups, then by data-age, you could do this:

shuffleInstance.sort({
compare: (a, b) => {
// Sort by first group, then by age.
const groupA = JSON.parse(a.element.dataset.groups)[0];
const groupB = JSON.parse(b.element.dataset.groups)[0];
if (groupA > groupB) {
return 1;
}
if (groupA < groupB) {
return -1;
}

// At this point, the group strings are the exact same. Test the age.
const ageA = parseInt(a.element.dataset.age, 10);
const ageB = parseInt(b.element.dataset.age, 10);
return ageA - ageB;
},
});
- + \ No newline at end of file diff --git a/docs/supported-browsers.html b/docs/supported-browsers.html index 08a5d4d4..ac1eed19 100644 --- a/docs/supported-browsers.html +++ b/docs/supported-browsers.html @@ -6,13 +6,13 @@ Supported browsers | Shuffle.js - +

Supported browsers

  • Chrome
  • Firefox
  • Edge
  • Safari

If you still need to support IE 11, you can use Shuffle v5. Did you know Microsoft 365 apps and services stopped supporting IE 11 in August 2021?

- + \ No newline at end of file diff --git a/index.html b/index.html index 89cfb673..821eb758 100644 --- a/index.html +++ b/index.html @@ -6,13 +6,13 @@ Home | Shuffle.js - +

Shuffle.js

Categorize, sort, and filter a responsive grid of items

Responsive design

Shuffle was built to make responsive design easy. Quickly update items in the grid by adding a class.

Powerful filters

Let your users find what they’re looking for with groups and custom filters.

Smooth animations

Transitions are all handled by the CSS, which lets the browser optimize them for the user’s device.

- + \ No newline at end of file