@edrlab/thorium-web 0.10.0 → 0.12.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/README.md CHANGED
@@ -34,7 +34,7 @@ The development server will automatically reload the page when you make changes
34
34
  To use Thorium Web in your own project, install the package and its peer dependencies:
35
35
 
36
36
  ```bash
37
- npm install @edrlab/thorium-web react-redux @reduxjs/toolkit motion react-aria react-aria-components react-stately react-modal-sheet react-resizable-panels
37
+ npm install @edrlab/thorium-web @readium/css @readium/navigator @readium/navigator-html-injectables @readium/shared react-redux @reduxjs/toolkit motion react-aria react-aria-components react-stately react-modal-sheet react-resizable-panels
38
38
  ```
39
39
 
40
40
  Then you can import and use the components in your own code:
@@ -148,17 +148,16 @@ var initialState2 = {
148
148
  layoutStrategy: "lineLength" /* lineLength */,
149
149
  letterSpacing: null,
150
150
  lineHeight: "publisher" /* publisher */,
151
- lineLength: null,
151
+ lineLength: {
152
+ optimal: 65
153
+ },
152
154
  paragraphIndent: null,
153
155
  paragraphSpacing: null,
154
156
  publisherStyles: true,
155
157
  scroll: false,
156
158
  textAlign: "publisher" /* publisher */,
157
159
  textNormalization: false,
158
- wordSpacing: null,
159
- tmpLineLengths: [],
160
- tmpMaxChars: false,
161
- tmpMinChars: false
160
+ wordSpacing: null
162
161
  };
