@charcoal-ui/react-sandbox 2.0.0-alpha.9 → 2.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +1814 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.modern.js +1707 -119
- package/dist/index.modern.js.map +1 -1
- package/dist/index.module.js +1766 -1
- package/dist/index.module.js.map +1 -1
- package/package.json +8 -8
- package/src/index.ts +0 -1
- package/dist/components/Spinner/index.d.ts +0 -15
- package/dist/components/Spinner/index.d.ts.map +0 -1
- package/dist/components/Spinner/index.story.d.ts +0 -10
- package/dist/components/Spinner/index.story.d.ts.map +0 -1
- package/src/components/Spinner/index.story.tsx +0 -47
- package/src/components/Spinner/index.tsx +0 -86
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,1815 @@
|
|
|
1
|
-
var e=require("react"),n=require("styled-components"),t=require("@charcoal-ui/react"),r=require("@charcoal-ui/utils"),o=require("@charcoal-ui/styled"),i=require("@charcoal-ui/foundation"),a=require("react-dom"),l=require("react-spring"),u=require("warning"),c=require("polished");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var f,s,p,m,h,v,x,g,b,y=/*#__PURE__*/d(e),w=/*#__PURE__*/d(n),E=/*#__PURE__*/d(a),k=/*#__PURE__*/d(u);function C(){return C=Object.assign||function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e},C.apply(this,arguments)}function L(e,n){if(null==e)return{};var t,r,o={},i=Object.keys(e);for(r=0;r<i.length;r++)n.indexOf(t=i[r])>=0||(o[t]=e[t]);return o}function z(e,n){return n||(n=e.slice(0)),e.raw=n,e}var R,T=["onClick","children","active","hover","reactive"],I=y.default.forwardRef(function(e,n){var t=e.active,r=void 0!==t&&t,o=e.reactive,i=void 0!==o&&o;/*#__PURE__*/return y.default.createElement(B,{active:r,reactive:i,hover:e.hover,onClick:r&&!i?void 0:e.onClick,ref:n},e.children)}),S=y.default.forwardRef(function(e,n){var t=e.active,r=void 0!==t&&t,o=e.reactive,i=void 0!==o&&o;/*#__PURE__*/return y.default.createElement(W,{active:r,reactive:i,hover:e.hover,onClick:r&&!i?void 0:e.onClick,ref:n,buttonWidth:e.width,buttonHeight:e.height},e.children)}),M=y.default.forwardRef(function(e,n){var r=e.onClick,o=e.children,i=e.active,a=void 0!==i&&i,l=e.hover,u=e.reactive,c=void 0!==u&&u,d=L(e,T),f=t.useComponentAbstraction().Link;return a&&!c?/*#__PURE__*/y.default.createElement(A,{active:!0,hover:l,ref:n},o):/*#__PURE__*/y.default.createElement(f,C({},d,{onClick:r}),/*#__PURE__*/y.default.createElement(A,{active:a,reactive:c,hover:l,ref:n},o))}),O=n.css(f||(f=z(["\n display: block;\n outline: none;\n border: none;\n padding: 9px 24px;\n font-size: 14px;\n line-height: 22px;\n font-weight: bold;\n border-radius: /* absurd radius, but ensures rounded corners */ 2000px;\n transition: color 0.2s;\n color: ",";\n cursor: pointer;\n user-select: none;\n background-color: transparent;\n\n &:hover {\n color: ",";\n }\n\n ","\n\n ","\n\n ","\n\n @media "," {\n padding: 5px 16px;\n }\n"])),function(e){return e.theme.color.text3},function(e){return e.theme.color.text2},function(e){var t=e.hover;return void 0!==t&&t&&n.css(s||(s=z(["\n color: ",";\n "])),function(e){return e.theme.color.text2})},function(e){var t=e.active;return void 0!==t&&t&&n.css(p||(p=z(["\n background-color: ",";\n color: ",";\n "])),function(e){return e.theme.color.surface3},function(e){return e.theme.color.text2})},function(e){var t=e.active,r=e.reactive;return void 0!==t&&t&&!(void 0!==r&&r)&&n.css(m||(m=z(["\n cursor: default;\n "])))},function(e){return r.maxWidth(e.theme.breakpoint.screen1)}),N=n.css(h||(h=z(["\n padding: 0;\n\n @media "," {\n padding: 0;\n }\n"])),function(e){return r.maxWidth(e.theme.breakpoint.screen1)}),B=w.default.button(v||(v=z(["\n ","\n"])),O),A=w.default.span(x||(x=z(["\n ","\n"])),O),W=w.default(B)(g||(g=z(["\n ",";\n ","\n ","\n"])),N,function(e){return void 0!==e.buttonWidth&&"width: "+e.buttonWidth+"px;"},function(e){return void 0!==e.buttonHeight&&"height: "+e.buttonHeight+"px;"}),_=w.default.div(b||(b=z(["\n display: flex;\n"]))),U=o.createTheme(w.default);function H(e){var n=e.size,t=e.viewBoxSize;/*#__PURE__*/return y.default.createElement(j,{viewBox:"0 0 "+t+" "+t,size:void 0===n?24:n,currentColor:e.currentColor},/*#__PURE__*/y.default.createElement(G,{path:e.path,transform:e.transform,fillRule:e.fillRule,clipRule:e.clipRule}))}var P,j=w.default.svg(R||(R=z(["\n stroke: none;\n fill: ",";\n width: ","px;\n height: ","px;\n line-height: 0;\n font-size: 0;\n vertical-align: middle;\n"])),function(e){var n=e.currentColor;return void 0!==n&&n?"currentColor":e.theme.color.text2},function(e){return e.size},function(e){return e.size}),G=function(e){var n=e.path;return"string"==typeof n?/*#__PURE__*/y.default.createElement("path",{d:n,transform:e.transform,fillRule:e.fillRule,clipRule:e.clipRule}):/*#__PURE__*/y.default.createElement(y.default.Fragment,null,n)};function D(){/*#__PURE__*/return y.default.createElement(H,{viewBoxSize:16,size:16,currentColor:!0,path:/*#__PURE__*/y.default.createElement(y.default.Fragment,null,/*#__PURE__*/y.default.createElement("path",{d:"M8 16C3.58172 16 0 12.4183 0 8C0 3.58172 3.58172 0 8 0C12.4183 0 16 3.58172 16 8C16 12.4183 12.4183 16 8 16Z"}),/*#__PURE__*/y.default.createElement(ce,{d:"M14 8C14 11.3137 11.3137 14 8 14C4.68629 14 2 11.3137 2 8C2 4.68629 4.68629 2 8 2C11.3137 2 14 4.68629 14 8ZM8 6.25C8.69036 6.25 9.25 5.69036 9.25 5C9.25 4.30964 8.69036 3.75 8 3.75C7.30964 3.75 6.75 4.30964 6.75 5C6.75 5.69036 7.30964 6.25 8 6.25ZM7 7.75V11.25C7 11.8023 7.44772 12.25 8 12.25C8.55228 12.25 9 11.8023 9 11.25V7.75C9 7.19772 8.55228 6.75 8 6.75C7.44772 6.75 7 7.19772 7 7.75Z"}))})}var V,q,F,Z,X,Y,J,K,Q,$,ee,ne,te,re,oe,ie,ae,le,ue,ce=w.default.path(P||(P=z(["\n fill: ",";\n fill-rule: evenodd;\n"])),function(e){return e.theme.color.surface1}),de=w.default.div.attrs(function(e){return C({},e,function(e){switch(e){case"page":return{default:{horizontal:40,vertical:24},screen1:{horizontal:16,vertical:16}};case"section":return{default:{horizontal:16,vertical:16},screen1:{horizontal:16,vertical:16}}}}(e.context))})(V||(V=z(["\n ","\n\n @media "," {\n ","\n }\n\n display: flex;\n align-items: flex-start;\n ","\n"])),function(e){return U(function(n){return[n.bg.surface3,n.borderRadius(8),n.padding.vertical(e.default.vertical),n.padding.horizontal(e.default.horizontal)]})},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return U(function(n){return[n.padding.vertical(e.screen1.vertical),n.padding.horizontal(e.screen1.horizontal)]})},function(e){return"page"===e.context&&n.css(q||(q=z(["\n justify-content: center;\n "])))}),fe=w.default.div(F||(F=z(["\n display: flex;\n align-items: center;\n color: ",";\n height: 22px;\n margin: -4px 4px -4px 0;\n"])),function(e){return e.theme.color.text4}),se=w.default.p(Z||(Z=z(["\n ","\n margin: 0;\n"])),U(function(e){return[e.font.text2,e.typography(14)]})),pe=i.columnSystem(2,i.COLUMN_UNIT,i.GUTTER_UNIT)+i.GUTTER_UNIT,me=i.columnSystem(12,i.COLUMN_UNIT,i.GUTTER_UNIT);function he(){return ve(r.maxWidth(n.useTheme().breakpoint.screen1))}function ve(n){var t=e.useMemo(function(){return __TEST__?{matches:!1,addListener:function(){},removeListener:function(){}}:matchMedia(n)},[n]),r=e.useState(t.matches),o=r[0],i=r[1];t.matches!==o&&i(t.matches);var a=function(e){try{E.default.flushSync(function(){i(e.matches)})}catch(n){i(e.matches)}};return e.useLayoutEffect(function(){return t.addListener(a),i(t.matches),function(){t.removeListener(a)}},[t]),e.useDebugValue(n+": "+o.toString()),o}function xe(e){return null!==e?e.getBoundingClientRect():void 0}function ge(n,t){void 0===t&&(t=[]);var r=e.useReducer(function(e,n){return void 0===e||void 0===n?n:e.height===n.height&&e.width===n.width?e:n},void 0),o=r[0],i=r[1],a=e.useState(null),l=a[0],u=a[1];return e.useLayoutEffect(function(){if(null!==l){var e=new ResizeObserver(function(){var e=xe(l);i(e)});return e.observe(l),function(){e.unobserve(l),i(void 0)}}},[l]),e.useLayoutEffect(function(){n.current!==l&&u(n.current)}),e.useLayoutEffect(function(){t.length>0&&i(xe(n.current))},t),e.useDebugValue(o),o}var be,ye,we,Ee,ke,Ce,Le,ze,Re,Te,Ie,Se,Me,Oe=y.default.createContext({wide:!1,center:!1,withLeft:!1}),Ne=w.default.div(X||(X=z(["\n margin-bottom: 40px;\n overflow-x: auto;\n word-break: keep-all;\n\n @media "," {\n margin-bottom: 0;\n padding-left: 16px;\n padding-bottom: 16px;\n background-color: ",";\n }\n"])),function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.theme.color.surface2}),Be=n.createGlobalStyle(Y||(Y=z(["\n :root {\n background-color: ",";\n\n @media "," {\n background-color: ",";\n }\n }\n"])),function(e){return e.theme.color.background2},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.theme.color.background1}),Ae=w.default.div(J||(J=z(["\n display: flex;\n background-color: ",";\n\n @media "," {\n background-color: ",";\n }\n"])),function(e){return e.theme.color.background2},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.theme.color.background1}),We=w.default.div(K||(K=z(["\n min-width: ","px;\n padding: 40px 0 40px ","px;\n box-sizing: border-box;\n\n @media "," {\n display: none;\n }\n"])),pe,i.GUTTER_UNIT,function(e){return e.theme.breakpoint.screen3}),_e=w.default.div(Q||(Q=z(["\n flex-grow: 1;\n /* https://www.w3.org/TR/css-flexbox-1/#min-size-auto */\n min-width: 0;\n max-width: ","px;\n padding: 40px ","px;\n margin: 0 auto;\n display: flex;\n flex-direction: column;\n\n @media "," {\n padding: 0;\n }\n"])),function(e){return e.center?i.columnSystem(6,i.COLUMN_UNIT,i.GUTTER_UNIT):me},72,function(e){return r.maxWidth(e.theme.breakpoint.screen1)}),Ue=w.default.div($||($=z(["\n font-weight: bold;\n margin-bottom: 12px;\n font-size: 20px;\n line-height: 28px;\n color: ",";\n\n @media "," {\n margin-bottom: 0;\n padding: 12px;\n font-size: 16px;\n line-height: 24px;\n display: flex;\n justify-content: center;\n background-color: ",";\n }\n"])),function(e){return e.theme.color.text2},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.theme.color.surface2}),He=w.default.div(ee||(ee=z(["\n display: grid;\n gap: ","px;\n grid-template-columns: 1fr;\n grid-auto-columns: 1fr;\n grid-auto-rows: auto;\n\n @media "," {\n gap: 0;\n background-color: ",";\n padding-bottom: 60px;\n }\n"])),i.GUTTER_UNIT,function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.theme.color.background1}),Pe=y.default.forwardRef(function(n,t){var r=n.span,o=n.children,i=e.useContext(Oe);/*#__PURE__*/return y.default.createElement(je,{span:r,withLeft:i.withLeft,ref:t},o)}),je=w.default.div(ne||(ne=z(["\n grid-column-start: auto;\n grid-column-end: span ",";\n border-radius: 24px;\n color: ",";\n background-color: ",";\n /* https://www.w3.org/TR/css-grid-1/#min-size-auto */\n min-width: 0;\n\n @media "," {\n ","\n }\n\n @media "," {\n ","\n\n border-radius: 0;\n padding-bottom: 40px;\n }\n"])),function(e){return e.span},function(e){return e.theme.color.text2},function(e){return e.theme.color.background1},function(e){return e.withLeft?e.theme.breakpoint.screen4:e.theme.breakpoint.screen3},function(e){return e.span>2&&n.css(te||(te=z(["\n grid-column-end: span 2;\n "])))},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.span>1&&n.css(re||(re=z(["\n grid-column-end: span 1;\n "])))}),Ge=w.default.div(oe||(oe=z(["\n padding: 0 ","px;\n height: ","px;\n display: grid;\n align-items: center;\n font-size: 16px;\n line-height: 24px;\n font-weight: bold;\n background-color: ",";\n color: ",";\n border-radius: 24px 24px 0 0;\n ","\n\n @media "," {\n margin-top: 4px;\n padding: 0 16px;\n background: none;\n overflow-x: auto;\n border-radius: unset;\n ","\n }\n"])),function(e){return e.wide?40:24},function(e){return e.wide?64:48},function(e){return e.theme.color.surface2},function(e){return e.theme.color.text2},function(e){return e.center&&n.css(ie||(ie=z(["\n justify-content: center;\n "])))},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.wide&&n.css(ae||(ae=z(["\n height: 48px;\n margin-top: 0;\n "])))}),De={wide:{x:40,y:40},default:{x:24,y:24},column1:{x:16,y:16},narrow:{x:24,yTop:12,yBottom:20},narrowColumn1:{x:16,yTop:4,yBottom:0}},Ve=w.default.div(le||(le=z(["\n padding: ",";\n\n @media "," {\n padding: ",";\n }\n\n width: 100%;\n box-sizing: border-box;\n"])),function(e){return e.narrow?De.narrow.yTop+"px "+(e.horizontal?0:De.narrow.x)+"px "+De.narrow.yBottom+"px":e.wide?(e.horizontal?0:De.wide.y)+"px "+De.wide.x+"px":(e.horizontal?0:De.default.y)+"px "+De.default.x+"px"},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},function(e){return e.narrow?De.narrowColumn1.yTop+"px "+(e.horizontal?0:De.narrowColumn1.x)+"px "+De.narrowColumn1.yBottom+"px":De.column1.y+"px "+De.column1.x+"px 0"}),qe=w.default.div(ue||(ue=z(["\n margin: 0 -","px;\n margin-top: -","px;\n\n @media "," {\n margin: 0 -","px;\n margin-top: -","px;\n }\n"])),function(e){return e.wide?De.wide.x:De.default.x},function(e){var n=e.cancelTop;return void 0!==n&&n?e.wide?De.wide.y:De.default.y:0},function(e){return r.maxWidth(e.theme.breakpoint.screen1)},De.column1.x,function(e){var n=e.cancelTop;return void 0!==n&&n?De.column1.x:0}),Fe=function(n){return e.isValidElement(n)&&Boolean(n.props.children)},Ze=function(e){return null==e||"boolean"==typeof e||"{}"===JSON.stringify(e)?"":e.toString()},Xe=function n(t){return Array.isArray(t)||e.isValidElement(t)?e.Children.toArray(t).reduce(function(t,r){var o;return o=e.isValidElement(r)&&Fe(r)?n(r.props.children):e.isValidElement(r)&&!Fe(r)?"":Ze(r),t.concat(o)},""):Ze(t)},Ye=w.default.div.attrs(function(e){var n=e.title,t=void 0===n?Xe(e.children):n;return{title:""!==t?t:void 0}})(be||(be=z(["\n overflow: hidden;\n line-height: ","px;\n /* For english */\n overflow-wrap: break-word;\n\n ","\n"])),function(e){return e.lineHeight},function(e){var t=e.lineLimit,r=void 0===t?1:t,o=e.lineHeight;return 1===r?n.css(ye||(ye=z(["\n text-overflow: ellipsis;\n white-space: nowrap;\n "]))):n.css(we||(we=z(["\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: ",";\n /* Fallback for -webkit-line-clamp */\n max-height: ","px;\n "])),r,o*r)}),Je=["link","onClick","disabled","primary","secondary","gtmClass","noHover","children"],Ke=["icon","primary"],Qe=["icon","primary"],$e=y.default.createContext({padding:24});function en(n){var t=n.primary,r=n.secondary,o=n.onClick,i=n.disabled,a=void 0!==i&&i,l=n.noHover,u=void 0!==l&&l,c=n.gtmClass,d=n.children,f=e.useContext($e);/*#__PURE__*/return y.default.createElement(nn,{hasSubLabel:void 0!==r,onClick:function(e){return!a&&o&&o(e)},sidePadding:f.padding,noHover:u,noClick:void 0===o,"aria-disabled":a,role:void 0!==o?"button":void 0,className:void 0!==c?"gtm-"+c:void 0},/*#__PURE__*/y.default.createElement(tn,null,/*#__PURE__*/y.default.createElement(rn,null,/*#__PURE__*/y.default.createElement(Ye,{lineHeight:22,lineLimit:1},t)),void 0!==r&&/*#__PURE__*/y.default.createElement(on,null,/*#__PURE__*/y.default.createElement(Ye,{lineHeight:22,lineLimit:1},r))),d)}var nn=w.default.div(Ee||(Ee=z(["\n display: flex;\n height: ","px;\n align-items: center;\n justify-content: space-between;\n padding: 0 ","px;\n user-select: none;\n cursor: ",";\n transition: 0.2s background-color;\n\n &:hover {\n ","\n }\n\n ","\n\n "," {\n cursor: default;\n pointer-events: none;\n\n &:hover {\n background-color: unset;\n }\n }\n"])),function(e){return e.hasSubLabel?56:40},function(e){return e.sidePadding},function(e){return e.noClick?"default":"pointer"},function(e){return!e.noHover&&n.css(ke||(ke=z(["\n background-color: ",";\n "])),function(e){return e.theme.color.surface3})},U(function(e){return e.disabled}),r.disabledSelector),tn=w.default.div(Ce||(Ce=z(["\n display: flex;\n flex-direction: column;\n"]))),rn=w.default.div(Le||(Le=z(["\n color: ",";\n line-height: 22px;\n font-size: 14px;\n display: grid;\n"])),function(e){return e.theme.color.text2}),on=w.default.div(ze||(ze=z(["\n color: ",";\n line-height: 18px;\n font-size: 10px;\n"])),function(e){return e.theme.color.text3});function an(e){var n=e.link,r=e.onClick,o=e.disabled,i=void 0!==o&&o,a=e.primary,l=e.secondary,u=e.gtmClass,c=e.noHover,d=e.children,f=L(e,Je),s=t.useComponentAbstraction().Link,p={disabled:i,primary:a,secondary:l,gtmClass:u,noHover:c,children:d};return i?/*#__PURE__*/y.default.createElement("span",{onClick:r},/*#__PURE__*/y.default.createElement(en,p)):/*#__PURE__*/y.default.createElement(On,C({as:s,to:n,onClick:r},f),/*#__PURE__*/y.default.createElement(en,C({onClick:function(){}},p)))}var ln,un,cn,dn,fn,sn,pn,mn,hn,vn,xn,gn,bn,yn,wn,En,kn,Cn,Ln,zn,Rn,Tn,In,Sn,Mn,On=w.default.a(Re||(Re=z(["\n display: block;\n"]))),Nn=w.default.div(Te||(Te=z(["\n display: grid;\n gap: 8px;\n grid-auto-flow: column;\n align-items: center;\n"]))),Bn=w.default.div(Ie||(Ie=z(["\n color: ",";\n display: flex;\n"])),function(e){return e.theme.color.text3}),An=w.default.div(Se||(Se=z(["\n height: 24px;\n"]))),Wn=w.default.div(Me||(Me=z(["\n padding: 0 16px;\n font-size: 12px;\n line-height: 16px;\n color: ",";\n margin-top: -2px;\n margin-bottom: 6px;\n"])),function(e){return e.theme.color.text3}),_n=w.default.div(ln||(ln=z(["\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n"]))),Un=w.default.div(un||(un=z(["\n display: flex;\n align-items: center;\n color: ",";\n border-radius: 24px;\n font-weight: bold;\n font-size: 14px;\n line-height: 22px;\n padding: 0 16px;\n height: 40px;\n transition: 0.2s color;\n &:hover {\n transition: 0.2s color;\n color: ",";\n }\n &[aria-current] {\n color: ",";\n background-color: ",";\n }\n"])),function(e){return e.theme.color.text3},function(e){return e.theme.color.text2},function(e){return e.theme.color.text2},function(e){return e.theme.color.surface3}),Hn=["gtmClass","flex","rowReverse","children","disabled"],Pn=y.default.forwardRef(function(e,n){var t=e.gtmClass,r=e.flex,o=void 0!==r&&r,i=e.rowReverse,a=void 0!==i&&i,l=e.children,u=e.disabled,c=L(e,Hn);/*#__PURE__*/return y.default.createElement(Gn,{className:void 0!==t?"gtm-"+t:"",flex:o,rowReverse:a,"aria-disabled":u},/*#__PURE__*/y.default.createElement(Dn,null,/*#__PURE__*/y.default.createElement(Fn,C({},c,{disabled:u,ref:n})),/*#__PURE__*/y.default.createElement(Vn,null,/*#__PURE__*/y.default.createElement(qn,null))),null!=l&&/*#__PURE__*/y.default.createElement(jn,{rowReverse:a},l))}),jn=w.default.span(cn||(cn=z(["\n ","\n"])),function(e){return n.css(e.rowReverse?dn||(dn=z(["\n margin-right: 8px;\n "])):fn||(fn=z(["\n margin-left: 8px;\n "])))}),Gn=w.default.label(sn||(sn=z(["\n display: inline-flex;\n align-items: center;\n ","\n ","\n cursor: pointer;\n outline: 0;\n\n &[aria-disabled='true'] {\n cursor: auto;\n }\n"])),function(e){return e.flex&&n.css(pn||(pn=z(["\n display: flex;\n justify-content: space-between;\n "])))},function(e){var t=e.rowReverse;return n.css(mn||(mn=z(["\n flex-direction: ",";\n "])),t?"row-reverse":"row")}),Dn=w.default.span(hn||(hn=z(["\n display: inline-flex;\n position: relative;\n z-index: 0;\n"]))),Vn=w.default.div(vn||(vn=z(["\n position: relative;\n box-sizing: border-box;\n width: 28px;\n height: 16px;\n border-radius: 16px;\n border: 2px solid transparent;\n background: ",";\n transition: box-shadow 0.2s, background-color 0.2s;\n"])),function(e){return e.theme.color.text4}),qn=w.default.div(xn||(xn=z(["\n position: absolute;\n display: block;\n top: 0;\n left: 0;\n width: 12px;\n height: 12px;\n background-color: ",";\n border-radius: 50%;\n transform: translateX(0);\n transition: transform 0.2s;\n"])),function(e){return e.theme.color.text5}),Fn=w.default.input.attrs({type:"checkbox"})(gn||(gn=z(["\n position: absolute;\n /* NOTE: this is contained by the GraphicCheckboxOuter */\n z-index: 1;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n /* just to control the clickable area if used standalone */\n border-radius: 16px;\n opacity: 0;\n appearance: none;\n outline: none;\n cursor: pointer;\n\n &:checked {\n ~ "," {\n background-color: ",";\n\n "," {\n transform: translateX(12px);\n }\n }\n }\n\n &:disabled {\n cursor: auto;\n\n ~ "," {\n opacity: ",";\n }\n }\n\n &:not(:disabled):focus {\n ~ "," {\n box-shadow: 0 0 0 4px\n ",";\n }\n }\n"])),Vn,function(e){return e.theme.color.brand},qn,Vn,function(e){return e.theme.elementEffect.disabled.opacity},Vn,function(e){var n=e.theme;return r.applyEffect(n.color.brand,n.elementEffect.disabled)}),Zn=y.default.memo(function(e){var n=e.children,t=e.icon,r=e.show,o=void 0===r||r,i=e.prefix,a=void 0!==i&&i,l=e.width,u=e.fit,c=e.fixed,d=void 0!==c&&c,f=void 0!==u&&u?void 0===l?/*#__PURE__*/y.default.createElement(Jn,{show:o,pre:a},t):/*#__PURE__*/y.default.createElement(ct,{width:l,show:o,pre:a},/*#__PURE__*/y.default.createElement(dt,null,t)):/*#__PURE__*/y.default.createElement(lt,{show:o,pre:a},/*#__PURE__*/y.default.createElement(ut,null,t));/*#__PURE__*/return y.default.createElement(Xn,null,a&&f,/*#__PURE__*/y.default.createElement(Yn,{fixed:d},n),!a&&f)}),Xn=w.default.div(bn||(bn=z(["\n display: flex;\n align-items: center;\n"]))),Yn=w.default.div(yn||(yn=z(["\n ","\n white-space: nowrap;\n text-overflow: ellipsis;\n"])),function(e){return!e.fixed&&n.css(wn||(wn=z(["\n min-width: 0;\n overflow: hidden;\n "])))});function Jn(n){var t,r,o=n.children,i=n.show,a=n.pre,l=e.useRef(null),u=null!=(t=null==(r=ge(l,[null]))?void 0:r.width)?t:0;/*#__PURE__*/return y.default.createElement(ct,{width:u,show:i,pre:a},/*#__PURE__*/y.default.createElement(dt,{ref:l},o))}var Kn,Qn,$n,et,nt,tt,rt,ot,it=n.css(En||(En=z(["\n > svg {\n display: block;\n }\n"]))),at=n.css(kn||(kn=z(["\n ",";\n ","\n"])),function(e){return"collapse"===e.show?n.css(Cn||(Cn=z(["\n display: none;\n "]))):n.css(Ln||(Ln=z(["\n visibility: ",";\n "])),e.show?"visible":"hidden")},function(e){return n.css(e.pre?zn||(zn=z(["\n margin-right: 4px;\n "])):Rn||(Rn=z(["\n margin-left: 4px;\n "])))}),lt=w.default.div(Tn||(Tn=z(["\n display: flex;\n align-items: center;\n\n ","\n"])),at),ut=w.default.div(In||(In=z(["\n display: inline-flex;\n\n ","\n"])),it),ct=w.default.div(Sn||(Sn=z(["\n display: flex;\n position: relative;\n /* Iconをline-heightに関与させない */\n height: 0;\n /* 横方向の領域は確保する */\n width: ","px;\n\n ","\n"])),function(e){return e.width},at),dt=w.default.div(Mn||(Mn=z(["\n display: inline-flex;\n position: absolute;\n transform: translateY(-50%);\n\n ","\n"])),it);function ft(e){throw new Error(0===arguments.length?"unreachable":"unreachable ("+JSON.stringify(e)+")")}function st(e){var n=function(e){switch(e){case Qn.Up:return"rotate(270 12 12)";case Qn.Down:return"rotate(90 12 12)";case Qn.Left:return"rotate(180 12 12)";case Qn.Right:return;default:return ft(e)}}(e.direction);/*#__PURE__*/return y.default.createElement(H,{viewBoxSize:24,size:24,currentColor:!0,path:"M8.08579 16.5858C7.30474 17.3668 7.30474 18.6332 8.08579 19.4142C8.86684 20.1953 10.1332 20.1953 10.9142 19.4142L18.3284 12L10.9142 4.58579C10.1332 3.80474 8.86684 3.80474 8.08579 4.58579C7.30474 5.36684 7.30474 6.63317 8.08579 7.41421L12.6716 12L8.08579 16.5858Z",transform:n})}function pt(e){var n=e.direction,t=e.show,r=e.offset,o=void 0===r?0:r,i=e.padding,a=void 0===i?0:i,l=e.bottomOffset,u=void 0===l?0:l,c=e.gradient,d=void 0!==c&&c,f=e.onClick,s=n===ot.Left?{left:d?o-72:o,paddingLeft:Math.max(a,0),paddingBottom:u}:{right:d?o-72:o,paddingRight:Math.max(a,0),paddingBottom:u};/*#__PURE__*/return y.default.createElement(ht,{type:"button",onClick:f,hide:!t,style:s,css:Rt},/*#__PURE__*/y.default.createElement(mt,null,/*#__PURE__*/y.default.createElement(st,{direction:n===ot.Right?Qn.Right:n===ot.Left?Qn.Left:ft()})))}!function(e){e.Up="up",e.Down="down",e.Left="left",e.Right="right"}(Qn||(Qn={})),function(e){e.Right="right",e.Left="left"}(ot||(ot={}));var mt=w.default.div($n||($n=z(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: ","px;\n height: ","px;\n border-radius: 50%;\n background-color: ",";\n transition: 0.4s visibility, 0.4s opacity, 0.2s background-color, 0.2s color;\n color: ",";\n"])),40,40,function(e){return e.theme.color.surface4},function(e){return e.theme.color.text5}),ht=w.default.button(et||(et=z(["\n position: absolute;\n top: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n padding: 0;\n min-width: 40px;\n border: none;\n outline: 0;\n background: transparent;\n cursor: pointer;\n transition: 0.4s visibility, 0.4s opacity;\n /* つらい */\n /* このコンポーネントはCarouselでしか使われてないのでそっちでコンテキストで切る */\n z-index: 1;\n\n &:hover "," {\n background-color: ",";\n color: ",";\n }\n\n &:active "," {\n background-color: ",";\n color: ",";\n }\n\n ","\n"])),mt,function(e){var n=e.theme;return r.applyEffect(n.color.surface4,n.effect.hover)},function(e){var n=e.theme;return r.applyEffect(n.color.text5,n.effect.hover)},mt,function(e){var n=e.theme;return r.applyEffect(n.color.surface4,n.effect.press)},function(e){var n=e.theme;return r.applyEffect(n.color.text5,n.effect.press)},function(e){return e.hide&&n.css(nt||(nt=z(["\n visibility: hidden;\n opacity: 0;\n pointer-events: none;\n "])))});w.default(mt)(tt||(tt=z(["\n cursor: pointer;\n\n &:hover {\n background-color: ",";\n color: ",";\n }\n\n &:active {\n background-color: ",";\n color: ",";\n }\n"])),function(e){var n=e.theme;return r.applyEffect(n.color.surface4,n.effect.hover)},function(e){var n=e.theme;return r.applyEffect(n.color.text5,n.effect.hover)},function(e){var n=e.theme;return r.applyEffect(n.color.surface4,n.effect.press)},function(e){var n=e.theme;return r.applyEffect(n.color.text5,n.effect.press)});var vt,xt,gt,bt,yt,wt,Et,kt,Ct,Lt,zt,Rt=n.css(rt||(rt=z(["\n @media (hover: none) and (pointer: coarse) {\n display: none;\n }\n"]))),Tt=["buttonOffset","buttonPadding","bottomOffset","defaultScroll","onScroll","onResize","children","centerItems","onScrollStateChange","scrollAmountCoef"],It=w.default.ul(vt||(vt=z(["\n vertical-align: top;\n overflow: hidden;\n list-style: none;\n padding: 0;\n\n /* 最小幅を100%にして親要素にぴったりくっつけることで子要素で要素を均等に割り付けるなどを出来るようにしてある */\n min-width: 100%;\n box-sizing: border-box;\n\n ","\n"])),function(e){var t=e.centerItems;return n.css(void 0!==t&&t?xt||(xt=z(["\n display: flex;\n width: max-content;\n margin: 0 auto;\n "])):gt||(gt=z(["\n display: inline-flex;\n margin: 0;\n "])))}),St=w.default.div(bt||(bt=z(["\n opacity: 0;\n transition: 0.4s opacity;\n"]))),Mt=w.default.div(yt||(yt=z(["\n &:hover "," {\n opacity: 1;\n }\n\n /* CarouselButtonの中にz-index:1があるのでここでコンテキストを切る */\n position: relative;\n z-index: 0;\n"])),St),Ot=w.default(l.animated.div)(wt||(wt=z(["\n overflow-x: auto;\n padding: 0;\n margin: 0;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n scrollbar-width: none;\n"]))),Nt=w.default.div(Et||(Et=z(["\n /* NOTE: LeftGradientがはみ出るためhidden */\n overflow: hidden;\n ","\n\n margin-right: ","px;\n /* stylelint-disable-next-line no-duplicate-selectors */\n "," {\n padding-right: ","px;\n }\n"])),function(e){return!e.fadeInGradient&&n.css(kt||(kt=z(["\n margin-left: ","px;\n "," {\n padding-left: ","px;\n }\n "])),-72,It,72)},-72,It,72),Bt=w.default.div(Ct||(Ct=z(["\n mask-image: linear-gradient(\n to right,\n #000 calc(100% - ","px),\n transparent\n );\n"])),72),At=w.default.div(Lt||(Lt=z(["\n /* NOTE: mask-position が left → negative px の時、right → abs(negative px) の位置に表示されるため */\n margin-right: ","px;\n padding-right: ","px;\n /* NOTE: mask-position に transition をつけたいが vender prefixes 対策で all につける */\n transition: 0.2s all ease-in;\n mask: linear-gradient(to right, transparent, #000 ","px)\n ","px 0;\n"])),-72,72,72,function(e){return e.show?0:-72});function Wt(e){var n=e.size;/*#__PURE__*/return y.default.createElement(Ht,{viewBox:"0 0 20 6",width:n,height:n},/*#__PURE__*/y.default.createElement("path",{fillRule:"evenodd",d:"M5,14.5 C3.61928813,14.5 2.5,13.3807119 2.5,12 C2.5,10.6192881 3.61928813,9.5 5,9.5\n C6.38071187,9.5 7.5,10.6192881 7.5,12 C7.5,13.3807119 6.38071187,14.5 5,14.5 Z M12,14.5\n C10.6192881,14.5 9.5,13.3807119 9.5,12 C9.5,10.6192881 10.6192881,9.5 12,9.5\n C13.3807119,9.5 14.5,10.6192881 14.5,12 C14.5,13.3807119 13.3807119,14.5 12,14.5 Z M19,14.5\n C17.6192881,14.5 16.5,13.3807119 16.5,12 C16.5,10.6192881 17.6192881,9.5 19,9.5\n C20.3807119,9.5 21.5,10.6192881 21.5,12 C21.5,13.3807119 20.3807119,14.5 19,14.5 Z",transform:"translate(-2 -9)"}))}Wt.defaultProps={size:16};var _t,Ut,Ht=w.default.svg(zt||(zt=z(["\n fill: currentColor;\n"])));function Pt(e){var n=e.size;/*#__PURE__*/return y.default.createElement("svg",{viewBox:"0 0 10 8",width:n,height:n},/*#__PURE__*/y.default.createElement(Ft,{strokeWidth:"2",points:"1,2 5,6 9,2",transform:jt(e.direction)}))}function jt(e){switch(e){case Ut.Up:return"rotate(180 5 4)";case Ut.Down:return;case Ut.Left:return"rotate(90 5 4)";case Ut.Right:return"rotate(-90 5 4)";default:return ft(e)}}!function(e){e.Up="up",e.Down="down",e.Left="left",e.Right="right"}(Ut||(Ut={})),Pt.defaultProps={size:16,white:!1,lightGray:!1};var Gt,Dt,Vt,qt,Ft=w.default.polyline(_t||(_t=z(["\n fill: none;\n stroke-linejoin: round;\n stroke-linecap: round;\n stroke: currentColor;\n"])));function Zt(n,t,r){void 0===r&&(r=7),"production"!==process.env.NODE_ENV&&(k.default((0|n)===n,"`page` must be interger ("+n+")"),k.default((0|t)===t,"`pageCount` must be interger ("+t+")"));var o=e.useMemo(function(){var e=1,o=Math.min(t,Math.max(n+Math.floor(r/2),r));if(o<=r)return Array.from({length:1+o-e},function(n,t){return e+t});var i=o-(r-1)+2;return[e,"..."].concat(Array.from({length:1+o-i},function(e,n){return i+n}))},[n,t,r]);return e.useDebugValue(o),o}var Xt,Yt,Jt,Kt=y.default.memo(function(n){var t=n.page,r=n.pageCount,o=n.onChange,i=Zt(t,r),a=e.useCallback(function(e){return function(){o(e)}},[o]),l=t<r,u=t>1;/*#__PURE__*/return y.default.createElement(Qt,null,/*#__PURE__*/y.default.createElement($t,{type:"button",hidden:!u,disabled:!u,onClick:a(Math.max(1,t-1)),noBackground:!0},/*#__PURE__*/y.default.createElement(Pt,{size:16,direction:Ut.Left})),i.map(function(e){return"..."===e?/*#__PURE__*/y.default.createElement(er,{key:e},/*#__PURE__*/y.default.createElement(Wt,{size:20})):/*#__PURE__*/y.default.createElement($t,e===t?{key:e,type:"button","aria-current":!0}:{key:e,type:"button",onClick:a(e)},/*#__PURE__*/y.default.createElement(nr,null,e))}),/*#__PURE__*/y.default.createElement($t,{type:"button",hidden:!l,disabled:!l,onClick:a(Math.min(r,t+1)),noBackground:!0},/*#__PURE__*/y.default.createElement(Pt,{size:16,direction:Ut.Right})))}),Qt=w.default.nav(Gt||(Gt=z(["\n display: flex;\n justify-content: center;\n align-items: center;\n"]))),$t=w.default.button(Dt||(Dt=z(["\n font-size: 1rem;\n line-height: calc(1em + 8px);\n text-decoration: none;\n border: none;\n outline: none;\n touch-action: manipulation;\n user-select: none;\n transition: box-shadow 0.2s ease 0s, color 0.2s ease 0s,\n background 0.2s ease 0s, opacity 0.2s ease 0s;\n\n display: flex;\n justify-content: center;\n align-items: center;\n box-sizing: content-box;\n min-width: 24px;\n min-height: 24px;\n padding: 8px;\n cursor: pointer;\n font-weight: bold;\n /* HACK:\n * Safari doesn't correctly repaint the elements when they're reordered in response to interaction.\n * This forces it to repaint them. This doesn't work if put on the parents either, has to be here.\n */\n /* stylelint-disable-next-line property-no-vendor-prefix */\n -webkit-transform: translateZ(0);\n\n &[hidden] {\n visibility: hidden;\n display: block;\n }\n\n border-radius: 48px;\n\n background: transparent;\n color: ",";\n\n &:hover {\n background: ",";\n color: ",";\n }\n\n &[aria-current] {\n background-color: ",";\n color: ",";\n }\n\n &[aria-current]:hover {\n background-color: ",";\n color: ",";\n }\n\n ","\n"])),function(e){return e.theme.color.text3},function(e){return e.theme.color.surface3},function(e){return e.theme.color.text2},function(e){return e.theme.color.surface6},function(e){return e.theme.color.text5},function(e){return e.theme.color.surface6},function(e){return e.theme.color.text5},function(e){var t=e.noBackground;return void 0!==t&&t&&n.css(Vt||(Vt=z(["\n /* stylelint-disable-next-line no-duplicate-selectors */\n &:hover {\n background: transparent;\n }\n "])))}),er=w.default($t).attrs({type:"button",disabled:!0})(qt||(qt=z(["\n && {\n color: ",";\n background: none;\n }\n"])),function(e){return e.theme.color.text3}),nr="span",tr=w.default.div.attrs({role:"progressbar"})(Xt||(Xt=z(["\n margin: auto;\n padding: ","px;\n border-radius: 8px;\n font-size: ","px;\n width: ","px;\n height: ","px;\n background-color: ",";\n color: ",";\n"])),function(e){return e.padding},function(e){return e.size},function(e){return e.size},function(e){return e.size},function(e){return e.transparent?"transparent":c.transparentize(.32,e.theme.color.background1)},function(e){return e.theme.color.text4}),rr=n.keyframes(Yt||(Yt=z(["\n from {\n transform: scale(0);\n opacity: 1;\n }\n\n to {\n transform: scale(1);\n opacity: 0;\n }\n"]))),or=w.default.div.attrs({role:"presentation"})(Jt||(Jt=z(["\n width: 1em;\n height: 1em;\n border-radius: 1em;\n background-color: currentColor;\n animation: "," 1s both ease-out;\n animation-iteration-count: ",";\n\n &[data-reset-animation] {\n animation: none;\n }\n"])),rr,function(e){return e.once?1:"infinite"}),ir=y.default.forwardRef(function(n,t){var r=n.once,o=void 0!==r&&r,i=e.useRef(null);return e.useImperativeHandle(t,function(){return{restart:function(){i.current&&(i.current.dataset.resetAnimation="true",delete i.current.dataset.resetAnimation)}}}),/*#__PURE__*/y.default.createElement(or,{ref:i,once:o})});Object.defineProperty(exports,"ComponentAbstraction",{enumerable:!0,get:function(){return t.ComponentAbstraction}}),Object.defineProperty(exports,"useComponentAbstraction",{enumerable:!0,get:function(){return t.useComponentAbstraction}}),exports.CancelLayoutItemBodyPadding=function(n){var t=n.children,r=n.cancelTop,o=e.useContext(Oe);/*#__PURE__*/return y.default.createElement(qe,{wide:o.wide,cancelTop:r},t)},exports.Carousel=function(n){var t=n.buttonOffset,r=void 0===t?0:t,o=n.buttonPadding,i=void 0===o?16:o,a=n.bottomOffset,u=void 0===a?0:a,c=n.defaultScroll,d=(c=void 0===c?{}:c).align,f=void 0===d?"left":d,s=c.offset,p=void 0===s?0:s,m=n.onScroll,h=n.onResize,v=n.children,x=n.centerItems,g=n.onScrollStateChange,b=n.scrollAmountCoef,w=void 0===b?.75:b,E=L(n,Tt),k=function(n){var t=e.useState(0),r=t[0],o=t[1],i=e.useRef();return[r,e.useCallback(function(e,n){void 0===n&&(n=!1),n?o(e):void 0===i.current&&(i.current=requestAnimationFrame(function(){o(e),void 0!==i.current&&(i.current=void 0)}))},[])]}(),C=k[0],z=k[1],R=e.useRef(!1),T=e.useState(0),I=T[0],S=T[1],M=e.useState(!1),O=M[0],N=M[1],B=e.useState(!1),A=B[0],W=B[1],_=l.useSpring(function(){return{scroll:0}}),U=_[0],H=_[1],P=e.useRef(null),j=e.useRef(null),G=e.useRef(null),D=e.useCallback(function(){if(null!==j.current){var e=Math.min(C+j.current.clientWidth*w,I);z(e,!0),H({scroll:e,from:{scroll:C},reset:!R.current}),R.current=!0}},[R,I,C,H,w,z]),V=e.useCallback(function(){if(null!==j.current){var e=Math.max(C-j.current.clientWidth*w,0);z(e,!0),H({scroll:e,from:{scroll:C},reset:!R.current}),R.current=!0}},[R,C,H,w,z]);e.useEffect(function(){var e=C>0,n=C<I&&I>0;e===O&&n===A||(N(e),W(n),null==g||g(e||n))},[O,I,g,A,C]);var q=e.useCallback(function(){null!==P.current&&(R.current&&(U.scroll.stop(),R.current=!1),z(P.current.scrollLeft))},[R,z,U]),F=e.useCallback(function(){if(null!==P.current){var e=P.current,n=e.clientWidth;S(e.scrollWidth-n),h&&h(n)}},[h]);e.useLayoutEffect(function(){var e=P.current,n=G.current;if(null!==e&&null!==n){e.addEventListener("wheel",q,function(){if(void 0!==Kn)return Kn;Kn=!1;try{var e=Object.defineProperty({},"passive",{get:function(){return Kn=!0}});window.addEventListener("test",n,e),window.removeEventListener("test",n)}catch(e){}return Kn;function n(){}}()&&{passive:!0});var t=new ResizeObserver(F);t.observe(e);var r=new ResizeObserver(F);return r.observe(n),function(){e.removeEventListener("wheel",q),t.disconnect(),r.disconnect()}}},[F,q]),e.useLayoutEffect(function(){if("left"!==f||0!==p){var e=P.current;if(null!==e){var n=Math.max(0,Math.min("left"===f&&p>0?p:"center"===f?I/2+p:"right"===f&&p<=I?I-p/2:0,I));e.scrollLeft=n,z(n,!0)}}},[P.current]);var Z=e.useCallback(function(){null!==P.current&&m&&m(P.current.scrollLeft)},[m]),X=e.useState(!1),Y=X[0],J=X[1];if(e.useLayoutEffect(function(){navigator.userAgent.includes("Edge/")&&J(!0)},[]),!Y&&!0===E.hasGradient){var K,Q=null!=(K=E.fadeInGradient)&&K,$=!Q;/*#__PURE__*/return y.default.createElement(Mt,{ref:j},/*#__PURE__*/y.default.createElement(Nt,{fadeInGradient:Q},/*#__PURE__*/y.default.createElement(Bt,null,/*#__PURE__*/y.default.createElement(At,{show:$||C>0},/*#__PURE__*/y.default.createElement(Ot,{ref:P,scrollLeft:U.scroll,onScroll:Z},/*#__PURE__*/y.default.createElement(It,{ref:G,centerItems:x},v))))),/*#__PURE__*/y.default.createElement(St,null,/*#__PURE__*/y.default.createElement(pt,{direction:ot.Left,show:O,offset:r,bottomOffset:u,padding:i,gradient:$,onClick:V}),/*#__PURE__*/y.default.createElement(pt,{direction:ot.Right,show:A,offset:r,bottomOffset:u,padding:i,gradient:!0,onClick:D})))}/*#__PURE__*/return y.default.createElement(Mt,{ref:j},/*#__PURE__*/y.default.createElement(Ot,{ref:P,scrollLeft:U.scroll,onScroll:Z},/*#__PURE__*/y.default.createElement(It,{ref:G,centerItems:x},v)),/*#__PURE__*/y.default.createElement(St,null,/*#__PURE__*/y.default.createElement(pt,{direction:ot.Left,show:O,offset:r,bottomOffset:u,padding:i,onClick:V}),/*#__PURE__*/y.default.createElement(pt,{direction:ot.Right,show:A,offset:r,bottomOffset:u,padding:i,onClick:D})))},exports.Filter=_,exports.FilterButton=I,exports.FilterIconButton=S,exports.FilterLink=M,exports.HintText=function(e){var n=e.children;/*#__PURE__*/return y.default.createElement(de,{className:e.className,context:e.context},/*#__PURE__*/y.default.createElement(fe,null,/*#__PURE__*/y.default.createElement(D,null)),/*#__PURE__*/y.default.createElement(se,null,n))},exports.LAYOUT_ITEM_BODY_PADDING=De,exports.Layout=function(e){var n=e.menu,t=e.children,r=e.header,o=e.center,i=void 0!==o&&o,a=e.wide,l=e.isHeaderTopMenu,u=void 0!==l&&l,c={center:i,wide:!!i||null!=a&&a,withLeft:null!=n&&!u};/*#__PURE__*/return y.default.createElement(Ae,null,/*#__PURE__*/y.default.createElement(Oe.Provider,{value:c},c.withLeft&&/*#__PURE__*/y.default.createElement(We,null,n),/*#__PURE__*/y.default.createElement(_e,{center:i},null!=r&&/*#__PURE__*/y.default.createElement(Ue,null,r),u&&/*#__PURE__*/y.default.createElement(Ne,null,n),/*#__PURE__*/y.default.createElement(He,null,t))),/*#__PURE__*/y.default.createElement(Be,null))},exports.LayoutItem=Pe,exports.LayoutItemBody=function(n){var t=n.children,r=n.horizontal,o=void 0!==r&&r,i=n.narrow,a=void 0!==i&&i,l=e.useContext(Oe);/*#__PURE__*/return y.default.createElement(Ve,{wide:l.wide,horizontal:o,narrow:a},t)},exports.LayoutItemHeader=function(n){var t=n.children,r=e.useContext(Oe);/*#__PURE__*/return y.default.createElement(Ge,{wide:r.wide,center:r.center},t)},exports.LeftMenu=function(e){var n=e.links,r=e.active,o=t.useComponentAbstraction().Link;/*#__PURE__*/return y.default.createElement(_n,null,n.map(function(e,n){/*#__PURE__*/return y.default.createElement(o,{to:e.to,key:n},/*#__PURE__*/y.default.createElement(Un,{"aria-current":e.id===r||void 0},e.text))}))},exports.LeftMenuContent=function(e){/*#__PURE__*/return y.default.createElement(y.default.Fragment,null,e.links.map(function(e,n){/*#__PURE__*/return y.default.createElement(an,{link:e.to,key:n,primary:e.text})}))},exports.LinkPager=function(e){var n=e.page,r=e.pageCount,o=e.makeUrl,i=t.useComponentAbstraction().Link,a=Zt(n,r),l=n<r,u=n>1;/*#__PURE__*/return y.default.createElement(Qt,null,/*#__PURE__*/y.default.createElement(i,{to:o(Math.max(1,n-1))},/*#__PURE__*/y.default.createElement($t,{hidden:!u,"aria-disabled":!u,noBackground:!0},/*#__PURE__*/y.default.createElement(Pt,{size:16,direction:Ut.Left}))),a.map(function(e){return"..."===e?/*#__PURE__*/y.default.createElement(er,{key:e},/*#__PURE__*/y.default.createElement(Wt,{size:20,subLink:!0})):e===n?/*#__PURE__*/y.default.createElement($t,{key:e,type:"button","aria-current":!0},/*#__PURE__*/y.default.createElement(nr,null,e)):/*#__PURE__*/y.default.createElement(i,{key:e,to:o(e)},/*#__PURE__*/y.default.createElement($t,{type:"button"},/*#__PURE__*/y.default.createElement(nr,null,e)))}),/*#__PURE__*/y.default.createElement(i,{to:o(Math.min(r,n+1))},/*#__PURE__*/y.default.createElement($t,{hidden:!l,"aria-disabled":!l,noBackground:!0},/*#__PURE__*/y.default.createElement(Pt,{size:16,direction:Ut.Right}))))},exports.MAIN_COLUMN_HORIZONTAL_MIN_MARGIN=72,exports.MenuListItem=en,exports.MenuListItemContext=$e,exports.MenuListItemWithIcon=function(e){var n=e.icon,t=e.primary,r=L(e,Qe);/*#__PURE__*/return y.default.createElement(en,C({primary:/*#__PURE__*/y.default.createElement(Nn,null,/*#__PURE__*/y.default.createElement(Bn,null,n),t)},r))},exports.MenuListLabel=Wn,exports.MenuListLinkItem=an,exports.MenuListLinkItemWithIcon=function(e){var n=e.icon,t=e.primary,r=L(e,Ke);/*#__PURE__*/return y.default.createElement(an,C({primary:/*#__PURE__*/y.default.createElement(Nn,null,/*#__PURE__*/y.default.createElement(Bn,null,n),t)},r))},exports.MenuListSpacer=An,exports.Pager=Kt,exports.RESPONSIVE_LEFT_WIDTH=pe,exports.RESPONSIVE_MAIN_MAX_WIDTH=me,exports.Spinner=function(e){var n=e.size,t=e.padding,r=e.transparent;/*#__PURE__*/return y.default.createElement(tr,{size:void 0===n?48:n,padding:void 0===t?16:t,transparent:void 0!==r&&r},/*#__PURE__*/y.default.createElement(ir,null))},exports.SpinnerIcon=ir,exports.StyledCancelLayoutItemBodyPadding=qe,exports.StyledLayoutItemBody=Ve,exports.SwitchCheckbox=Pn,exports.TextEllipsis=Ye,exports.WithIcon=Zn,exports.useElementSize=ge,exports.useLayoutItemBodyPadding=function(){var n=e.useContext(Oe).wide;return he()?De.column1:n?De.wide:De.default},exports.useMedia=ve,exports.useMediaScreen1=he;
|
|
1
|
+
var React = require('react');
|
|
2
|
+
var styled = require('styled-components');
|
|
3
|
+
var react = require('@charcoal-ui/react');
|
|
4
|
+
var utils = require('@charcoal-ui/utils');
|
|
5
|
+
var styled$1 = require('@charcoal-ui/styled');
|
|
6
|
+
var foundation = require('@charcoal-ui/foundation');
|
|
7
|
+
var ReactDOM = require('react-dom');
|
|
8
|
+
var reactSpring = require('react-spring');
|
|
9
|
+
var warning = require('warning');
|
|
10
|
+
|
|
11
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
12
|
+
|
|
13
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
14
|
+
var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
|
|
15
|
+
var ReactDOM__default = /*#__PURE__*/_interopDefaultLegacy(ReactDOM);
|
|
16
|
+
var warning__default = /*#__PURE__*/_interopDefaultLegacy(warning);
|
|
17
|
+
|
|
18
|
+
function _extends() {
|
|
19
|
+
_extends = Object.assign || function (target) {
|
|
20
|
+
for (var i = 1; i < arguments.length; i++) {
|
|
21
|
+
var source = arguments[i];
|
|
22
|
+
|
|
23
|
+
for (var key in source) {
|
|
24
|
+
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
25
|
+
target[key] = source[key];
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
return _extends.apply(this, arguments);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function _objectWithoutPropertiesLoose(source, excluded) {
|
|
37
|
+
if (source == null) return {};
|
|
38
|
+
var target = {};
|
|
39
|
+
var sourceKeys = Object.keys(source);
|
|
40
|
+
var key, i;
|
|
41
|
+
|
|
42
|
+
for (i = 0; i < sourceKeys.length; i++) {
|
|
43
|
+
key = sourceKeys[i];
|
|
44
|
+
if (excluded.indexOf(key) >= 0) continue;
|
|
45
|
+
target[key] = source[key];
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
return target;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function _taggedTemplateLiteralLoose(strings, raw) {
|
|
52
|
+
if (!raw) {
|
|
53
|
+
raw = strings.slice(0);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
strings.raw = raw;
|
|
57
|
+
return strings;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
var _templateObject$e, _templateObject2$a, _templateObject3$9, _templateObject4$8, _templateObject5$6, _templateObject6$5, _templateObject7$5, _templateObject8$5, _templateObject9$5;
|
|
61
|
+
|
|
62
|
+
var _excluded$3 = ["onClick", "children", "active", "hover", "reactive"];
|
|
63
|
+
var FilterButton = React__default["default"].forwardRef(function FilterButton(_ref, ref) {
|
|
64
|
+
var onClick = _ref.onClick,
|
|
65
|
+
children = _ref.children,
|
|
66
|
+
_ref$active = _ref.active,
|
|
67
|
+
active = _ref$active === void 0 ? false : _ref$active,
|
|
68
|
+
hover = _ref.hover,
|
|
69
|
+
_ref$reactive = _ref.reactive,
|
|
70
|
+
reactive = _ref$reactive === void 0 ? false : _ref$reactive;
|
|
71
|
+
return /*#__PURE__*/React__default["default"].createElement(ButtonLike, {
|
|
72
|
+
active: active,
|
|
73
|
+
reactive: reactive,
|
|
74
|
+
hover: hover,
|
|
75
|
+
onClick: active && !reactive ? undefined : onClick,
|
|
76
|
+
ref: ref
|
|
77
|
+
}, children);
|
|
78
|
+
});
|
|
79
|
+
var FilterIconButton = React__default["default"].forwardRef(function FilterIconButton(_ref2, ref) {
|
|
80
|
+
var onClick = _ref2.onClick,
|
|
81
|
+
children = _ref2.children,
|
|
82
|
+
_ref2$active = _ref2.active,
|
|
83
|
+
active = _ref2$active === void 0 ? false : _ref2$active,
|
|
84
|
+
hover = _ref2.hover,
|
|
85
|
+
_ref2$reactive = _ref2.reactive,
|
|
86
|
+
reactive = _ref2$reactive === void 0 ? false : _ref2$reactive,
|
|
87
|
+
width = _ref2.width,
|
|
88
|
+
height = _ref2.height;
|
|
89
|
+
return /*#__PURE__*/React__default["default"].createElement(StyledButtonLike, {
|
|
90
|
+
active: active,
|
|
91
|
+
reactive: reactive,
|
|
92
|
+
hover: hover,
|
|
93
|
+
onClick: active && !reactive ? undefined : onClick,
|
|
94
|
+
ref: ref,
|
|
95
|
+
buttonWidth: width,
|
|
96
|
+
buttonHeight: height
|
|
97
|
+
}, children);
|
|
98
|
+
});
|
|
99
|
+
var FilterLink = React__default["default"].forwardRef(function FilterLink(_ref3, ref) {
|
|
100
|
+
var onClick = _ref3.onClick,
|
|
101
|
+
children = _ref3.children,
|
|
102
|
+
_ref3$active = _ref3.active,
|
|
103
|
+
active = _ref3$active === void 0 ? false : _ref3$active,
|
|
104
|
+
hover = _ref3.hover,
|
|
105
|
+
_ref3$reactive = _ref3.reactive,
|
|
106
|
+
reactive = _ref3$reactive === void 0 ? false : _ref3$reactive,
|
|
107
|
+
props = _objectWithoutPropertiesLoose(_ref3, _excluded$3);
|
|
108
|
+
|
|
109
|
+
var _useComponentAbstract = react.useComponentAbstraction(),
|
|
110
|
+
Link = _useComponentAbstract.Link;
|
|
111
|
+
|
|
112
|
+
if (active && !reactive) {
|
|
113
|
+
return /*#__PURE__*/React__default["default"].createElement(PlainElement, {
|
|
114
|
+
active: true,
|
|
115
|
+
hover: hover,
|
|
116
|
+
ref: ref
|
|
117
|
+
}, children);
|
|
118
|
+
} else {
|
|
119
|
+
return /*#__PURE__*/React__default["default"].createElement(Link, _extends({}, props, {
|
|
120
|
+
onClick: onClick
|
|
121
|
+
}), /*#__PURE__*/React__default["default"].createElement(PlainElement, {
|
|
122
|
+
active: active,
|
|
123
|
+
reactive: reactive,
|
|
124
|
+
hover: hover,
|
|
125
|
+
ref: ref
|
|
126
|
+
}, children));
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
var buttonCss = styled.css(_templateObject$e || (_templateObject$e = _taggedTemplateLiteralLoose(["\n display: block;\n outline: none;\n border: none;\n padding: 9px 24px;\n font-size: 14px;\n line-height: 22px;\n font-weight: bold;\n border-radius: /* absurd radius, but ensures rounded corners */ 2000px;\n transition: color 0.2s;\n color: ", ";\n cursor: pointer;\n user-select: none;\n background-color: transparent;\n\n &:hover {\n color: ", ";\n }\n\n ", "\n\n ", "\n\n ", "\n\n @media ", " {\n padding: 5px 16px;\n }\n"])), function (_ref4) {
|
|
130
|
+
var theme = _ref4.theme;
|
|
131
|
+
return theme.color.text3;
|
|
132
|
+
}, function (_ref5) {
|
|
133
|
+
var theme = _ref5.theme;
|
|
134
|
+
return theme.color.text2;
|
|
135
|
+
}, function (_ref6) {
|
|
136
|
+
var _ref6$hover = _ref6.hover,
|
|
137
|
+
hover = _ref6$hover === void 0 ? false : _ref6$hover;
|
|
138
|
+
return hover && styled.css(_templateObject2$a || (_templateObject2$a = _taggedTemplateLiteralLoose(["\n color: ", ";\n "])), function (_ref7) {
|
|
139
|
+
var theme = _ref7.theme;
|
|
140
|
+
return theme.color.text2;
|
|
141
|
+
});
|
|
142
|
+
}, function (_ref8) {
|
|
143
|
+
var _ref8$active = _ref8.active,
|
|
144
|
+
active = _ref8$active === void 0 ? false : _ref8$active;
|
|
145
|
+
return active && styled.css(_templateObject3$9 || (_templateObject3$9 = _taggedTemplateLiteralLoose(["\n background-color: ", ";\n color: ", ";\n "])), function (_ref9) {
|
|
146
|
+
var theme = _ref9.theme;
|
|
147
|
+
return theme.color.surface3;
|
|
148
|
+
}, function (_ref10) {
|
|
149
|
+
var theme = _ref10.theme;
|
|
150
|
+
return theme.color.text2;
|
|
151
|
+
});
|
|
152
|
+
}, function (_ref11) {
|
|
153
|
+
var _ref11$active = _ref11.active,
|
|
154
|
+
active = _ref11$active === void 0 ? false : _ref11$active,
|
|
155
|
+
_ref11$reactive = _ref11.reactive,
|
|
156
|
+
reactive = _ref11$reactive === void 0 ? false : _ref11$reactive;
|
|
157
|
+
return active && !reactive && styled.css(_templateObject4$8 || (_templateObject4$8 = _taggedTemplateLiteralLoose(["\n cursor: default;\n "])));
|
|
158
|
+
}, function (_ref12) {
|
|
159
|
+
var theme = _ref12.theme;
|
|
160
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
161
|
+
});
|
|
162
|
+
var padding0Css = styled.css(_templateObject5$6 || (_templateObject5$6 = _taggedTemplateLiteralLoose(["\n padding: 0;\n\n @media ", " {\n padding: 0;\n }\n"])), function (_ref13) {
|
|
163
|
+
var theme = _ref13.theme;
|
|
164
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
165
|
+
});
|
|
166
|
+
var ButtonLike = styled__default["default"].button(_templateObject6$5 || (_templateObject6$5 = _taggedTemplateLiteralLoose(["\n ", "\n"])), buttonCss);
|
|
167
|
+
var PlainElement = styled__default["default"].span(_templateObject7$5 || (_templateObject7$5 = _taggedTemplateLiteralLoose(["\n ", "\n"])), buttonCss);
|
|
168
|
+
var StyledButtonLike = styled__default["default"](ButtonLike)(_templateObject8$5 || (_templateObject8$5 = _taggedTemplateLiteralLoose(["\n ", ";\n ", "\n ", "\n"])), padding0Css, function (p) {
|
|
169
|
+
return p.buttonWidth !== undefined && "width: " + p.buttonWidth + "px;";
|
|
170
|
+
}, function (p) {
|
|
171
|
+
return p.buttonHeight !== undefined && "height: " + p.buttonHeight + "px;";
|
|
172
|
+
});
|
|
173
|
+
var Filter = styled__default["default"].div(_templateObject9$5 || (_templateObject9$5 = _taggedTemplateLiteralLoose(["\n display: flex;\n"])));
|
|
174
|
+
|
|
175
|
+
var theme = styled$1.createTheme(styled__default["default"]);
|
|
176
|
+
|
|
177
|
+
var _templateObject$d;
|
|
178
|
+
function IconBase(_ref) {
|
|
179
|
+
var _ref$size = _ref.size,
|
|
180
|
+
size = _ref$size === void 0 ? 24 : _ref$size,
|
|
181
|
+
viewBoxSize = _ref.viewBoxSize,
|
|
182
|
+
currentColor = _ref.currentColor,
|
|
183
|
+
path = _ref.path,
|
|
184
|
+
transform = _ref.transform,
|
|
185
|
+
fillRule = _ref.fillRule,
|
|
186
|
+
clipRule = _ref.clipRule;
|
|
187
|
+
return /*#__PURE__*/React__default["default"].createElement(Icon$2, {
|
|
188
|
+
viewBox: "0 0 " + viewBoxSize + " " + viewBoxSize,
|
|
189
|
+
size: size,
|
|
190
|
+
currentColor: currentColor
|
|
191
|
+
}, /*#__PURE__*/React__default["default"].createElement(IconBasePath, {
|
|
192
|
+
path: path,
|
|
193
|
+
transform: transform,
|
|
194
|
+
fillRule: fillRule,
|
|
195
|
+
clipRule: clipRule
|
|
196
|
+
}));
|
|
197
|
+
}
|
|
198
|
+
var Icon$2 = styled__default["default"].svg(_templateObject$d || (_templateObject$d = _taggedTemplateLiteralLoose(["\n stroke: none;\n fill: ", ";\n width: ", "px;\n height: ", "px;\n line-height: 0;\n font-size: 0;\n vertical-align: middle;\n"])), function (_ref2) {
|
|
199
|
+
var _ref2$currentColor = _ref2.currentColor,
|
|
200
|
+
currentColor = _ref2$currentColor === void 0 ? false : _ref2$currentColor,
|
|
201
|
+
theme = _ref2.theme;
|
|
202
|
+
return currentColor ? 'currentColor' : theme.color.text2;
|
|
203
|
+
}, function (props) {
|
|
204
|
+
return props.size;
|
|
205
|
+
}, function (props) {
|
|
206
|
+
return props.size;
|
|
207
|
+
});
|
|
208
|
+
var IconBasePath = function IconBasePath(_ref3) {
|
|
209
|
+
var path = _ref3.path,
|
|
210
|
+
transform = _ref3.transform,
|
|
211
|
+
fillRule = _ref3.fillRule,
|
|
212
|
+
clipRule = _ref3.clipRule;
|
|
213
|
+
|
|
214
|
+
if (typeof path === 'string') {
|
|
215
|
+
return /*#__PURE__*/React__default["default"].createElement("path", {
|
|
216
|
+
d: path,
|
|
217
|
+
transform: transform,
|
|
218
|
+
fillRule: fillRule,
|
|
219
|
+
clipRule: clipRule
|
|
220
|
+
});
|
|
221
|
+
} else {
|
|
222
|
+
// eslint-disable-next-line react/jsx-no-useless-fragment
|
|
223
|
+
return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, path);
|
|
224
|
+
}
|
|
225
|
+
};
|
|
226
|
+
|
|
227
|
+
var _templateObject$c;
|
|
228
|
+
var size$1 = 16;
|
|
229
|
+
function InfoIcon() {
|
|
230
|
+
var path = /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement("path", {
|
|
231
|
+
d: "M8 16C3.58172 16 0 12.4183 0 8C0 3.58172 3.58172 0 8 0C12.4183 0 16 3.58172 16 8C16 12.4183 12.4183 16 8 16Z"
|
|
232
|
+
}), /*#__PURE__*/React__default["default"].createElement(Path, {
|
|
233
|
+
d: "M14 8C14 11.3137 11.3137 14 8 14C4.68629 14 2 11.3137 2 8C2 4.68629 4.68629 2 8 2C11.3137 2 14 4.68629 14 8ZM8 6.25C8.69036 6.25 9.25 5.69036 9.25 5C9.25 4.30964 8.69036 3.75 8 3.75C7.30964 3.75 6.75 4.30964 6.75 5C6.75 5.69036 7.30964 6.25 8 6.25ZM7 7.75V11.25C7 11.8023 7.44772 12.25 8 12.25C8.55228 12.25 9 11.8023 9 11.25V7.75C9 7.19772 8.55228 6.75 8 6.75C7.44772 6.75 7 7.19772 7 7.75Z"
|
|
234
|
+
}));
|
|
235
|
+
return /*#__PURE__*/React__default["default"].createElement(IconBase, {
|
|
236
|
+
viewBoxSize: size$1,
|
|
237
|
+
size: size$1,
|
|
238
|
+
currentColor: true,
|
|
239
|
+
path: path
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
var Path = styled__default["default"].path(_templateObject$c || (_templateObject$c = _taggedTemplateLiteralLoose(["\n fill: ", ";\n fill-rule: evenodd;\n"])), function (_ref) {
|
|
243
|
+
var theme = _ref.theme;
|
|
244
|
+
return theme.color.surface1;
|
|
245
|
+
});
|
|
246
|
+
|
|
247
|
+
var _templateObject$b, _templateObject2$9, _templateObject3$8, _templateObject4$7;
|
|
248
|
+
function HintText(_ref) {
|
|
249
|
+
var children = _ref.children,
|
|
250
|
+
context = _ref.context,
|
|
251
|
+
className = _ref.className;
|
|
252
|
+
return /*#__PURE__*/React__default["default"].createElement(Container$2, {
|
|
253
|
+
className: className,
|
|
254
|
+
context: context
|
|
255
|
+
}, /*#__PURE__*/React__default["default"].createElement(IconWrap, null, /*#__PURE__*/React__default["default"].createElement(InfoIcon, null)), /*#__PURE__*/React__default["default"].createElement(Text$2, null, children));
|
|
256
|
+
}
|
|
257
|
+
var Container$2 = styled__default["default"].div.attrs(styledProps)(_templateObject$b || (_templateObject$b = _taggedTemplateLiteralLoose(["\n ", "\n\n @media ", " {\n ", "\n }\n\n display: flex;\n align-items: flex-start;\n ", "\n"])), function (p) {
|
|
258
|
+
return theme(function (o) {
|
|
259
|
+
return [o.bg.surface3, o.borderRadius(8), o.padding.vertical(p["default"].vertical), o.padding.horizontal(p["default"].horizontal)];
|
|
260
|
+
});
|
|
261
|
+
}, function (_ref2) {
|
|
262
|
+
var t = _ref2.theme;
|
|
263
|
+
return utils.maxWidth(t.breakpoint.screen1);
|
|
264
|
+
}, function (p) {
|
|
265
|
+
return theme(function (o) {
|
|
266
|
+
return [o.padding.vertical(p.screen1.vertical), o.padding.horizontal(p.screen1.horizontal)];
|
|
267
|
+
});
|
|
268
|
+
}, function (p) {
|
|
269
|
+
return p.context === 'page' && styled.css(_templateObject2$9 || (_templateObject2$9 = _taggedTemplateLiteralLoose(["\n justify-content: center;\n "])));
|
|
270
|
+
});
|
|
271
|
+
var IconWrap = styled__default["default"].div(_templateObject3$8 || (_templateObject3$8 = _taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n color: ", ";\n height: 22px;\n margin: -4px 4px -4px 0;\n"])), function (p) {
|
|
272
|
+
return p.theme.color.text4;
|
|
273
|
+
});
|
|
274
|
+
var Text$2 = styled__default["default"].p(_templateObject4$7 || (_templateObject4$7 = _taggedTemplateLiteralLoose(["\n ", "\n margin: 0;\n"])), theme(function (o) {
|
|
275
|
+
return [o.font.text2, o.typography(14)];
|
|
276
|
+
}));
|
|
277
|
+
|
|
278
|
+
function styledProps(props) {
|
|
279
|
+
return _extends({}, props, contextToProps(props.context));
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
function contextToProps(context) {
|
|
283
|
+
switch (context) {
|
|
284
|
+
case 'page':
|
|
285
|
+
return {
|
|
286
|
+
"default": {
|
|
287
|
+
horizontal: 40,
|
|
288
|
+
vertical: 24
|
|
289
|
+
},
|
|
290
|
+
screen1: {
|
|
291
|
+
horizontal: 16,
|
|
292
|
+
vertical: 16
|
|
293
|
+
}
|
|
294
|
+
};
|
|
295
|
+
|
|
296
|
+
case 'section':
|
|
297
|
+
return {
|
|
298
|
+
"default": {
|
|
299
|
+
horizontal: 16,
|
|
300
|
+
vertical: 16
|
|
301
|
+
},
|
|
302
|
+
screen1: {
|
|
303
|
+
horizontal: 16,
|
|
304
|
+
vertical: 16
|
|
305
|
+
}
|
|
306
|
+
};
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
var MAIN_COLUMN_HORIZONTAL_MIN_MARGIN = 72;
|
|
311
|
+
var RESPONSIVE_LEFT_WIDTH = foundation.columnSystem(2, foundation.COLUMN_UNIT, foundation.GUTTER_UNIT) + foundation.GUTTER_UNIT;
|
|
312
|
+
var RESPONSIVE_MAIN_MAX_WIDTH = foundation.columnSystem(12, foundation.COLUMN_UNIT, foundation.GUTTER_UNIT);
|
|
313
|
+
|
|
314
|
+
/**
|
|
315
|
+
* 現在の画面幅がモバイル幅かどうかを返す
|
|
316
|
+
*/
|
|
317
|
+
|
|
318
|
+
function useMediaScreen1() {
|
|
319
|
+
return useMedia(utils.maxWidth(styled.useTheme().breakpoint.screen1));
|
|
320
|
+
}
|
|
321
|
+
/**
|
|
322
|
+
* Returns a dynamically-updating media query result.
|
|
323
|
+
*
|
|
324
|
+
* When the media query's matching state changes, this hook's result
|
|
325
|
+
* will update with sync priority.
|
|
326
|
+
*
|
|
327
|
+
* @param query A full media query (the string written between `@media` and the `{` in CSS)
|
|
328
|
+
* @returns true if the query matches, false if it doesn't
|
|
329
|
+
*/
|
|
330
|
+
|
|
331
|
+
function useMedia(query) {
|
|
332
|
+
var matcher = React.useMemo(function () {
|
|
333
|
+
return __TEST__ ? {
|
|
334
|
+
matches: false,
|
|
335
|
+
addListener: function addListener() {// do nothing
|
|
336
|
+
},
|
|
337
|
+
removeListener: function removeListener() {// do nothing
|
|
338
|
+
}
|
|
339
|
+
} : matchMedia(query);
|
|
340
|
+
}, [query]);
|
|
341
|
+
|
|
342
|
+
var _useState = React.useState(matcher.matches),
|
|
343
|
+
matches = _useState[0],
|
|
344
|
+
setMatches = _useState[1]; // can only happen if/when the query changes
|
|
345
|
+
|
|
346
|
+
|
|
347
|
+
if (matcher.matches !== matches) {
|
|
348
|
+
setMatches(matcher.matches);
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
var callback = function callback(e) {
|
|
352
|
+
// We're not on a React event listener, so React doesn't know the priority of the setState call
|
|
353
|
+
// Media query updates _are_ very high priority to avoid FOUC
|
|
354
|
+
// so we need to emit a sync priority update
|
|
355
|
+
try {
|
|
356
|
+
// However, flushSync may throw if the matcher is triggered by a
|
|
357
|
+
// forced relayout that happens during a React lifecycle handler.
|
|
358
|
+
// Try to be resilient and retry without flushSync if flushSync throws.
|
|
359
|
+
ReactDOM__default["default"].flushSync(function () {
|
|
360
|
+
setMatches(e.matches);
|
|
361
|
+
});
|
|
362
|
+
} catch (_unused) {
|
|
363
|
+
setMatches(e.matches);
|
|
364
|
+
}
|
|
365
|
+
};
|
|
366
|
+
|
|
367
|
+
React.useLayoutEffect(function () {
|
|
368
|
+
matcher.addListener(callback); // sync update
|
|
369
|
+
|
|
370
|
+
setMatches(matcher.matches);
|
|
371
|
+
return function () {
|
|
372
|
+
matcher.removeListener(callback);
|
|
373
|
+
};
|
|
374
|
+
}, [matcher]);
|
|
375
|
+
React.useDebugValue(query + ": " + matches.toString());
|
|
376
|
+
return matches;
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
function measure(ref) {
|
|
380
|
+
return ref !== null ? ref.getBoundingClientRect() : undefined;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
function useElementSize(ref, // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
384
|
+
deps) {
|
|
385
|
+
if (deps === void 0) {
|
|
386
|
+
deps = [];
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
// _don't_ call measure synchronously here even if you somehow can
|
|
390
|
+
// measurement has to be done outside the render phase, either
|
|
391
|
+
// as the resize observer callback or as a layout effect
|
|
392
|
+
var _useReducer = React.useReducer(function (state, next) {
|
|
393
|
+
// width, height, etc are not own properties but getters in the prototype
|
|
394
|
+
// can't use shallowEqual or other iterative checks
|
|
395
|
+
if (state === undefined || next === undefined) {
|
|
396
|
+
return next;
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
if (state.height === next.height && state.width === next.width) {
|
|
400
|
+
return state;
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
return next;
|
|
404
|
+
}, undefined),
|
|
405
|
+
size = _useReducer[0],
|
|
406
|
+
setSize = _useReducer[1];
|
|
407
|
+
|
|
408
|
+
var _useState2 = React.useState(null),
|
|
409
|
+
watch = _useState2[0],
|
|
410
|
+
setWatch = _useState2[1];
|
|
411
|
+
|
|
412
|
+
React.useLayoutEffect(function () {
|
|
413
|
+
if (watch === null) {
|
|
414
|
+
return;
|
|
415
|
+
}
|
|
416
|
+
|
|
417
|
+
var observer = new ResizeObserver(function () {
|
|
418
|
+
// NOTE: the ResizeObserverCallback receives a rect,
|
|
419
|
+
// but it's not measured in the same way as getBoundingClientRect,
|
|
420
|
+
// which causes unstable layout
|
|
421
|
+
var newSize = measure(watch);
|
|
422
|
+
setSize(newSize);
|
|
423
|
+
}); // The ResizeObserver is supposed to call handleResize on observe
|
|
424
|
+
|
|
425
|
+
observer.observe(watch);
|
|
426
|
+
return function () {
|
|
427
|
+
// this will correctly unobserve if either the observer
|
|
428
|
+
// or the current changes, and even on unmount
|
|
429
|
+
// no need for an observer.disconnect() 🎉
|
|
430
|
+
observer.unobserve(watch);
|
|
431
|
+
setSize(undefined);
|
|
432
|
+
};
|
|
433
|
+
}, [watch]); // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
434
|
+
|
|
435
|
+
React.useLayoutEffect(function () {
|
|
436
|
+
if (ref.current !== watch) {
|
|
437
|
+
setWatch(ref.current);
|
|
438
|
+
}
|
|
439
|
+
});
|
|
440
|
+
React.useLayoutEffect(function () {
|
|
441
|
+
if (deps.length > 0) {
|
|
442
|
+
// Sync measuring
|
|
443
|
+
setSize(measure(ref.current));
|
|
444
|
+
} // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
445
|
+
|
|
446
|
+
}, deps);
|
|
447
|
+
React.useDebugValue(size);
|
|
448
|
+
return size;
|
|
449
|
+
}
|
|
450
|
+
/**
|
|
451
|
+
* Debounce version of setState with `requestAnimationFrame`
|
|
452
|
+
*
|
|
453
|
+
* @param defaultValue Default value for `useState`
|
|
454
|
+
*/
|
|
455
|
+
|
|
456
|
+
function useDebounceAnimationState(defaultValue) {
|
|
457
|
+
var _useState3 = React.useState(defaultValue),
|
|
458
|
+
state = _useState3[0],
|
|
459
|
+
setState = _useState3[1];
|
|
460
|
+
|
|
461
|
+
var timer = React.useRef(); // typescript bug? (any when omitting type annotation)
|
|
462
|
+
// eslint-disable-next-line @typescript-eslint/no-inferrable-types
|
|
463
|
+
|
|
464
|
+
var setDebounceState = React.useCallback(function (value, force) {
|
|
465
|
+
if (force === void 0) {
|
|
466
|
+
force = false;
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
if (force) {
|
|
470
|
+
setState(value);
|
|
471
|
+
return;
|
|
472
|
+
}
|
|
473
|
+
|
|
474
|
+
if (timer.current !== undefined) {
|
|
475
|
+
return;
|
|
476
|
+
}
|
|
477
|
+
|
|
478
|
+
timer.current = requestAnimationFrame(function () {
|
|
479
|
+
setState(value);
|
|
480
|
+
|
|
481
|
+
if (timer.current !== undefined) {
|
|
482
|
+
timer.current = undefined;
|
|
483
|
+
}
|
|
484
|
+
});
|
|
485
|
+
}, []);
|
|
486
|
+
return [state, setDebounceState];
|
|
487
|
+
}
|
|
488
|
+
|
|
489
|
+
var _templateObject$a, _templateObject2$8, _templateObject3$7, _templateObject4$6, _templateObject5$5, _templateObject6$4, _templateObject7$4, _templateObject8$4, _templateObject9$4, _templateObject10$4, _templateObject11$1, _templateObject12$1, _templateObject13$1, _templateObject14, _templateObject15;
|
|
490
|
+
var LayoutConfigContext = React__default["default"].createContext({
|
|
491
|
+
wide: false,
|
|
492
|
+
center: false,
|
|
493
|
+
withLeft: false
|
|
494
|
+
});
|
|
495
|
+
function Layout(_ref) {
|
|
496
|
+
var menu = _ref.menu,
|
|
497
|
+
children = _ref.children,
|
|
498
|
+
header = _ref.header,
|
|
499
|
+
_ref$center = _ref.center,
|
|
500
|
+
center = _ref$center === void 0 ? false : _ref$center,
|
|
501
|
+
wide = _ref.wide,
|
|
502
|
+
_ref$isHeaderTopMenu = _ref.isHeaderTopMenu,
|
|
503
|
+
isHeaderTopMenu = _ref$isHeaderTopMenu === void 0 ? false : _ref$isHeaderTopMenu;
|
|
504
|
+
var config = {
|
|
505
|
+
center: center,
|
|
506
|
+
wide: center ? true : wide != null ? wide : false,
|
|
507
|
+
withLeft: menu != null && !isHeaderTopMenu
|
|
508
|
+
};
|
|
509
|
+
return /*#__PURE__*/React__default["default"].createElement(LayoutRoot, null, /*#__PURE__*/React__default["default"].createElement(LayoutConfigContext.Provider, {
|
|
510
|
+
value: config
|
|
511
|
+
}, config.withLeft && /*#__PURE__*/React__default["default"].createElement(LeftArea, null, menu), /*#__PURE__*/React__default["default"].createElement(MainArea, {
|
|
512
|
+
center: center
|
|
513
|
+
}, header != null && /*#__PURE__*/React__default["default"].createElement(Header, null, header), isHeaderTopMenu && /*#__PURE__*/React__default["default"].createElement(HeaderTopMenuContainer, null, menu), /*#__PURE__*/React__default["default"].createElement(Grid, null, children))), /*#__PURE__*/React__default["default"].createElement(GlobalStyle, null));
|
|
514
|
+
}
|
|
515
|
+
var HeaderTopMenuContainer = styled__default["default"].div(_templateObject$a || (_templateObject$a = _taggedTemplateLiteralLoose(["\n margin-bottom: 40px;\n overflow-x: auto;\n word-break: keep-all;\n\n @media ", " {\n margin-bottom: 0;\n padding-left: 16px;\n padding-bottom: 16px;\n background-color: ", ";\n }\n"])), function (_ref2) {
|
|
516
|
+
var theme = _ref2.theme;
|
|
517
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
518
|
+
}, function (_ref3) {
|
|
519
|
+
var theme = _ref3.theme;
|
|
520
|
+
return theme.color.surface2;
|
|
521
|
+
});
|
|
522
|
+
var GlobalStyle = styled.createGlobalStyle(_templateObject2$8 || (_templateObject2$8 = _taggedTemplateLiteralLoose(["\n :root {\n background-color: ", ";\n\n @media ", " {\n background-color: ", ";\n }\n }\n"])), function (_ref4) {
|
|
523
|
+
var theme = _ref4.theme;
|
|
524
|
+
return theme.color.background2;
|
|
525
|
+
}, function (_ref5) {
|
|
526
|
+
var theme = _ref5.theme;
|
|
527
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
528
|
+
}, function (_ref6) {
|
|
529
|
+
var theme = _ref6.theme;
|
|
530
|
+
return theme.color.background1;
|
|
531
|
+
});
|
|
532
|
+
var LayoutRoot = styled__default["default"].div(_templateObject3$7 || (_templateObject3$7 = _taggedTemplateLiteralLoose(["\n display: flex;\n background-color: ", ";\n\n @media ", " {\n background-color: ", ";\n }\n"])), function (_ref7) {
|
|
533
|
+
var theme = _ref7.theme;
|
|
534
|
+
return theme.color.background2;
|
|
535
|
+
}, function (_ref8) {
|
|
536
|
+
var theme = _ref8.theme;
|
|
537
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
538
|
+
}, function (_ref9) {
|
|
539
|
+
var theme = _ref9.theme;
|
|
540
|
+
return theme.color.background1;
|
|
541
|
+
});
|
|
542
|
+
var LeftArea = styled__default["default"].div(_templateObject4$6 || (_templateObject4$6 = _taggedTemplateLiteralLoose(["\n min-width: ", "px;\n padding: 40px 0 40px ", "px;\n box-sizing: border-box;\n\n @media ", " {\n display: none;\n }\n"])), RESPONSIVE_LEFT_WIDTH, foundation.GUTTER_UNIT, function (_ref10) {
|
|
543
|
+
var theme = _ref10.theme;
|
|
544
|
+
return theme.breakpoint.screen3;
|
|
545
|
+
});
|
|
546
|
+
var MainArea = styled__default["default"].div(_templateObject5$5 || (_templateObject5$5 = _taggedTemplateLiteralLoose(["\n flex-grow: 1;\n /* https://www.w3.org/TR/css-flexbox-1/#min-size-auto */\n min-width: 0;\n max-width: ", "px;\n padding: 40px ", "px;\n margin: 0 auto;\n display: flex;\n flex-direction: column;\n\n @media ", " {\n padding: 0;\n }\n"])), function (p) {
|
|
547
|
+
return p.center ? foundation.columnSystem(6, foundation.COLUMN_UNIT, foundation.GUTTER_UNIT) : RESPONSIVE_MAIN_MAX_WIDTH;
|
|
548
|
+
}, MAIN_COLUMN_HORIZONTAL_MIN_MARGIN, function (_ref11) {
|
|
549
|
+
var theme = _ref11.theme;
|
|
550
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
551
|
+
});
|
|
552
|
+
var Header = styled__default["default"].div(_templateObject6$4 || (_templateObject6$4 = _taggedTemplateLiteralLoose(["\n font-weight: bold;\n margin-bottom: 12px;\n font-size: 20px;\n line-height: 28px;\n color: ", ";\n\n @media ", " {\n margin-bottom: 0;\n padding: 12px;\n font-size: 16px;\n line-height: 24px;\n display: flex;\n justify-content: center;\n background-color: ", ";\n }\n"])), function (_ref12) {
|
|
553
|
+
var theme = _ref12.theme;
|
|
554
|
+
return theme.color.text2;
|
|
555
|
+
}, function (_ref13) {
|
|
556
|
+
var theme = _ref13.theme;
|
|
557
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
558
|
+
}, function (_ref14) {
|
|
559
|
+
var theme = _ref14.theme;
|
|
560
|
+
return theme.color.surface2;
|
|
561
|
+
});
|
|
562
|
+
var Grid = styled__default["default"].div(_templateObject7$4 || (_templateObject7$4 = _taggedTemplateLiteralLoose(["\n display: grid;\n gap: ", "px;\n grid-template-columns: 1fr;\n grid-auto-columns: 1fr;\n grid-auto-rows: auto;\n\n @media ", " {\n gap: 0;\n background-color: ", ";\n padding-bottom: 60px;\n }\n"])), foundation.GUTTER_UNIT, function (_ref15) {
|
|
563
|
+
var theme = _ref15.theme;
|
|
564
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
565
|
+
}, function (_ref16) {
|
|
566
|
+
var theme = _ref16.theme;
|
|
567
|
+
return theme.color.background1;
|
|
568
|
+
});
|
|
569
|
+
var LayoutItem = React__default["default"].forwardRef(function LayoutItem(_ref17, ref) {
|
|
570
|
+
var span = _ref17.span,
|
|
571
|
+
children = _ref17.children;
|
|
572
|
+
|
|
573
|
+
var _useContext = React.useContext(LayoutConfigContext),
|
|
574
|
+
withLeft = _useContext.withLeft;
|
|
575
|
+
|
|
576
|
+
return /*#__PURE__*/React__default["default"].createElement(StyledLayoutItem, {
|
|
577
|
+
span: span,
|
|
578
|
+
withLeft: withLeft,
|
|
579
|
+
ref: ref
|
|
580
|
+
}, children);
|
|
581
|
+
});
|
|
582
|
+
var StyledLayoutItem = styled__default["default"].div(_templateObject8$4 || (_templateObject8$4 = _taggedTemplateLiteralLoose(["\n grid-column-start: auto;\n grid-column-end: span ", ";\n border-radius: 24px;\n color: ", ";\n background-color: ", ";\n /* https://www.w3.org/TR/css-grid-1/#min-size-auto */\n min-width: 0;\n\n @media ", " {\n ", "\n }\n\n @media ", " {\n ", "\n\n border-radius: 0;\n padding-bottom: 40px;\n }\n"])), function (p) {
|
|
583
|
+
return p.span;
|
|
584
|
+
}, function (_ref18) {
|
|
585
|
+
var theme = _ref18.theme;
|
|
586
|
+
return theme.color.text2;
|
|
587
|
+
}, function (_ref19) {
|
|
588
|
+
var theme = _ref19.theme;
|
|
589
|
+
return theme.color.background1;
|
|
590
|
+
}, function (p) {
|
|
591
|
+
return p.withLeft ? p.theme.breakpoint.screen4 : p.theme.breakpoint.screen3;
|
|
592
|
+
}, function (p) {
|
|
593
|
+
return p.span > 2 && styled.css(_templateObject9$4 || (_templateObject9$4 = _taggedTemplateLiteralLoose(["\n grid-column-end: span 2;\n "])));
|
|
594
|
+
}, function (_ref20) {
|
|
595
|
+
var theme = _ref20.theme;
|
|
596
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
597
|
+
}, function (p) {
|
|
598
|
+
return p.span > 1 && styled.css(_templateObject10$4 || (_templateObject10$4 = _taggedTemplateLiteralLoose(["\n grid-column-end: span 1;\n "])));
|
|
599
|
+
});
|
|
600
|
+
function LayoutItemHeader(_ref21) {
|
|
601
|
+
var children = _ref21.children;
|
|
602
|
+
|
|
603
|
+
var _useContext2 = React.useContext(LayoutConfigContext),
|
|
604
|
+
wide = _useContext2.wide,
|
|
605
|
+
center = _useContext2.center;
|
|
606
|
+
|
|
607
|
+
return /*#__PURE__*/React__default["default"].createElement(StyledLayoutItemHeader, {
|
|
608
|
+
wide: wide,
|
|
609
|
+
center: center
|
|
610
|
+
}, children);
|
|
611
|
+
}
|
|
612
|
+
var StyledLayoutItemHeader = styled__default["default"].div(_templateObject11$1 || (_templateObject11$1 = _taggedTemplateLiteralLoose(["\n padding: 0 ", "px;\n height: ", "px;\n display: grid;\n align-items: center;\n font-size: 16px;\n line-height: 24px;\n font-weight: bold;\n background-color: ", ";\n color: ", ";\n border-radius: 24px 24px 0 0;\n ", "\n\n @media ", " {\n margin-top: 4px;\n padding: 0 16px;\n background: none;\n overflow-x: auto;\n border-radius: unset;\n ", "\n }\n"])), function (p) {
|
|
613
|
+
return p.wide ? 40 : 24;
|
|
614
|
+
}, function (p) {
|
|
615
|
+
return p.wide ? 64 : 48;
|
|
616
|
+
}, function (_ref22) {
|
|
617
|
+
var theme = _ref22.theme;
|
|
618
|
+
return theme.color.surface2;
|
|
619
|
+
}, function (_ref23) {
|
|
620
|
+
var theme = _ref23.theme;
|
|
621
|
+
return theme.color.text2;
|
|
622
|
+
}, function (p) {
|
|
623
|
+
return p.center && styled.css(_templateObject12$1 || (_templateObject12$1 = _taggedTemplateLiteralLoose(["\n justify-content: center;\n "])));
|
|
624
|
+
}, function (_ref24) {
|
|
625
|
+
var theme = _ref24.theme;
|
|
626
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
627
|
+
}, function (p) {
|
|
628
|
+
return p.wide && styled.css(_templateObject13$1 || (_templateObject13$1 = _taggedTemplateLiteralLoose(["\n height: 48px;\n margin-top: 0;\n "])));
|
|
629
|
+
});
|
|
630
|
+
var LAYOUT_ITEM_BODY_PADDING = {
|
|
631
|
+
wide: {
|
|
632
|
+
x: 40,
|
|
633
|
+
y: 40
|
|
634
|
+
},
|
|
635
|
+
"default": {
|
|
636
|
+
x: 24,
|
|
637
|
+
y: 24
|
|
638
|
+
},
|
|
639
|
+
column1: {
|
|
640
|
+
x: 16,
|
|
641
|
+
y: 16
|
|
642
|
+
},
|
|
643
|
+
narrow: {
|
|
644
|
+
x: 24,
|
|
645
|
+
yTop: 12,
|
|
646
|
+
yBottom: 20
|
|
647
|
+
},
|
|
648
|
+
narrowColumn1: {
|
|
649
|
+
x: 16,
|
|
650
|
+
yTop: 4,
|
|
651
|
+
yBottom: 0
|
|
652
|
+
}
|
|
653
|
+
};
|
|
654
|
+
function LayoutItemBody(_ref25) {
|
|
655
|
+
var children = _ref25.children,
|
|
656
|
+
_ref25$horizontal = _ref25.horizontal,
|
|
657
|
+
horizontal = _ref25$horizontal === void 0 ? false : _ref25$horizontal,
|
|
658
|
+
_ref25$narrow = _ref25.narrow,
|
|
659
|
+
narrow = _ref25$narrow === void 0 ? false : _ref25$narrow;
|
|
660
|
+
|
|
661
|
+
var _useContext3 = React.useContext(LayoutConfigContext),
|
|
662
|
+
wide = _useContext3.wide;
|
|
663
|
+
|
|
664
|
+
return /*#__PURE__*/React__default["default"].createElement(StyledLayoutItemBody, {
|
|
665
|
+
wide: wide,
|
|
666
|
+
horizontal: horizontal,
|
|
667
|
+
narrow: narrow
|
|
668
|
+
}, children);
|
|
669
|
+
}
|
|
670
|
+
var StyledLayoutItemBody = styled__default["default"].div(_templateObject14 || (_templateObject14 = _taggedTemplateLiteralLoose(["\n padding: ", ";\n\n @media ", " {\n padding: ", ";\n }\n\n width: 100%;\n box-sizing: border-box;\n"])), function (p) {
|
|
671
|
+
return p.narrow ? LAYOUT_ITEM_BODY_PADDING.narrow.yTop + "px " + (p.horizontal ? 0 : LAYOUT_ITEM_BODY_PADDING.narrow.x) + "px " + LAYOUT_ITEM_BODY_PADDING.narrow.yBottom + "px" : p.wide ? (p.horizontal ? 0 : LAYOUT_ITEM_BODY_PADDING.wide.y) + "px " + LAYOUT_ITEM_BODY_PADDING.wide.x + "px" : (p.horizontal ? 0 : LAYOUT_ITEM_BODY_PADDING["default"].y) + "px " + LAYOUT_ITEM_BODY_PADDING["default"].x + "px";
|
|
672
|
+
}, function (_ref26) {
|
|
673
|
+
var theme = _ref26.theme;
|
|
674
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
675
|
+
}, function (p) {
|
|
676
|
+
return p.narrow ? LAYOUT_ITEM_BODY_PADDING.narrowColumn1.yTop + "px " + (p.horizontal ? 0 : LAYOUT_ITEM_BODY_PADDING.narrowColumn1.x) + "px " + LAYOUT_ITEM_BODY_PADDING.narrowColumn1.yBottom + "px" : LAYOUT_ITEM_BODY_PADDING.column1.y + "px " + LAYOUT_ITEM_BODY_PADDING.column1.x + "px " + 0;
|
|
677
|
+
});
|
|
678
|
+
function useLayoutItemBodyPadding() {
|
|
679
|
+
var _useContext4 = React.useContext(LayoutConfigContext),
|
|
680
|
+
wide = _useContext4.wide;
|
|
681
|
+
|
|
682
|
+
return useMediaScreen1() ? LAYOUT_ITEM_BODY_PADDING.column1 : wide ? LAYOUT_ITEM_BODY_PADDING.wide : LAYOUT_ITEM_BODY_PADDING["default"];
|
|
683
|
+
}
|
|
684
|
+
function CancelLayoutItemBodyPadding(_ref27) {
|
|
685
|
+
var children = _ref27.children,
|
|
686
|
+
cancelTop = _ref27.cancelTop;
|
|
687
|
+
|
|
688
|
+
var _useContext5 = React.useContext(LayoutConfigContext),
|
|
689
|
+
wide = _useContext5.wide;
|
|
690
|
+
|
|
691
|
+
return /*#__PURE__*/React__default["default"].createElement(StyledCancelLayoutItemBodyPadding, {
|
|
692
|
+
wide: wide,
|
|
693
|
+
cancelTop: cancelTop
|
|
694
|
+
}, children);
|
|
695
|
+
}
|
|
696
|
+
/* eslint-disable max-len */
|
|
697
|
+
|
|
698
|
+
var StyledCancelLayoutItemBodyPadding = styled__default["default"].div(_templateObject15 || (_templateObject15 = _taggedTemplateLiteralLoose(["\n margin: 0 -", "px;\n margin-top: -", "px;\n\n @media ", " {\n margin: 0 -", "px;\n margin-top: -", "px;\n }\n"])), function (p) {
|
|
699
|
+
return p.wide ? LAYOUT_ITEM_BODY_PADDING.wide.x : LAYOUT_ITEM_BODY_PADDING["default"].x;
|
|
700
|
+
}, function (_ref28) {
|
|
701
|
+
var _ref28$cancelTop = _ref28.cancelTop,
|
|
702
|
+
cancelTop = _ref28$cancelTop === void 0 ? false : _ref28$cancelTop,
|
|
703
|
+
wide = _ref28.wide;
|
|
704
|
+
return !cancelTop ? 0 : wide ? LAYOUT_ITEM_BODY_PADDING.wide.y : LAYOUT_ITEM_BODY_PADDING["default"].y;
|
|
705
|
+
}, function (_ref29) {
|
|
706
|
+
var theme = _ref29.theme;
|
|
707
|
+
return utils.maxWidth(theme.breakpoint.screen1);
|
|
708
|
+
}, LAYOUT_ITEM_BODY_PADDING.column1.x, function (_ref30) {
|
|
709
|
+
var _ref30$cancelTop = _ref30.cancelTop,
|
|
710
|
+
cancelTop = _ref30$cancelTop === void 0 ? false : _ref30$cancelTop;
|
|
711
|
+
return !cancelTop ? 0 : LAYOUT_ITEM_BODY_PADDING.column1.x;
|
|
712
|
+
});
|
|
713
|
+
/* eslint-enable max-len */
|
|
714
|
+
|
|
715
|
+
// https://github.com/fernandopasik/react-children-utilities/blob/971d8a0324e6183734d8d1af9a65dbad18ab3d00/src/lib/onlyText.ts
|
|
716
|
+
|
|
717
|
+
var hasChildren = function hasChildren(element) {
|
|
718
|
+
return React.isValidElement(element) && Boolean(element.props.children);
|
|
719
|
+
};
|
|
720
|
+
|
|
721
|
+
var childToString = function childToString( // eslint-disable-next-line @typescript-eslint/ban-types
|
|
722
|
+
child) {
|
|
723
|
+
if (typeof child === 'undefined' || child === null || typeof child === 'boolean') {
|
|
724
|
+
return '';
|
|
725
|
+
}
|
|
726
|
+
|
|
727
|
+
if (JSON.stringify(child) === '{}') {
|
|
728
|
+
return '';
|
|
729
|
+
}
|
|
730
|
+
|
|
731
|
+
return child.toString();
|
|
732
|
+
};
|
|
733
|
+
var onlyText = function onlyText(children) {
|
|
734
|
+
if (!Array.isArray(children) && !React.isValidElement(children)) {
|
|
735
|
+
return childToString(children);
|
|
736
|
+
}
|
|
737
|
+
|
|
738
|
+
return React.Children.toArray(children).reduce(function (text, child) {
|
|
739
|
+
var newText = '';
|
|
740
|
+
|
|
741
|
+
if (React.isValidElement(child) && hasChildren(child)) {
|
|
742
|
+
newText = onlyText(child.props.children);
|
|
743
|
+
} else if (React.isValidElement(child) && !hasChildren(child)) {
|
|
744
|
+
newText = '';
|
|
745
|
+
} else {
|
|
746
|
+
newText = childToString(child);
|
|
747
|
+
}
|
|
748
|
+
|
|
749
|
+
return text.concat(newText);
|
|
750
|
+
}, '');
|
|
751
|
+
};
|
|
752
|
+
|
|
753
|
+
var _templateObject$9, _templateObject2$7, _templateObject3$6;
|
|
754
|
+
/**
|
|
755
|
+
* 複数行のテキストに表示行数制限を設けて`...`で省略する
|
|
756
|
+
*/
|
|
757
|
+
|
|
758
|
+
var TextEllipsis = styled__default["default"].div.attrs(function (_ref) {
|
|
759
|
+
var children = _ref.children,
|
|
760
|
+
_ref$title = _ref.title,
|
|
761
|
+
title = _ref$title === void 0 ? onlyText(children) : _ref$title;
|
|
762
|
+
return {
|
|
763
|
+
title: title !== '' ? title : undefined
|
|
764
|
+
};
|
|
765
|
+
})(_templateObject$9 || (_templateObject$9 = _taggedTemplateLiteralLoose(["\n overflow: hidden;\n line-height: ", "px;\n /* For english */\n overflow-wrap: break-word;\n\n ", "\n"])), function (props) {
|
|
766
|
+
return props.lineHeight;
|
|
767
|
+
}, function (_ref2) {
|
|
768
|
+
var _ref2$lineLimit = _ref2.lineLimit,
|
|
769
|
+
lineLimit = _ref2$lineLimit === void 0 ? 1 : _ref2$lineLimit,
|
|
770
|
+
lineHeight = _ref2.lineHeight;
|
|
771
|
+
return lineLimit === 1 ? styled.css(_templateObject2$7 || (_templateObject2$7 = _taggedTemplateLiteralLoose(["\n text-overflow: ellipsis;\n white-space: nowrap;\n "]))) : styled.css(_templateObject3$6 || (_templateObject3$6 = _taggedTemplateLiteralLoose(["\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: ", ";\n /* Fallback for -webkit-line-clamp */\n max-height: ", "px;\n "])), lineLimit, lineHeight * lineLimit);
|
|
772
|
+
});
|
|
773
|
+
|
|
774
|
+
var _excluded$2 = ["link", "onClick", "disabled", "primary", "secondary", "gtmClass", "noHover", "children"],
|
|
775
|
+
_excluded2 = ["icon", "primary"],
|
|
776
|
+
_excluded3 = ["icon", "primary"];
|
|
777
|
+
|
|
778
|
+
var _templateObject$8, _templateObject2$6, _templateObject3$5, _templateObject4$5, _templateObject5$4, _templateObject6$3, _templateObject7$3, _templateObject8$3, _templateObject9$3, _templateObject10$3;
|
|
779
|
+
var MenuListItemContext = React__default["default"].createContext({
|
|
780
|
+
padding: 24
|
|
781
|
+
});
|
|
782
|
+
function MenuListItem(_ref) {
|
|
783
|
+
var primary = _ref.primary,
|
|
784
|
+
secondary = _ref.secondary,
|
|
785
|
+
_onClick = _ref.onClick,
|
|
786
|
+
_ref$disabled = _ref.disabled,
|
|
787
|
+
disabled = _ref$disabled === void 0 ? false : _ref$disabled,
|
|
788
|
+
_ref$noHover = _ref.noHover,
|
|
789
|
+
noHover = _ref$noHover === void 0 ? false : _ref$noHover,
|
|
790
|
+
gtmClass = _ref.gtmClass,
|
|
791
|
+
children = _ref.children;
|
|
792
|
+
|
|
793
|
+
var _useContext = React.useContext(MenuListItemContext),
|
|
794
|
+
padding = _useContext.padding;
|
|
795
|
+
|
|
796
|
+
return /*#__PURE__*/React__default["default"].createElement(Item, {
|
|
797
|
+
hasSubLabel: secondary !== undefined,
|
|
798
|
+
onClick: function onClick(e) {
|
|
799
|
+
return !disabled && _onClick && _onClick(e);
|
|
800
|
+
},
|
|
801
|
+
sidePadding: padding,
|
|
802
|
+
noHover: noHover,
|
|
803
|
+
noClick: _onClick === undefined,
|
|
804
|
+
"aria-disabled": disabled,
|
|
805
|
+
role: _onClick !== undefined ? 'button' : undefined,
|
|
806
|
+
className: gtmClass !== undefined ? "gtm-" + gtmClass : undefined
|
|
807
|
+
}, /*#__PURE__*/React__default["default"].createElement(Labels, null, /*#__PURE__*/React__default["default"].createElement(PrimaryText, null, /*#__PURE__*/React__default["default"].createElement(TextEllipsis, {
|
|
808
|
+
lineHeight: 22,
|
|
809
|
+
lineLimit: 1
|
|
810
|
+
}, primary)), secondary !== undefined && /*#__PURE__*/React__default["default"].createElement(SecondaryText, null, /*#__PURE__*/React__default["default"].createElement(TextEllipsis, {
|
|
811
|
+
lineHeight: 22,
|
|
812
|
+
lineLimit: 1
|
|
813
|
+
}, secondary))), children);
|
|
814
|
+
}
|
|
815
|
+
var Item = styled__default["default"].div(_templateObject$8 || (_templateObject$8 = _taggedTemplateLiteralLoose(["\n display: flex;\n height: ", "px;\n align-items: center;\n justify-content: space-between;\n padding: 0 ", "px;\n user-select: none;\n cursor: ", ";\n transition: 0.2s background-color;\n\n &:hover {\n ", "\n }\n\n ", "\n\n ", " {\n cursor: default;\n pointer-events: none;\n\n &:hover {\n background-color: unset;\n }\n }\n"])), function (p) {
|
|
816
|
+
return p.hasSubLabel ? 56 : 40;
|
|
817
|
+
}, function (p) {
|
|
818
|
+
return p.sidePadding;
|
|
819
|
+
}, function (p) {
|
|
820
|
+
return p.noClick ? 'default' : 'pointer';
|
|
821
|
+
}, function (p) {
|
|
822
|
+
return !p.noHover && styled.css(_templateObject2$6 || (_templateObject2$6 = _taggedTemplateLiteralLoose(["\n background-color: ", ";\n "])), function (_ref2) {
|
|
823
|
+
var theme = _ref2.theme;
|
|
824
|
+
return theme.color.surface3;
|
|
825
|
+
});
|
|
826
|
+
}, theme(function (o) {
|
|
827
|
+
return o.disabled;
|
|
828
|
+
}), utils.disabledSelector);
|
|
829
|
+
var Labels = styled__default["default"].div(_templateObject3$5 || (_templateObject3$5 = _taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n"])));
|
|
830
|
+
var PrimaryText = styled__default["default"].div(_templateObject4$5 || (_templateObject4$5 = _taggedTemplateLiteralLoose(["\n color: ", ";\n line-height: 22px;\n font-size: 14px;\n display: grid;\n"])), function (p) {
|
|
831
|
+
return p.theme.color.text2;
|
|
832
|
+
});
|
|
833
|
+
var SecondaryText = styled__default["default"].div(_templateObject5$4 || (_templateObject5$4 = _taggedTemplateLiteralLoose(["\n color: ", ";\n line-height: 18px;\n font-size: 10px;\n"])), function (p) {
|
|
834
|
+
return p.theme.color.text3;
|
|
835
|
+
});
|
|
836
|
+
function MenuListLinkItem(_ref3) {
|
|
837
|
+
var link = _ref3.link,
|
|
838
|
+
onClick = _ref3.onClick,
|
|
839
|
+
_ref3$disabled = _ref3.disabled,
|
|
840
|
+
disabled = _ref3$disabled === void 0 ? false : _ref3$disabled,
|
|
841
|
+
primary = _ref3.primary,
|
|
842
|
+
secondary = _ref3.secondary,
|
|
843
|
+
gtmClass = _ref3.gtmClass,
|
|
844
|
+
noHover = _ref3.noHover,
|
|
845
|
+
children = _ref3.children,
|
|
846
|
+
linkProps = _objectWithoutPropertiesLoose(_ref3, _excluded$2);
|
|
847
|
+
|
|
848
|
+
var _useComponentAbstract = react.useComponentAbstraction(),
|
|
849
|
+
Link = _useComponentAbstract.Link;
|
|
850
|
+
|
|
851
|
+
var props = {
|
|
852
|
+
disabled: disabled,
|
|
853
|
+
primary: primary,
|
|
854
|
+
secondary: secondary,
|
|
855
|
+
gtmClass: gtmClass,
|
|
856
|
+
noHover: noHover,
|
|
857
|
+
children: children
|
|
858
|
+
};
|
|
859
|
+
return disabled ? /*#__PURE__*/React__default["default"].createElement("span", {
|
|
860
|
+
onClick: onClick
|
|
861
|
+
}, /*#__PURE__*/React__default["default"].createElement(MenuListItem, props)) : /*#__PURE__*/React__default["default"].createElement(A, _extends({
|
|
862
|
+
as: Link,
|
|
863
|
+
to: link,
|
|
864
|
+
onClick: onClick
|
|
865
|
+
}, linkProps), /*#__PURE__*/React__default["default"].createElement(MenuListItem, _extends({
|
|
866
|
+
onClick: function onClick() {
|
|
867
|
+
return void 0;
|
|
868
|
+
}
|
|
869
|
+
}, props)));
|
|
870
|
+
}
|
|
871
|
+
var A = styled__default["default"].a(_templateObject6$3 || (_templateObject6$3 = _taggedTemplateLiteralLoose(["\n display: block;\n"])));
|
|
872
|
+
function MenuListLinkItemWithIcon(_ref4) {
|
|
873
|
+
var icon = _ref4.icon,
|
|
874
|
+
text = _ref4.primary,
|
|
875
|
+
props = _objectWithoutPropertiesLoose(_ref4, _excluded2);
|
|
876
|
+
|
|
877
|
+
var primary = /*#__PURE__*/React__default["default"].createElement(IconContainer, null, /*#__PURE__*/React__default["default"].createElement(Icon$1, null, icon), text);
|
|
878
|
+
return /*#__PURE__*/React__default["default"].createElement(MenuListLinkItem, _extends({
|
|
879
|
+
primary: primary
|
|
880
|
+
}, props));
|
|
881
|
+
}
|
|
882
|
+
function MenuListItemWithIcon(_ref5) {
|
|
883
|
+
var icon = _ref5.icon,
|
|
884
|
+
text = _ref5.primary,
|
|
885
|
+
props = _objectWithoutPropertiesLoose(_ref5, _excluded3);
|
|
886
|
+
|
|
887
|
+
var primary = /*#__PURE__*/React__default["default"].createElement(IconContainer, null, /*#__PURE__*/React__default["default"].createElement(Icon$1, null, icon), text);
|
|
888
|
+
return /*#__PURE__*/React__default["default"].createElement(MenuListItem, _extends({
|
|
889
|
+
primary: primary
|
|
890
|
+
}, props));
|
|
891
|
+
}
|
|
892
|
+
var IconContainer = styled__default["default"].div(_templateObject7$3 || (_templateObject7$3 = _taggedTemplateLiteralLoose(["\n display: grid;\n gap: 8px;\n grid-auto-flow: column;\n align-items: center;\n"])));
|
|
893
|
+
var Icon$1 = styled__default["default"].div(_templateObject8$3 || (_templateObject8$3 = _taggedTemplateLiteralLoose(["\n color: ", ";\n display: flex;\n"])), function (_ref6) {
|
|
894
|
+
var theme = _ref6.theme;
|
|
895
|
+
return theme.color.text3;
|
|
896
|
+
});
|
|
897
|
+
var MenuListSpacer = styled__default["default"].div(_templateObject9$3 || (_templateObject9$3 = _taggedTemplateLiteralLoose(["\n height: 24px;\n"])));
|
|
898
|
+
var MenuListLabel = styled__default["default"].div(_templateObject10$3 || (_templateObject10$3 = _taggedTemplateLiteralLoose(["\n padding: 0 16px;\n font-size: 12px;\n line-height: 16px;\n color: ", ";\n margin-top: -2px;\n margin-bottom: 6px;\n"])), function (_ref7) {
|
|
899
|
+
var theme = _ref7.theme;
|
|
900
|
+
return theme.color.text3;
|
|
901
|
+
});
|
|
902
|
+
|
|
903
|
+
var _templateObject$7, _templateObject2$5;
|
|
904
|
+
function LeftMenu(_ref) {
|
|
905
|
+
var links = _ref.links,
|
|
906
|
+
active = _ref.active;
|
|
907
|
+
|
|
908
|
+
var _useComponentAbstract = react.useComponentAbstraction(),
|
|
909
|
+
Link = _useComponentAbstract.Link;
|
|
910
|
+
|
|
911
|
+
return /*#__PURE__*/React__default["default"].createElement(Container$1, null, links.map(function (link, index) {
|
|
912
|
+
return /*#__PURE__*/React__default["default"].createElement(Link, {
|
|
913
|
+
to: link.to,
|
|
914
|
+
key: index
|
|
915
|
+
}, /*#__PURE__*/React__default["default"].createElement(LinkItem, {
|
|
916
|
+
"aria-current": link.id === active || undefined
|
|
917
|
+
}, link.text));
|
|
918
|
+
}));
|
|
919
|
+
}
|
|
920
|
+
function LeftMenuContent(_ref2) {
|
|
921
|
+
var links = _ref2.links;
|
|
922
|
+
return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, links.map(function (link, index) {
|
|
923
|
+
return /*#__PURE__*/React__default["default"].createElement(MenuListLinkItem, {
|
|
924
|
+
link: link.to,
|
|
925
|
+
key: index,
|
|
926
|
+
primary: link.text
|
|
927
|
+
});
|
|
928
|
+
}));
|
|
929
|
+
}
|
|
930
|
+
var Container$1 = styled__default["default"].div(_templateObject$7 || (_templateObject$7 = _taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n"])));
|
|
931
|
+
var LinkItem = styled__default["default"].div(_templateObject2$5 || (_templateObject2$5 = _taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n color: ", ";\n border-radius: 24px;\n font-weight: bold;\n font-size: 14px;\n line-height: 22px;\n padding: 0 16px;\n height: 40px;\n transition: 0.2s color;\n &:hover {\n transition: 0.2s color;\n color: ", ";\n }\n &[aria-current] {\n color: ", ";\n background-color: ", ";\n }\n"])), function (_ref3) {
|
|
932
|
+
var theme = _ref3.theme;
|
|
933
|
+
return theme.color.text3;
|
|
934
|
+
}, function (_ref4) {
|
|
935
|
+
var theme = _ref4.theme;
|
|
936
|
+
return theme.color.text2;
|
|
937
|
+
}, function (_ref5) {
|
|
938
|
+
var theme = _ref5.theme;
|
|
939
|
+
return theme.color.text2;
|
|
940
|
+
}, function (_ref6) {
|
|
941
|
+
var theme = _ref6.theme;
|
|
942
|
+
return theme.color.surface3;
|
|
943
|
+
});
|
|
944
|
+
|
|
945
|
+
var _templateObject$6, _templateObject2$4, _templateObject3$4, _templateObject4$4, _templateObject5$3, _templateObject6$2, _templateObject7$2, _templateObject8$2, _templateObject9$2, _templateObject10$2;
|
|
946
|
+
|
|
947
|
+
var _excluded$1 = ["gtmClass", "flex", "rowReverse", "children", "disabled"];
|
|
948
|
+
var index$2 = React__default["default"].forwardRef(function SwitchCheckbox(_ref, ref) {
|
|
949
|
+
var gtmClass = _ref.gtmClass,
|
|
950
|
+
_ref$flex = _ref.flex,
|
|
951
|
+
flex = _ref$flex === void 0 ? false : _ref$flex,
|
|
952
|
+
_ref$rowReverse = _ref.rowReverse,
|
|
953
|
+
rowReverse = _ref$rowReverse === void 0 ? false : _ref$rowReverse,
|
|
954
|
+
children = _ref.children,
|
|
955
|
+
disabled = _ref.disabled,
|
|
956
|
+
props = _objectWithoutPropertiesLoose(_ref, _excluded$1);
|
|
957
|
+
|
|
958
|
+
return /*#__PURE__*/React__default["default"].createElement(Label, {
|
|
959
|
+
className: gtmClass !== undefined ? "gtm-" + gtmClass : '',
|
|
960
|
+
flex: flex,
|
|
961
|
+
rowReverse: rowReverse,
|
|
962
|
+
"aria-disabled": disabled
|
|
963
|
+
}, /*#__PURE__*/React__default["default"].createElement(SwitchOuter, null, /*#__PURE__*/React__default["default"].createElement(SwitchInput, _extends({}, props, {
|
|
964
|
+
disabled: disabled,
|
|
965
|
+
ref: ref
|
|
966
|
+
})), /*#__PURE__*/React__default["default"].createElement(SwitchInner, null, /*#__PURE__*/React__default["default"].createElement(SwitchInnerKnob, null))), children != null && /*#__PURE__*/React__default["default"].createElement(Children, {
|
|
967
|
+
rowReverse: rowReverse
|
|
968
|
+
}, children));
|
|
969
|
+
});
|
|
970
|
+
var Children = styled__default["default"].span(_templateObject$6 || (_templateObject$6 = _taggedTemplateLiteralLoose(["\n ", "\n"])), function (p) {
|
|
971
|
+
return p.rowReverse ? styled.css(_templateObject2$4 || (_templateObject2$4 = _taggedTemplateLiteralLoose(["\n margin-right: 8px;\n "]))) : styled.css(_templateObject3$4 || (_templateObject3$4 = _taggedTemplateLiteralLoose(["\n margin-left: 8px;\n "])));
|
|
972
|
+
});
|
|
973
|
+
var Label = styled__default["default"].label(_templateObject4$4 || (_templateObject4$4 = _taggedTemplateLiteralLoose(["\n display: inline-flex;\n align-items: center;\n ", "\n ", "\n cursor: pointer;\n outline: 0;\n\n &[aria-disabled='true'] {\n cursor: auto;\n }\n"])), function (_ref2) {
|
|
974
|
+
var flex = _ref2.flex;
|
|
975
|
+
return flex && styled.css(_templateObject5$3 || (_templateObject5$3 = _taggedTemplateLiteralLoose(["\n display: flex;\n justify-content: space-between;\n "])));
|
|
976
|
+
}, function (_ref3) {
|
|
977
|
+
var rowReverse = _ref3.rowReverse;
|
|
978
|
+
return styled.css(_templateObject6$2 || (_templateObject6$2 = _taggedTemplateLiteralLoose(["\n flex-direction: ", ";\n "])), rowReverse ? 'row-reverse' : 'row');
|
|
979
|
+
});
|
|
980
|
+
var SwitchOuter = styled__default["default"].span(_templateObject7$2 || (_templateObject7$2 = _taggedTemplateLiteralLoose(["\n display: inline-flex;\n position: relative;\n z-index: 0;\n"])));
|
|
981
|
+
var SwitchInner = styled__default["default"].div(_templateObject8$2 || (_templateObject8$2 = _taggedTemplateLiteralLoose(["\n position: relative;\n box-sizing: border-box;\n width: 28px;\n height: 16px;\n border-radius: 16px;\n border: 2px solid transparent;\n background: ", ";\n transition: box-shadow 0.2s, background-color 0.2s;\n"])), function (_ref4) {
|
|
982
|
+
var theme = _ref4.theme;
|
|
983
|
+
return theme.color.text4;
|
|
984
|
+
});
|
|
985
|
+
var SwitchInnerKnob = styled__default["default"].div(_templateObject9$2 || (_templateObject9$2 = _taggedTemplateLiteralLoose(["\n position: absolute;\n display: block;\n top: 0;\n left: 0;\n width: 12px;\n height: 12px;\n background-color: ", ";\n border-radius: 50%;\n transform: translateX(0);\n transition: transform 0.2s;\n"])), function (_ref5) {
|
|
986
|
+
var theme = _ref5.theme;
|
|
987
|
+
return theme.color.text5;
|
|
988
|
+
});
|
|
989
|
+
var SwitchInput = styled__default["default"].input.attrs({
|
|
990
|
+
type: 'checkbox'
|
|
991
|
+
})(_templateObject10$2 || (_templateObject10$2 = _taggedTemplateLiteralLoose(["\n position: absolute;\n /* NOTE: this is contained by the GraphicCheckboxOuter */\n z-index: 1;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n /* just to control the clickable area if used standalone */\n border-radius: 16px;\n opacity: 0;\n appearance: none;\n outline: none;\n cursor: pointer;\n\n &:checked {\n ~ ", " {\n background-color: ", ";\n\n ", " {\n transform: translateX(12px);\n }\n }\n }\n\n &:disabled {\n cursor: auto;\n\n ~ ", " {\n opacity: ", ";\n }\n }\n\n &:not(:disabled):focus {\n ~ ", " {\n box-shadow: 0 0 0 4px\n ", ";\n }\n }\n"])), SwitchInner, function (_ref6) {
|
|
992
|
+
var theme = _ref6.theme;
|
|
993
|
+
return theme.color.brand;
|
|
994
|
+
}, SwitchInnerKnob, SwitchInner, function (_ref7) {
|
|
995
|
+
var theme = _ref7.theme;
|
|
996
|
+
return theme.elementEffect.disabled.opacity;
|
|
997
|
+
}, SwitchInner, function (_ref8) {
|
|
998
|
+
var theme = _ref8.theme;
|
|
999
|
+
return utils.applyEffect(theme.color.brand, theme.elementEffect.disabled);
|
|
1000
|
+
});
|
|
1001
|
+
|
|
1002
|
+
var _templateObject$5, _templateObject2$3, _templateObject3$3, _templateObject4$3, _templateObject5$2, _templateObject6$1, _templateObject7$1, _templateObject8$1, _templateObject9$1, _templateObject10$1, _templateObject11, _templateObject12, _templateObject13;
|
|
1003
|
+
var index$1 = React__default["default"].memo(function WithIcon(_ref) {
|
|
1004
|
+
var children = _ref.children,
|
|
1005
|
+
icon = _ref.icon,
|
|
1006
|
+
_ref$show = _ref.show,
|
|
1007
|
+
show = _ref$show === void 0 ? true : _ref$show,
|
|
1008
|
+
_ref$prefix = _ref.prefix,
|
|
1009
|
+
pre = _ref$prefix === void 0 ? false : _ref$prefix,
|
|
1010
|
+
width = _ref.width,
|
|
1011
|
+
_ref$fit = _ref.fit,
|
|
1012
|
+
fit = _ref$fit === void 0 ? false : _ref$fit,
|
|
1013
|
+
_ref$fixed = _ref.fixed,
|
|
1014
|
+
fixed = _ref$fixed === void 0 ? false : _ref$fixed;
|
|
1015
|
+
var node = fit ? width === undefined ? /*#__PURE__*/React__default["default"].createElement(AutoWidthIconAnchor, {
|
|
1016
|
+
show: show,
|
|
1017
|
+
pre: pre
|
|
1018
|
+
}, icon) : /*#__PURE__*/React__default["default"].createElement(IconAnchor, {
|
|
1019
|
+
width: width,
|
|
1020
|
+
show: show,
|
|
1021
|
+
pre: pre
|
|
1022
|
+
}, /*#__PURE__*/React__default["default"].createElement(Icon, null, icon)) : /*#__PURE__*/React__default["default"].createElement(IconAnchorNaive, {
|
|
1023
|
+
show: show,
|
|
1024
|
+
pre: pre
|
|
1025
|
+
}, /*#__PURE__*/React__default["default"].createElement(IconNaive, null, icon));
|
|
1026
|
+
return /*#__PURE__*/React__default["default"].createElement(Root, null, pre && node, /*#__PURE__*/React__default["default"].createElement(Text$1, {
|
|
1027
|
+
fixed: fixed
|
|
1028
|
+
}, children), !pre && node);
|
|
1029
|
+
});
|
|
1030
|
+
var Root = styled__default["default"].div(_templateObject$5 || (_templateObject$5 = _taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n"])));
|
|
1031
|
+
var Text$1 = styled__default["default"].div(_templateObject2$3 || (_templateObject2$3 = _taggedTemplateLiteralLoose(["\n ", "\n white-space: nowrap;\n text-overflow: ellipsis;\n"])), function (p) {
|
|
1032
|
+
return !p.fixed && styled.css(_templateObject3$3 || (_templateObject3$3 = _taggedTemplateLiteralLoose(["\n min-width: 0;\n overflow: hidden;\n "])));
|
|
1033
|
+
});
|
|
1034
|
+
|
|
1035
|
+
function AutoWidthIconAnchor(_ref2) {
|
|
1036
|
+
var _useElementSize$width, _useElementSize;
|
|
1037
|
+
|
|
1038
|
+
var children = _ref2.children,
|
|
1039
|
+
show = _ref2.show,
|
|
1040
|
+
pre = _ref2.pre;
|
|
1041
|
+
var ref = React.useRef(null); // depsを空配列にしないことで初回だけ同期で幅を計算させるテクニック
|
|
1042
|
+
|
|
1043
|
+
var width = (_useElementSize$width = (_useElementSize = useElementSize(ref, [null])) == null ? void 0 : _useElementSize.width) != null ? _useElementSize$width : 0;
|
|
1044
|
+
return /*#__PURE__*/React__default["default"].createElement(IconAnchor, {
|
|
1045
|
+
width: width,
|
|
1046
|
+
show: show,
|
|
1047
|
+
pre: pre
|
|
1048
|
+
}, /*#__PURE__*/React__default["default"].createElement(Icon, {
|
|
1049
|
+
ref: ref
|
|
1050
|
+
}, children));
|
|
1051
|
+
}
|
|
1052
|
+
|
|
1053
|
+
var forceCenteringCss = styled.css(_templateObject4$3 || (_templateObject4$3 = _taggedTemplateLiteralLoose(["\n > svg {\n display: block;\n }\n"])));
|
|
1054
|
+
var iconAnchorCss = styled.css(_templateObject5$2 || (_templateObject5$2 = _taggedTemplateLiteralLoose(["\n ", ";\n ", "\n"])), function (p) {
|
|
1055
|
+
return p.show === 'collapse' ? styled.css(_templateObject6$1 || (_templateObject6$1 = _taggedTemplateLiteralLoose(["\n display: none;\n "]))) : styled.css(_templateObject7$1 || (_templateObject7$1 = _taggedTemplateLiteralLoose(["\n visibility: ", ";\n "])), p.show ? 'visible' : 'hidden');
|
|
1056
|
+
}, function (p) {
|
|
1057
|
+
return p.pre ? styled.css(_templateObject8$1 || (_templateObject8$1 = _taggedTemplateLiteralLoose(["\n margin-right: 4px;\n "]))) : styled.css(_templateObject9$1 || (_templateObject9$1 = _taggedTemplateLiteralLoose(["\n margin-left: 4px;\n "])));
|
|
1058
|
+
});
|
|
1059
|
+
var IconAnchorNaive = styled__default["default"].div(_templateObject10$1 || (_templateObject10$1 = _taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n\n ", "\n"])), iconAnchorCss);
|
|
1060
|
+
var IconNaive = styled__default["default"].div(_templateObject11 || (_templateObject11 = _taggedTemplateLiteralLoose(["\n display: inline-flex;\n\n ", "\n"])), forceCenteringCss);
|
|
1061
|
+
var IconAnchor = styled__default["default"].div(_templateObject12 || (_templateObject12 = _taggedTemplateLiteralLoose(["\n display: flex;\n position: relative;\n /* Icon\u3092line-height\u306B\u95A2\u4E0E\u3055\u305B\u306A\u3044 */\n height: 0;\n /* \u6A2A\u65B9\u5411\u306E\u9818\u57DF\u306F\u78BA\u4FDD\u3059\u308B */\n width: ", "px;\n\n ", "\n"])), function (p) {
|
|
1062
|
+
return p.width;
|
|
1063
|
+
}, iconAnchorCss);
|
|
1064
|
+
var Icon = styled__default["default"].div(_templateObject13 || (_templateObject13 = _taggedTemplateLiteralLoose(["\n display: inline-flex;\n position: absolute;\n transform: translateY(-50%);\n\n ", "\n"])), forceCenteringCss);
|
|
1065
|
+
|
|
1066
|
+
var passiveEventsResult; // eslint-disable-line no-var
|
|
1067
|
+
|
|
1068
|
+
function passiveEvents() {
|
|
1069
|
+
if (passiveEventsResult !== undefined) {
|
|
1070
|
+
return passiveEventsResult;
|
|
1071
|
+
}
|
|
1072
|
+
|
|
1073
|
+
passiveEventsResult = false;
|
|
1074
|
+
|
|
1075
|
+
try {
|
|
1076
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
1077
|
+
var options = Object.defineProperty({}, 'passive', {
|
|
1078
|
+
get: function get() {
|
|
1079
|
+
return passiveEventsResult = true;
|
|
1080
|
+
}
|
|
1081
|
+
});
|
|
1082
|
+
window.addEventListener('test', test, options);
|
|
1083
|
+
window.removeEventListener('test', test);
|
|
1084
|
+
} catch (_unused) {// test fail
|
|
1085
|
+
}
|
|
1086
|
+
|
|
1087
|
+
return passiveEventsResult;
|
|
1088
|
+
|
|
1089
|
+
function test() {
|
|
1090
|
+
/* empty */
|
|
1091
|
+
}
|
|
1092
|
+
}
|
|
1093
|
+
var isEdge = function isEdge() {
|
|
1094
|
+
return navigator.userAgent.includes('Edge/');
|
|
1095
|
+
};
|
|
1096
|
+
|
|
1097
|
+
function unreachable(value) {
|
|
1098
|
+
throw new Error(arguments.length === 0 ? 'unreachable' : "unreachable (" + JSON.stringify(value) + ")");
|
|
1099
|
+
}
|
|
1100
|
+
|
|
1101
|
+
var WedgeDirection$1;
|
|
1102
|
+
|
|
1103
|
+
(function (WedgeDirection) {
|
|
1104
|
+
WedgeDirection["Up"] = "up";
|
|
1105
|
+
WedgeDirection["Down"] = "down";
|
|
1106
|
+
WedgeDirection["Left"] = "left";
|
|
1107
|
+
WedgeDirection["Right"] = "right";
|
|
1108
|
+
})(WedgeDirection$1 || (WedgeDirection$1 = {})); // eslint-disable-next-line max-len
|
|
1109
|
+
|
|
1110
|
+
|
|
1111
|
+
var path = "M8.08579 16.5858C7.30474 17.3668 7.30474 18.6332 8.08579 19.4142C8.86684 20.1953 10.1332 20.1953 10.9142 19.4142L18.3284 12L10.9142 4.58579C10.1332 3.80474 8.86684 3.80474 8.08579 4.58579C7.30474 5.36684 7.30474 6.63317 8.08579 7.41421L12.6716 12L8.08579 16.5858Z";
|
|
1112
|
+
var size = 24;
|
|
1113
|
+
function NextIcon(_ref) {
|
|
1114
|
+
var direction = _ref.direction;
|
|
1115
|
+
var transform = directionToTransform$1(direction);
|
|
1116
|
+
return /*#__PURE__*/React__default["default"].createElement(IconBase, {
|
|
1117
|
+
viewBoxSize: size,
|
|
1118
|
+
size: size,
|
|
1119
|
+
currentColor: true,
|
|
1120
|
+
path: path,
|
|
1121
|
+
transform: transform
|
|
1122
|
+
});
|
|
1123
|
+
}
|
|
1124
|
+
|
|
1125
|
+
function directionToTransform$1(direction) {
|
|
1126
|
+
// "5 4" is the center point of the "0 0 10 8" viewBox
|
|
1127
|
+
switch (direction) {
|
|
1128
|
+
case WedgeDirection$1.Up:
|
|
1129
|
+
return 'rotate(270 12 12)';
|
|
1130
|
+
|
|
1131
|
+
case WedgeDirection$1.Down:
|
|
1132
|
+
return 'rotate(90 12 12)';
|
|
1133
|
+
|
|
1134
|
+
case WedgeDirection$1.Left:
|
|
1135
|
+
return 'rotate(180 12 12)';
|
|
1136
|
+
|
|
1137
|
+
case WedgeDirection$1.Right:
|
|
1138
|
+
return undefined;
|
|
1139
|
+
|
|
1140
|
+
default:
|
|
1141
|
+
return unreachable(direction);
|
|
1142
|
+
}
|
|
1143
|
+
}
|
|
1144
|
+
|
|
1145
|
+
var _templateObject$4, _templateObject2$2, _templateObject3$2, _templateObject4$2, _templateObject5$1;
|
|
1146
|
+
var Direction;
|
|
1147
|
+
|
|
1148
|
+
(function (Direction) {
|
|
1149
|
+
Direction["Right"] = "right";
|
|
1150
|
+
Direction["Left"] = "left";
|
|
1151
|
+
})(Direction || (Direction = {}));
|
|
1152
|
+
|
|
1153
|
+
function CarouselButton(_ref) {
|
|
1154
|
+
var direction = _ref.direction,
|
|
1155
|
+
show = _ref.show,
|
|
1156
|
+
_ref$offset = _ref.offset,
|
|
1157
|
+
offset = _ref$offset === void 0 ? 0 : _ref$offset,
|
|
1158
|
+
_ref$padding = _ref.padding,
|
|
1159
|
+
padding = _ref$padding === void 0 ? 0 : _ref$padding,
|
|
1160
|
+
_ref$bottomOffset = _ref.bottomOffset,
|
|
1161
|
+
bottom = _ref$bottomOffset === void 0 ? 0 : _ref$bottomOffset,
|
|
1162
|
+
_ref$gradient = _ref.gradient,
|
|
1163
|
+
gradient = _ref$gradient === void 0 ? false : _ref$gradient,
|
|
1164
|
+
onClick = _ref.onClick;
|
|
1165
|
+
var offsetStyle = direction === Direction.Left ? {
|
|
1166
|
+
left: gradient ? offset - 72 : offset,
|
|
1167
|
+
paddingLeft: Math.max(padding, 0),
|
|
1168
|
+
paddingBottom: bottom
|
|
1169
|
+
} : {
|
|
1170
|
+
right: gradient ? offset - 72 : offset,
|
|
1171
|
+
paddingRight: Math.max(padding, 0),
|
|
1172
|
+
paddingBottom: bottom
|
|
1173
|
+
};
|
|
1174
|
+
return /*#__PURE__*/React__default["default"].createElement(Button, {
|
|
1175
|
+
type: "button",
|
|
1176
|
+
onClick: onClick,
|
|
1177
|
+
hide: !show,
|
|
1178
|
+
style: offsetStyle,
|
|
1179
|
+
css: onlyNonTouchDevice
|
|
1180
|
+
}, /*#__PURE__*/React__default["default"].createElement(CarouselButtonIcon, null, /*#__PURE__*/React__default["default"].createElement(NextIcon, {
|
|
1181
|
+
direction: direction === Direction.Right ? WedgeDirection$1.Right : // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
1182
|
+
direction === Direction.Left ? WedgeDirection$1.Left : unreachable()
|
|
1183
|
+
})));
|
|
1184
|
+
}
|
|
1185
|
+
var CAROUSEL_BUTTON_SIZE = 40;
|
|
1186
|
+
var CarouselButtonIcon = styled__default["default"].div(_templateObject$4 || (_templateObject$4 = _taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: ", "px;\n height: ", "px;\n border-radius: 50%;\n background-color: ", ";\n transition: 0.4s visibility, 0.4s opacity, 0.2s background-color, 0.2s color;\n color: ", ";\n"])), CAROUSEL_BUTTON_SIZE, CAROUSEL_BUTTON_SIZE, function (_ref2) {
|
|
1187
|
+
var theme = _ref2.theme;
|
|
1188
|
+
return theme.color.surface4;
|
|
1189
|
+
}, function (_ref3) {
|
|
1190
|
+
var theme = _ref3.theme;
|
|
1191
|
+
return theme.color.text5;
|
|
1192
|
+
});
|
|
1193
|
+
var Button = styled__default["default"].button(_templateObject2$2 || (_templateObject2$2 = _taggedTemplateLiteralLoose(["\n position: absolute;\n top: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n padding: 0;\n min-width: 40px;\n border: none;\n outline: 0;\n background: transparent;\n cursor: pointer;\n transition: 0.4s visibility, 0.4s opacity;\n /* \u3064\u3089\u3044 */\n /* \u3053\u306E\u30B3\u30F3\u30DD\u30FC\u30CD\u30F3\u30C8\u306FCarousel\u3067\u3057\u304B\u4F7F\u308F\u308C\u3066\u306A\u3044\u306E\u3067\u305D\u3063\u3061\u3067\u30B3\u30F3\u30C6\u30AD\u30B9\u30C8\u3067\u5207\u308B */\n z-index: 1;\n\n &:hover ", " {\n background-color: ", ";\n color: ", ";\n }\n\n &:active ", " {\n background-color: ", ";\n color: ", ";\n }\n\n ", "\n"])), CarouselButtonIcon, function (_ref4) {
|
|
1194
|
+
var theme = _ref4.theme;
|
|
1195
|
+
return utils.applyEffect(theme.color.surface4, theme.effect.hover);
|
|
1196
|
+
}, function (_ref5) {
|
|
1197
|
+
var theme = _ref5.theme;
|
|
1198
|
+
return utils.applyEffect(theme.color.text5, theme.effect.hover);
|
|
1199
|
+
}, CarouselButtonIcon, function (_ref6) {
|
|
1200
|
+
var theme = _ref6.theme;
|
|
1201
|
+
return utils.applyEffect(theme.color.surface4, theme.effect.press);
|
|
1202
|
+
}, function (_ref7) {
|
|
1203
|
+
var theme = _ref7.theme;
|
|
1204
|
+
return utils.applyEffect(theme.color.text5, theme.effect.press);
|
|
1205
|
+
}, function (p) {
|
|
1206
|
+
return p.hide && styled.css(_templateObject3$2 || (_templateObject3$2 = _taggedTemplateLiteralLoose(["\n visibility: hidden;\n opacity: 0;\n pointer-events: none;\n "])));
|
|
1207
|
+
});
|
|
1208
|
+
styled__default["default"](CarouselButtonIcon)(_templateObject4$2 || (_templateObject4$2 = _taggedTemplateLiteralLoose(["\n cursor: pointer;\n\n &:hover {\n background-color: ", ";\n color: ", ";\n }\n\n &:active {\n background-color: ", ";\n color: ", ";\n }\n"])), function (_ref9) {
|
|
1209
|
+
var theme = _ref9.theme;
|
|
1210
|
+
return utils.applyEffect(theme.color.surface4, theme.effect.hover);
|
|
1211
|
+
}, function (_ref10) {
|
|
1212
|
+
var theme = _ref10.theme;
|
|
1213
|
+
return utils.applyEffect(theme.color.text5, theme.effect.hover);
|
|
1214
|
+
}, function (_ref11) {
|
|
1215
|
+
var theme = _ref11.theme;
|
|
1216
|
+
return utils.applyEffect(theme.color.surface4, theme.effect.press);
|
|
1217
|
+
}, function (_ref12) {
|
|
1218
|
+
var theme = _ref12.theme;
|
|
1219
|
+
return utils.applyEffect(theme.color.text5, theme.effect.press);
|
|
1220
|
+
});
|
|
1221
|
+
var onlyNonTouchDevice = styled.css(_templateObject5$1 || (_templateObject5$1 = _taggedTemplateLiteralLoose(["\n @media (hover: none) and (pointer: coarse) {\n display: none;\n }\n"])));
|
|
1222
|
+
|
|
1223
|
+
var _templateObject$3, _templateObject2$1, _templateObject3$1, _templateObject4$1, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
|
|
1224
|
+
|
|
1225
|
+
var _excluded = ["buttonOffset", "buttonPadding", "bottomOffset", "defaultScroll", "onScroll", "onResize", "children", "centerItems", "onScrollStateChange", "scrollAmountCoef"];
|
|
1226
|
+
var GRADIENT_WIDTH = 72;
|
|
1227
|
+
/**
|
|
1228
|
+
* カルーセル系のスクロール量の定数
|
|
1229
|
+
*
|
|
1230
|
+
* @example
|
|
1231
|
+
* const scrollAmount = containerElm.clientWidth * SCROLL_AMOUNT_COEF
|
|
1232
|
+
*/
|
|
1233
|
+
|
|
1234
|
+
var SCROLL_AMOUNT_COEF = 0.75;
|
|
1235
|
+
function Carousel(_ref) {
|
|
1236
|
+
var _ref$buttonOffset = _ref.buttonOffset,
|
|
1237
|
+
buttonOffset = _ref$buttonOffset === void 0 ? 0 : _ref$buttonOffset,
|
|
1238
|
+
_ref$buttonPadding = _ref.buttonPadding,
|
|
1239
|
+
buttonPadding = _ref$buttonPadding === void 0 ? 16 : _ref$buttonPadding,
|
|
1240
|
+
_ref$bottomOffset = _ref.bottomOffset,
|
|
1241
|
+
bottomOffset = _ref$bottomOffset === void 0 ? 0 : _ref$bottomOffset,
|
|
1242
|
+
_ref$defaultScroll = _ref.defaultScroll;
|
|
1243
|
+
_ref$defaultScroll = _ref$defaultScroll === void 0 ? {} : _ref$defaultScroll;
|
|
1244
|
+
|
|
1245
|
+
var _ref$defaultScroll$al = _ref$defaultScroll.align,
|
|
1246
|
+
align = _ref$defaultScroll$al === void 0 ? 'left' : _ref$defaultScroll$al,
|
|
1247
|
+
_ref$defaultScroll$of = _ref$defaultScroll.offset,
|
|
1248
|
+
scrollOffset = _ref$defaultScroll$of === void 0 ? 0 : _ref$defaultScroll$of,
|
|
1249
|
+
onScroll = _ref.onScroll,
|
|
1250
|
+
onResize = _ref.onResize,
|
|
1251
|
+
children = _ref.children,
|
|
1252
|
+
centerItems = _ref.centerItems,
|
|
1253
|
+
onScrollStateChange = _ref.onScrollStateChange,
|
|
1254
|
+
_ref$scrollAmountCoef = _ref.scrollAmountCoef,
|
|
1255
|
+
scrollAmountCoef = _ref$scrollAmountCoef === void 0 ? SCROLL_AMOUNT_COEF : _ref$scrollAmountCoef,
|
|
1256
|
+
options = _objectWithoutPropertiesLoose(_ref, _excluded);
|
|
1257
|
+
|
|
1258
|
+
// スクロール位置を保存する
|
|
1259
|
+
// アニメーション中の場合は、アニメーション終了時のスクロール位置が保存される
|
|
1260
|
+
var _useDebounceAnimation = useDebounceAnimationState(0),
|
|
1261
|
+
scrollLeft = _useDebounceAnimation[0],
|
|
1262
|
+
setScrollLeft = _useDebounceAnimation[1]; // アニメーション中かどうか
|
|
1263
|
+
|
|
1264
|
+
|
|
1265
|
+
var animation = React.useRef(false); // スクロール可能な領域を保存する
|
|
1266
|
+
|
|
1267
|
+
var _useState = React.useState(0),
|
|
1268
|
+
maxScrollLeft = _useState[0],
|
|
1269
|
+
setMaxScrollLeft = _useState[1]; // 左右のボタンの表示状態を保存する
|
|
1270
|
+
|
|
1271
|
+
|
|
1272
|
+
var _useState2 = React.useState(false),
|
|
1273
|
+
leftShow = _useState2[0],
|
|
1274
|
+
setLeftShow = _useState2[1];
|
|
1275
|
+
|
|
1276
|
+
var _useState3 = React.useState(false),
|
|
1277
|
+
rightShow = _useState3[0],
|
|
1278
|
+
setRightShow = _useState3[1]; // const [props, set, stop] = useSpring(() => ({
|
|
1279
|
+
// scroll: 0
|
|
1280
|
+
// }))
|
|
1281
|
+
|
|
1282
|
+
|
|
1283
|
+
var _useSpring = reactSpring.useSpring(function () {
|
|
1284
|
+
return {
|
|
1285
|
+
scroll: 0
|
|
1286
|
+
};
|
|
1287
|
+
}),
|
|
1288
|
+
styles = _useSpring[0],
|
|
1289
|
+
set = _useSpring[1];
|
|
1290
|
+
|
|
1291
|
+
var ref = React.useRef(null);
|
|
1292
|
+
var visibleAreaRef = React.useRef(null);
|
|
1293
|
+
var innerRef = React.useRef(null);
|
|
1294
|
+
var handleRight = React.useCallback(function () {
|
|
1295
|
+
if (visibleAreaRef.current === null) {
|
|
1296
|
+
return;
|
|
1297
|
+
}
|
|
1298
|
+
|
|
1299
|
+
var clientWidth = visibleAreaRef.current.clientWidth; // スクロール領域を超えないように、アニメーションを開始
|
|
1300
|
+
// アニメーション中にアニメーションが開始されたときに、アニメーション終了予定の位置から再度計算するようにする
|
|
1301
|
+
|
|
1302
|
+
var scroll = Math.min(scrollLeft + clientWidth * scrollAmountCoef, maxScrollLeft);
|
|
1303
|
+
setScrollLeft(scroll, true);
|
|
1304
|
+
set({
|
|
1305
|
+
scroll: scroll,
|
|
1306
|
+
from: {
|
|
1307
|
+
scroll: scrollLeft
|
|
1308
|
+
},
|
|
1309
|
+
reset: !animation.current
|
|
1310
|
+
});
|
|
1311
|
+
animation.current = true;
|
|
1312
|
+
}, [animation, maxScrollLeft, scrollLeft, set, scrollAmountCoef, setScrollLeft]);
|
|
1313
|
+
var handleLeft = React.useCallback(function () {
|
|
1314
|
+
if (visibleAreaRef.current === null) {
|
|
1315
|
+
return;
|
|
1316
|
+
}
|
|
1317
|
+
|
|
1318
|
+
var clientWidth = visibleAreaRef.current.clientWidth;
|
|
1319
|
+
var scroll = Math.max(scrollLeft - clientWidth * scrollAmountCoef, 0);
|
|
1320
|
+
setScrollLeft(scroll, true);
|
|
1321
|
+
set({
|
|
1322
|
+
scroll: scroll,
|
|
1323
|
+
from: {
|
|
1324
|
+
scroll: scrollLeft
|
|
1325
|
+
},
|
|
1326
|
+
reset: !animation.current
|
|
1327
|
+
});
|
|
1328
|
+
animation.current = true;
|
|
1329
|
+
}, [animation, scrollLeft, set, scrollAmountCoef, setScrollLeft]); // スクロール可能な場合にボタンを表示する
|
|
1330
|
+
// scrollLeftが変化したときに処理する (アニメーション開始時 & 手動スクロール時)
|
|
1331
|
+
|
|
1332
|
+
React.useEffect(function () {
|
|
1333
|
+
var newleftShow = scrollLeft > 0;
|
|
1334
|
+
var newrightShow = scrollLeft < maxScrollLeft && maxScrollLeft > 0;
|
|
1335
|
+
|
|
1336
|
+
if (newleftShow !== leftShow || newrightShow !== rightShow) {
|
|
1337
|
+
setLeftShow(newleftShow);
|
|
1338
|
+
setRightShow(newrightShow);
|
|
1339
|
+
onScrollStateChange == null ? void 0 : onScrollStateChange(newleftShow || newrightShow);
|
|
1340
|
+
}
|
|
1341
|
+
}, [leftShow, maxScrollLeft, onScrollStateChange, rightShow, scrollLeft]);
|
|
1342
|
+
var handleScroll = React.useCallback(function () {
|
|
1343
|
+
if (ref.current === null) {
|
|
1344
|
+
return;
|
|
1345
|
+
} // 手動でスクロールが開始されたときにアニメーションを中断
|
|
1346
|
+
|
|
1347
|
+
|
|
1348
|
+
if (animation.current) {
|
|
1349
|
+
styles.scroll.stop();
|
|
1350
|
+
animation.current = false;
|
|
1351
|
+
} // スクロール位置を保存 (アニメーションの基準になる)
|
|
1352
|
+
|
|
1353
|
+
|
|
1354
|
+
var manualScrollLeft = ref.current.scrollLeft; // 過剰にsetStateが走らないようにDebouceする
|
|
1355
|
+
|
|
1356
|
+
setScrollLeft(manualScrollLeft);
|
|
1357
|
+
}, [animation, setScrollLeft, styles]); // リサイズが起きたときに、アニメーション用のスクロール領域 & ボタンの表示状態 を再計算する
|
|
1358
|
+
|
|
1359
|
+
var handleResize = React.useCallback(function () {
|
|
1360
|
+
if (ref.current === null) {
|
|
1361
|
+
return;
|
|
1362
|
+
}
|
|
1363
|
+
|
|
1364
|
+
var _ref$current = ref.current,
|
|
1365
|
+
clientWidth = _ref$current.clientWidth,
|
|
1366
|
+
scrollWidth = _ref$current.scrollWidth;
|
|
1367
|
+
var newMaxScrollLeft = scrollWidth - clientWidth;
|
|
1368
|
+
setMaxScrollLeft(newMaxScrollLeft);
|
|
1369
|
+
|
|
1370
|
+
if (onResize) {
|
|
1371
|
+
onResize(clientWidth);
|
|
1372
|
+
}
|
|
1373
|
+
}, [onResize]);
|
|
1374
|
+
React.useLayoutEffect(function () {
|
|
1375
|
+
var elm = ref.current;
|
|
1376
|
+
var innerElm = innerRef.current;
|
|
1377
|
+
|
|
1378
|
+
if (elm === null || innerElm === null) {
|
|
1379
|
+
return;
|
|
1380
|
+
}
|
|
1381
|
+
|
|
1382
|
+
elm.addEventListener('wheel', handleScroll, passiveEvents() && {
|
|
1383
|
+
passive: true
|
|
1384
|
+
});
|
|
1385
|
+
var resizeObserver = new ResizeObserver(handleResize);
|
|
1386
|
+
resizeObserver.observe(elm);
|
|
1387
|
+
var resizeObserverInner = new ResizeObserver(handleResize);
|
|
1388
|
+
resizeObserverInner.observe(innerElm);
|
|
1389
|
+
return function () {
|
|
1390
|
+
elm.removeEventListener('wheel', handleScroll);
|
|
1391
|
+
resizeObserver.disconnect();
|
|
1392
|
+
resizeObserverInner.disconnect();
|
|
1393
|
+
};
|
|
1394
|
+
}, [handleResize, handleScroll]); // 初期スクロールを行う
|
|
1395
|
+
|
|
1396
|
+
React.useLayoutEffect(function () {
|
|
1397
|
+
if (align !== 'left' || scrollOffset !== 0) {
|
|
1398
|
+
var scroll = ref.current;
|
|
1399
|
+
|
|
1400
|
+
if (scroll !== null) {
|
|
1401
|
+
var scrollLength = Math.max(0, Math.min(align === 'left' && scrollOffset > 0 ? scrollOffset : align === 'center' ? maxScrollLeft / 2 + scrollOffset : align === 'right' && scrollOffset <= maxScrollLeft ? maxScrollLeft - scrollOffset / 2 : 0, maxScrollLeft));
|
|
1402
|
+
scroll.scrollLeft = scrollLength;
|
|
1403
|
+
setScrollLeft(scrollLength, true);
|
|
1404
|
+
}
|
|
1405
|
+
} // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
1406
|
+
|
|
1407
|
+
}, [ref.current]);
|
|
1408
|
+
var handleScrollMove = React.useCallback(function () {
|
|
1409
|
+
if (ref.current === null) {
|
|
1410
|
+
return;
|
|
1411
|
+
}
|
|
1412
|
+
|
|
1413
|
+
if (onScroll) {
|
|
1414
|
+
onScroll(ref.current.scrollLeft);
|
|
1415
|
+
}
|
|
1416
|
+
}, [onScroll]);
|
|
1417
|
+
|
|
1418
|
+
var _useState4 = React.useState(false),
|
|
1419
|
+
disableGradient = _useState4[0],
|
|
1420
|
+
setDisableGradient = _useState4[1];
|
|
1421
|
+
|
|
1422
|
+
React.useLayoutEffect(function () {
|
|
1423
|
+
if (isEdge()) {
|
|
1424
|
+
setDisableGradient(true);
|
|
1425
|
+
}
|
|
1426
|
+
}, []); // NOTE: Edgeではmaskを使うと要素のレンダリングがバグる(場合によっては画像が表示されない)のでグラデーションを無効にする
|
|
1427
|
+
|
|
1428
|
+
if (!disableGradient && options.hasGradient === true) {
|
|
1429
|
+
var _options$fadeInGradie;
|
|
1430
|
+
|
|
1431
|
+
var fadeInGradient = (_options$fadeInGradie = options.fadeInGradient) != null ? _options$fadeInGradie : false;
|
|
1432
|
+
var overflowGradient = !fadeInGradient;
|
|
1433
|
+
return /*#__PURE__*/React__default["default"].createElement(Container, {
|
|
1434
|
+
ref: visibleAreaRef
|
|
1435
|
+
}, /*#__PURE__*/React__default["default"].createElement(GradientContainer, {
|
|
1436
|
+
fadeInGradient: fadeInGradient
|
|
1437
|
+
}, /*#__PURE__*/React__default["default"].createElement(RightGradient, null, /*#__PURE__*/React__default["default"].createElement(LeftGradient, {
|
|
1438
|
+
show: overflowGradient || scrollLeft > 0
|
|
1439
|
+
}, /*#__PURE__*/React__default["default"].createElement(ScrollArea, {
|
|
1440
|
+
ref: ref,
|
|
1441
|
+
scrollLeft: styles.scroll,
|
|
1442
|
+
onScroll: handleScrollMove
|
|
1443
|
+
}, /*#__PURE__*/React__default["default"].createElement(CarouselContainer, {
|
|
1444
|
+
ref: innerRef,
|
|
1445
|
+
centerItems: centerItems
|
|
1446
|
+
}, children))))), /*#__PURE__*/React__default["default"].createElement(ButtonsContainer, null, /*#__PURE__*/React__default["default"].createElement(CarouselButton, {
|
|
1447
|
+
direction: Direction.Left,
|
|
1448
|
+
show: leftShow,
|
|
1449
|
+
offset: buttonOffset,
|
|
1450
|
+
bottomOffset: bottomOffset,
|
|
1451
|
+
padding: buttonPadding,
|
|
1452
|
+
gradient: overflowGradient,
|
|
1453
|
+
onClick: handleLeft
|
|
1454
|
+
}), /*#__PURE__*/React__default["default"].createElement(CarouselButton, {
|
|
1455
|
+
direction: Direction.Right,
|
|
1456
|
+
show: rightShow,
|
|
1457
|
+
offset: buttonOffset,
|
|
1458
|
+
bottomOffset: bottomOffset,
|
|
1459
|
+
padding: buttonPadding,
|
|
1460
|
+
gradient: true,
|
|
1461
|
+
onClick: handleRight
|
|
1462
|
+
})));
|
|
1463
|
+
}
|
|
1464
|
+
|
|
1465
|
+
return /*#__PURE__*/React__default["default"].createElement(Container, {
|
|
1466
|
+
ref: visibleAreaRef
|
|
1467
|
+
}, /*#__PURE__*/React__default["default"].createElement(ScrollArea // eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
1468
|
+
// @ts-expect-error
|
|
1469
|
+
, {
|
|
1470
|
+
ref: ref,
|
|
1471
|
+
scrollLeft: styles.scroll,
|
|
1472
|
+
onScroll: handleScrollMove
|
|
1473
|
+
}, /*#__PURE__*/React__default["default"].createElement(CarouselContainer, {
|
|
1474
|
+
ref: innerRef,
|
|
1475
|
+
centerItems: centerItems
|
|
1476
|
+
}, children)), /*#__PURE__*/React__default["default"].createElement(ButtonsContainer, null, /*#__PURE__*/React__default["default"].createElement(CarouselButton, {
|
|
1477
|
+
direction: Direction.Left,
|
|
1478
|
+
show: leftShow,
|
|
1479
|
+
offset: buttonOffset,
|
|
1480
|
+
bottomOffset: bottomOffset,
|
|
1481
|
+
padding: buttonPadding,
|
|
1482
|
+
onClick: handleLeft
|
|
1483
|
+
}), /*#__PURE__*/React__default["default"].createElement(CarouselButton, {
|
|
1484
|
+
direction: Direction.Right,
|
|
1485
|
+
show: rightShow,
|
|
1486
|
+
offset: buttonOffset,
|
|
1487
|
+
bottomOffset: bottomOffset,
|
|
1488
|
+
padding: buttonPadding,
|
|
1489
|
+
onClick: handleRight
|
|
1490
|
+
})));
|
|
1491
|
+
}
|
|
1492
|
+
var CarouselContainer = styled__default["default"].ul(_templateObject$3 || (_templateObject$3 = _taggedTemplateLiteralLoose(["\n vertical-align: top;\n overflow: hidden;\n list-style: none;\n padding: 0;\n\n /* \u6700\u5C0F\u5E45\u3092100%\u306B\u3057\u3066\u89AA\u8981\u7D20\u306B\u3074\u3063\u305F\u308A\u304F\u3063\u3064\u3051\u308B\u3053\u3068\u3067\u5B50\u8981\u7D20\u3067\u8981\u7D20\u3092\u5747\u7B49\u306B\u5272\u308A\u4ED8\u3051\u308B\u306A\u3069\u3092\u51FA\u6765\u308B\u3088\u3046\u306B\u3057\u3066\u3042\u308B */\n min-width: 100%;\n box-sizing: border-box;\n\n ", "\n"])), function (_ref2) {
|
|
1493
|
+
var _ref2$centerItems = _ref2.centerItems,
|
|
1494
|
+
centerItems = _ref2$centerItems === void 0 ? false : _ref2$centerItems;
|
|
1495
|
+
return centerItems ? styled.css(_templateObject2$1 || (_templateObject2$1 = _taggedTemplateLiteralLoose(["\n display: flex;\n width: max-content;\n margin: 0 auto;\n "]))) : styled.css(_templateObject3$1 || (_templateObject3$1 = _taggedTemplateLiteralLoose(["\n display: inline-flex;\n margin: 0;\n "])));
|
|
1496
|
+
});
|
|
1497
|
+
var ButtonsContainer = styled__default["default"].div(_templateObject4$1 || (_templateObject4$1 = _taggedTemplateLiteralLoose(["\n opacity: 0;\n transition: 0.4s opacity;\n"])));
|
|
1498
|
+
var Container = styled__default["default"].div(_templateObject5 || (_templateObject5 = _taggedTemplateLiteralLoose(["\n &:hover ", " {\n opacity: 1;\n }\n\n /* CarouselButton\u306E\u4E2D\u306Bz-index:1\u304C\u3042\u308B\u306E\u3067\u3053\u3053\u3067\u30B3\u30F3\u30C6\u30AD\u30B9\u30C8\u3092\u5207\u308B */\n position: relative;\n z-index: 0;\n"])), ButtonsContainer);
|
|
1499
|
+
var ScrollArea = styled__default["default"](reactSpring.animated.div)(_templateObject6 || (_templateObject6 = _taggedTemplateLiteralLoose(["\n overflow-x: auto;\n padding: 0;\n margin: 0;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n scrollbar-width: none;\n"])));
|
|
1500
|
+
var GradientContainer = styled__default["default"].div(_templateObject7 || (_templateObject7 = _taggedTemplateLiteralLoose(["\n /* NOTE: LeftGradient\u304C\u306F\u307F\u51FA\u308B\u305F\u3081hidden */\n overflow: hidden;\n ", "\n\n margin-right: ", "px;\n /* stylelint-disable-next-line no-duplicate-selectors */\n ", " {\n padding-right: ", "px;\n }\n"])), function (p) {
|
|
1501
|
+
return !p.fadeInGradient && styled.css(_templateObject8 || (_templateObject8 = _taggedTemplateLiteralLoose(["\n margin-left: ", "px;\n ", " {\n padding-left: ", "px;\n }\n "])), -GRADIENT_WIDTH, CarouselContainer, GRADIENT_WIDTH);
|
|
1502
|
+
}, -GRADIENT_WIDTH, CarouselContainer, GRADIENT_WIDTH);
|
|
1503
|
+
var RightGradient = styled__default["default"].div(_templateObject9 || (_templateObject9 = _taggedTemplateLiteralLoose(["\n mask-image: linear-gradient(\n to right,\n #000 calc(100% - ", "px),\n transparent\n );\n"])), GRADIENT_WIDTH);
|
|
1504
|
+
var LeftGradient = styled__default["default"].div(_templateObject10 || (_templateObject10 = _taggedTemplateLiteralLoose(["\n /* NOTE: mask-position \u304C left \u2192 negative px \u306E\u6642\u3001right \u2192 abs(negative px) \u306E\u4F4D\u7F6E\u306B\u8868\u793A\u3055\u308C\u308B\u305F\u3081 */\n margin-right: ", "px;\n padding-right: ", "px;\n /* NOTE: mask-position \u306B transition \u3092\u3064\u3051\u305F\u3044\u304C vender prefixes \u5BFE\u7B56\u3067 all \u306B\u3064\u3051\u308B */\n transition: 0.2s all ease-in;\n mask: linear-gradient(to right, transparent, #000 ", "px)\n ", "px 0;\n"])), -GRADIENT_WIDTH, GRADIENT_WIDTH, GRADIENT_WIDTH, function (p) {
|
|
1505
|
+
return p.show ? 0 : -GRADIENT_WIDTH;
|
|
1506
|
+
});
|
|
1507
|
+
|
|
1508
|
+
var _templateObject$2;
|
|
1509
|
+
|
|
1510
|
+
function DotsIcon(_ref) {
|
|
1511
|
+
var size = _ref.size;
|
|
1512
|
+
return /*#__PURE__*/React__default["default"].createElement(StyledSVG, {
|
|
1513
|
+
viewBox: "0 0 20 6",
|
|
1514
|
+
width: size,
|
|
1515
|
+
height: size
|
|
1516
|
+
}, /*#__PURE__*/React__default["default"].createElement("path", {
|
|
1517
|
+
fillRule: "evenodd",
|
|
1518
|
+
d: "M5,14.5 C3.61928813,14.5 2.5,13.3807119 2.5,12 C2.5,10.6192881 3.61928813,9.5 5,9.5\n C6.38071187,9.5 7.5,10.6192881 7.5,12 C7.5,13.3807119 6.38071187,14.5 5,14.5 Z M12,14.5\n C10.6192881,14.5 9.5,13.3807119 9.5,12 C9.5,10.6192881 10.6192881,9.5 12,9.5\n C13.3807119,9.5 14.5,10.6192881 14.5,12 C14.5,13.3807119 13.3807119,14.5 12,14.5 Z M19,14.5\n C17.6192881,14.5 16.5,13.3807119 16.5,12 C16.5,10.6192881 17.6192881,9.5 19,9.5\n C20.3807119,9.5 21.5,10.6192881 21.5,12 C21.5,13.3807119 20.3807119,14.5 19,14.5 Z",
|
|
1519
|
+
transform: "translate(-2 -9)"
|
|
1520
|
+
}));
|
|
1521
|
+
}
|
|
1522
|
+
|
|
1523
|
+
DotsIcon.defaultProps = {
|
|
1524
|
+
size: 16
|
|
1525
|
+
};
|
|
1526
|
+
var StyledSVG = styled__default["default"].svg(_templateObject$2 || (_templateObject$2 = _taggedTemplateLiteralLoose(["\n fill: currentColor;\n"])));
|
|
1527
|
+
|
|
1528
|
+
var _templateObject$1;
|
|
1529
|
+
var WedgeDirection;
|
|
1530
|
+
|
|
1531
|
+
(function (WedgeDirection) {
|
|
1532
|
+
WedgeDirection["Up"] = "up";
|
|
1533
|
+
WedgeDirection["Down"] = "down";
|
|
1534
|
+
WedgeDirection["Left"] = "left";
|
|
1535
|
+
WedgeDirection["Right"] = "right";
|
|
1536
|
+
})(WedgeDirection || (WedgeDirection = {}));
|
|
1537
|
+
|
|
1538
|
+
function WedgeIcon(_ref) {
|
|
1539
|
+
var size = _ref.size,
|
|
1540
|
+
direction = _ref.direction;
|
|
1541
|
+
return (
|
|
1542
|
+
/*#__PURE__*/
|
|
1543
|
+
// NOTE: directionToTransform depends on the value of viewBox
|
|
1544
|
+
React__default["default"].createElement("svg", {
|
|
1545
|
+
viewBox: "0 0 10 8",
|
|
1546
|
+
width: size,
|
|
1547
|
+
height: size
|
|
1548
|
+
}, /*#__PURE__*/React__default["default"].createElement(StyledPolyline, {
|
|
1549
|
+
strokeWidth: "2",
|
|
1550
|
+
points: "1,2 5,6 9,2",
|
|
1551
|
+
transform: directionToTransform(direction)
|
|
1552
|
+
}))
|
|
1553
|
+
);
|
|
1554
|
+
}
|
|
1555
|
+
WedgeIcon.defaultProps = {
|
|
1556
|
+
size: 16,
|
|
1557
|
+
white: false,
|
|
1558
|
+
lightGray: false
|
|
1559
|
+
};
|
|
1560
|
+
|
|
1561
|
+
function directionToTransform(direction) {
|
|
1562
|
+
// "5 4" is the center point of the "0 0 10 8" viewBox
|
|
1563
|
+
switch (direction) {
|
|
1564
|
+
case WedgeDirection.Up:
|
|
1565
|
+
return 'rotate(180 5 4)';
|
|
1566
|
+
|
|
1567
|
+
case WedgeDirection.Down:
|
|
1568
|
+
return undefined;
|
|
1569
|
+
|
|
1570
|
+
case WedgeDirection.Left:
|
|
1571
|
+
return 'rotate(90 5 4)';
|
|
1572
|
+
|
|
1573
|
+
case WedgeDirection.Right:
|
|
1574
|
+
return 'rotate(-90 5 4)';
|
|
1575
|
+
|
|
1576
|
+
default:
|
|
1577
|
+
return unreachable(direction);
|
|
1578
|
+
}
|
|
1579
|
+
}
|
|
1580
|
+
|
|
1581
|
+
var StyledPolyline = styled__default["default"].polyline(_templateObject$1 || (_templateObject$1 = _taggedTemplateLiteralLoose(["\n fill: none;\n stroke-linejoin: round;\n stroke-linecap: round;\n stroke: currentColor;\n"])));
|
|
1582
|
+
|
|
1583
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
|
|
1584
|
+
|
|
1585
|
+
function usePagerWindow(page, pageCount, windowSize) {
|
|
1586
|
+
if (windowSize === void 0) {
|
|
1587
|
+
windowSize = 7;
|
|
1588
|
+
}
|
|
1589
|
+
|
|
1590
|
+
// ページャーのリンク生成例:
|
|
1591
|
+
//
|
|
1592
|
+
// < [ 1 ] [*2*] [ 3 ] [ 4 ] [ 5 ] [ 6 ] [ 7 ] >
|
|
1593
|
+
//
|
|
1594
|
+
// < [ 1 ] [ 2 ] [ 3 ] [*4*] [ 5 ] [ 6 ] [ 7 ] >
|
|
1595
|
+
//
|
|
1596
|
+
// < [ 1 ] ... [ 4 ] [*5*] [ 6 ] [ 7 ] [ 8 ] >
|
|
1597
|
+
//
|
|
1598
|
+
// < [ 1 ] ... [ 99 ] [*100*] [ 101 ] [ 102 ] [ 103 ] >
|
|
1599
|
+
//
|
|
1600
|
+
// < [ 1 ] ... [ 99 ] [ 100 ] [ 101 ] [ 102 ] [*103*]
|
|
1601
|
+
//
|
|
1602
|
+
// [*1*] [ 2 ] >
|
|
1603
|
+
//
|
|
1604
|
+
// デザインの意図: 前後移動時のカーソル移動を最小限にする。
|
|
1605
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
1606
|
+
warning__default["default"]((page | 0) === page, "`page` must be interger (" + page + ")");
|
|
1607
|
+
warning__default["default"]((pageCount | 0) === pageCount, "`pageCount` must be interger (" + pageCount + ")");
|
|
1608
|
+
}
|
|
1609
|
+
|
|
1610
|
+
var window = React.useMemo(function () {
|
|
1611
|
+
var visibleFirstPage = 1;
|
|
1612
|
+
var visibleLastPage = Math.min(pageCount, Math.max(page + Math.floor(windowSize / 2), windowSize));
|
|
1613
|
+
|
|
1614
|
+
if (visibleLastPage <= windowSize) {
|
|
1615
|
+
// 表示範囲が1-7ページなら省略は無い。
|
|
1616
|
+
return Array.from({
|
|
1617
|
+
length: 1 + visibleLastPage - visibleFirstPage
|
|
1618
|
+
}, function (_, i) {
|
|
1619
|
+
return visibleFirstPage + i;
|
|
1620
|
+
});
|
|
1621
|
+
} else {
|
|
1622
|
+
var start = visibleLastPage - (windowSize - 1) + 2;
|
|
1623
|
+
return [// 表示範囲が1-7ページを超えるなら、
|
|
1624
|
+
// - 1ページ目は固定で表示する
|
|
1625
|
+
visibleFirstPage, // - 2ページ目から現在のページの直前までは省略する
|
|
1626
|
+
'...'].concat(Array.from({
|
|
1627
|
+
length: 1 + visibleLastPage - start
|
|
1628
|
+
}, function (_, i) {
|
|
1629
|
+
return start + i;
|
|
1630
|
+
}));
|
|
1631
|
+
}
|
|
1632
|
+
}, [page, pageCount, windowSize]);
|
|
1633
|
+
React.useDebugValue(window);
|
|
1634
|
+
return window;
|
|
1635
|
+
} // this pager is just regular buttons; for links use LinkPager
|
|
1636
|
+
|
|
1637
|
+
|
|
1638
|
+
var index = React__default["default"].memo(function Pager(_ref) {
|
|
1639
|
+
var page = _ref.page,
|
|
1640
|
+
pageCount = _ref.pageCount,
|
|
1641
|
+
onChange = _ref.onChange;
|
|
1642
|
+
// TODO: refactor Pager and LinkPager to use a common parent component
|
|
1643
|
+
var window = usePagerWindow(page, pageCount);
|
|
1644
|
+
var makeClickHandler = React.useCallback(function (value) {
|
|
1645
|
+
return function () {
|
|
1646
|
+
onChange(value);
|
|
1647
|
+
};
|
|
1648
|
+
}, [onChange]);
|
|
1649
|
+
var hasNext = page < pageCount;
|
|
1650
|
+
var hasPrev = page > 1;
|
|
1651
|
+
return /*#__PURE__*/React__default["default"].createElement(PagerContainer, null, /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1652
|
+
type: "button",
|
|
1653
|
+
hidden: !hasPrev,
|
|
1654
|
+
disabled: !hasPrev,
|
|
1655
|
+
onClick: makeClickHandler(Math.max(1, page - 1)),
|
|
1656
|
+
noBackground: true
|
|
1657
|
+
}, /*#__PURE__*/React__default["default"].createElement(WedgeIcon, {
|
|
1658
|
+
size: 16,
|
|
1659
|
+
direction: WedgeDirection.Left
|
|
1660
|
+
})), window.map(function (p) {
|
|
1661
|
+
return p === '...' ? /*#__PURE__*/React__default["default"].createElement(Spacer, {
|
|
1662
|
+
key: p
|
|
1663
|
+
}, /*#__PURE__*/React__default["default"].createElement(DotsIcon, {
|
|
1664
|
+
size: 20
|
|
1665
|
+
})) : p === page ?
|
|
1666
|
+
/*#__PURE__*/
|
|
1667
|
+
// we remove the onClick but don't mark it as disabled to preserve keyboard focus
|
|
1668
|
+
// not doing so causes the focus ring to flicker in and out of existence
|
|
1669
|
+
React__default["default"].createElement(CircleButton, {
|
|
1670
|
+
key: p,
|
|
1671
|
+
type: "button",
|
|
1672
|
+
"aria-current": true
|
|
1673
|
+
}, /*#__PURE__*/React__default["default"].createElement(Text, null, p)) : /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1674
|
+
key: p,
|
|
1675
|
+
type: "button",
|
|
1676
|
+
onClick: makeClickHandler(p)
|
|
1677
|
+
}, /*#__PURE__*/React__default["default"].createElement(Text, null, p));
|
|
1678
|
+
}), /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1679
|
+
type: "button",
|
|
1680
|
+
hidden: !hasNext,
|
|
1681
|
+
disabled: !hasNext,
|
|
1682
|
+
onClick: makeClickHandler(Math.min(pageCount, page + 1)),
|
|
1683
|
+
noBackground: true
|
|
1684
|
+
}, /*#__PURE__*/React__default["default"].createElement(WedgeIcon, {
|
|
1685
|
+
size: 16,
|
|
1686
|
+
direction: WedgeDirection.Right
|
|
1687
|
+
})));
|
|
1688
|
+
});
|
|
1689
|
+
function LinkPager(_ref2) {
|
|
1690
|
+
var page = _ref2.page,
|
|
1691
|
+
pageCount = _ref2.pageCount,
|
|
1692
|
+
makeUrl = _ref2.makeUrl;
|
|
1693
|
+
|
|
1694
|
+
var _useComponentAbstract = react.useComponentAbstraction(),
|
|
1695
|
+
Link = _useComponentAbstract.Link;
|
|
1696
|
+
|
|
1697
|
+
var window = usePagerWindow(page, pageCount);
|
|
1698
|
+
var hasNext = page < pageCount;
|
|
1699
|
+
var hasPrev = page > 1;
|
|
1700
|
+
return /*#__PURE__*/React__default["default"].createElement(PagerContainer, null, /*#__PURE__*/React__default["default"].createElement(Link, {
|
|
1701
|
+
to: makeUrl(Math.max(1, page - 1))
|
|
1702
|
+
}, /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1703
|
+
hidden: !hasPrev,
|
|
1704
|
+
"aria-disabled": !hasPrev,
|
|
1705
|
+
noBackground: true
|
|
1706
|
+
}, /*#__PURE__*/React__default["default"].createElement(WedgeIcon, {
|
|
1707
|
+
size: 16,
|
|
1708
|
+
direction: WedgeDirection.Left
|
|
1709
|
+
}))), window.map(function (p) {
|
|
1710
|
+
return p === '...' ? /*#__PURE__*/React__default["default"].createElement(Spacer, {
|
|
1711
|
+
key: p
|
|
1712
|
+
}, /*#__PURE__*/React__default["default"].createElement(DotsIcon, {
|
|
1713
|
+
size: 20,
|
|
1714
|
+
subLink: true
|
|
1715
|
+
})) : p === page ? /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1716
|
+
key: p,
|
|
1717
|
+
type: "button",
|
|
1718
|
+
"aria-current": true
|
|
1719
|
+
}, /*#__PURE__*/React__default["default"].createElement(Text, null, p)) : /*#__PURE__*/React__default["default"].createElement(Link, {
|
|
1720
|
+
key: p,
|
|
1721
|
+
to: makeUrl(p)
|
|
1722
|
+
}, /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1723
|
+
type: "button"
|
|
1724
|
+
}, /*#__PURE__*/React__default["default"].createElement(Text, null, p)));
|
|
1725
|
+
}), /*#__PURE__*/React__default["default"].createElement(Link, {
|
|
1726
|
+
to: makeUrl(Math.min(pageCount, page + 1))
|
|
1727
|
+
}, /*#__PURE__*/React__default["default"].createElement(CircleButton, {
|
|
1728
|
+
hidden: !hasNext,
|
|
1729
|
+
"aria-disabled": !hasNext,
|
|
1730
|
+
noBackground: true
|
|
1731
|
+
}, /*#__PURE__*/React__default["default"].createElement(WedgeIcon, {
|
|
1732
|
+
size: 16,
|
|
1733
|
+
direction: WedgeDirection.Right
|
|
1734
|
+
}))));
|
|
1735
|
+
}
|
|
1736
|
+
var PagerContainer = styled__default["default"].nav(_templateObject || (_templateObject = _taggedTemplateLiteralLoose(["\n display: flex;\n justify-content: center;\n align-items: center;\n"])));
|
|
1737
|
+
var CircleButton = styled__default["default"].button(_templateObject2 || (_templateObject2 = _taggedTemplateLiteralLoose(["\n font-size: 1rem;\n line-height: calc(1em + 8px);\n text-decoration: none;\n border: none;\n outline: none;\n touch-action: manipulation;\n user-select: none;\n transition: box-shadow 0.2s ease 0s, color 0.2s ease 0s,\n background 0.2s ease 0s, opacity 0.2s ease 0s;\n\n display: flex;\n justify-content: center;\n align-items: center;\n box-sizing: content-box;\n min-width: 24px;\n min-height: 24px;\n padding: 8px;\n cursor: pointer;\n font-weight: bold;\n /* HACK:\n * Safari doesn't correctly repaint the elements when they're reordered in response to interaction.\n * This forces it to repaint them. This doesn't work if put on the parents either, has to be here.\n */\n /* stylelint-disable-next-line property-no-vendor-prefix */\n -webkit-transform: translateZ(0);\n\n &[hidden] {\n visibility: hidden;\n display: block;\n }\n\n border-radius: 48px;\n\n background: transparent;\n color: ", ";\n\n &:hover {\n background: ", ";\n color: ", ";\n }\n\n &[aria-current] {\n background-color: ", ";\n color: ", ";\n }\n\n &[aria-current]:hover {\n background-color: ", ";\n color: ", ";\n }\n\n ", "\n"])), function (_ref3) {
|
|
1738
|
+
var theme = _ref3.theme;
|
|
1739
|
+
return theme.color.text3;
|
|
1740
|
+
}, function (_ref4) {
|
|
1741
|
+
var theme = _ref4.theme;
|
|
1742
|
+
return theme.color.surface3;
|
|
1743
|
+
}, function (_ref5) {
|
|
1744
|
+
var theme = _ref5.theme;
|
|
1745
|
+
return theme.color.text2;
|
|
1746
|
+
}, function (_ref6) {
|
|
1747
|
+
var theme = _ref6.theme;
|
|
1748
|
+
return theme.color.surface6;
|
|
1749
|
+
}, function (_ref7) {
|
|
1750
|
+
var theme = _ref7.theme;
|
|
1751
|
+
return theme.color.text5;
|
|
1752
|
+
}, function (_ref8) {
|
|
1753
|
+
var theme = _ref8.theme;
|
|
1754
|
+
return theme.color.surface6;
|
|
1755
|
+
}, function (_ref9) {
|
|
1756
|
+
var theme = _ref9.theme;
|
|
1757
|
+
return theme.color.text5;
|
|
1758
|
+
}, function (_ref10) {
|
|
1759
|
+
var _ref10$noBackground = _ref10.noBackground,
|
|
1760
|
+
noBackground = _ref10$noBackground === void 0 ? false : _ref10$noBackground;
|
|
1761
|
+
return noBackground && styled.css(_templateObject3 || (_templateObject3 = _taggedTemplateLiteralLoose(["\n /* stylelint-disable-next-line no-duplicate-selectors */\n &:hover {\n background: transparent;\n }\n "])));
|
|
1762
|
+
});
|
|
1763
|
+
var Spacer = styled__default["default"](CircleButton).attrs({
|
|
1764
|
+
type: 'button',
|
|
1765
|
+
disabled: true
|
|
1766
|
+
})(_templateObject4 || (_templateObject4 = _taggedTemplateLiteralLoose(["\n && {\n color: ", ";\n background: none;\n }\n"])), function (_ref11) {
|
|
1767
|
+
var theme = _ref11.theme;
|
|
1768
|
+
return theme.color.text3;
|
|
1769
|
+
});
|
|
1770
|
+
var Text = 'span';
|
|
1771
|
+
|
|
1772
|
+
Object.defineProperty(exports, 'ComponentAbstraction', {
|
|
1773
|
+
enumerable: true,
|
|
1774
|
+
get: function () { return react.ComponentAbstraction; }
|
|
1775
|
+
});
|
|
1776
|
+
Object.defineProperty(exports, 'useComponentAbstraction', {
|
|
1777
|
+
enumerable: true,
|
|
1778
|
+
get: function () { return react.useComponentAbstraction; }
|
|
1779
|
+
});
|
|
1780
|
+
exports.CancelLayoutItemBodyPadding = CancelLayoutItemBodyPadding;
|
|
1781
|
+
exports.Carousel = Carousel;
|
|
1782
|
+
exports.Filter = Filter;
|
|
1783
|
+
exports.FilterButton = FilterButton;
|
|
1784
|
+
exports.FilterIconButton = FilterIconButton;
|
|
1785
|
+
exports.FilterLink = FilterLink;
|
|
1786
|
+
exports.HintText = HintText;
|
|
1787
|
+
exports.LAYOUT_ITEM_BODY_PADDING = LAYOUT_ITEM_BODY_PADDING;
|
|
1788
|
+
exports.Layout = Layout;
|
|
1789
|
+
exports.LayoutItem = LayoutItem;
|
|
1790
|
+
exports.LayoutItemBody = LayoutItemBody;
|
|
1791
|
+
exports.LayoutItemHeader = LayoutItemHeader;
|
|
1792
|
+
exports.LeftMenu = LeftMenu;
|
|
1793
|
+
exports.LeftMenuContent = LeftMenuContent;
|
|
1794
|
+
exports.LinkPager = LinkPager;
|
|
1795
|
+
exports.MAIN_COLUMN_HORIZONTAL_MIN_MARGIN = MAIN_COLUMN_HORIZONTAL_MIN_MARGIN;
|
|
1796
|
+
exports.MenuListItem = MenuListItem;
|
|
1797
|
+
exports.MenuListItemContext = MenuListItemContext;
|
|
1798
|
+
exports.MenuListItemWithIcon = MenuListItemWithIcon;
|
|
1799
|
+
exports.MenuListLabel = MenuListLabel;
|
|
1800
|
+
exports.MenuListLinkItem = MenuListLinkItem;
|
|
1801
|
+
exports.MenuListLinkItemWithIcon = MenuListLinkItemWithIcon;
|
|
1802
|
+
exports.MenuListSpacer = MenuListSpacer;
|
|
1803
|
+
exports.Pager = index;
|
|
1804
|
+
exports.RESPONSIVE_LEFT_WIDTH = RESPONSIVE_LEFT_WIDTH;
|
|
1805
|
+
exports.RESPONSIVE_MAIN_MAX_WIDTH = RESPONSIVE_MAIN_MAX_WIDTH;
|
|
1806
|
+
exports.StyledCancelLayoutItemBodyPadding = StyledCancelLayoutItemBodyPadding;
|
|
1807
|
+
exports.StyledLayoutItemBody = StyledLayoutItemBody;
|
|
1808
|
+
exports.SwitchCheckbox = index$2;
|
|
1809
|
+
exports.TextEllipsis = TextEllipsis;
|
|
1810
|
+
exports.WithIcon = index$1;
|
|
1811
|
+
exports.useElementSize = useElementSize;
|
|
1812
|
+
exports.useLayoutItemBodyPadding = useLayoutItemBodyPadding;
|
|
1813
|
+
exports.useMedia = useMedia;
|
|
1814
|
+
exports.useMediaScreen1 = useMediaScreen1;
|
|
2
1815
|
//# sourceMappingURL=index.cjs.map
|