163
162
  var settingsSlice = createSlice({
164
163
  name: "settings",
@@ -189,7 +188,41 @@ var settingsSlice = createSlice({
189
188
  state.lineHeight = action.payload;
190
189
  },
191
190
  setLineLength: (state, action) => {
192
- state.lineLength = action.payload;
191
+ const deriveIsDisabled = (value, isDisabled) => {
192
+ if (value === null) return true;
193
+ if (isDisabled !== void 0) return isDisabled;
194
+ return false;
195
+ };
196
+ switch (action.payload.key) {
197
+ case "optimal":
198
+ if (action.payload.value) {
199
+ state.lineLength = {
200
+ ...state.lineLength,
201
+ optimal: action.payload.value
202
+ };
203
+ }
204
+ break;
205
+ case "min":
206
+ state.lineLength = {
207
+ ...state.lineLength,
208
+ min: {
209
+ ...state.lineLength.min,
210
+ chars: action.payload.value !== void 0 ? action.payload.value : state.lineLength.min?.chars,
211
+ isDisabled: deriveIsDisabled(action.payload.value, action.payload.isDisabled)
212
+ }
213
+ };
214
+ break;
215
+ case "max":
216
+ state.lineLength = {
217
+ ...state.lineLength,
218
+ max: {
219
+ ...state.lineLength.max,
220
+ chars: action.payload.value !== void 0 ? action.payload.value : state.lineLength.max?.chars,
221
+ isDisabled: deriveIsDisabled(action.payload.value, action.payload.isDisabled)
222
+ }
223
+ };
224
+ break;
225
+ }
193
226
  },
194
227
  setParagraphIndent: (state, action) => {
195
228
  state.paragraphIndent = action.payload;
@@ -211,15 +244,6 @@ var settingsSlice = createSlice({
211
244
  },
212
245
  setWordSpacing: (state, action) => {
213
246
  state.wordSpacing = action.payload;
214
- },
215
- setTmpLineLengths: (state, action) => {
216
- state.tmpLineLengths = action.payload;
217
- },
218
- setTmpMaxChars: (state, action) => {
219
- state.tmpMaxChars = action.payload;
220
- },
221
- setTmpMinChars: (state, action) => {
222
- state.tmpMinChars = action.payload;
223
247
  }
224
248
  }
225
249
  });
@@ -239,10 +263,7 @@ var {
239
263
  setScroll,
240
264
  setTextAlign,
241
265
  setTextNormalization,
242
- setWordSpacing,
243
- setTmpLineLengths,
244
- setTmpMaxChars,
245
- setTmpMinChars
266
+ setWordSpacing
246
267
  } = settingsSlice.actions;
247
268
  var settingsReducer_default = settingsSlice.reducer;
248
269
  var initialState3 = {
@@ -600,6 +621,6 @@ var useAppDispatch = useDispatch;
600
621
  var useAppSelector = useSelector;
601
622
  var useAppStore = useStore;
602
623
 
603
- export { ThStoreProvider, actionsSlice, activateDockPanel, collapseDockPanel, deactivateDockPanel, dockAction, expandDockPanel, makeStore, publicationSlice, readerSlice, require_debounce, setActionOpen, setArrows, setBreakpoint, setColorScheme, setColumnCount, setContrast, setDirection, setDockPanelWidth, setFXL, setFontFamily, setFontSize, setFontWeight, setForcedColors, setFullscreen, setHovering, setHyphens, setImmersive, setLayoutStrategy, setLetterSpacing, setLineHeight, setLineLength, setLoading, setMonochrome, setOverflow, setParagraphIndent, setParagraphSpacing, setPlatformModifier, setPositionsList, setProgression, setPublicationEnd, setPublicationStart, setPublisherStyles, setRTL, setReducedMotion, setReducedTransparency, setRunningHead, setScroll, setSettingsContainer, setTextAlign, setTextNormalization, setTheme, setTmpLineLengths, setTmpMaxChars, setTmpMinChars, setTocEntry, setTocTree, setWordSpacing, settingsSlice, themeSlice, toggleActionOpen, toggleImmersive, useAppDispatch, useAppSelector, useAppStore };
604
- //# sourceMappingURL=chunk-IUF5GAPA.mjs.map
605
- //# sourceMappingURL=chunk-IUF5GAPA.mjs.map
624
+ export { ThStoreProvider, actionsSlice, activateDockPanel, collapseDockPanel, deactivateDockPanel, dockAction, expandDockPanel, makeStore, publicationSlice, readerSlice, require_debounce, setActionOpen, setArrows, setBreakpoint, setColorScheme, setColumnCount, setContrast, setDirection, setDockPanelWidth, setFXL, setFontFamily, setFontSize, setFontWeight, setForcedColors, setFullscreen, setHovering, setHyphens, setImmersive, setLayoutStrategy, setLetterSpacing, setLineHeight, setLineLength, setLoading, setMonochrome, setOverflow, setParagraphIndent, setParagraphSpacing, setPlatformModifier, setPositionsList, setProgression, setPublicationEnd, setPublicationStart, setPublisherStyles, setRTL, setReducedMotion, setReducedTransparency, setRunningHead, setScroll, setSettingsContainer, setTextAlign, setTextNormalization, setTheme, setTocEntry, setTocTree, setWordSpacing, settingsSlice, themeSlice, toggleActionOpen, toggleImmersive, useAppDispatch, useAppSelector, useAppStore };
625
+ //# sourceMappingURL=chunk-AFXHD6TS.mjs.map
626
+ //# sourceMappingURL=chunk-AFXHD6TS.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../node_modules/.pnpm/debounce@2.2.0/node_modules/debounce/index.js","../src/lib/readerReducer.ts","../src/lib/settingsReducer.ts","../src/lib/themeReducer.ts","../src/lib/actionsReducer.ts","../src/lib/publicationReducer.ts","../src/lib/store.ts","../src/lib/ThStoreProvider.tsx","../src/lib/hooks.ts"],"names":["debounce","initialState","createSlice"],"mappings":"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","file":"chunk-AFXHD6TS.mjs","sourcesContent":["function debounce(function_, wait = 100, options = {}) {\n\tif (typeof function_ !== 'function') {\n\t\tthrow new TypeError(`Expected the first parameter to be a function, got \\`${typeof function_}\\`.`);\n\t}\n\n\tif (wait < 0) {\n\t\tthrow new RangeError('`wait` must not be negative.');\n\t}\n\n\t// TODO: Deprecate the boolean parameter at some point.\n\tconst {immediate} = typeof options === 'boolean' ? {immediate: options} : options;\n\n\tlet storedContext;\n\tlet storedArguments;\n\tlet timeoutId;\n\tlet timestamp;\n\tlet result;\n\n\tfunction run() {\n\t\tconst callContext = storedContext;\n\t\tconst callArguments = storedArguments;\n\t\tstoredContext = undefined;\n\t\tstoredArguments = undefined;\n\t\tresult = function_.apply(callContext, callArguments);\n\t\treturn result;\n\t}\n\n\tfunction later() {\n\t\tconst last = Date.now() - timestamp;\n\n\t\tif (last < wait && last >= 0) {\n\t\t\ttimeoutId = setTimeout(later, wait - last);\n\t\t} else {\n\t\t\ttimeoutId = undefined;\n\n\t\t\tif (!immediate) {\n\t\t\t\tresult = run();\n\t\t\t}\n\t\t}\n\t}\n\n\tconst debounced = function (...arguments_) {\n\t\tif (\n\t\t\tstoredContext\n\t\t\t&& this !== storedContext\n\t\t\t&& Object.getPrototypeOf(this) === Object.getPrototypeOf(storedContext)\n\t\t) {\n\t\t\tthrow new Error('Debounced method called with different contexts of the same prototype.');\n\t\t}\n\n\t\tstoredContext = this; // eslint-disable-line unicorn/no-this-assignment\n\t\tstoredArguments = arguments_;\n\t\ttimestamp = Date.now();\n\n\t\tconst callNow = immediate && !timeoutId;\n\n\t\tif (!timeoutId) {\n\t\t\ttimeoutId = setTimeout(later, wait);\n\t\t}\n\n\t\tif (callNow) {\n\t\t\tresult = run();\n\t\t}\n\n\t\treturn result;\n\t};\n\n\tObject.defineProperty(debounced, 'isPending', {\n\t\tget() {\n\t\t\treturn timeoutId !== undefined;\n\t\t},\n\t});\n\n\tdebounced.clear = () => {\n\t\tif (!timeoutId) {\n\t\t\treturn;\n\t\t}\n\n\t\tclearTimeout(timeoutId);\n\t\ttimeoutId = undefined;\n\t};\n\n\tdebounced.flush = () => {\n\t\tif (!timeoutId) {\n\t\t\treturn;\n\t\t}\n\n\t\tdebounced.trigger();\n\t};\n\n\tdebounced.trigger = () => {\n\t\tresult = run();\n\n\t\tdebounced.clear();\n\t};\n\n\treturn debounced;\n}\n\n// Adds compatibility for ES modules\nmodule.exports.debounce = debounce;\n\nmodule.exports = debounce;\n","import { createSlice } from \"@reduxjs/toolkit\";\n\nimport { defaultPlatformModifier, UnstablePlatformModifier } from \"@/core/Helpers/keyboardUtilities\";\nimport { ThSettingsContainerKeys, ThLayoutDirection } from \"@/preferences/models/enums\";\n\nexport interface ReaderReducerState {\n direction: ThLayoutDirection;\n isLoading: boolean;\n isImmersive: boolean;\n isHovering: boolean;\n hasArrows: boolean;\n isFullscreen: boolean;\n settingsContainer: ThSettingsContainerKeys;\n platformModifier: UnstablePlatformModifier;\n}\n\nconst initialState: ReaderReducerState = {\n direction: ThLayoutDirection.ltr,\n isLoading: true,\n isImmersive: false,\n isHovering: false,\n hasArrows: true,\n isFullscreen: false,\n settingsContainer: ThSettingsContainerKeys.initial,\n platformModifier: defaultPlatformModifier\n}\n\nexport const readerSlice = createSlice({\n name: \"reader\",\n initialState,\n reducers: {\n setDirection: (state, action) => {\n state.direction = action.payload\n },\n setLoading: (state, action) => {\n state.isLoading = action.payload\n },\n setPlatformModifier: (state, action) => {\n state.platformModifier = action.payload\n },\n setImmersive: (state, action) => {\n state.isImmersive = action.payload\n },\n toggleImmersive: (state) => {\n state.isImmersive = !state.isImmersive;\n },\n setHovering: (state, action) => {\n state.isHovering = action.payload\n },\n setArrows: (state, action) => {\n state.hasArrows = action.payload\n },\n setFullscreen: (state, action) => {\n state.isFullscreen = action.payload\n },\n setSettingsContainer: (state, action) => {\n state.settingsContainer = action.payload\n }\n }\n})\n\n// Action creators are generated for each case reducer function\nexport const { \n setDirection, \n setLoading,\n setPlatformModifier, \n setImmersive, \n toggleImmersive, \n setHovering, \n setArrows, \n setFullscreen, \n setSettingsContainer\n} = readerSlice.actions;\n\nexport default readerSlice.reducer;","import { createSlice } from \"@reduxjs/toolkit\";\n\nimport { ThLineHeightOptions, ThTextAlignOptions, ThLayoutStrategy } from \"@/preferences/models/enums\";\nimport { defaultFontFamilyOptions } from \"@/preferences/models/const\";\n\nexport interface LineLengthStateObject {\n optimal: number;\n min?: {\n chars?: number | null;\n isDisabled?: boolean;\n },\n max?: {\n chars?: number | null;\n isDisabled?: boolean;\n }\n}\n\nexport interface SetLineLengthPayload {\n type: string;\n payload: {\n key: \"optimal\" | \"min\" | \"max\";\n value?: number | null;\n isDisabled?: boolean;\n }\n}\n\nexport interface SettingsReducerState {\n columnCount: string;\n fontFamily: keyof typeof defaultFontFamilyOptions;\n fontSize: number;\n fontWeight: number;\n hyphens: boolean | null;\n layoutStrategy: ThLayoutStrategy;\n letterSpacing: number | null;\n lineHeight: ThLineHeightOptions;\n lineLength: LineLengthStateObject;\n paragraphIndent: number | null;\n paragraphSpacing: number | null;\n publisherStyles: boolean;\n scroll: boolean;\n textAlign: ThTextAlignOptions;\n textNormalization: boolean;\n wordSpacing: number | null;\n}\n\nconst initialState: SettingsReducerState = {\n columnCount: \"auto\",\n fontFamily: \"publisher\",\n fontSize: 1,\n fontWeight: 400,\n hyphens: null,\n layoutStrategy: ThLayoutStrategy.lineLength,\n letterSpacing: null,\n lineHeight: ThLineHeightOptions.publisher,\n lineLength: {\n optimal: 65,\n },\n paragraphIndent: null,\n paragraphSpacing: null,\n publisherStyles: true,\n scroll: false,\n textAlign: ThTextAlignOptions.publisher,\n textNormalization: false,\n wordSpacing: null,\n}\n\nexport const settingsSlice = createSlice({\n name: \"settings\",\n initialState,\n reducers: {\n setColumnCount: (state, action) => {\n state.columnCount = action.payload\n },\n setFontFamily: (state, action) => {\n state.fontFamily = action.payload\n },\n setFontSize: (state, action) => {\n state.fontSize = action.payload\n },\n setFontWeight: (state, action) => {\n state.fontWeight = action.payload\n },\n setHyphens: (state, action) => {\n state.hyphens = action.payload\n },\n setLayoutStrategy: (state, action) => {\n state.layoutStrategy = action.payload\n },\n setLetterSpacing: (state, action) => {\n state.letterSpacing = action.payload\n },\n setLineHeight: (state, action) => {\n state.lineHeight = action.payload\n },\n setLineLength: (state, action: SetLineLengthPayload) => {\n // For min and max, we need to spread and handle isDisabled\n // when it is directly set, or depending on the payload value\n const deriveIsDisabled = (value: number | null | undefined, isDisabled?: boolean): boolean => {\n if (value === null) return true;\n if (isDisabled !== undefined) return isDisabled;\n return false;\n };\n\n switch (action.payload.key) {\n case \"optimal\":\n if (action.payload.value) {\n state.lineLength = {\n ...state.lineLength,\n optimal: action.payload.value\n };\n }\n break;\n \n case \"min\":\n state.lineLength = {\n ...state.lineLength,\n min: {\n ...state.lineLength.min,\n chars: action.payload.value !== undefined \n ? action.payload.value \n : state.lineLength.min?.chars,\n isDisabled: deriveIsDisabled(action.payload.value, action.payload.isDisabled)\n }\n };\n break;\n case \"max\":\n state.lineLength = {\n ...state.lineLength,\n max: {\n ...state.lineLength.max,\n chars: action.payload.value !== undefined \n ? action.payload.value \n : state.lineLength.max?.chars,\n isDisabled: deriveIsDisabled(action.payload.value, action.payload.isDisabled)\n }\n };\n break;\n default:\n break;\n }\n },\n setParagraphIndent: (state, action) => {\n state.paragraphIndent = action.payload\n },\n setParagraphSpacing: (state, action) => {\n state.paragraphSpacing = action.payload\n },\n setPublisherStyles: (state, action) => {\n state.publisherStyles = action.payload\n },\n setScroll: (state, action) => {\n state.scroll = action.payload\n },\n setTextAlign: (state, action) => {\n state.textAlign = action.payload\n },\n setTextNormalization: (state, action) => {\n state.textNormalization = action.payload\n },\n setWordSpacing: (state, action) => {\n state.wordSpacing = action.payload\n }\n }\n})\n\n// Action creators are generated for each case reducer function\nexport const { \n setColumnCount,\n setFontSize,\n setFontWeight, \n setFontFamily,\n setHyphens, \n setLayoutStrategy,\n setLetterSpacing,\n setLineHeight,\n setLineLength,\n setParagraphIndent,\n setParagraphSpacing,\n setPublisherStyles,\n setScroll,\n setTextAlign,\n setTextNormalization, \n setWordSpacing\n} = settingsSlice.actions;\n\nexport default settingsSlice.reducer;","import { createSlice } from \"@reduxjs/toolkit\";\n\nimport { ThColorScheme } from \"@/core/Hooks/useColorScheme\";\nimport { ThContrast } from \"@/core/Hooks/useContrast\";\nimport { ThBreakpoints } from \"@/preferences/models/enums\";\n\nexport interface ThemeReducerState {\n monochrome: boolean;\n colorScheme: ThColorScheme;\n theme: string;\n prefersReducedMotion: boolean;\n prefersReducedTransparency: boolean;\n prefersContrast: ThContrast;\n forcedColors: boolean;\n breakpoint?: ThBreakpoints;\n}\n\nconst initialState: ThemeReducerState = {\n monochrome: false,\n colorScheme: ThColorScheme.light,\n theme: \"auto\",\n prefersReducedMotion: false,\n prefersReducedTransparency: false, \n prefersContrast: ThContrast.none,\n forcedColors: false, \n breakpoint: undefined\n}\n\nexport const themeSlice = createSlice({\n name: \"theming\",\n initialState,\n reducers: {\n setMonochrome: (state, action) => {\n state.monochrome = action.payload\n },\n setColorScheme: (state, action) => {\n state.colorScheme = action.payload\n },\n setTheme: (state, action) => {\n state.theme = action.payload\n },\n setReducedMotion: (state, action) => {\n state.prefersReducedMotion = action.payload\n },\n setReducedTransparency: (state, action) => {\n state.prefersReducedTransparency = action.payload\n },\n setContrast: (state, action) => {\n state.prefersContrast = action.payload\n },\n setForcedColors: (state, action) => {\n state.forcedColors = action.payload\n },\n setBreakpoint: (state, action) => {\n state.breakpoint = action.payload\n }\n }\n})\n\n// Action creators are generated for each case reducer function\nexport const { \n setMonochrome, \n setColorScheme, \n setTheme, \n setReducedMotion, \n setReducedTransparency, \n setContrast, \n setForcedColors, \n setBreakpoint,\n} = themeSlice.actions;\n\nexport default themeSlice.reducer;","import { createSlice } from \"@reduxjs/toolkit\";\n\nimport { ThDockingKeys } from \"../preferences/models/enums\";\n\nexport type ActionsStateKeys = string;\nexport type OverflowStateKeys = string; \n\nexport interface ActionStateObject {\n isOpen?: boolean | null;\n docking?: ThDockingKeys | null;\n dockedWidth?: number;\n}\n\nexport interface OverflowStateObject {\n isOpen: boolean;\n}\n\nexport interface DockStateObject {\n actionKey: ActionsStateKeys | null;\n active: boolean;\n collapsed: boolean;\n width?: number;\n}\n\nexport interface ActionStateDockPayload {\n type: string;\n payload: {\n key: ActionsStateKeys;\n dockingKey: ThDockingKeys;\n }\n}\n\nexport interface ActionStateOpenPayload {\n type: string;\n payload: {\n key: ActionsStateKeys;\n isOpen: boolean;\n }\n}\n\nexport interface ActionStateTogglePayload {\n type: string;\n payload: {\n key: ActionsStateKeys\n }\n}\n\nexport interface ActionOverflowOpenPayload {\n type: string;\n payload: {\n key: OverflowStateKeys;\n isOpen: boolean;\n }\n}\n\nexport interface ActionStateDockedPayload {\n type: string;\n payload: { \n slot: ThDockingKeys.start | ThDockingKeys.end;\n docked: DockStateObject;\n }\n}\n\nexport interface ActionStateSlotPayload {\n type: string;\n payload: ThDockingKeys.start | ThDockingKeys.end;\n}\n\nexport interface ActionStateSlotWidthPayload {\n type: string;\n payload: { \n key: ThDockingKeys.start | ThDockingKeys.end;\n width: number;\n }\n}\n\nexport interface DockState {\n [ThDockingKeys.start]: DockStateObject;\n [ThDockingKeys.end]: DockStateObject;\n}\n\nexport type ActionsReducerState = {\n keys: {\n [key in ActionsStateKeys]?: ActionStateObject;\n };\n dock: DockState,\n overflow: {\n [key in OverflowStateKeys]?: OverflowStateObject;\n }\n}\n\nconst initialState: ActionsReducerState = {\n dock: {\n [ThDockingKeys.start]: {\n actionKey: null,\n active: false,\n collapsed: false\n },\n [ThDockingKeys.end]: {\n actionKey: null,\n active: false,\n collapsed: false\n }\n },\n keys: {},\n overflow: {}\n}\n\nexport const actionsSlice = createSlice({\n name: \"actions\",\n initialState,\n reducers: {\n dockAction: (state, action: ActionStateDockPayload) => {\n // The user should be able to override the dock slot\n // so we override the previous value, and sync \n // any other action with the same docking key\n switch(action.payload.dockingKey) {\n case ThDockingKeys.start:\n // We need to find if any other action has the same docking key. \n // If it does, we also have to close it so that its transient sheet \n // doesn’t pop over on the screen when it’s replaced\n for (const key in state.keys) {\n if (state.keys[key as ActionsStateKeys]?.docking === action.payload.dockingKey) {\n state.keys[key as ActionsStateKeys] = { \n ...state.keys[key as ActionsStateKeys],\n docking: ThDockingKeys.transient,\n isOpen: false\n };\n }\n }\n\n // We need to populate the docking slot\n state.dock[ThDockingKeys.start] = {\n ...state.dock[ThDockingKeys.start],\n actionKey: action.payload.key\n }\n // And remove it from the other one\n if (state.dock[ThDockingKeys.end].actionKey === action.payload.key) {\n state.dock[ThDockingKeys.end] = {\n ...state.dock[ThDockingKeys.end],\n actionKey: null\n }\n }\n break;\n\n case ThDockingKeys.end:\n // We need to find if any other action has the same docking key. \n // If it does, we also have to close it so that its transient sheet \n // doesn’t pop over on the screen when it’s replaced\n for (const key in state.keys) {\n if (state.keys[key as ActionsStateKeys]?.docking === action.payload.dockingKey) {\n state.keys[key as ActionsStateKeys] = { \n ...state.keys[key as ActionsStateKeys],\n docking: ThDockingKeys.transient,\n isOpen: false\n };\n }\n }\n\n // We need to populate the docking slot\n state.dock[ThDockingKeys.end] = {\n ...state.dock[ThDockingKeys.end],\n actionKey: action.payload.key\n }\n // And remove it from the other one\n if (state.dock[ThDockingKeys.start].actionKey === action.payload.key) {\n state.dock[ThDockingKeys.start] = {\n ...state.dock[ThDockingKeys.start],\n actionKey: null\n }\n }\n break;\n\n // We don’t need to sync another action\n case ThDockingKeys.transient:\n default: \n // We need to empty the docking slot\n if (state.dock[ThDockingKeys.start].actionKey === action.payload.key) {\n state.dock[ThDockingKeys.start] = {\n ...state.dock[ThDockingKeys.start],\n actionKey: null\n }\n }\n if (state.dock[ThDockingKeys.end].actionKey === action.payload.key) {\n state.dock[ThDockingKeys.end] = {\n ...state.dock[ThDockingKeys.end],\n actionKey: null\n }\n } \n break;\n }\n\n state.keys[action.payload.key] = { \n ...state.keys[action.payload.key],\n docking: action.payload.dockingKey \n };\n },\n setActionOpen: (state, action: ActionStateOpenPayload) => { \n // If the action is docked and set Open, we must take care of \n // the dock panel’s collapsibility. Otherwise we end up with bugs \n // i.e. user has to click/tap action icon twice to open, \n const dockingKey = state.keys[action.payload.key]?.docking;\n if (\n !action.payload.isOpen && \n dockingKey && \n dockingKey !== ThDockingKeys.transient &&\n state.dock[dockingKey].actionKey === action.payload.key &&\n state.dock[dockingKey].active &&\n state.dock[dockingKey].collapsed\n ) {\n state.dock[dockingKey] = {\n ...state.dock[dockingKey],\n collapsed: false\n }\n } else {\n state.keys[action.payload.key] = {\n ...state.keys[action.payload.key],\n isOpen: action.payload.isOpen \n };\n }\n },\n toggleActionOpen: (state, action: ActionStateTogglePayload) => {\n const payload = {\n key: action.payload.key,\n isOpen: state.keys[action.payload.key]?.isOpen ? !state.keys[action.payload.key]?.isOpen : true\n };\n actionsSlice.caseReducers.setActionOpen(state, {\n type: \"toggleActionOpen\",\n payload: payload\n });\n },\n setOverflow: (state, action: ActionOverflowOpenPayload) => {\n state.overflow[action.payload.key] = {\n ...state.overflow[action.payload.key],\n isOpen: action.payload.isOpen \n }\n },\n activateDockPanel: (state, action: ActionStateSlotPayload) => {\n state.dock[action.payload] = {\n ...state.dock[action.payload],\n active: true\n }\n },\n deactivateDockPanel: (state, action: ActionStateSlotPayload) => {\n state.dock[action.payload] = {\n ...state.dock[action.payload],\n active: false\n }\n },\n collapseDockPanel: (state, action: ActionStateSlotPayload) => {\n state.dock[action.payload] = {\n ...state.dock[action.payload],\n collapsed: true\n }\n },\n expandDockPanel: (state, action: ActionStateSlotPayload) => {\n state.dock[action.payload] = {\n ...state.dock[action.payload],\n collapsed: false\n }\n },\n setDockPanelWidth: (state, action: ActionStateSlotWidthPayload) => {\n // Copy the value in the action state \n // in case we do something with it later.\n\n const key: ActionsStateKeys | null = state.dock[action.payload.key].actionKey;\n if (key) {\n state.keys[key] = {\n ...state.keys[key],\n dockedWidth: action.payload.width\n }\n }\n\n // We only care if it’s populated.\n if (state.dock[action.payload.key] !== null) {\n state.dock[action.payload.key] = {\n ...state.dock[action.payload.key],\n width: action.payload.width\n }\n }\n }\n }\n})\n\nexport const { \n dockAction, \n setActionOpen, \n toggleActionOpen, \n setOverflow, \n activateDockPanel, \n deactivateDockPanel, \n collapseDockPanel,\n expandDockPanel, \n setDockPanelWidth\n} = actionsSlice.actions;\n\nexport default actionsSlice.reducer;","import { createSlice } from \"@reduxjs/toolkit\";\n\nimport { UnstableProgressionObject } from \"@/components/StatefulReaderProgression\";\nimport { TocItem } from \"@/helpers/createTocTree\";\nimport { Locator } from \"@readium/shared\";\n\nexport interface PublicationReducerState {\n runningHead?: string;\n isFXL: boolean;\n isRTL: boolean;\n progression: UnstableProgressionObject;\n positionsList: Locator[],\n atPublicationStart: boolean;\n atPublicationEnd: boolean;\n tocTree?: TocItem[];\n tocEntry?: string;\n}\n\nconst initialState: PublicationReducerState = {\n runningHead: undefined,\n isFXL: false,\n isRTL: false,\n progression: {},\n positionsList: [],\n atPublicationStart: false,\n atPublicationEnd: false,\n tocTree: undefined, \n tocEntry: undefined\n}\n\nexport const publicationSlice = createSlice({\n name: \"publication\",\n initialState,\n reducers: {\n setRunningHead: (state, action) => {\n state.runningHead = action.payload\n },\n setFXL: (state, action) => {\n state.isFXL = action.payload\n },\n setRTL: (state, action) => {\n state.isRTL = action.payload\n },\n setProgression: (state, action) => {\n state.progression = {...state.progression, ...action.payload }\n },\n setPositionsList: (state, action) => {\n state.positionsList = action.payload\n },\n setPublicationStart: (state, action) => {\n state.atPublicationStart = action.payload\n },\n setPublicationEnd: (state, action) => {\n state.atPublicationEnd = action.payload\n },\n setTocTree: (state, action) => {\n state.tocTree = action.payload;\n },\n setTocEntry: (state, action) => {\n state.tocEntry = action.payload;\n }\n }\n});\n\n// Action creators are generated for each case reducer function\nexport const { \n setRunningHead,\n setFXL,\n setRTL,\n setProgression,\n setPositionsList,\n setPublicationStart,\n setPublicationEnd,\n setTocTree, \n setTocEntry\n} = publicationSlice.actions;\n\nexport default publicationSlice.reducer;","import { ThDockingKeys } from \"@/preferences/models/enums\";\n\nimport { configureStore } from \"@reduxjs/toolkit\";\n\nimport readerReducer from \"@/lib/readerReducer\";\nimport settingsReducer from \"@/lib/settingsReducer\";\nimport themeReducer from \"@/lib/themeReducer\";\nimport actionsReducer, { ActionsReducerState } from \"@/lib/actionsReducer\";\nimport publicationReducer from \"./publicationReducer\";\n\nimport debounce from \"debounce\";\n\nconst DEFAULT_STORAGE_KEY = \"thorium-web-state\";\n\nconst updateActionsState = (state: ActionsReducerState) => {\n const updatedKeys = Object.fromEntries(\n Object.entries(state.keys).map(([key, value]) => [\n key,\n {\n ...value,\n isOpen: value?.docking === ThDockingKeys.transient || value?.docking === null && value?.isOpen === true ? false : value?.isOpen,\n },\n ])\n );\n\n return {\n ...state,\n keys: updatedKeys,\n overflow: {}\n };\n};\n\nconst loadState = (storageKey?: string) => {\n try {\n const resolvedKey = storageKey || DEFAULT_STORAGE_KEY;\n const serializedState = localStorage.getItem(resolvedKey);\n if (serializedState === null) {\n return { actions: undefined, settings: undefined, theming: undefined };\n }\n const deserializedState = JSON.parse(serializedState);\n deserializedState.actions = updateActionsState(deserializedState.actions);\n return deserializedState;\n } catch (err) {\n return { actions: undefined, settings: undefined, theming: undefined };\n }\n};\n\nconst saveState = (state: object, storageKey?: string) => {\n try {\n const resolvedKey = storageKey || DEFAULT_STORAGE_KEY;\n const serializedState = JSON.stringify(state);\n localStorage.setItem(resolvedKey, serializedState);\n } catch (err) {\n console.error(err);\n }\n};\n\nexport const makeStore = (storageKey?: string) => {\n const store = configureStore({\n reducer: {\n reader: readerReducer,\n settings: settingsReducer,\n theming: themeReducer,\n actions: actionsReducer,\n publication: publicationReducer\n },\n preloadedState: {\n actions: loadState(storageKey).actions,\n settings: loadState(storageKey).settings,\n theming: loadState(storageKey).theming\n },\n });\n\n const saveStateDebounced = debounce(() => {\n saveState(store.getState(), storageKey);\n }, 500);\n\n store.subscribe(saveStateDebounced);\n\n return store;\n}\n\n// Infer the type of makeStore\nexport type AppStore = ReturnType<typeof makeStore>;\n// Infer the `RootState` and `AppDispatch` types from the store itself\nexport type RootState = ReturnType<AppStore[\"getState\"]>;\nexport type AppDispatch = AppStore[\"dispatch\"];","\"use client\";\n\nimport { useRef } from \"react\";\nimport { Provider } from \"react-redux\";\nimport { makeStore, AppStore } from \"./store\";\n\nexport function ThStoreProvider({\n storageKey,\n store,\n children\n}: {\n storageKey?: string,\n store?: AppStore,\n children: React.ReactNode\n}) {\n const storeRef = useRef<AppStore | null>(null);\n if (!storeRef.current) {\n storeRef.current = store || makeStore(storageKey);\n }\n\n return <Provider store={ storeRef.current }>{ children }</Provider>\n}\n\nexport default ThStoreProvider;","import { TypedUseSelectorHook, useDispatch, useSelector, useStore } from \"react-redux\";\nimport type { AppDispatch, AppStore, RootState } from \"./store\";\n\n// Use throughout your app instead of plain `useDispatch` and `useSelector`\nexport const useAppDispatch: () => AppDispatch = useDispatch;\nexport const useAppSelector: TypedUseSelectorHook<RootState> = useSelector;\nexport const useAppStore: () => AppStore = useStore;"]}
@@ -997,7 +997,8 @@ var ThRadioGroup = ({
997
997
  {
998
998
  ...compounds?.radio,
999
999
  key: index,
1000
- value: item.value
1000
+ value: item.value,
1001
+ isDisabled: item.isDisabled
1001
1002
  },
1002
1003
  /* @__PURE__ */ jsxs(React19.Fragment, { children: [
1003
1004
  item.icon && /* @__PURE__ */ jsx(item.icon, { "aria-hidden": "true", focusable: "false" }),
@@ -1174,5 +1175,5 @@ var ThSettingsWrapper = ({
1174
1175
  };
1175
1176
 
1176
1177
  export { ThActionButton, ThActionsBar, ThActionsTriggerVariant, ThBottomSheet, ThCloseButton, ThCollapsibleActionsBar, ThContainerBody, ThContainerHeader, ThContainerHeaderWithClose, ThContainerHeaderWithPrevious, ThDockedPanel, ThDragIndicatorButton, ThDropdown, ThDropdownButton, ThFooter, ThForm, ThFormNumberField, ThFormSearchField, ThFormTextField, ThHeader, ThLoader, ThMenu, ThMenuButton, ThMenuItem, ThModal, ThNavigationButton, ThNumberField, ThPopover, ThProgression, ThRadioGroup, ThRunningHead, ThSettingsWrapper, ThSettingsWrapperButton, ThSlider, ThSwitch, ThTypedComponentRenderer, useActions, useFirstFocusable };
1177
- //# sourceMappingURL=chunk-SG5SZZVH.mjs.map
1178
- //# sourceMappingURL=chunk-SG5SZZVH.mjs.map
1178
+ //# sourceMappingURL=chunk-GSWRWFPI.mjs.map
1179
+ //# sourceMappingURL=chunk-GSWRWFPI.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/Components/Actions/hooks/useActions.ts","../src/core/Components/Actions/ThActionsBar.tsx","../src/core/Components/Menu/assets/icons/more_vert.svg","../src/core/Components/Buttons/ThActionButton.tsx","../src/core/Components/Menu/ThMenuButton.tsx","../src/core/Components/Menu/ThMenu.tsx","../src/core/Components/Actions/ThCollapsibleActionsBar.tsx","../src/core/Components/Buttons/assets/icons/close.svg","../src/core/Components/Buttons/ThCloseButton.tsx","../src/core/Components/Containers/ThBottomSheet/assets/icons/horizontal_rule.svg","../src/core/Components/Containers/ThBottomSheet/ThDragIndicatorButton.tsx","../src/core/Components/Buttons/assets/icons/arrow_back.svg","../src/core/Components/Buttons/assets/icons/arrow_forward.svg","../src/core/Components/Buttons/ThNavigationButton.tsx","../src/core/Components/Containers/hooks/useFirstFocusable.ts","../src/core/Components/Containers/ThPopover.tsx","../src/core/Components/Containers/ThModal.tsx","../src/core/Components/Containers/ThDockedPanel.tsx","../src/core/Components/Containers/ThContainerHeader/ThContainerHeader.tsx","../src/core/Components/Containers/ThContainerHeader/ThContainerHeaderWithClose.tsx","../src/core/Components/Containers/ThContainerHeader/ThContainerHeaderWithPrevious.tsx","../src/core/Components/Containers/ThContainerBody.tsx","../src/core/Components/Containers/ThBottomSheet/ThBottomSheet.tsx","../src/core/Components/Containers/ThTypedComponentRenderer.tsx","../src/core/Components/Form/ThForm.tsx","../src/core/Components/Form/Fields/ThFormNumberField.tsx","../src/core/Components/Form/Fields/ThFormTextField.tsx","../src/core/Components/Form/Fields/assets/icons/search.svg","../src/core/Components/Form/Fields/ThFormSearchField.tsx","../src/core/Components/Menu/ThMenuItem.tsx","../src/core/Components/Reader/ThFooter.tsx","../src/core/Components/Reader/ThLoader.tsx","../src/core/Components/Reader/ThHeader.tsx","../src/core/Components/Reader/ThProgression.tsx","../src/core/Components/Reader/ThRunningHead.tsx","../src/core/Components/Settings/assets/icons/add.svg","../src/core/Components/Settings/assets/icons/remove.svg","../src/core/Components/Settings/ThNumberField.tsx","../src/core/Components/Settings/ThRadioGroup.tsx","../src/core/Components/Settings/ThSlider.tsx","../src/core/Components/Settings/ThSwitch.tsx","../src/core/Components/Settings/ThDropdown/assets/icons/arrow_drop_down.svg","../src/core/Components/Settings/ThDropdown/ThDropdownButton.tsx","../src/core/Components/Settings/ThDropdown/ThDropdown.tsx","../src/core/Components/Settings/ThSettingsWrapper/assets/icons/settings.svg","../src/core/Components/Settings/ThSettingsWrapper/ThSettingsWrapperButton.tsx","../src/core/Components/Settings/ThSettingsWrapper/ThSettingsWrapper.tsx"],"names":["ThActionsTriggerVariant","jsx","jsxs","Fragment","React","useObjectRef","Button","useRef","input","element","Popover","Dialog","useEffect","FocusScope","Label","Input","Text","FieldError","NumberField","Heading","createElement"],"mappings":"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","file":"chunk-GSWRWFPI.mjs","sourcesContent":["\"use client\";\n\nimport { ActionStateObject } from \"@/lib/actionsReducer\";\n\nexport interface ThActionMap {\n [key: string | number | symbol]: ActionStateObject | undefined;\n}\n\nexport const useActions = <K extends string | number | symbol>(actionMap: ThActionMap) => {\n const findOpen = () => {\n const open: K[] = [];\n\n Object.entries(actionMap).forEach(([key, value]) => {\n if (value?.isOpen) open.push(key as K);\n });\n\n return open;\n };\n\n const anyOpen = () => {\n return Object.values(actionMap).some((value) => value?.isOpen);\n };\n\n const isOpen = (key?: K | null) => {\n if (key) {\n if (actionMap[key]?.isOpen == null) {\n return false;\n } else {\n return actionMap[key]?.isOpen;\n }\n }\n return false;\n };\n\n const findDocked = () => {\n const docked: K[] = [];\n\n Object.entries(actionMap).forEach(([key, value]) => {\n if (value?.docking) docked.push(key as K);\n });\n\n return docked;\n };\n\n const anyDocked = () => {\n return Object.values(actionMap).some((value) => value?.docking);\n };\n\n const isDocked = (key?: K | null) => {\n return key ? !!(actionMap[key]?.docking) : false;\n };\n\n const whichDocked = (key?: K | null) => {\n return key ? actionMap[key]?.docking : null;\n };\n\n const getDockedWidth = (key?: K | null) => {\n return key && actionMap[key]?.dockedWidth || undefined;\n };\n\n const everyOpenDocked = () => {\n const opens = findOpen();\n\n return opens.every((key) => {\n return isDocked(key);\n });\n };\n\n return {\n findOpen,\n anyOpen,\n isOpen,\n findDocked,\n anyDocked,\n isDocked,\n whichDocked,\n getDockedWidth,\n everyOpenDocked,\n };\n};","\"use client\";\n\nimport { useObjectRef } from \"react-aria\";\nimport { Toolbar, ToolbarProps } from \"react-aria-components\";\n\nexport enum ThActionsTriggerVariant {\n button = \"iconButton\",\n menu = \"menuItem\"\n}\n\nexport interface ThActionEntry<T> {\n key: T;\n associatedKey?: string;\n Trigger: React.ComponentType<any>;\n Target?: React.ComponentType<any>;\n}\n\nexport interface ThActionsBarProps extends ToolbarProps {\n ref?: React.ForwardedRef<HTMLDivElement>\n};\n\nexport const ThActionsBar = ({ \n ref, \n children, \n ...props \n}: ThActionsBarProps) => {\n const resolvedRef = useObjectRef(ref);\n\n return (\n <Toolbar \n ref={ resolvedRef } \n { ...props }\n >\n { children }\n </Toolbar>\n )\n}","import * as React from \"react\";\nconst SvgMoreVert = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M480-160q-33 0-56.5-23.5T400-240q0-33 23.5-56.5T480-320q33 0 56.5 23.5T560-240q0 33-23.5 56.5T480-160Zm0-240q-33 0-56.5-23.5T400-480q0-33 23.5-56.5T480-560q33 0 56.5 23.5T560-480q0 33-23.5 56.5T480-400Zm0-240q-33 0-56.5-23.5T400-720q0-33 23.5-56.5T480-800q33 0 56.5 23.5T560-720q0 33-23.5 56.5T480-640Z\" /></svg>;\nexport default SvgMoreVert;","\"use client\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { Button, ButtonProps, Tooltip, TooltipProps, TooltipTrigger } from \"react-aria-components\";\nimport { TooltipTriggerProps } from \"react-aria\";\n\nexport interface ThActionButtonProps extends ButtonProps {\n label?: string,\n ref?: React.ForwardedRef<HTMLButtonElement>,\n compounds?: {\n /**\n * Props for the tooltipTrigger component. See `TooltipTriggerProps` for more information.\n */\n tooltipTrigger?: WithRef<TooltipTriggerProps, HTMLDivElement>,\n /**\n * Props for the tooltip component. See `TooltipProps` for more information.\n */\n tooltip?: WithRef<TooltipProps, HTMLDivElement>,\n /**\n * String for the tooltip\n */\n label: string \n }\n}\n\nexport const ThActionButton = ({\n ref,\n compounds,\n children,\n ...props\n}: ThActionButtonProps) => { \n if (compounds) {\n return (\n <>\n <TooltipTrigger\n { ...compounds.tooltipTrigger }\n >\n <Button \n ref={ ref }\n { ...props }\n >\n { children } \n </Button>\n <Tooltip\n arrowBoundaryOffset={ 0 }\n { ...compounds.tooltip }\n >\n { compounds.label }\n </Tooltip>\n </TooltipTrigger>\n </>\n )\n } else {\n return (\n <>\n <Button \n { ...props }\n >\n { children }\n </Button>\n </>\n )\n }\n}","\"use client\";\n\nimport MoreVertIcon from \"./assets/icons/more_vert.svg\";\n\nimport { ThActionButton, ThActionButtonProps } from \"../Buttons/ThActionButton\";\n\nexport const ThMenuButton = ({\n label,\n ref,\n compounds,\n children,\n ...props\n}: ThActionButtonProps) => {\n return (\n <ThActionButton\n ref={ ref }\n compounds={ compounds }\n { ...props }\n >\n { children \n ? children \n : <>\n <MoreVertIcon aria-hidden=\"true\" focusable=\"false\" /> \n { label }\n </> \n }\n </ThActionButton>\n )\n}","\"use client\";\n\nimport React, { useRef } from \"react\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { Menu, MenuProps, MenuTrigger, MenuTriggerProps, Popover, PopoverProps } from \"react-aria-components\";\n\nimport { ThMenuButton } from \"./ThMenuButton\";\nimport { ThActionButtonProps } from \"../Buttons\";\nimport { ThActionEntry, ThActionsTriggerVariant } from \"../Actions/ThActionsBar\";\n\nexport interface THMenuProps<T> extends MenuProps<ThActionEntry<T>> {\n ref?: React.ForwardedRef<HTMLDivElement>;\n triggerRef?: React.RefObject<HTMLElement | null>;\n items?: Iterable<ThActionEntry<T>>;\n children?: never;\n compounds?: {\n /**\n * Props for the trigger component. See `MenuTriggerProps` for more information.\n */\n menuTrigger?: Omit<WithRef<MenuTriggerProps, HTMLDivElement>, \"children\">;\n /**\n * Props for the button component. See `ThActionButtonProps` for more information.\n * Alternatively you can provide your own component\n */\n button?: ThActionButtonProps | React.ReactElement<ThActionButtonProps>;\n /**\n * Props for the popover component. See `PopoverProps` for more information.\n */\n popover?: WithRef<PopoverProps, HTMLDivElement>;\n }\n}\n\nexport const ThMenu = ({\n ref,\n id,\n triggerRef,\n items,\n dependencies,\n compounds,\n ...props\n}: THMenuProps<string>) => {\n const buttonRef = useRef<HTMLButtonElement | null>(null);\n\n if (items) {\n return (\n <>\n <MenuTrigger \n { ...compounds?.menuTrigger }\n >\n { compounds?.button && React.isValidElement(compounds.button) \n ? compounds.button \n : <ThMenuButton \n ref={ buttonRef }\n { ...compounds?.button as ThActionButtonProps }\n />\n }\n <Popover { ...compounds?.popover }>\n <Menu \n ref={ ref }\n id={ id }\n dependencies={ dependencies }\n { ...props }\n >\n { Array.from(items).map(({ Trigger, key, associatedKey }) => \n <Trigger \n key={ `${ key }-menuItem` } \n variant={ ThActionsTriggerVariant.menu }\n { ...(associatedKey ? { associatedKey: associatedKey } : {}) } \n { ...props }\n />\n )}\n </Menu>\n </Popover>\n </MenuTrigger>\n { Array.from(items).map(({ Target, key }) => \n Target && <Target key={ `${ key }-container` } triggerRef={ triggerRef || buttonRef } { ...props } />\n )}\n </>\n )\n }\n}","\"use client\";\n\nimport React, { Fragment } from \"react\";\n\nimport { ThActionEntry, ThActionsBar, ThActionsBarProps, ThActionsTriggerVariant } from \"./ThActionsBar\";\nimport { ThMenu, THMenuProps } from \"../Menu/ThMenu\";\n\nimport { useObjectRef } from \"react-aria\";\nimport { CollapsiblePref, useCollapsibility } from \"./hooks/useCollapsibility\";\n\nexport interface ThCollapsibleActionsBarProps extends ThActionsBarProps {\n id: string;\n items: ThActionEntry<string>[];\n prefs: CollapsiblePref;\n breakpoint?: string;\n children?: never;\n compounds?: {\n menu: THMenuProps<string> | React.ReactElement<typeof ThMenu>;\n }\n}\n\nexport const ThCollapsibleActionsBar = ({\n ref,\n id,\n items,\n prefs,\n breakpoint,\n compounds,\n ...props\n}: ThCollapsibleActionsBarProps) => {\n const resolvedRef = useObjectRef(ref);\n const Actions = useCollapsibility(items, prefs, breakpoint);\n\n return (\n <>\n <ThActionsBar \n ref={ resolvedRef }\n { ...props }\n >\n { Actions.ActionIcons.map(({ Trigger, Target, key, associatedKey }) => \n <Fragment key={ key }>\n <Trigger \n key={ `${ key }-trigger` } \n variant={ ThActionsTriggerVariant.button }\n { ...(associatedKey ? { associatedKey: associatedKey } : {}) } \n { ...props }\n />\n { Target && <Target key={ `${ key }-container` } triggerRef={ resolvedRef } /> }\n </Fragment>\n ) \n }\n\n { React.isValidElement(compounds?.menu) \n ? (React.cloneElement(compounds.menu, {\n ...compounds.menu.props,\n id: id,\n triggerRef: resolvedRef,\n items: Actions.MenuItems,\n dependencies: [\"Trigger\"],\n } as THMenuProps<string>)) \n : (<ThMenu \n id={ id } \n triggerRef={ resolvedRef }\n items={ Actions.MenuItems }\n dependencies={ [\"Trigger\"] }\n { ...compounds?.menu }\n />\n )}\n </ThActionsBar>\n </>\n )\n}\n","import * as React from \"react\";\nconst SvgClose = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"m256-200-56-56 224-224-224-224 56-56 224 224 224-224 56 56-224 224 224 224-56 56-224-224-224 224Z\" /></svg>;\nexport default SvgClose;","\"use client\";\n\nimport Close from \"./assets/icons/close.svg\";\n\nimport { ThActionButton, ThActionButtonProps } from \"./ThActionButton\";\n\nexport const ThCloseButton = ({\n label,\n ref,\n compounds,\n children,\n ...props\n}: ThActionButtonProps) => {\n return (\n <ThActionButton\n ref={ ref }\n compounds={ compounds }\n { ...props }\n >\n { children \n ? children \n : <>\n <Close aria-hidden=\"true\" focusable=\"false\" /> \n { label }\n </> \n }\n </ThActionButton>\n )\n}","import * as React from \"react\";\nconst SvgHorizontalRule = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M200-440q-17 0-28.5-11.5T160-480q0-17 11.5-28.5T200-520h560q17 0 28.5 11.5T800-480q0 17-11.5 28.5T760-440H200Z\" /></svg>;\nexport default SvgHorizontalRule;","\"use client\";\n\nimport HorizontalRule from \"./assets/icons/horizontal_rule.svg\";\n\nimport { Button, ButtonProps } from \"react-aria-components\";\n\nexport interface ThDragIndicatorButtonProps extends ButtonProps {\n ref?: React.ForwardedRef<HTMLButtonElement>;\n}\n\nexport const ThDragIndicatorButton = ({\n ref,\n children,\n ...props\n}: ThDragIndicatorButtonProps) => {\n return (\n <>\n <Button \n ref={ ref }\n { ...props }\n >\n { children ? children : <HorizontalRule aria-hidden=\"true\" focusable=\"false\" /> }\n </Button>\n </>\n )\n}","import * as React from \"react\";\nconst SvgArrowBack = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M640-80 240-480l400-400 71 71-329 329 329 329-71 71Z\" /></svg>;\nexport default SvgArrowBack;","import * as React from \"react\";\nconst SvgArrowForward = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"m321-80-71-71 329-329-329-329 71-71 400 400L321-80Z\" /></svg>;\nexport default SvgArrowForward;","\"use client\";\n\nimport React from \"react\";\n\nimport ArrowBack from \"./assets/icons/arrow_back.svg\";\nimport ArrowForward from \"./assets/icons/arrow_forward.svg\";\n\nimport { ThActionButton, ThActionButtonProps } from \"./ThActionButton\";\n\nexport interface ThNavigationButtonProps extends ThActionButtonProps {\n direction?: \"left\" | \"right\";\n}\n\nexport const ThNavigationButton = ({\n direction,\n label,\n ref,\n compounds,\n children,\n ...props\n}: ThNavigationButtonProps) => {\n const fallBackChildren = (\n <React.Fragment>\n { direction === \"right\"\n ? <ArrowForward aria-hidden=\"true\" focusable=\"false\" />\n : <ArrowBack aria-hidden=\"true\" focusable=\"false\" />\n }\n { label }\n </React.Fragment>\n );\n\n return (\n <ThActionButton\n ref={ ref }\n compounds={ compounds }\n { ...props }\n >\n { children || fallBackChildren }\n </ThActionButton>\n )\n}\n","\"use client\";\n\nimport { useEffect, useRef } from \"react\";\n\nexport interface UseFirstFocusableProps {\n withinRef?: React.RefObject<HTMLElement | null>;\n fallbackRef?: React.RefObject<HTMLElement | null>;\n scrollerRef?: React.RefObject<HTMLElement | null>;\n trackedState?: boolean;\n autoFocus?: boolean;\n updateState?: unknown;\n}\n\nexport const useFirstFocusable = (props?: UseFirstFocusableProps) => {\n const { withinRef, fallbackRef, scrollerRef, trackedState, autoFocus = true, updateState } = props ?? {};\n\n const focusableElement = useRef<HTMLElement | null>(null);\n const attemptsRef = useRef(0);\n\n useEffect(() => {\n if (!withinRef || !trackedState) return;\n\n attemptsRef.current = 0;\n\n const tryFocus = () => {\n const targetElement = withinRef.current && withinRef.current.firstElementChild || withinRef.current;\n const selectedEl = targetElement && targetElement.querySelector(\"[data-selected]\");\n\n let firstFocusable: HTMLElement | null = null;\n\n if (selectedEl === null) {\n const inputs = targetElement && targetElement.querySelectorAll(\"input\");\n const input = inputs && Array.from(inputs).find((input: HTMLInputElement) => !input.disabled && input.tabIndex >= 0);\n firstFocusable = input as HTMLElement | null;\n } else if (selectedEl instanceof HTMLElement) {\n firstFocusable = selectedEl;\n }\n\n if (!firstFocusable) {\n const focusableElements = withinRef.current && withinRef.current.querySelectorAll(\"a, button, input, select\");\n const element = focusableElements && Array.from(focusableElements).find(element => {\n const htmlElement = element as HTMLAnchorElement | HTMLButtonElement | HTMLInputElement | HTMLSelectElement;\n if (htmlElement instanceof HTMLAnchorElement) return true;\n return !htmlElement.disabled && htmlElement.tabIndex >= 0;\n });\n firstFocusable = element as HTMLElement | null;\n }\n\n if (firstFocusable) {\n if (autoFocus) {\n firstFocusable.focus({ preventScroll: true });\n if (scrollerRef?.current) {\n scrollerRef.current.scrollTop = 0;\n } else {\n withinRef.current!.scrollTop = 0;\n }\n }\n focusableElement.current = firstFocusable;\n } else {\n attemptsRef.current++;\n if (attemptsRef.current < 3) {\n setTimeout(tryFocus, 50);\n } else {\n if (fallbackRef?.current) {\n if (autoFocus) {\n fallbackRef.current.focus({ preventScroll: true });\n }\n focusableElement.current = fallbackRef.current;\n }\n }\n }\n };\n\n tryFocus();\n\n return () => {\n attemptsRef.current = 0;\n };\n }, [withinRef, fallbackRef, scrollerRef, trackedState, autoFocus, updateState]);\n\n return focusableElement.current;\n};","\"use client\";\n\nimport React from \"react\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { ThContainerProps } from \"./ThContainer\";\n\nimport { Dialog, DialogProps, Popover, PopoverProps } from \"react-aria-components\";\n\nimport { useObjectRef } from \"react-aria\";\nimport { useFirstFocusable } from \"./hooks/useFirstFocusable\";\n\nexport interface ThPopoverProps extends Omit<PopoverProps, \"children\">, ThContainerProps {\n triggerRef: React.RefObject<HTMLElement | null>;\n compounds?: {\n dialog: WithRef<DialogProps, HTMLDivElement>;\n }\n}\n\nexport const ThPopover = ({ \n ref,\n triggerRef,\n focusOptions,\n compounds,\n maxHeight,\n children, \n ...props \n}: ThPopoverProps) => {\n const resolvedRef = useObjectRef(ref as React.RefObject<HTMLDivElement | null>);\n\n useFirstFocusable(focusOptions);\n\n const computeMaxHeight = () => {\n if (!resolvedRef.current) return;\n return window.innerHeight - resolvedRef.current.offsetTop;\n };\n\n return (\n <Popover \n ref={ resolvedRef }\n triggerRef={ triggerRef }\n maxHeight={ maxHeight || computeMaxHeight() }\n { ...props }\n >\n <Dialog { ...compounds?.dialog }>\n { children }\n </Dialog>\n </Popover>\n )\n}","\"use client\";\n\nimport React from \"react\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { ThContainerProps } from \"./ThContainer\";\n\nimport { Dialog, DialogProps, Modal, ModalOverlayProps } from \"react-aria-components\";\n\nimport { useObjectRef } from \"react-aria\";\nimport { useFirstFocusable } from \"./hooks/useFirstFocusable\";\n\nexport interface ThModalProps extends Omit<ModalOverlayProps, \"children\">, ThContainerProps {\n compounds?: {\n dialog: WithRef<DialogProps, HTMLDivElement>;\n }\n}\n\nexport const ThModal = ({ \n ref,\n focusOptions,\n compounds,\n children, \n ...props \n}: ThModalProps) => {\n const resolvedRef = useObjectRef(ref as React.RefObject<HTMLDivElement | null>);\n\n useFirstFocusable(focusOptions);\n\n return (\n <Modal \n ref={ resolvedRef }\n { ...props }\n >\n <Dialog { ...compounds?.dialog }>\n { children }\n </Dialog>\n </Modal>\n )\n}","\"use client\";\n\nimport React from \"react\";\nimport { createPortal } from \"react-dom\";\n\nimport { ThContainerProps } from \"./ThContainer\";\n\nimport { FocusScope, useObjectRef } from \"react-aria\";\nimport { useFirstFocusable } from \"./hooks/useFirstFocusable\";\n\nexport interface ThDockedPanelProps extends Omit<React.HTMLAttributes<HTMLDivElement>, \"children\">, ThContainerProps {\n isOpen: boolean;\n portal: HTMLElement | null;\n}\n\nexport const ThDockedPanel = ({ \n ref,\n isOpen,\n portal,\n focusOptions,\n children, \n ...props \n}: ThDockedPanelProps) => {\n const resolvedRef = useObjectRef(ref as React.RefObject<HTMLDivElement | null>);\n\n useFirstFocusable(focusOptions);\n\n return (\n <>\n { isOpen && portal && createPortal(\n <FocusScope \n contain={ false }\n autoFocus={ focusOptions?.autoFocus ?? true } \n restoreFocus={ true }\n >\n <div\n ref={ resolvedRef } \n { ...props }\n >\n { children }\n </div>\n </FocusScope>\n , portal)\n }\n </>\n )\n}","\"use client\";\n\nimport { Heading, HeadingProps } from \"react-aria-components\";\nimport { HTMLAttributesWithRef, WithRef } from \"../../customTypes\";\n\nexport interface ThContainerHeaderProps extends HTMLAttributesWithRef<HTMLDivElement> {\n ref?: React.ForwardedRef<HTMLDivElement>;\n label: string;\n compounds?: {\n heading?: WithRef<HeadingProps, HTMLHeadingElement>;\n }\n}\n\nexport const ThContainerHeader = ({ \n ref,\n label,\n compounds,\n children,\n ...props \n}: ThContainerHeaderProps) => {\n return (\n <div \n ref={ ref } \n { ...props }\n >\n <Heading \n slot=\"title\"\n { ...compounds?.heading }\n >\n { label }\n </Heading>\n { children }\n </div>\n )\n}","\"use client\";\n\nimport { WithRef } from \"../../customTypes\";\n\nimport { HeadingProps } from \"react-aria-components\";\nimport { ThActionButtonProps, ThCloseButton } from \"../../Buttons\";\nimport { ThContainerHeader, ThContainerHeaderProps } from \"./ThContainerHeader\"\n\nexport interface THContainerWithCloseProps extends ThContainerHeaderProps {\n closeRef?: React.ForwardedRef<HTMLButtonElement>;\n children?: never;\n compounds?: {\n heading: WithRef<HeadingProps, HTMLHeadingElement>;\n button: ThActionButtonProps;\n }\n}\nexport const ThContainerHeaderWithClose = ({ \n ref,\n closeRef,\n label,\n compounds,\n ...props \n}: THContainerWithCloseProps) => {\n return (\n <ThContainerHeader \n ref={ ref } \n label={ label }\n { ...props }\n compounds={ { heading: compounds?.heading }}\n >\n <ThCloseButton ref={ closeRef } { ...compounds?.button } />\n </ThContainerHeader>\n )\n}","\"use client\";\n\nimport { WithRef } from \"../../customTypes\";\n\nimport { HeadingProps } from \"react-aria-components\";\nimport { ThNavigationButton, ThNavigationButtonProps } from \"../../Buttons\";\nimport { ThContainerHeader, ThContainerHeaderProps } from \"./ThContainerHeader\"\n\nexport interface THContainerWithPreviousProps extends ThContainerHeaderProps {\n previousRef?: React.ForwardedRef<HTMLButtonElement>;\n children?: never;\n compounds?: {\n heading: WithRef<HeadingProps, HTMLHeadingElement>;\n button: ThNavigationButtonProps;\n }\n}\nexport const ThContainerHeaderWithPrevious = ({ \n ref,\n previousRef,\n label,\n compounds,\n ...props \n}: THContainerWithPreviousProps) => {\n return (\n <ThContainerHeader \n ref={ ref } \n label={ label }\n { ...props }\n compounds={ { heading: compounds?.heading }}\n >\n <ThNavigationButton ref={ previousRef } { ...compounds?.button } />\n </ThContainerHeader>\n )\n}","\"use client\";\n\nimport { HTMLAttributesWithRef } from \"../customTypes\";\n\nexport interface ThContainerBodyProps extends HTMLAttributesWithRef<HTMLDivElement> {}\n\nexport const ThContainerBody = ({ \n ref,\n children,\n ...props \n}: ThContainerBodyProps) => {\n return (\n <div \n ref={ ref } \n { ...props }\n >\n { children }\n </div>\n )\n}","\"use client\";\n\nimport React, { \n CSSProperties,\n RefObject, \n useCallback, \n useEffect, \n useMemo, \n useState \n} from \"react\";\n\nimport { OverlayTriggerState, useOverlayTriggerState } from \"react-stately\";\n\nimport { ThContainerHeader, ThContainerHeaderProps } from \"../ThContainerHeader\";\nimport { ThContainerBody } from \"../ThContainerBody\";\nimport { ThContainerProps } from \"../ThContainer\";\nimport { useFirstFocusable, UseFirstFocusableProps } from \"../hooks/useFirstFocusable\";\n\nimport { ThDragIndicatorButton, ThDragIndicatorButtonProps } from \"./ThDragIndicatorButton\";\n\nimport { Sheet, SheetRef } from \"react-modal-sheet\";\nimport { HeadingProps } from \"react-aria-components\";\nimport { \n AriaOverlayProps, \n FocusScope, \n OverlayProvider, \n useDialog, \n useModal, \n useObjectRef, \n useOverlay \n} from \"react-aria\";\n\nexport interface ThBottomSheetHeaderProps extends ThContainerHeaderProps {\n wrapper: React.ComponentProps<typeof Sheet.Header>,\n dragIndicator: React.ComponentProps<typeof ThDragIndicatorButton>,\n header: ThContainerHeaderProps,\n heading: HeadingProps\n}\n\nexport interface ThBottomSheetCompounds {\n container?: Omit<React.ComponentProps<typeof Sheet.Container>, \"children\">,\n header?: React.ComponentProps<typeof Sheet.Header>,\n dragIndicator?: ThDragIndicatorButtonProps,\n content?: React.ComponentProps<typeof Sheet.Content>,\n scroller?: React.ComponentProps<typeof Sheet.Scroller>,\n backdrop?: React.ComponentProps<typeof Sheet.Backdrop>\n}\n\nexport interface ThBottomSheetProps extends Omit<React.ComponentProps<typeof Sheet>, \"children\" | \"ref\" | \"isOpen\" | \"onClose\">, AriaOverlayProps, ThContainerProps {\n onOpenChange?: (isOpen: boolean) => void;\n isKeyboardDismissDisabled?: boolean;\n compounds?: ThBottomSheetCompounds;\n}\n\nconst ThBottomSheetContainer = ({\n sheetRef,\n sheetState,\n isDraggable, \n isKeyboardDismissDisabled,\n focusOptions,\n compounds,\n children\n}: {\n sheetRef: RefObject<HTMLDivElement | SheetRef | null>;\n sheetState: OverlayTriggerState;\n onFullHeight?: Omit<React.ComponentProps<typeof Sheet.Container>, \"children\">;\n isDraggable?: boolean;\n isKeyboardDismissDisabled?: boolean;\n focusOptions?: UseFirstFocusableProps;\n compounds?: ThBottomSheetCompounds;\n children: ThContainerProps[\"children\"];\n}) => {\n const containerRef = useObjectRef(compounds?.container?.ref);\n const scrollerRef = useObjectRef(compounds?.scroller?.ref);\n const dialog = useDialog({}, containerRef);\n const overlay = useOverlay({ \n onClose: sheetState.close, \n isOpen: true, \n isDismissable: true,\n isKeyboardDismissDisabled: isKeyboardDismissDisabled\n }, containerRef);\n const [isFullHeight, setFullHeight] = useState<boolean>(false);\n\n useModal();\n\n const fullHeightIntersectionCallback = useCallback((entries: IntersectionObserverEntry[]) => {\n entries.forEach( (entry) => {\n if (\n entry.isIntersecting && \n entry.intersectionRatio === 1 && \n // For some reason width is larger on mobile (and border-right is almost invisible)…\n entry.boundingClientRect.width >= window.innerWidth\n ) {\n setFullHeight(true);\n } else {\n setFullHeight(false);\n }\n });\n }, [setFullHeight]);\n\n useEffect(() => {\n const observer = new IntersectionObserver(fullHeightIntersectionCallback, {\n threshold: 1.0\n });\n containerRef.current && observer.observe(containerRef.current);\n\n return () => {\n observer.disconnect();\n }\n });\n\n const [Header, Body] = useMemo(() => {\n const header = children.find((child) => child.type === ThContainerHeader);\n const body = children.find((child) => child.type === ThContainerBody);\n \n const modifiedHeader = header ? React.cloneElement(header as React.ReactElement<ThContainerHeaderProps>, {\n ...header.props,\n compounds: {\n ...(header.props as ThContainerHeaderProps).compounds,\n heading: {\n ...(header.props as ThContainerHeaderProps).compounds?.heading,\n ...dialog.titleProps\n }\n }\n }) : null;\n\n return [modifiedHeader, body];\n }, [children, dialog.titleProps]);\n\n const updatedFocusOptions = focusOptions ? {\n ...focusOptions,\n scrollerRef: scrollerRef\n } : undefined;\n\n useFirstFocusable(updatedFocusOptions);\n\n return (\n <>\n <Sheet.Container \n { ...compounds?.container }\n ref={ containerRef }\n {...(isFullHeight ? { \"data-full-height\": \"true\" } : {} )}\n { ...overlay.overlayProps as any}\n { ...dialog.dialogProps }\n >\n <Sheet.Header\n { ...compounds?.header }\n >\n { isDraggable && \n <ThDragIndicatorButton \n { ...compounds?.dragIndicator }\n /> \n }\n { Header }\n </Sheet.Header>\n <Sheet.Content \n { ...compounds?.content }\n // Motion being picky with style on bundling so we have to cast like this… \n { ...(isDraggable ? { style: { paddingBottom: (sheetRef.current as SheetRef)?.y }} as { [key: string]: any } : {} )}\n >\n <Sheet.Scroller \n ref={ scrollerRef }\n { ...compounds?.scroller }\n // This is enabled by default since 4.4 but breaks scroll on focus…\n autoPadding={ false }\n >\n { Body }\n </Sheet.Scroller>\n </Sheet.Content>\n </Sheet.Container>\n <Sheet.Backdrop \n { ...compounds?.backdrop }\n />\n </>\n )\n}\n\nexport const ThBottomSheet = ({\n id,\n isOpen,\n onOpenChange,\n ref,\n focusOptions,\n isKeyboardDismissDisabled,\n detent,\n snapPoints,\n compounds,\n children, \n ...props\n}: ThBottomSheetProps) => {\n const resolvedRef = useObjectRef(ref);\n\n let sheetState = useOverlayTriggerState({\n isOpen: isOpen,\n onOpenChange: onOpenChange\n });\n\n const isDraggable = useMemo(() => snapPoints && snapPoints.length > 1, [snapPoints]);\n\n return(\n <>\n <Sheet\n ref={ resolvedRef }\n isOpen={ sheetState.isOpen }\n onClose={ sheetState.close }\n // Otherwise buggy with prefersReducedMotion\n // as the bottom sheet won’t be displayed on mount\n style={{\n zIndex: isOpen ? \"999999\" : \"-1\",\n visibility: isOpen ? \"visible\" : \"hidden\"\n } as CSSProperties }\n detent={ detent }\n snapPoints={ snapPoints }\n { ...props }\n >\n <OverlayProvider>\n <FocusScope \n contain={ true } \n autoFocus={ focusOptions?.autoFocus ?? true } \n restoreFocus={ true }\n >\n <ThBottomSheetContainer \n sheetRef={ resolvedRef } \n sheetState={ sheetState } \n isDraggable= { isDraggable }\n isKeyboardDismissDisabled={ isKeyboardDismissDisabled }\n focusOptions={ focusOptions }\n compounds={ compounds }\n >\n { children }\n </ThBottomSheetContainer>\n </FocusScope>\n </OverlayProvider>\n </Sheet> \n </>\n )\n}","\"use client\";\n\nimport React, { ReactNode } from \"react\";\n\nexport type ComponentMap<T extends string> = {\n [type in T]: React.ComponentType<any>;\n}\n\nexport interface TypedComponentRendererProps<T extends string, K extends keyof ComponentMap<T>> {\n type: K;\n componentMap: ComponentMap<T>;\n props?: any;\n children?: ReactNode;\n}\n\nexport const ThTypedComponentRenderer = <T extends string, K extends keyof ComponentMap<T>>({\n type,\n componentMap,\n props,\n children,\n}: TypedComponentRendererProps<T, K>) => {\n const Component = componentMap[type];\n\n if (!Component) {\n throw new Error(`Unsupported type: ${type}`);\n }\n\n return React.createElement(Component, props, children);\n};","\"use client\";\n\nimport React from \"react\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { Button, ButtonProps, Form, FormProps } from \"react-aria-components\";\n\nexport interface ThFormProps extends FormProps {\n ref?: React.ForwardedRef<HTMLFormElement>;\n label: string;\n compounds?: {\n button?: Exclude<WithRef<ButtonProps, HTMLButtonElement>, \"type\"> | React.ReactElement<typeof Button>;\n }\n}\n\nexport const ThForm = ({\n ref,\n label,\n compounds,\n children,\n ...props\n}: ThFormProps) => {\n return(\n <>\n <Form\n ref={ ref }\n {...props}\n >\n { children }\n \n { compounds?.button && React.isValidElement(compounds.button) \n ? compounds.button \n : <Button\n { ...compounds?.button }\n type=\"submit\"\n >\n { label }\n </Button>\n }\n </Form>\n </>\n )\n}","\"use client\";\n\nimport { WithRef } from \"../../customTypes\";\n\nimport { \n Input, \n InputProps, \n Label, \n LabelProps, \n NumberField, \n NumberFieldProps, \n Text \n} from \"react-aria-components\";\n\nexport interface ThFormNumberFieldProps extends NumberFieldProps {\n ref?: React.ForwardedRef<HTMLInputElement>;\n label?: string;\n compounds?: {\n label?: WithRef<LabelProps, HTMLLabelElement>;\n input?: WithRef<InputProps, HTMLInputElement>;\n description?: string;\n }\n}\n\nexport const ThFormNumberField = ({\n ref,\n label,\n compounds,\n children,\n ...props\n}: ThFormNumberFieldProps) => {\n return(\n <>\n <NumberField\n ref={ ref }\n {...props }\n >\n { children \n ? children \n : <>\n { label && <Label {...compounds?.label }>\n { label }\n </Label>\n }\n\n <Input {...compounds?.input } />\n \n { compounds?.description && <Text slot=\"description\"> \n { compounds?.description } \n </Text> \n }\n </> \n }\n </NumberField>\n </>\n )\n}","\"use client\";\n\nimport { WithRef } from \"../../customTypes\";\n\nimport { \n FieldError, \n FieldErrorProps, \n Input, \n InputProps, \n Label, \n LabelProps, \n Text, \n TextField, \n TextFieldProps, \n ValidationResult \n} from \"react-aria-components\";\n\nexport interface ThFormTextFieldProps extends TextFieldProps {\n ref?: React.ForwardedRef<HTMLInputElement>;\n label?: string;\n compounds?: {\n label?: WithRef<LabelProps, HTMLLabelElement>;\n input?: WithRef<InputProps, HTMLInputElement>;\n description?: string;\n fieldError?: WithRef<FieldErrorProps, HTMLDivElement>;\n },\n errorMessage?: string | ((validation: ValidationResult) => string);\n}\n\nexport const ThFormTextField = ({\n ref,\n label,\n children,\n compounds,\n errorMessage,\n ...props\n}: ThFormTextFieldProps) => {\n return(\n <>\n <TextField\n ref={ ref }\n {...props }\n >\n <>\n { children \n ? children \n : <>\n { label && <Label {...compounds?.label }>\n { label }\n </Label>\n }\n \n { errorMessage && <FieldError { ...compounds?.fieldError }>\n { errorMessage }\n </FieldError> \n }\n \n <Input {...compounds?.input } />\n \n { compounds?.description && <Text slot=\"description\"> \n { compounds?.description } \n </Text> \n }\n </> \n }\n </>\n </TextField>\n </>\n )\n}","import * as React from \"react\";\nconst SvgSearch = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"M784-120 532-372q-30 24-69 38t-83 14q-109 0-184.5-75.5T120-580q0-109 75.5-184.5T380-840q109 0 184.5 75.5T640-580q0 44-14 83t-38 69l252 252-56 56ZM380-400q75 0 127.5-52.5T560-580q0-75-52.5-127.5T380-760q-75 0-127.5 52.5T200-580q0 75 52.5 127.5T380-400Z\" /></svg>;\nexport default SvgSearch;","\"use client\";\n\nimport React, { HTMLAttributes } from \"react\";\n\nimport { WithRef } from \"../../customTypes\";\n\nimport SearchIcon from \"./assets/icons/search.svg\";\n\nimport { \n FieldError, \n FieldErrorProps, \n Input, \n InputProps, \n Label, \n LabelProps, \n SearchField, \n SearchFieldProps, \n Text, \n ValidationResult \n} from \"react-aria-components\";\nimport { ThActionButtonProps, ThCloseButton } from \"../../Buttons\";\n\nexport interface ThFormSearchFieldProps extends SearchFieldProps {\n ref?: React.ForwardedRef<HTMLInputElement>;\n label?: string;\n compounds?: {\n label?: WithRef<LabelProps, HTMLLabelElement>;\n input?: WithRef<InputProps, HTMLInputElement>;\n searchIcon?: HTMLAttributes<HTMLDivElement> | React.ReactElement<HTMLDivElement>;\n clearButton?: ThActionButtonProps | React.ReactElement<ThActionButtonProps>;\n description?: string;\n fieldError?: WithRef<FieldErrorProps, HTMLDivElement>;\n },\n errorMessage?: string | ((validation: ValidationResult) => string);\n}\n\nexport const ThFormSearchField = ({\n ref,\n label,\n children,\n compounds,\n errorMessage,\n ...props\n}: ThFormSearchFieldProps) => {\n return(\n <>\n <SearchField\n ref={ ref }\n {...props }\n >\n <>\n { children \n ? children \n : <>\n { label && <Label { ...compounds?.label }>\n { label }\n </Label>\n }\n\n { errorMessage && <FieldError { ...compounds?.fieldError }>\n { errorMessage }\n </FieldError> \n }\n \n <Input { ...compounds?.input } />\n\n { compounds?.searchIcon && React.isValidElement(compounds.searchIcon)\n ? compounds.searchIcon\n : <div {...compounds?.searchIcon }>\n <SearchIcon aria-hidden=\"true\" focusable=\"false\" />\n </div>\n }\n \n { compounds?.clearButton && React.isValidElement(compounds.clearButton) \n ? compounds.clearButton \n : <ThCloseButton { ...compounds?.clearButton } type=\"button\" />\n }\n \n { compounds?.description && <Text slot=\"description\"> \n { compounds?.description } \n </Text> \n }\n </> \n }\n </>\n </SearchField>\n </>\n )\n}","\"use client\";\n\nimport React from \"react\";\nimport { KeyboardProps } from \"react-aria\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { Keyboard, LabelProps, MenuItem, MenuItemProps, Text } from \"react-aria-components\";\n\nexport interface ThMenuItemProps extends MenuItemProps {\n ref?: React.Ref<HTMLLIElement>;\n id: string;\n SVGIcon?: React.ComponentType<React.SVGProps<SVGElement>>;\n label: string;\n shortcut?: string;\n compounds?: {\n label: WithRef<LabelProps, HTMLSpanElement>;\n shortcut: WithRef<KeyboardProps, HTMLSpanElement>;\n }\n}\n\nexport const ThMenuItem = ({\n ref,\n id,\n SVGIcon,\n label, \n shortcut,\n compounds,\n children,\n ...props\n}: ThMenuItemProps) => {\n const menuItemLabelId = `${ id }-label`; \n return(\n <>\n <MenuItem \n ref={ ref }\n id={ id } \n { ...(children ? {} : { \"aria-labelledby\": menuItemLabelId }) }\n { ...props }\n >\n { children \n ? children \n : <>\n { SVGIcon && <SVGIcon aria-hidden=\"true\" focusable=\"false\" /> }\n <Text \n { ...compounds?.label } \n slot=\"label\"\n id={ menuItemLabelId }\n >\n { label }\n </Text>\n { shortcut && <Keyboard { ...compounds?.shortcut }>{ shortcut }</Keyboard> }\n </>\n }\n </MenuItem>\n </>\n )\n}","\"use client\";\n\nimport { HTMLAttributesWithRef } from \"../customTypes\";\n\nexport const ThFooter = ({ \n ref,\n children,\n ...props \n}: HTMLAttributesWithRef<HTMLDivElement>) => {\n return (\n <aside \n ref={ ref } \n { ...props }\n >\n { children }\n </aside>\n )\n}","\"use client\";\n\nimport { ReactNode } from \"react\";\n\nimport { HTMLAttributesWithRef } from \"../customTypes\";\n\nexport interface ThLoaderProps extends Omit<HTMLAttributesWithRef<HTMLDivElement>, \"aria-busy\" | \"aria-live\"> {\n ref?: React.ForwardedRef<HTMLDivElement>;\n isLoading: boolean;\n loader: ReactNode;\n}\n\n// Since we are removing loader entirely, no need for aria-hidden={ !isLoading }\n// No need for a label either since we are using the string for the animation\nexport const ThLoader = ({ \n ref, \n isLoading,\n loader,\n children,\n ...props\n }: ThLoaderProps) => {\n return (\n <>\n <div \n ref={ ref }\n { ...props }\n aria-busy={ isLoading } \n aria-live=\"polite\"\n >\n { isLoading && loader }\n { children }\n </div>\n </>\n )\n}","\"use client\";\n\nimport { HTMLAttributesWithRef } from \"../customTypes\";\n\nexport const ThHeader = ({ \n ref,\n children,\n ...props \n}: HTMLAttributesWithRef<HTMLDivElement>) => {\n return (\n <header \n ref={ ref } \n { ...props }\n >\n { children }\n </header>\n )\n}","\"use client\";\n\nimport React from \"react\";\n\nexport interface ThProgressionProps extends React.HTMLAttributes<HTMLDivElement> {\n ref?: React.RefObject<HTMLDivElement>\n}\n\nexport const ThProgression = ({ \n ref,\n children, \n ...props\n}: ThProgressionProps) => {\n return (\n <>\n <div \n ref={ ref } \n {...props }\n >\n { children }\n </div>\n </>\n )\n}","\"use client\";\n\nimport React, { useEffect } from \"react\";\n\nimport { HTMLAttributesWithRef } from \"../customTypes\";\n\nexport interface ThRunningHeadProps extends HTMLAttributesWithRef<HTMLHeadingElement> {\n ref?: React.RefObject<HTMLHeadingElement>\n label: string;\n syncDocTitle?: boolean; \n}\n\nexport const ThRunningHead = ({ \n ref,\n label,\n syncDocTitle,\n ...props\n}: ThRunningHeadProps) => {\n\n useEffect(() => {\n if (syncDocTitle && label) document.title = label;\n }, [syncDocTitle, label])\n\n return(\n <>\n <h1 \n ref={ ref }\n { ...props }\n >\n { label }\n </h1>\n </>\n )\n}","import * as React from \"react\";\nconst SvgAdd = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"Inherit\" {...props}><path d=\"M440-440H200v-80h240v-240h80v240h240v80H520v240h-80v-240Z\" /></svg>;\nexport default SvgAdd;","import * as React from \"react\";\nconst SvgRemove = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"Inherit\" {...props}><path d=\"M200-440v-80h560v80H200Z\" /></svg>;\nexport default SvgRemove;","\"use client\";\n\nimport { ComponentType, SVGProps } from \"react\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport AddIcon from \"./assets/icons/add.svg\";\nimport RemoveIcon from \"./assets/icons/remove.svg\";\n\nimport { \n Button, \n ButtonProps, \n Group, \n GroupProps, \n Input, \n InputProps, \n Label, \n LabelProps, \n NumberField, \n NumberFieldProps \n} from \"react-aria-components\";\n\nexport interface ThNumberFieldProps extends Omit<NumberFieldProps, \"minValue\" | \"maxValue\" | \"decrementAriaLabel\" | \"incrementAriaLabel\"> {\n ref?: React.ForwardedRef<HTMLInputElement>;\n label?: string;\n range: number[];\n isVirtualKeyboardDisabled?: boolean;\n steppers?: {\n decrementIcon?: ComponentType<SVGProps<SVGElement>> | null;\n decrementLabel: string;\n incrementIcon?: ComponentType<SVGProps<SVGElement>> | null;\n incrementLabel: string;\n };\n compounds?: {\n /**\n * Props for the Group component. See `GroupProps` for more information.\n */\n group?: WithRef<GroupProps, HTMLDivElement>;\n /**\n * Props for the Input component. See `InputProps` for more information.\n */\n input?: WithRef<InputProps, HTMLInputElement>;\n /**\n * Props for the Label component. See `LabelProps` for more information.\n */\n label?: WithRef<LabelProps, HTMLLabelElement>;\n /**\n * Props for the Button component used for decrement/increment. See `ButtonProps` for more information.\n */\n stepper?: ButtonProps;\n };\n}\n\nexport const ThNumberField = ({\n ref,\n label,\n range,\n isVirtualKeyboardDisabled,\n steppers,\n compounds,\n ...props\n}: ThNumberFieldProps) => {\n\n return (\n <NumberField \n ref={ ref }\n minValue={ Math.min(...range) }\n maxValue={ Math.max(...range) }\n decrementAriaLabel={ steppers?.decrementLabel }\n incrementAriaLabel={ steppers?.incrementLabel }\n { ...props }\n >\n { label && <Label { ...compounds?.label }>\n { label }\n </Label>\n }\n\n <Group { ...compounds?.group }>\n { steppers && \n <Button \n { ...compounds?.stepper }\n slot=\"decrement\" \n >\n { steppers.decrementIcon \n ? <steppers.decrementIcon aria-hidden=\"true\" focusable=\"false\" /> \n : <RemoveIcon aria-hidden=\"true\" focusable=\"false\" /> }\n </Button> \n }\n\n <Input \n { ...compounds?.input } \n { ...(isVirtualKeyboardDisabled ? { inputMode: \"none\" } : {}) } \n />\n\n { steppers && \n <Button \n { ...compounds?.stepper }\n slot=\"increment\" \n >\n { steppers.incrementIcon \n ? <steppers.incrementIcon aria-hidden=\"true\" focusable=\"false\" /> \n : <AddIcon aria-hidden=\"true\" focusable=\"false\" /> }\n </Button>\n }\n </Group>\n </NumberField>\n );\n};","\"use client\";\n\nimport React, { ComponentType, SVGProps } from \"react\";\n\nimport { HTMLAttributesWithRef, WithRef } from \"../customTypes\";\n\nimport { \n Label, \n LabelProps, \n Radio, \n RadioGroup, \n RadioGroupProps, \n RadioProps \n} from \"react-aria-components\"\n\nexport interface ThRadioGroupItems {\n value: string;\n icon?: ComponentType<SVGProps<SVGElement>>;\n label: string;\n isDisabled?: boolean;\n}\n\nexport interface ThRadioGroupProps extends RadioGroupProps {\n ref?: React.ForwardedRef<HTMLDivElement>;\n label?: string;\n items?: ThRadioGroupItems[];\n compounds?: {\n /**\n * Props for the wrapper component. See `HTMLAttributesWithRef` for more information.\n */\n wrapper?: HTMLAttributesWithRef<HTMLDivElement>;\n /**\n * Props for the label component. See `LabelProps` for more information.\n */\n label?: WithRef<LabelProps, HTMLLabelElement>;\n /**\n * Props for the radio component. See `RadioProps` for more information.\n */\n radio?: Omit<RadioProps, \"value\">;\n /**\n * Props for the radio label component. See `HTMLAttributesWithRef` for more information.\n */\n radioLabel?: HTMLAttributesWithRef<HTMLSpanElement>;\n }\n}\n\nexport const ThRadioGroup = ({\n ref,\n label,\n items,\n compounds,\n children,\n ...props\n}: ThRadioGroupProps) => {\n if (React.isValidElement(children)) {\n return (\n <RadioGroup \n ref={ ref }\n { ...props }\n >\n { label && <Label { ...compounds?.label }>\n { label }\n </Label> \n }\n { children }\n </RadioGroup>\n )\n } else if (items) {\n return (\n <RadioGroup \n { ...props }\n >\n { label && <Label { ...compounds?.label }>\n { label }\n </Label> \n }\n <div { ...compounds?.wrapper }>\n { items.map((item, index) => (\n <Radio \n { ...compounds?.radio }\n key={ index }\n value={ item.value }\n isDisabled={ item.isDisabled }\n >\n <React.Fragment>\n { item.icon && <item.icon aria-hidden=\"true\" focusable=\"false\" /> }\n <span { ...compounds?.radioLabel }>\n { item.label }\n </span> \n </React.Fragment>\n </Radio>\n )) }\n </div>\n </RadioGroup>\n )\n }\n}","\"use client\";\n\nimport { WithRef } from \"../customTypes\";\n\nimport { \n Label, \n LabelProps, \n Slider, \n SliderOutput, \n SliderOutputProps, \n SliderProps, \n SliderThumb, \n SliderThumbProps, \n SliderTrack, \n SliderTrackProps \n} from \"react-aria-components\";\n\nexport interface ThSliderProps extends Omit<SliderProps, \"minValue\" | \"maxValue\"> {\n ref?: React.ForwardedRef<HTMLDivElement>;\n label?: string;\n range: number[];\n compounds?: {\n /**\n * Props for the label component. See `LabelProps` for more information.\n */\n label?: WithRef<LabelProps, HTMLLabelElement>;\n /**\n * Props for the slider output component. See `SliderOutputProps` for more information.\n */\n output?: WithRef<SliderOutputProps, HTMLOutputElement>;\n /**\n * Props for the slider track component. See `SliderTrackProps` for more information.\n */\n track?: WithRef<SliderTrackProps, HTMLDivElement>;\n /**\n * Props for the slider thumb component. See `SliderThumbProps` for more information.\n */\n thumb?: WithRef<SliderThumbProps, HTMLDivElement>;\n };\n}\n\nexport const ThSlider = ({\n ref,\n label,\n range,\n compounds,\n ...props\n}: ThSliderProps) => {\n return(\n <>\n <Slider \n ref={ ref }\n minValue={ Math.min(...range) }\n maxValue={ Math.max(...range) }\n { ...props }\n >\n { label && <Label { ...compounds?.label }>\n { label }\n </Label> \n }\n <SliderOutput { ...compounds?.output } />\n <SliderTrack { ...compounds?.track }>\n <SliderThumb { ...compounds?.thumb } />\n </SliderTrack>\n </Slider>\n </>\n )\n}","\"use client\";\n\nimport { HTMLAttributesWithRef, WithRef } from \"../customTypes\";\n\nimport { Heading, HeadingProps, Switch, SwitchProps } from \"react-aria-components\";\n\nexport interface ThSwitchProps extends SwitchProps {\n ref?: React.ForwardedRef<HTMLLabelElement>;\n label: string;\n heading?: string;\n compounds?: {\n /**\n * Props for the wrapper component. See `HTMLAttributesWithRef` for more information.\n */\n wrapper?: HTMLAttributesWithRef<HTMLDivElement>;\n /**\n * Props for the heading component. See `HeadingProps` for more information.\n */\n heading?: WithRef<HeadingProps, HTMLHeadingElement>;\n /**\n * Props for the indicator component. See `HTMLAttributesWithRef` for more information.\n */\n indicator?: HTMLAttributesWithRef<HTMLDivElement>;\n }\n}\n\nexport const ThSwitch = ({\n ref,\n label,\n compounds,\n heading, \n ...props\n}: ThSwitchProps) => {\n return(\n <>\n <div { ...compounds?.wrapper }>\n { heading && <Heading { ...compounds?.heading }>\n { heading }\n </Heading> \n }\n <Switch \n ref={ ref }\n { ...props }\n >\n <div { ...compounds?.indicator } />\n { label }\n </Switch>\n </div>\n </>\n )\n}","import * as React from \"react\";\nconst SvgArrowDropDown = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"Inherit\" {...props}><path d=\"M480-360 280-560h400L480-360Z\" /></svg>;\nexport default SvgArrowDropDown;","\"use client\";\n\nimport ArrowDropDownIcon from \"./assets/icons/arrow_drop_down.svg\";\n\nimport { Button, ButtonProps, SelectValue } from \"react-aria-components\";\n\nexport interface ThDropdownButtonProps extends ButtonProps {\n ref?: React.ForwardedRef<HTMLButtonElement>;\n}\n\nexport const ThDropdownButton = ({\n ref,\n children,\n ...props\n}: ThDropdownButtonProps) => {\n return (\n <>\n <Button \n ref={ ref }\n { ...props }\n >\n { children \n ? children \n : <>\n <SelectValue /> \n <ArrowDropDownIcon aria-hidden=\"true\" focusable=\"false\" />\n </> \n }\n </Button>\n </>\n )\n}","\"use client\";\n\nimport React from \"react\";\n\nimport { WithRef } from \"../../customTypes\";\n\nimport { \n Button,\n ButtonProps, \n Label, \n LabelProps, \n ListBox, \n ListBoxItem, \n ListBoxItemProps, \n ListBoxProps, \n Popover, \n PopoverProps, \n Select, \n SelectProps \n} from \"react-aria-components\";\nimport { ThDropdownButton, ThDropdownButtonProps } from \"./ThDropdownButton\";\n\nexport interface ThDropdownEntry {\n id: string;\n label: string;\n value: string;\n}\n\nexport interface ThDropdownProps extends SelectProps {\n ref?: React.ForwardedRef<HTMLDivElement>;\n label?: string;\n items?: Iterable<ThDropdownEntry>;\n children?: never;\n compounds?: {\n /**\n * Props for the label component. See `LabelProps` for more information.\n */\n label?: WithRef<LabelProps, HTMLLabelElement>;\n /**\n * Props for the button component. See `ThDropdownButtonProps` for more information.\n * Alternatively you can provide your own Button component\n */\n button?: WithRef<ButtonProps, HTMLButtonElement> | React.ReactElement<typeof Button>;\n /**\n * Props for the popover component. See `PopoverProps` for more information.\n */\n popover?: WithRef<PopoverProps, HTMLDivElement>;\n /**\n * Props for the listbox component. See `LisboxProps` for more information.\n * Alternatively you can provide your own Listbox component\n */\n listbox?: WithRef<ListBoxProps<ThDropdownEntry>, HTMLDivElement> | React.ReactElement<typeof ListBox | HTMLDivElement>;\n /**\n * Props for the listboxItem component. See `ListBoxItemProps` for more information.\n */\n listboxItem?: ListBoxItemProps<ThDropdownEntry>;\n }\n}\n\nexport const ThDropdown = ({\n ref,\n label,\n items,\n compounds,\n ...props\n}: ThDropdownProps) => {\n if (!items && !React.isValidElement(compounds?.listbox)) {\n return null;\n }\n\n return(\n <>\n <Select\n ref={ ref }\n { ...props }\n >\n { label && <Label { ...compounds?.label }>\n { label }\n </Label>\n }\n { compounds?.button && React.isValidElement(compounds.button) \n ? compounds.button \n : <ThDropdownButton { ...compounds?.button as ThDropdownButtonProps } />\n }\n <Popover\n { ...compounds?.popover }\n >\n { compounds?.listbox && React.isValidElement(compounds.listbox) \n ? compounds.listbox \n : <ListBox \n items={ items } \n { ...compounds?.listbox }>\n { (item: ThDropdownEntry) => <ListBoxItem \n { ...compounds?.listboxItem }\n id={ item.id } \n key={ item.id } \n textValue={ item.value || undefined }\n >\n { item.label }\n </ListBoxItem>\n }\n </ListBox>\n }\n </Popover>\n </Select>\n </>\n )\n}\n","import * as React from \"react\";\nconst SvgSettings = props => <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"inherit\" {...props}><path d=\"m370-80-16-128q-13-5-24.5-12T307-235l-119 50L78-375l103-78q-1-7-1-13.5v-27q0-6.5 1-13.5L78-585l110-190 119 50q11-8 23-15t24-12l16-128h220l16 128q13 5 24.5 12t22.5 15l119-50 110 190-103 78q1 7 1 13.5v27q0 6.5-2 13.5l103 78-110 190-118-50q-11 8-23 15t-24 12L590-80H370Zm70-80h79l14-106q31-8 57.5-23.5T639-327l99 41 39-68-86-65q5-14 7-29.5t2-31.5q0-16-2-31.5t-7-29.5l86-65-39-68-99 42q-22-23-48.5-38.5T533-694l-13-106h-79l-14 106q-31 8-57.5 23.5T321-633l-99-41-39 68 86 64q-5 15-7 30t-2 32q0 16 2 31t7 30l-86 65 39 68 99-42q22 23 48.5 38.5T427-266l13 106Zm42-180q58 0 99-41t41-99q0-58-41-99t-99-41q-59 0-99.5 41T342-480q0 58 40.5 99t99.5 41Zm-2-140Z\" /></svg>;\nexport default SvgSettings;","\"use client\";\n\nimport Settings from \"./assets/icons/settings.svg\";\n\nimport { ThActionButton, ThActionButtonProps } from \"../../Buttons/ThActionButton\";\n\nexport const ThSettingsWrapperButton = ({\n label,\n ref,\n compounds,\n children,\n ...props\n}: ThActionButtonProps) => {\n return (\n <ThActionButton\n ref={ ref }\n compounds={ compounds }\n { ...props }\n >\n { children \n ? children \n : <>\n <Settings aria-hidden=\"true\" focusable=\"false\" /> \n { label }\n </> \n }\n </ThActionButton>\n )\n}","\"use client\";\n\nimport { ThSettingsWrapperButton } from \"./ThSettingsWrapperButton\";\n\nimport { Heading, HeadingProps } from \"react-aria-components\";\nimport { HTMLAttributesWithRef, WithRef } from \"../../customTypes\";\nimport { ThActionButtonProps } from \"../../Buttons\";\n\nexport interface ThSettingsEntry {\n Comp: React.ComponentType<any>\n}\n\nexport interface ThSettingsPrefs {\n main: string[];\n subPanel?: string[] | null;\n}\n\nexport interface ThSettingsWrapperProps extends HTMLAttributesWithRef<HTMLDivElement> {\n items?: Record<string, ThSettingsEntry> | null;\n prefs: ThSettingsPrefs;\n compounds?: {\n /**\n * Label for advanced settings that will be displayed as a heading\n */\n label?: string;\n /**\n * Props for the heading. See `HeadingProps` for more information.\n */\n heading?: WithRef<HeadingProps, HTMLHeadingElement>;\n /**\n * Props for the button that triggers the subpanel. See `ThActionButtonProps` for more information.\n */\n button?: ThActionButtonProps;\n }\n}\n\n// TODO: Handle Standalone and Usage as Group\nexport const ThSettingsWrapper = ({\n ref,\n items,\n prefs,\n compounds,\n ...props\n}: ThSettingsWrapperProps) => {\n const main = prefs.main;\n const displayOrder = prefs.subPanel;\n \n const isAdvanced = items &&(\n main.length < Object.keys(items).length && \n displayOrder && displayOrder.length > 0\n );\n\n if (items) {\n return(\n <>\n <div \n ref={ ref }\n { ...props }\n >\n { isAdvanced && compounds?.label &&\n <Heading { ...compounds?.heading }>\n { compounds.label }\n </Heading> }\n { main.map((key, index) => {\n const match = items[key];\n return match && <match.Comp key={ key } standalone={ !isAdvanced || index !== 0 } { ...props } />;\n }) }\n { isAdvanced && (\n <ThSettingsWrapperButton\n { ...compounds?.button }\n />\n ) }\n </div>\n </>\n )\n }\n}"]}
@@ -111,7 +111,7 @@ var defaultPreferences = createPreferences({
111
111
  direction: "ltr" /* ltr */,
112
112
  locale: "en",
113
113
  typography: {
114
- minimalLineLength: 45,
114
+ minimalLineLength: 40,
115
115
  // undefined | null | number of characters. If 2 cols will switch to 1 based on this
116
116
  optimalLineLength: 65,
117
117
  // number of characters. If auto layout, picks colCount based on this
@@ -665,5 +665,5 @@ var useTheming = ({
665
665
  };
666
666
 
667
667
  export { ThPreferencesContext, ThPreferencesProvider, buildThemeObject, createPreferences, defaultActionKeysObject, defaultFontFamilyOptions, defaultFontSize, defaultLetterSpacing, defaultLineHeights, defaultParagraphIndent, defaultParagraphSpacing, defaultPreferences, defaultSpacingSettingsMain, defaultSpacingSettingsSubpanel, defaultTextSettingsMain, defaultTextSettingsSubpanel, defaultWordSpacing, usePreferenceKeys, usePreferences, useTheming };
668
- //# sourceMappingURL=chunk-4BUYRCGX.mjs.map
669
- //# sourceMappingURL=chunk-4BUYRCGX.mjs.map
668
+ //# sourceMappingURL=chunk-VMGV6SUR.mjs.map
669
+ //# sourceMappingURL=chunk-VMGV6SUR.mjs.map