@sanity/orderable-document-list 1.2.2 → 1.3.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/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/helpers/constants.ts","../src/helpers/initialRank.ts","../src/fields/orderRankField.ts","../src/fields/orderRankOrdering.ts","../src/OrderableContext.ts","../src/Document.tsx","../src/helpers/reorderDocuments.ts","../src/helpers/client.ts","../src/DraggableList.tsx","../src/DocumentListQuery.tsx","../src/DocumentListWrapper.tsx","../src/helpers/resetOrder.ts","../src/OrderableDocumentList.tsx","../src/desk-structure/orderableDocumentListDeskItem.ts"],"sourcesContent":["export const ORDER_FIELD_NAME = `orderRank` as const\n\nexport const API_VERSION = `2021-09-01` as const\n","import {LexoRank} from 'lexorank'\nimport {NewItemPosition} from '../types'\n\n// Use in initial value field by passing in the rank value of the last document\n// If not value passed, generate a sensibly low rank\nexport default function initialRank(\n compareRankValue = ``,\n newItemPosition: NewItemPosition = 'after'\n): string {\n const compareRank = compareRankValue ? LexoRank.parse(compareRankValue) : LexoRank.min()\n const rank =\n newItemPosition === 'before' ? compareRank.genPrev().genPrev() : compareRank.genNext().genNext()\n\n return rank.toString()\n}\n","import {type ConfigContext, defineField} from 'sanity'\nimport {API_VERSION, ORDER_FIELD_NAME} from '../helpers/constants'\nimport initialRank from '../helpers/initialRank'\nimport {NewItemPosition} from '../types'\n\nexport type SchemaContext = Omit<ConfigContext, 'schema' | 'currentUser' | 'client'>\n\nexport interface RankFieldConfig {\n type: string\n newItemPosition?: NewItemPosition\n}\n\nexport const orderRankField = (config: RankFieldConfig) => {\n if (!config?.type) {\n throw new Error(\n `\n type must be provided.\n Example: orderRankField({type: 'category'})\n `\n )\n }\n\n const {type, newItemPosition = 'after'} = config\n return defineField({\n title: 'Order Rank',\n readOnly: true,\n hidden: true,\n ...config,\n name: ORDER_FIELD_NAME,\n type: 'string',\n initialValue: async (p, {getClient}) => {\n const direction = newItemPosition === 'before' ? 'asc' : 'desc'\n\n const lastDocOrderRank = await getClient({apiVersion: API_VERSION}).fetch(\n `*[_type == $type]|order(@[$order] ${direction})[0][$order]`,\n {type, order: ORDER_FIELD_NAME}\n )\n return initialRank(lastDocOrderRank, newItemPosition)\n },\n })\n}\n","import {SortOrdering} from 'sanity'\nimport {ORDER_FIELD_NAME} from '../helpers/constants'\n\nexport const orderRankOrdering: SortOrdering = {\n title: 'Ordered',\n name: 'ordered',\n by: [{field: ORDER_FIELD_NAME, direction: 'asc'}],\n}\n","import React from 'react'\n\nexport interface OrderableContextValue {\n showIncrements?: boolean\n}\n\nexport const OrderableContext = React.createContext<OrderableContextValue>({})\n","import {useContext, useMemo, type ReactNode} from 'react'\nimport {ChevronDownIcon, ChevronUpIcon, DragHandleIcon} from '@sanity/icons'\nimport {AvatarCounter, Card, Box, Button, Flex, Text} from '@sanity/ui'\nimport {useSchema, SchemaType, PreviewCard, Preview} from 'sanity'\nimport {usePaneRouter} from 'sanity/structure'\n\nimport {OrderableContext} from './OrderableContext'\nimport {SanityDocumentWithOrder} from './types'\n\nexport interface DocumentProps {\n doc: SanityDocumentWithOrder\n entities: SanityDocumentWithOrder[]\n increment: (\n index: number,\n nextIndex: number,\n docId: string,\n entities: SanityDocumentWithOrder[]\n ) => void\n index: number\n isFirst: boolean\n isLast: boolean\n dragBadge: number | false\n}\n\nexport default function Document({\n doc,\n increment,\n entities,\n index,\n isFirst,\n isLast,\n dragBadge,\n}: DocumentProps) {\n const {showIncrements} = useContext(OrderableContext)\n const schema = useSchema()\n const router = usePaneRouter()\n const {ChildLink, groupIndex, routerPanesState} = router\n\n const currentDoc = routerPanesState[groupIndex + 1]?.[0]?.id || false\n const pressed = currentDoc === doc._id || currentDoc === doc._id.replace(`drafts.`, ``)\n const selected = pressed && routerPanesState.length === groupIndex + 2\n\n const Link = useMemo(\n () =>\n function LinkComponent(linkProps: {children: ReactNode}) {\n return <ChildLink {...linkProps} childId={doc._id} />\n },\n [ChildLink, doc._id]\n )\n\n return (\n <PreviewCard\n __unstable_focusRing\n // @ts-expect-error\n as={Link}\n data-as=\"a\"\n data-ui=\"PaneItem\"\n radius={2}\n pressed={pressed}\n selected={selected}\n sizing=\"border\"\n tabIndex={-1}\n tone=\"inherit\"\n width=\"100%\"\n flex={1}\n >\n <Flex align=\"center\">\n <Box paddingX={2} style={{flexShrink: 0}}>\n <Text size={2}>\n <DragHandleIcon cursor=\"grab\" />\n </Text>\n </Box>\n {showIncrements && (\n <Flex style={{flexShrink: 0}} align=\"center\" gap={1} paddingRight={1}>\n <Button\n padding={2}\n mode=\"ghost\"\n // eslint-disable-next-line react/jsx-no-bind\n onClick={() => increment(index, index + -1, doc._id, entities)}\n disabled={isFirst}\n icon={ChevronUpIcon}\n />\n <Button\n padding={2}\n mode=\"ghost\"\n disabled={isLast}\n // eslint-disable-next-line react/jsx-no-bind\n onClick={() => increment(index, index + 1, doc._id, entities)}\n icon={ChevronDownIcon}\n />\n </Flex>\n )}\n <Box style={{width: `100%`}}>\n <Flex flex={1} align=\"center\">\n <Preview\n layout=\"default\"\n value={doc}\n schemaType={schema.get(doc._type) as SchemaType}\n />\n </Flex>\n </Box>\n {dragBadge && (\n <Card tone=\"default\" marginRight={4} radius={5}>\n <AvatarCounter count={dragBadge} />\n </Card>\n )}\n </Flex>\n </PreviewCard>\n )\n}\n","import {LexoRank} from 'lexorank'\nimport type {PatchOperations} from 'sanity'\n\nimport {SanityDocumentWithOrder} from '../types'\nimport {ORDER_FIELD_NAME} from './constants'\n\nexport interface MaifestArgs {\n entities: SanityDocumentWithOrder[]\n selectedItems: SanityDocumentWithOrder[]\n isMovingUp: boolean\n curIndex: number\n nextIndex: number\n prevIndex: number\n}\n\nexport interface ReorderArgs {\n entities: SanityDocumentWithOrder[]\n selectedIds: string[]\n source: any\n destination: any\n}\n\nexport interface ReorderReturn {\n newOrder: SanityDocumentWithOrder[]\n patches: [string, PatchOperations][]\n message: any\n}\n\nfunction lexicographicalSort(a: SanityDocumentWithOrder, b: SanityDocumentWithOrder) {\n if (!a[ORDER_FIELD_NAME] || !b[ORDER_FIELD_NAME]) {\n return 0\n } else if (a[ORDER_FIELD_NAME] < b[ORDER_FIELD_NAME]) {\n return -1\n } else if (a[ORDER_FIELD_NAME] > b[ORDER_FIELD_NAME]) {\n return 1\n }\n return 0\n}\n\nexport const reorderDocuments = ({\n entities,\n selectedIds,\n source,\n destination,\n}: ReorderArgs): ReorderReturn => {\n const startIndex = source.index\n const endIndex = destination.index\n const isMovingUp = startIndex > endIndex\n const selectedItems = entities.filter((item) => selectedIds.includes(item._id))\n const message = [\n `Moved`,\n selectedItems.length === 1 ? `1 document` : `${selectedItems.length} documents`,\n isMovingUp ? `up` : `down`,\n `from position`,\n `${startIndex + 1} to ${endIndex + 1}`,\n ].join(' ')\n\n const {all, selected} = entities.reduce<{\n all: SanityDocumentWithOrder[]\n selected: SanityDocumentWithOrder[]\n }>(\n (acc, cur, curIndex) => {\n // Selected items get spread in below, so skip them here\n if (selectedIds.includes(cur._id)) {\n return {all: acc.all, selected: acc.selected}\n }\n\n // Drop selected items in\n if (curIndex === endIndex) {\n const prevIndex = curIndex - 1\n const prevRank = entities[prevIndex]?.[ORDER_FIELD_NAME]\n ? LexoRank.parse(entities[prevIndex]?.[ORDER_FIELD_NAME] as string)\n : LexoRank.min()\n\n const curRank = LexoRank.parse(entities[curIndex][ORDER_FIELD_NAME] as string)\n\n const nextIndex = curIndex + 1\n const nextRank = entities[nextIndex]?.[ORDER_FIELD_NAME]\n ? LexoRank.parse(entities[nextIndex]?.[ORDER_FIELD_NAME] as string)\n : LexoRank.max()\n\n let betweenRank = isMovingUp ? prevRank.between(curRank) : curRank.between(nextRank)\n\n // For each selected item, assign a new orderRank between now and next\n for (let selectedIndex = 0; selectedIndex < selectedItems.length; selectedIndex += 1) {\n selectedItems[selectedIndex][ORDER_FIELD_NAME] = betweenRank.toString()\n betweenRank = isMovingUp ? betweenRank.between(curRank) : betweenRank.between(nextRank)\n }\n\n return {\n // The `all` array gets sorted by order field later anyway\n // so that this probably isn't necessary ¯\\_(ツ)_/¯\n all: isMovingUp\n ? [...acc.all, ...selectedItems, cur]\n : [...acc.all, cur, ...selectedItems],\n selected: selectedItems,\n }\n }\n\n return {all: [...acc.all, cur], selected: acc.selected}\n },\n {all: [], selected: []}\n )\n\n const patches = selected.flatMap((doc) => {\n const docPatches: [string, PatchOperations][] = [\n [\n doc._id,\n {\n set: {\n [ORDER_FIELD_NAME]: doc[ORDER_FIELD_NAME],\n },\n },\n ],\n ]\n\n // If it's a draft, we need to patch the published document as well\n if (doc._id.startsWith(`drafts.`) && doc.hasPublished) {\n docPatches.push([\n doc._id.replace(`drafts.`, ``),\n {\n set: {\n [ORDER_FIELD_NAME]: doc[ORDER_FIELD_NAME],\n },\n },\n ])\n }\n\n return docPatches\n })\n\n // Safety-check to make sure everything is in order\n const allSorted = all.sort(lexicographicalSort)\n\n return {newOrder: allSorted, patches, message}\n}\n","import {useClient} from 'sanity'\nimport {API_VERSION} from './constants'\n\nexport function useSanityClient() {\n return useClient({apiVersion: API_VERSION})\n}\n","import {useEffect, useState, useMemo, useCallback, CSSProperties} from 'react'\nimport {DragDropContext, Draggable, Droppable, type DropResult} from '@hello-pangea/dnd'\nimport {Box, Card, useToast} from '@sanity/ui'\nimport type {PatchOperations} from 'sanity'\nimport {usePaneRouter} from 'sanity/structure'\n\nimport Document from './Document'\nimport {reorderDocuments} from './helpers/reorderDocuments'\nimport {ORDER_FIELD_NAME} from './helpers/constants'\nimport {useSanityClient} from './helpers/client'\nimport {SanityDocumentWithOrder} from './types'\n\ninterface ListSetting {\n isDuplicate: boolean\n isGhosting: boolean\n isDragging: boolean\n isSelected: boolean\n}\n\nexport interface DraggableListProps {\n data: SanityDocumentWithOrder[]\n listIsUpdating: boolean\n setListIsUpdating: (val: boolean) => void\n}\n\nconst getItemStyle = (\n draggableStyle: CSSProperties | undefined,\n itemIsUpdating: boolean\n): CSSProperties => ({\n userSelect: 'none',\n transition: `opacity 500ms ease-in-out`,\n opacity: itemIsUpdating ? 0.2 : 1,\n pointerEvents: itemIsUpdating ? `none` : undefined,\n ...draggableStyle,\n})\n\nconst cardTone = (settings: ListSetting) => {\n const {isDuplicate, isGhosting, isDragging, isSelected} = settings\n\n if (isGhosting) return `transparent`\n if (isDragging || isSelected) return `primary`\n if (isDuplicate) return `caution`\n\n return undefined\n}\n\nexport default function DraggableList({\n data,\n listIsUpdating,\n setListIsUpdating,\n}: DraggableListProps) {\n const toast = useToast()\n const router = usePaneRouter()\n const {groupIndex, routerPanesState} = router\n\n const currentDoc = routerPanesState[groupIndex + 1]?.[0]?.id || false\n\n // Maintains local state order before transaction completes\n const [orderedData, setOrderedData] = useState<SanityDocumentWithOrder[]>(data)\n\n // Update local state when documents change from an outside source\n useEffect(() => {\n if (!listIsUpdating) setOrderedData(data)\n /* eslint-disable-next-line react-hooks/exhaustive-deps */\n }, [data])\n\n const [draggingId, setDraggingId] = useState(``)\n const [selectedIds, setSelectedIds] = useState<string[]>(currentDoc ? [currentDoc] : [])\n\n const clearSelected = useCallback(() => setSelectedIds([]), [setSelectedIds])\n\n const handleSelect = useCallback(\n (clickedId: string, index: number, nativeEvent: MouseEvent) => {\n const isSelected = selectedIds.includes(clickedId)\n const selectMultiple = nativeEvent.shiftKey\n const isUsingWindows = navigator.appVersion.indexOf('Win') !== -1\n const selectAdditional = isUsingWindows ? nativeEvent.ctrlKey : nativeEvent.metaKey\n\n let updatedIds = []\n\n // No modifier keys pressed during click:\n // - update selected to just this one\n // - open document\n if (!selectMultiple && !selectAdditional) {\n return setSelectedIds([clickedId])\n }\n\n // If shift key was held, prevent default to avoid new window opening\n if (selectMultiple) {\n nativeEvent.preventDefault()\n }\n\n // Shift key was held, add id's between last selected and this one\n // ...before adding this one\n if (selectMultiple && !isSelected) {\n const lastSelectedId = selectedIds[selectedIds.length - 1]\n const lastSelectedIndex = orderedData.findIndex((item) => item._id === lastSelectedId)\n\n const firstSelected = index < lastSelectedIndex ? index : lastSelectedIndex\n const lastSelected = index > lastSelectedIndex ? index : lastSelectedIndex\n\n const betweenIds = orderedData\n .filter((item, itemIndex) => itemIndex > firstSelected && itemIndex < lastSelected)\n .map((item) => item._id)\n\n updatedIds = [...selectedIds, ...betweenIds, clickedId]\n } else if (isSelected) {\n // Toggle off a single id\n updatedIds = selectedIds.filter((id) => id !== clickedId)\n } else {\n // Toggle on a single id\n updatedIds = [...selectedIds, clickedId]\n }\n\n return setSelectedIds(updatedIds)\n },\n [setSelectedIds, orderedData, selectedIds]\n )\n\n const client = useSanityClient()\n\n const transactPatches = useCallback(\n async (patches: [string, PatchOperations][], message: string) => {\n const transaction = client.transaction()\n\n patches.forEach(([docId, ops]) => transaction.patch(docId, ops))\n\n await transaction\n .commit()\n .then((updated) => {\n clearSelected()\n setDraggingId(``)\n setListIsUpdating(false)\n toast.push({\n title: `${\n updated.results.length === 1 ? `1 Document` : `${updated.results.length} Documents`\n } Reordered`,\n status: `success`,\n description: message,\n })\n })\n .catch(() => {\n setDraggingId(``)\n setListIsUpdating(false)\n toast.push({\n title: `Reordering failed`,\n status: `error`,\n })\n })\n },\n [client, setDraggingId, clearSelected, setListIsUpdating, toast]\n )\n\n const handleDragEnd = useCallback(\n (result: DropResult | undefined, entities: SanityDocumentWithOrder[]) => {\n setDraggingId(``)\n\n const {source, destination, draggableId} = result ?? {}\n\n // Don't do anything if nothing changed\n if (source?.index === destination?.index) return\n\n // Don't do anything if we don't have the entitites\n if (!entities?.length || !draggableId) return\n\n // A document can be dragged without being one-of-many-selected\n const effectedIds = selectedIds?.length ? selectedIds : [draggableId]\n\n // Don't do anything if we don't have ids to effect\n if (!effectedIds?.length) return\n\n // Update state to update styles + prevent data refetching\n setListIsUpdating(true)\n setSelectedIds(effectedIds)\n\n const {newOrder, patches, message} = reorderDocuments({\n entities,\n selectedIds: effectedIds,\n source,\n destination,\n })\n\n // Update local state\n if (newOrder?.length) {\n setOrderedData(newOrder)\n }\n\n // Transact new order patches\n if (patches?.length) {\n transactPatches(patches, message)\n }\n },\n [selectedIds, setDraggingId, setSelectedIds, transactPatches, setListIsUpdating]\n )\n\n const handleDragStart = useCallback(\n (start: {draggableId: string}) => {\n const id = start.draggableId\n const selected = selectedIds.includes(id)\n\n // if dragging an item that is not selected - unselect all items\n if (!selected) clearSelected()\n\n setDraggingId(id)\n },\n [selectedIds, clearSelected, setDraggingId]\n )\n\n // Move one document up or down one place, by fake invoking the drag function\n const incrementIndex = useCallback(\n (shiftFrom: number, shiftTo: number, id: string, entities: SanityDocumentWithOrder[]) => {\n const result = {\n draggableId: id,\n source: {index: shiftFrom},\n destination: {index: shiftTo},\n }\n\n return handleDragEnd(result as DropResult, entities)\n },\n [handleDragEnd]\n )\n\n const onWindowKeyDown = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n clearSelected()\n }\n },\n [clearSelected]\n )\n\n useEffect(() => {\n window.addEventListener('keydown', onWindowKeyDown)\n\n return () => {\n window.removeEventListener('keydown', onWindowKeyDown)\n }\n }, [onWindowKeyDown])\n\n // Find all items with duplicate order field\n const duplicateOrders = useMemo(() => {\n if (!orderedData.length) return []\n\n const orderField = orderedData.map((item) => item[ORDER_FIELD_NAME])\n\n return orderField.filter((item, index) => orderField.indexOf(item) !== index)\n }, [orderedData])\n\n const onDragEnd = useCallback(\n (result: DropResult) => handleDragEnd(result, orderedData),\n [orderedData, handleDragEnd]\n )\n\n return (\n <DragDropContext onDragStart={handleDragStart} onDragEnd={onDragEnd}>\n <Droppable droppableId=\"documentSortZone\">\n {(provided) => (\n <div {...provided.droppableProps} ref={provided.innerRef}>\n {orderedData.map((item, index) => (\n <Draggable\n key={`${item._id}-${item[ORDER_FIELD_NAME]}`}\n draggableId={item._id}\n index={index}\n // onClick={(event) => handleDraggableClick(event, provided, snapshot)}\n >\n {(innerProvided, innerSnapshot) => {\n const isSelected = selectedIds.includes(item._id)\n const isDragging = innerSnapshot.isDragging\n const isGhosting = Boolean(!isDragging && draggingId && isSelected)\n const isUpdating = listIsUpdating && isSelected\n const isDisabled = Boolean(!item[ORDER_FIELD_NAME])\n const isDuplicate = duplicateOrders.includes(item[ORDER_FIELD_NAME])\n const tone = cardTone({isDuplicate, isGhosting, isDragging, isSelected})\n const selectedCount = selectedIds.length\n\n const dragBadge = isDragging && selectedCount > 1 ? selectedCount : false\n\n return (\n <div\n ref={innerProvided.innerRef}\n {...innerProvided.draggableProps}\n {...innerProvided.dragHandleProps}\n style={\n isDisabled\n ? {opacity: 0.2, pointerEvents: `none`}\n : getItemStyle(innerProvided.draggableProps.style, isUpdating)\n }\n >\n <Box paddingBottom={1}>\n <Card\n tone={tone}\n shadow={isDragging ? 2 : undefined}\n radius={2}\n // eslint-disable-next-line react/jsx-no-bind\n onClick={(e) => handleSelect(item._id, index, e.nativeEvent)}\n >\n <Document\n doc={item}\n entities={orderedData}\n increment={incrementIndex}\n index={index}\n isFirst={index === 0}\n isLast={index === orderedData.length - 1}\n dragBadge={dragBadge}\n />\n </Card>\n </Box>\n </div>\n )\n }}\n </Draggable>\n ))}\n {provided.placeholder}\n </div>\n )}\n </Droppable>\n </DragDropContext>\n )\n}\n","import {useEffect, useMemo, useState} from 'react'\nimport {Box, Flex, Container, Spinner, Stack, Text} from '@sanity/ui'\n\nimport {useListeningQuery, Feedback} from 'sanity-plugin-utils'\nimport DraggableList from './DraggableList'\nimport {ORDER_FIELD_NAME} from './helpers/constants'\nimport {SanityDocumentWithOrder} from './types'\n\nexport interface DocumentListQueryProps {\n type: string\n filter?: string\n params?: Record<string, unknown>\n}\n\nconst DEFAULT_PARAMS = {}\n\nexport default function DocumentListQuery({\n type,\n filter,\n params = DEFAULT_PARAMS,\n}: DocumentListQueryProps) {\n const [listIsUpdating, setListIsUpdating] = useState(false)\n const [data, setData] = useState<SanityDocumentWithOrder[] | null>([])\n\n const query = `*[_type == $type ${filter ? `&& ${filter}` : ''}]|order(@[$order] asc){\n _id, _type, ${ORDER_FIELD_NAME}\n }`\n const queryParams = {\n ...params,\n type,\n order: ORDER_FIELD_NAME,\n }\n\n const {\n data: queryData,\n loading,\n error,\n } = useListeningQuery<SanityDocumentWithOrder[]>(query, {\n params: queryParams,\n initialValue: [],\n })\n\n useEffect(() => {\n if (queryData) {\n const filteredDocuments = queryData.reduce<SanityDocumentWithOrder[]>((acc, cur) => {\n if (!cur._id.startsWith(`drafts.`)) {\n // eslint-disable-next-line max-nested-callbacks\n const alsoHasDraft = queryData.some((doc) => doc._id === `drafts.${cur._id}`)\n return alsoHasDraft ? acc : [...acc, cur]\n }\n\n // Check if the draft has a published version\n cur.hasPublished = queryData.some((doc) => doc._id === cur._id.replace(`drafts.`, ``))\n\n return [...acc, cur]\n }, [])\n\n setData(filteredDocuments)\n } else {\n setData([])\n }\n }, [queryData])\n\n const unorderedDataCount = useMemo(\n () => (data?.length ? data.filter((doc) => !doc[ORDER_FIELD_NAME]).length : 0),\n [data]\n )\n\n if (loading) {\n return (\n <Flex style={{width: `100%`, height: `100%`}} align=\"center\" justify=\"center\">\n <Spinner />\n </Flex>\n )\n }\n\n if (error) {\n return (\n <Box padding={2}>\n <Feedback tone=\"critical\" title=\"There was an error\" description=\"Please try again later\" />\n </Box>\n )\n }\n\n if (!data || data?.length == 0)\n return (\n <Flex align=\"center\" direction=\"column\" height=\"fill\" justify=\"center\">\n <Container width={1}>\n <Box paddingX={4} paddingY={5}>\n <Text align=\"center\" muted>\n No documents of this type\n </Text>\n </Box>\n </Container>\n </Flex>\n )\n\n return (\n <Stack space={1} style={{overflow: `auto`, height: `100%`}}>\n <Box padding={2}>\n {unorderedDataCount > 0 && (\n <Box marginBottom={2}>\n <Feedback\n tone=\"caution\"\n description={\n <>\n {unorderedDataCount}/{data?.length} documents have no order. Select{' '}\n <strong>Reset Order</strong> from the menu above to fix.\n </>\n }\n />\n </Box>\n )}\n <DraggableList\n data={data}\n listIsUpdating={listIsUpdating}\n setListIsUpdating={setListIsUpdating}\n />\n </Box>\n </Stack>\n )\n}\n","import {useEffect, useMemo} from 'react'\nimport {useToast} from '@sanity/ui'\n\nimport {useSchema} from 'sanity'\nimport {Box, type ToastParams} from '@sanity/ui'\nimport {Feedback} from 'sanity-plugin-utils'\nimport DocumentListQuery from './DocumentListQuery'\nimport {OrderableContext} from './OrderableContext'\n\nimport {ORDER_FIELD_NAME} from './helpers/constants'\n\nexport interface DocumentListWrapperProps {\n showIncrements: boolean\n type: string\n resetOrderTransaction: ToastParams\n // eslint-disable-next-line react/require-default-props\n filter?: string\n // eslint-disable-next-line react/require-default-props\n params?: Record<string, unknown>\n}\n\n// 1. Validate first that the schema has been configured for ordering\n// 2. Setup context for showIncrements\nexport default function DocumentListWrapper({\n type,\n showIncrements,\n resetOrderTransaction,\n filter,\n params,\n}: DocumentListWrapperProps) {\n const toast = useToast()\n const schema = useSchema()\n\n useEffect(() => {\n if (resetOrderTransaction?.title && resetOrderTransaction?.status) {\n toast.push(resetOrderTransaction)\n }\n }, [resetOrderTransaction, toast])\n\n const schemaIsInvalid = useMemo(() => {\n // Option not passed\n if (!type) {\n return (\n <>\n No <code>type</code> was configured\n </>\n )\n }\n\n const typeSchema = schema.get(type)\n\n // Schema not found\n if (!typeSchema) {\n return (\n <>\n Schema <code>{type}</code> not found\n </>\n )\n }\n\n // Schema lacks an order field\n if (\n !('fields' in typeSchema) ||\n !typeSchema.fields.some((field) => field?.name === ORDER_FIELD_NAME)\n ) {\n return (\n <>\n Schema <code>{type}</code> must have an <code>{ORDER_FIELD_NAME}</code> field of type{' '}\n <code>string</code>\n </>\n )\n }\n\n // Schema's order field is not a string\n if (\n 'fields' in typeSchema &&\n typeSchema.fields.some(\n (field) => field?.name === ORDER_FIELD_NAME && field?.type?.name !== 'string'\n )\n ) {\n return (\n <>\n <code>{ORDER_FIELD_NAME}</code> field on Schema <code>{type}</code> must be{' '}\n <code>string</code> type\n </>\n )\n }\n\n return ''\n }, [type, schema])\n\n if (schemaIsInvalid) {\n return (\n <Box padding={2}>\n <Feedback description={schemaIsInvalid} tone=\"caution\" />\n </Box>\n )\n }\n\n return (\n <OrderableContext.Provider value={{showIncrements}}>\n <DocumentListQuery type={type} filter={filter} params={params} />\n </OrderableContext.Provider>\n )\n}\n","import {LexoRank} from 'lexorank'\nimport {SanityClient} from '@sanity/client'\nimport {ORDER_FIELD_NAME} from './constants'\n// Function to wipe and re-do ordering with LexoRank\n// Will at least attempt to start with the current order\nexport async function resetOrder(type = ``, client: SanityClient) {\n const query = `*[_type == $type]|order(@[$order] asc)._id`\n const queryParams = {type, order: ORDER_FIELD_NAME}\n const documents = await client.fetch(query, queryParams)\n\n if (!documents.length) {\n return null\n }\n\n const transaction = client.transaction()\n let aLexoRank = LexoRank.min()\n\n for (let index = 0; index < documents.length; index += 1) {\n // Generate next rank before even the first document so there's room to move!\n aLexoRank = aLexoRank.genNext().genNext()\n\n transaction.patch(documents[index], {\n set: {[ORDER_FIELD_NAME]: aLexoRank.toString()},\n })\n }\n\n return transaction\n .commit()\n .then((update) => update)\n .catch((err) => err)\n}\n","import {Component} from 'react'\n\nimport {SanityClient} from '@sanity/client'\nimport type {ToastParams} from '@sanity/ui'\nimport DocumentListWrapper from './DocumentListWrapper'\nimport {resetOrder} from './helpers/resetOrder'\n\nexport interface OrderableDocumentListProps {\n options: {\n type: string\n client: SanityClient\n filter?: string\n params?: Record<string, unknown>\n }\n}\n\ninterface State {\n showIncrements: boolean\n resetOrderTransaction: ToastParams\n}\n\n// Must use a Class Component here so the actionHandlers can be called\nexport default class OrderableDocumentList extends Component<OrderableDocumentListProps, State> {\n constructor(props: OrderableDocumentListProps) {\n super(props)\n this.state = {\n showIncrements: false,\n resetOrderTransaction: {},\n }\n }\n\n actionHandlers = {\n showIncrements: () => {\n this.setState((state) => ({\n showIncrements: !state.showIncrements,\n }))\n },\n\n resetOrder: async () => {\n this.setState(() => ({\n resetOrderTransaction: {\n status: `info`,\n title: `Reordering started...`,\n closable: true,\n },\n }))\n\n const update = await resetOrder(this.props.options.type, this.props.options.client)\n\n const reorderWasSuccessful = update?.results?.length\n\n this.setState(() => ({\n resetOrderTransaction: {\n status: reorderWasSuccessful ? `success` : `info`,\n title: reorderWasSuccessful\n ? `Reordered ${update.results.length === 1 ? `Document` : `Documents`}`\n : `Reordering failed`,\n closable: true,\n },\n }))\n },\n }\n\n render() {\n const type = this?.props?.options?.type\n if (!type) {\n return null\n }\n return (\n <DocumentListWrapper\n filter={this?.props?.options?.filter}\n params={this?.props?.options?.params}\n type={type}\n showIncrements={this.state.showIncrements}\n resetOrderTransaction={this.state.resetOrderTransaction}\n />\n )\n }\n}\n","import {GenerateIcon, SortIcon} from '@sanity/icons'\nimport type {ConfigContext} from 'sanity'\n\nimport {ComponentType} from 'react'\nimport {StructureBuilder, type ListItem, type MenuItem} from 'sanity/structure'\nimport OrderableDocumentList from '../OrderableDocumentList'\nimport {API_VERSION} from '../helpers/constants'\n\nexport interface OrderableListConfig {\n type: string\n id?: string\n title?: string\n icon?: ComponentType\n params?: Record<string, unknown>\n filter?: string\n menuItems?: MenuItem[]\n createIntent?: boolean\n context: ConfigContext\n S: StructureBuilder\n}\n\nexport function orderableDocumentListDeskItem(config: OrderableListConfig): ListItem {\n if (!config?.type || !config.context || !config.S) {\n throw new Error(`\n type, context and S (StructureBuilder) must be provided.\n context and S are available when configuring structure.\n Example: orderableDocumentListDeskItem({type: 'category'})\n `)\n }\n\n const {type, filter, menuItems = [], createIntent, params, title, icon, id, context, S} = config\n const {schema, getClient} = context\n const client = getClient({apiVersion: API_VERSION})\n\n const listTitle = title ?? `Orderable ${type}`\n const listId = id ?? `orderable-${type}`\n const listIcon = icon ?? SortIcon\n const typeTitle = schema.get(type)?.title ?? type\n\n if (createIntent !== false) {\n menuItems.push(\n S.menuItem()\n .title(`Create new ${typeTitle}`)\n .intent({type: 'create', params: {type}})\n .serialize()\n )\n }\n return S.listItem()\n .title(listTitle)\n .id(listId)\n .icon(listIcon)\n .schemaType(type)\n .child(\n Object.assign(\n S.documentTypeList(type)\n .canHandleIntent(() => !!createIntent)\n .serialize(),\n {\n // Prevents the component from re-rendering when switching documents\n __preserveInstance: true,\n // Prevents the component from NOT re-rendering when switching listItems\n key: listId,\n\n type: 'component',\n component: OrderableDocumentList,\n options: {type, filter, params, client},\n menuItems: [\n ...menuItems,\n S.menuItem().title(`Reset Order`).icon(GenerateIcon).action(`resetOrder`).serialize(),\n S.menuItem()\n .title(`Toggle Increments`)\n .icon(SortIcon)\n .action(`showIncrements`)\n .serialize(),\n ],\n }\n )\n )\n .serialize()\n}\n"],"names":["ORDER_FIELD_NAME","API_VERSION","initialRank","compareRankValue","arguments","length","undefined","newItemPosition","compareRank","LexoRank","parse","min","rank","genPrev","genNext","toString","orderRankField","config","type","Error","defineField","title","readOnly","hidden","name","initialValue","p","_ref","getClient","direction","lastDocOrderRank","apiVersion","fetch","concat","order","orderRankOrdering","by","field","OrderableContext","React","createContext","Document","_ref2","doc","increment","entities","index","isFirst","isLast","dragBadge","_a","_b","showIncrements","useContext","schema","useSchema","router","usePaneRouter","ChildLink","groupIndex","routerPanesState","currentDoc","id","pressed","_id","replace","selected","Link","useMemo","LinkComponent","linkProps","childId","jsx","PreviewCard","__unstable_focusRing","as","radius","sizing","tabIndex","tone","width","flex","children","jsxs","Flex","align","Box","paddingX","style","flexShrink","Text","size","DragHandleIcon","cursor","gap","paddingRight","Button","padding","mode","onClick","disabled","icon","ChevronUpIcon","ChevronDownIcon","Preview","layout","value","schemaType","get","_type","Card","marginRight","AvatarCounter","count","lexicographicalSort","a","b","reorderDocuments","_ref3","selectedIds","source","destination","startIndex","endIndex","isMovingUp","selectedItems","filter","item","includes","message","join","all","reduce","acc","cur","curIndex","_c","_d","prevIndex","prevRank","curRank","nextIndex","nextRank","max","betweenRank","between","selectedIndex","patches","flatMap","docPatches","set","startsWith","hasPublished","push","allSorted","sort","newOrder","useSanityClient","useClient","getItemStyle","draggableStyle","itemIsUpdating","userSelect","transition","opacity","pointerEvents","cardTone","settings","isDuplicate","isGhosting","isDragging","isSelected","DraggableList","_ref4","data","listIsUpdating","setListIsUpdating","toast","useToast","orderedData","setOrderedData","useState","useEffect","draggingId","setDraggingId","setSelectedIds","clearSelected","useCallback","handleSelect","clickedId","nativeEvent","selectMultiple","shiftKey","isUsingWindows","navigator","appVersion","indexOf","selectAdditional","ctrlKey","metaKey","updatedIds","preventDefault","lastSelectedId","lastSelectedIndex","findIndex","firstSelected","lastSelected","betweenIds","itemIndex","map","client","transactPatches","transaction","forEach","_ref5","docId","ops","patch","commit","then","updated","results","status","description","catch","handleDragEnd","result","draggableId","effectedIds","handleDragStart","start","incrementIndex","shiftFrom","shiftTo","onWindowKeyDown","event","key","window","addEventListener","removeEventListener","duplicateOrders","orderField","onDragEnd","DragDropContext","onDragStart","Droppable","droppableId","provided","droppableProps","ref","innerRef","Draggable","innerProvided","innerSnapshot","Boolean","isUpdating","isDisabled","selectedCount","draggableProps","dragHandleProps","paddingBottom","shadow","e","placeholder","DEFAULT_PARAMS","DocumentListQuery","_ref6","params","setData","query","queryParams","queryData","loading","error","useListeningQuery","filteredDocuments","alsoHasDraft","some","unorderedDataCount","height","justify","Spinner","Feedback","Container","paddingY","muted","Stack","space","overflow","marginBottom","Fragment","DocumentListWrapper","_ref7","resetOrderTransaction","schemaIsInvalid","typeSchema","fields","Provider","resetOrder","documents","aLexoRank","update","err","OrderableDocumentList","Component","constructor","props","__publicField","setState","state","closable","options","reorderWasSuccessful","render","_e","_f","orderableDocumentListDeskItem","context","S","menuItems","createIntent","listTitle","listId","listIcon","SortIcon","typeTitle","menuItem","intent","serialize","listItem","child","Object","assign","documentTypeList","canHandleIntent","__preserveInstance","component","GenerateIcon","action"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/helpers/constants.ts","../src/helpers/initialRank.ts","../src/fields/orderRankField.ts","../src/fields/orderRankOrdering.ts","../src/OrderableContext.ts","../src/Document.tsx","../src/helpers/reorderDocuments.ts","../src/helpers/client.ts","../src/DraggableList.tsx","../src/DocumentListQuery.tsx","../src/DocumentListWrapper.tsx","../src/helpers/resetOrder.ts","../src/OrderableDocumentList.tsx","../src/desk-structure/orderableDocumentListDeskItem.ts"],"sourcesContent":["export const ORDER_FIELD_NAME = `orderRank` as const\n\nexport const API_VERSION = `2021-09-01` as const\n","import {LexoRank} from 'lexorank'\nimport {NewItemPosition} from '../types'\n\n// Use in initial value field by passing in the rank value of the last document\n// If not value passed, generate a sensibly low rank\nexport function initialRank(\n compareRankValue = ``,\n newItemPosition: NewItemPosition = 'after',\n): string {\n const compareRank = compareRankValue ? LexoRank.parse(compareRankValue) : LexoRank.min()\n const rank =\n newItemPosition === 'before' ? compareRank.genPrev().genPrev() : compareRank.genNext().genNext()\n\n return rank.toString()\n}\n","import {type ConfigContext, defineField, type StringDefinition} from 'sanity'\nimport {API_VERSION, ORDER_FIELD_NAME} from '../helpers/constants'\nimport {initialRank} from '../helpers/initialRank'\nimport type {NewItemPosition} from '../types'\n\nexport type SchemaContext = Omit<ConfigContext, 'schema' | 'currentUser' | 'client'>\n\nexport interface RankFieldConfig extends Omit<StringDefinition, 'name' | 'type' | 'initialValue'> {\n type: string\n newItemPosition?: NewItemPosition\n}\n\nexport const orderRankField = (config: RankFieldConfig): StringDefinition => {\n if (!config?.type) {\n throw new Error(\n `\n type must be provided.\n Example: orderRankField({type: 'category'})\n `,\n )\n }\n\n const {type, newItemPosition = 'after', ...rest} = config\n return defineField({\n title: 'Order Rank',\n readOnly: true,\n hidden: true,\n ...rest,\n name: ORDER_FIELD_NAME,\n type: 'string',\n initialValue: async (p, {getClient}) => {\n const direction = newItemPosition === 'before' ? 'asc' : 'desc'\n\n const lastDocOrderRank = await getClient({apiVersion: API_VERSION}).fetch(\n `*[_type == $type]|order(@[$order] ${direction})[0][$order]`,\n {type, order: ORDER_FIELD_NAME},\n {tag: 'orderable-document-list.last-doc-order-rank'},\n )\n return initialRank(lastDocOrderRank, newItemPosition)\n },\n })\n}\n","import type {SortOrdering} from 'sanity'\nimport {ORDER_FIELD_NAME} from '../helpers/constants'\n\nexport const orderRankOrdering: SortOrdering = {\n title: 'Ordered',\n name: 'ordered',\n by: [{field: ORDER_FIELD_NAME, direction: 'asc'}],\n}\n","import {createContext} from 'react'\n\nexport interface OrderableContextValue {\n showIncrements?: boolean\n}\n\nexport const OrderableContext = createContext<OrderableContextValue>({})\n","import {useContext, useMemo, type ReactNode} from 'react'\nimport {ChevronDownIcon, ChevronUpIcon, DragHandleIcon} from '@sanity/icons'\nimport {AvatarCounter, Card, Box, Button, Flex, Text} from '@sanity/ui'\nimport {useSchema, SchemaType, PreviewCard, Preview} from 'sanity'\nimport {usePaneRouter} from 'sanity/structure'\n\nimport {OrderableContext} from './OrderableContext'\nimport type {SanityDocumentWithOrder} from './types'\n\nexport interface DocumentProps {\n doc: SanityDocumentWithOrder\n entities: SanityDocumentWithOrder[]\n increment: (\n index: number,\n nextIndex: number,\n docId: string,\n entities: SanityDocumentWithOrder[],\n ) => void\n index: number\n isFirst: boolean\n isLast: boolean\n dragBadge: number | false\n}\n\nexport function Document({\n doc,\n increment,\n entities,\n index,\n isFirst,\n isLast,\n dragBadge,\n}: DocumentProps) {\n const {showIncrements} = useContext(OrderableContext)\n const schema = useSchema()\n const router = usePaneRouter()\n const {ChildLink, groupIndex, routerPanesState} = router\n\n const currentDoc = routerPanesState[groupIndex + 1]?.[0]?.id || false\n const pressed = currentDoc === doc._id || currentDoc === doc._id.replace(`drafts.`, ``)\n const selected = pressed && routerPanesState.length === groupIndex + 2\n\n const Link = useMemo(\n () =>\n function LinkComponent(linkProps: {children: ReactNode}) {\n return <ChildLink {...linkProps} childId={doc._id} />\n },\n [ChildLink, doc._id],\n )\n\n return (\n <PreviewCard\n __unstable_focusRing\n // @ts-expect-error\n as={Link}\n data-as=\"a\"\n data-ui=\"PaneItem\"\n radius={2}\n pressed={pressed}\n selected={selected}\n sizing=\"border\"\n tabIndex={-1}\n tone=\"inherit\"\n width=\"100%\"\n flex={1}\n >\n <Flex align=\"center\">\n <Box paddingX={2} style={{flexShrink: 0}}>\n <Text size={2}>\n <DragHandleIcon cursor=\"grab\" />\n </Text>\n </Box>\n {showIncrements && (\n <Flex style={{flexShrink: 0}} align=\"center\" gap={1} paddingRight={1}>\n <Button\n padding={2}\n mode=\"ghost\"\n // eslint-disable-next-line react/jsx-no-bind\n onClick={() => increment(index, index + -1, doc._id, entities)}\n disabled={isFirst}\n icon={ChevronUpIcon}\n />\n <Button\n padding={2}\n mode=\"ghost\"\n disabled={isLast}\n // eslint-disable-next-line react/jsx-no-bind\n onClick={() => increment(index, index + 1, doc._id, entities)}\n icon={ChevronDownIcon}\n />\n </Flex>\n )}\n <Box style={{width: `100%`}}>\n <Flex flex={1} align=\"center\">\n <Preview\n layout=\"default\"\n value={doc}\n schemaType={schema.get(doc._type) as SchemaType}\n />\n </Flex>\n </Box>\n {dragBadge && (\n <Card tone=\"default\" marginRight={4} radius={5}>\n <AvatarCounter count={dragBadge} />\n </Card>\n )}\n </Flex>\n </PreviewCard>\n )\n}\n","import {LexoRank} from 'lexorank'\nimport type {PatchOperations} from 'sanity'\n\nimport type {SanityDocumentWithOrder} from '../types'\nimport {ORDER_FIELD_NAME} from './constants'\n\nexport interface MaifestArgs {\n entities: SanityDocumentWithOrder[]\n selectedItems: SanityDocumentWithOrder[]\n isMovingUp: boolean\n curIndex: number\n nextIndex: number\n prevIndex: number\n}\n\nexport interface ReorderArgs {\n entities: SanityDocumentWithOrder[]\n selectedIds: string[]\n source: any\n destination: any\n}\n\nexport interface ReorderReturn {\n newOrder: SanityDocumentWithOrder[]\n patches: [string, PatchOperations][]\n message: any\n}\n\nfunction lexicographicalSort(a: SanityDocumentWithOrder, b: SanityDocumentWithOrder) {\n if (!a[ORDER_FIELD_NAME] || !b[ORDER_FIELD_NAME]) {\n return 0\n } else if (a[ORDER_FIELD_NAME] < b[ORDER_FIELD_NAME]) {\n return -1\n } else if (a[ORDER_FIELD_NAME] > b[ORDER_FIELD_NAME]) {\n return 1\n }\n return 0\n}\n\nexport const reorderDocuments = ({\n entities,\n selectedIds,\n source,\n destination,\n}: ReorderArgs): ReorderReturn => {\n const startIndex = source.index\n const endIndex = destination.index\n const isMovingUp = startIndex > endIndex\n const selectedItems = entities.filter((item) => selectedIds.includes(item._id))\n const message = [\n 'Moved',\n selectedItems.length === 1 ? '1 document' : `${selectedItems.length} documents`,\n isMovingUp ? 'up' : 'down',\n 'from position',\n `${startIndex + 1} to ${endIndex + 1}`,\n ].join(' ')\n\n const {all, selected} = entities.reduce<{\n all: SanityDocumentWithOrder[]\n selected: SanityDocumentWithOrder[]\n }>(\n (acc, cur, curIndex) => {\n // Selected items get spread in below, so skip them here\n if (selectedIds.includes(cur._id)) {\n return {all: acc.all, selected: acc.selected}\n }\n\n // Drop selected items in\n if (curIndex === endIndex) {\n const prevIndex = curIndex - 1\n const prevRank = entities[prevIndex]?.[ORDER_FIELD_NAME]\n ? LexoRank.parse(entities[prevIndex]?.[ORDER_FIELD_NAME] as string)\n : LexoRank.min()\n\n const curRank = LexoRank.parse(entities[curIndex][ORDER_FIELD_NAME] as string)\n\n const nextIndex = curIndex + 1\n const nextRank = entities[nextIndex]?.[ORDER_FIELD_NAME]\n ? LexoRank.parse(entities[nextIndex]?.[ORDER_FIELD_NAME] as string)\n : LexoRank.max()\n\n let betweenRank = isMovingUp ? prevRank.between(curRank) : curRank.between(nextRank)\n\n // For each selected item, assign a new orderRank between now and next\n for (let selectedIndex = 0; selectedIndex < selectedItems.length; selectedIndex += 1) {\n selectedItems[selectedIndex][ORDER_FIELD_NAME] = betweenRank.toString()\n betweenRank = isMovingUp ? betweenRank.between(curRank) : betweenRank.between(nextRank)\n }\n\n return {\n // The `all` array gets sorted by order field later anyway\n // so that this probably isn't necessary ¯\\_(ツ)_/¯\n all: isMovingUp\n ? [...acc.all, ...selectedItems, cur]\n : [...acc.all, cur, ...selectedItems],\n selected: selectedItems,\n }\n }\n\n return {all: [...acc.all, cur], selected: acc.selected}\n },\n {all: [], selected: []},\n )\n\n const patches = selected.flatMap((doc) => {\n const docPatches: [string, PatchOperations][] = [\n [\n doc._id,\n {\n set: {\n [ORDER_FIELD_NAME]: doc[ORDER_FIELD_NAME],\n },\n },\n ],\n ]\n\n // If it's a draft, we need to patch the published document as well\n if (doc._id.startsWith('drafts.') && doc.hasPublished) {\n docPatches.push([\n doc._id.replace('drafts.', ''),\n {\n set: {\n [ORDER_FIELD_NAME]: doc[ORDER_FIELD_NAME],\n },\n },\n ])\n }\n\n return docPatches\n })\n\n // Safety-check to make sure everything is in order\n const allSorted = all.sort(lexicographicalSort)\n\n return {newOrder: allSorted, patches, message}\n}\n","import {type SanityClient, useClient} from 'sanity'\nimport {API_VERSION} from './constants'\n\nexport function useSanityClient(): SanityClient {\n return useClient({apiVersion: API_VERSION})\n}\n","import {useEffect, useState, useMemo, useCallback, type CSSProperties} from 'react'\nimport {DragDropContext, Draggable, Droppable, type DropResult} from '@hello-pangea/dnd'\nimport {Box, Card, useToast} from '@sanity/ui'\nimport type {PatchOperations} from 'sanity'\nimport {usePaneRouter} from 'sanity/structure'\n\nimport {Document} from './Document'\nimport {reorderDocuments} from './helpers/reorderDocuments'\nimport {ORDER_FIELD_NAME} from './helpers/constants'\nimport {useSanityClient} from './helpers/client'\nimport type {SanityDocumentWithOrder} from './types'\n\ninterface ListSetting {\n isDuplicate: boolean\n isGhosting: boolean\n isDragging: boolean\n isSelected: boolean\n}\n\nexport interface DraggableListProps {\n data: SanityDocumentWithOrder[]\n listIsUpdating: boolean\n setListIsUpdating: (val: boolean) => void\n}\n\nconst getItemStyle = (\n draggableStyle: CSSProperties | undefined,\n itemIsUpdating: boolean,\n): CSSProperties => ({\n userSelect: 'none',\n transition: 'opacity 500ms ease-in-out',\n opacity: itemIsUpdating ? 0.2 : 1,\n pointerEvents: itemIsUpdating ? 'none' : undefined,\n ...draggableStyle,\n})\n\nconst cardTone = (settings: ListSetting) => {\n const {isDuplicate, isGhosting, isDragging, isSelected} = settings\n\n if (isGhosting) return 'transparent'\n if (isDragging || isSelected) return 'primary'\n if (isDuplicate) return 'caution'\n\n return undefined\n}\n\nexport function DraggableList({data, listIsUpdating, setListIsUpdating}: DraggableListProps) {\n const toast = useToast()\n const router = usePaneRouter()\n const {groupIndex, routerPanesState} = router\n\n const currentDoc = routerPanesState[groupIndex + 1]?.[0]?.id || false\n\n // Maintains local state order before transaction completes\n const [orderedData, setOrderedData] = useState<SanityDocumentWithOrder[]>(data)\n\n // Update local state when documents change from an outside source\n useEffect(() => {\n if (!listIsUpdating) setOrderedData(data)\n /* eslint-disable-next-line react-hooks/exhaustive-deps */\n }, [data])\n\n const [draggingId, setDraggingId] = useState('')\n const [selectedIds, setSelectedIds] = useState<string[]>(currentDoc ? [currentDoc] : [])\n\n const clearSelected = useCallback(() => setSelectedIds([]), [setSelectedIds])\n\n const handleSelect = useCallback(\n (clickedId: string, index: number, nativeEvent: MouseEvent) => {\n const isSelected = selectedIds.includes(clickedId)\n const selectMultiple = nativeEvent.shiftKey\n const isUsingWindows = navigator.appVersion.indexOf('Win') !== -1\n const selectAdditional = isUsingWindows ? nativeEvent.ctrlKey : nativeEvent.metaKey\n\n let updatedIds = []\n\n // No modifier keys pressed during click:\n // - update selected to just this one\n // - open document\n if (!selectMultiple && !selectAdditional) {\n return setSelectedIds([clickedId])\n }\n\n // If shift key was held, prevent default to avoid new window opening\n if (selectMultiple) {\n nativeEvent.preventDefault()\n }\n\n // Shift key was held, add id's between last selected and this one\n // ...before adding this one\n if (selectMultiple && !isSelected) {\n const lastSelectedId = selectedIds[selectedIds.length - 1]\n const lastSelectedIndex = orderedData.findIndex((item) => item._id === lastSelectedId)\n\n const firstSelected = index < lastSelectedIndex ? index : lastSelectedIndex\n const lastSelected = index > lastSelectedIndex ? index : lastSelectedIndex\n\n const betweenIds = orderedData\n .filter((item, itemIndex) => itemIndex > firstSelected && itemIndex < lastSelected)\n .map((item) => item._id)\n\n updatedIds = [...selectedIds, ...betweenIds, clickedId]\n } else if (isSelected) {\n // Toggle off a single id\n updatedIds = selectedIds.filter((id) => id !== clickedId)\n } else {\n // Toggle on a single id\n updatedIds = [...selectedIds, clickedId]\n }\n\n return setSelectedIds(updatedIds)\n },\n [setSelectedIds, orderedData, selectedIds],\n )\n\n const client = useSanityClient()\n\n const transactPatches = useCallback(\n async (patches: [string, PatchOperations][], message: string) => {\n const transaction = client.transaction()\n\n patches.forEach(([docId, ops]) => transaction.patch(docId, ops))\n\n try {\n const updated = await transaction.commit({\n visibility: 'async',\n tag: 'orderable-document-list.reorder',\n })\n clearSelected()\n setDraggingId('')\n setListIsUpdating(false)\n toast.push({\n title: `${\n updated.results.length === 1 ? '1 document' : `${updated.results.length} documents`\n } reordered`,\n status: 'success',\n description: message,\n })\n } catch (err) {\n setDraggingId('')\n setListIsUpdating(false)\n toast.push({\n title: 'Reordering failed',\n status: 'error',\n })\n }\n },\n [client, setDraggingId, clearSelected, setListIsUpdating, toast],\n )\n\n const handleDragEnd = useCallback(\n (result: DropResult | undefined, entities: SanityDocumentWithOrder[]) => {\n setDraggingId('')\n\n const {source, destination, draggableId} = result ?? {}\n\n // Don't do anything if nothing changed\n if (source?.index === destination?.index) return\n\n // Don't do anything if we don't have the entitites\n if (!entities?.length || !draggableId) return\n\n // A document can be dragged without being one-of-many-selected\n const effectedIds = selectedIds?.length ? selectedIds : [draggableId]\n\n // Don't do anything if we don't have ids to effect\n if (!effectedIds?.length) return\n\n // Update state to update styles + prevent data refetching\n setListIsUpdating(true)\n setSelectedIds(effectedIds)\n\n const {newOrder, patches, message} = reorderDocuments({\n entities,\n selectedIds: effectedIds,\n source,\n destination,\n })\n\n // Update local state\n if (newOrder?.length) {\n setOrderedData(newOrder)\n }\n\n // Transact new order patches\n if (patches?.length) {\n transactPatches(patches, message)\n }\n },\n [selectedIds, setDraggingId, setSelectedIds, transactPatches, setListIsUpdating],\n )\n\n const handleDragStart = useCallback(\n (start: {draggableId: string}) => {\n const id = start.draggableId\n const selected = selectedIds.includes(id)\n\n // if dragging an item that is not selected - unselect all items\n if (!selected) clearSelected()\n\n setDraggingId(id)\n },\n [selectedIds, clearSelected, setDraggingId],\n )\n\n // Move one document up or down one place, by fake invoking the drag function\n const incrementIndex = useCallback(\n (shiftFrom: number, shiftTo: number, id: string, entities: SanityDocumentWithOrder[]) => {\n const result = {\n draggableId: id,\n source: {index: shiftFrom},\n destination: {index: shiftTo},\n }\n\n return handleDragEnd(result as DropResult, entities)\n },\n [handleDragEnd],\n )\n\n const onWindowKeyDown = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n clearSelected()\n }\n },\n [clearSelected],\n )\n\n useEffect(() => {\n window.addEventListener('keydown', onWindowKeyDown)\n\n return () => {\n window.removeEventListener('keydown', onWindowKeyDown)\n }\n }, [onWindowKeyDown])\n\n // Find all items with duplicate order field\n const duplicateOrders = useMemo(() => {\n if (!orderedData.length) return []\n\n const orderField = orderedData.map((item) => item[ORDER_FIELD_NAME])\n\n return orderField.filter((item, index) => orderField.indexOf(item) !== index)\n }, [orderedData])\n\n const onDragEnd = useCallback(\n (result: DropResult) => handleDragEnd(result, orderedData),\n [orderedData, handleDragEnd],\n )\n\n return (\n <DragDropContext onDragStart={handleDragStart} onDragEnd={onDragEnd}>\n <Droppable droppableId=\"documentSortZone\">\n {(provided) => (\n <div {...provided.droppableProps} ref={provided.innerRef}>\n {orderedData.map((item, index) => (\n <Draggable\n key={`${item._id}-${item[ORDER_FIELD_NAME]}`}\n draggableId={item._id}\n index={index}\n // onClick={(event) => handleDraggableClick(event, provided, snapshot)}\n >\n {(innerProvided, innerSnapshot) => {\n const isSelected = selectedIds.includes(item._id)\n const isDragging = innerSnapshot.isDragging\n const isGhosting = Boolean(!isDragging && draggingId && isSelected)\n const isUpdating = listIsUpdating && isSelected\n const isDisabled = Boolean(!item[ORDER_FIELD_NAME])\n const isDuplicate = duplicateOrders.includes(item[ORDER_FIELD_NAME])\n const tone = cardTone({isDuplicate, isGhosting, isDragging, isSelected})\n const selectedCount = selectedIds.length\n\n const dragBadge = isDragging && selectedCount > 1 ? selectedCount : false\n\n return (\n <div\n ref={innerProvided.innerRef}\n {...innerProvided.draggableProps}\n {...innerProvided.dragHandleProps}\n style={\n isDisabled\n ? {opacity: 0.2, pointerEvents: 'none'}\n : getItemStyle(innerProvided.draggableProps.style, isUpdating)\n }\n >\n <Box paddingBottom={1}>\n <Card\n tone={tone}\n shadow={isDragging ? 2 : undefined}\n radius={2}\n // eslint-disable-next-line react/jsx-no-bind\n onClick={(e) => handleSelect(item._id, index, e.nativeEvent)}\n >\n <Document\n doc={item}\n entities={orderedData}\n increment={incrementIndex}\n index={index}\n isFirst={index === 0}\n isLast={index === orderedData.length - 1}\n dragBadge={dragBadge}\n />\n </Card>\n </Box>\n </div>\n )\n }}\n </Draggable>\n ))}\n {provided.placeholder}\n </div>\n )}\n </Droppable>\n </DragDropContext>\n )\n}\n","import {useEffect, useMemo, useState} from 'react'\nimport {Box, Flex, Container, Spinner, Stack, Text} from '@sanity/ui'\n\nimport {useListeningQuery, Feedback} from 'sanity-plugin-utils'\nimport {DraggableList} from './DraggableList'\nimport {ORDER_FIELD_NAME} from './helpers/constants'\nimport type {SanityDocumentWithOrder} from './types'\n\nexport interface DocumentListQueryProps {\n type: string\n filter?: string\n params?: Record<string, unknown>\n}\n\nconst DEFAULT_PARAMS = {}\n\nexport function DocumentListQuery({type, filter, params = DEFAULT_PARAMS}: DocumentListQueryProps) {\n const [listIsUpdating, setListIsUpdating] = useState(false)\n const [data, setData] = useState<SanityDocumentWithOrder[] | null>([])\n\n const query = `*[_type == $type ${filter ? `&& ${filter}` : ''}]|order(@[$order] asc){\n _id, _type, ${ORDER_FIELD_NAME}\n }`\n const queryParams = {\n ...params,\n type,\n order: ORDER_FIELD_NAME,\n }\n\n const {\n data: _queryData,\n loading,\n error,\n } = useListeningQuery<SanityDocumentWithOrder[]>(query, {\n params: queryParams,\n initialValue: [],\n })\n // @ts-expect-error Should not be needed to \"cast\", but sanity-plugin-utils is not typed correctly\n const queryData: SanityDocumentWithOrder[] = _queryData\n\n useEffect(() => {\n if (queryData) {\n const filteredDocuments = queryData.reduce<SanityDocumentWithOrder[]>((acc, cur) => {\n if (!cur._id.startsWith(`drafts.`)) {\n // eslint-disable-next-line max-nested-callbacks\n const alsoHasDraft = queryData.some((doc) => doc._id === `drafts.${cur._id}`)\n return alsoHasDraft ? acc : [...acc, cur]\n }\n\n // Check if the draft has a published version\n cur.hasPublished = queryData.some((doc) => doc._id === cur._id.replace(`drafts.`, ``))\n\n return [...acc, cur]\n }, [])\n\n setData(filteredDocuments)\n } else {\n setData([])\n }\n }, [queryData])\n\n const unorderedDataCount = useMemo(\n () => (data?.length ? data.filter((doc) => !doc[ORDER_FIELD_NAME]).length : 0),\n [data],\n )\n\n if (loading) {\n return (\n <Flex style={{width: `100%`, height: `100%`}} align=\"center\" justify=\"center\">\n <Spinner />\n </Flex>\n )\n }\n\n if (error) {\n return (\n <Box padding={2}>\n <Feedback tone=\"critical\" title=\"There was an error\" description=\"Please try again later\" />\n </Box>\n )\n }\n\n if (!data || data?.length == 0)\n return (\n <Flex align=\"center\" direction=\"column\" height=\"fill\" justify=\"center\">\n <Container width={1}>\n <Box paddingX={4} paddingY={5}>\n <Text align=\"center\" muted>\n No documents of this type\n </Text>\n </Box>\n </Container>\n </Flex>\n )\n\n return (\n <Stack space={1} style={{overflow: `auto`, height: `100%`}}>\n <Box padding={2}>\n {unorderedDataCount > 0 && (\n <Box marginBottom={2}>\n <Feedback\n tone=\"caution\"\n description={\n <>\n {unorderedDataCount}/{data?.length} documents have no order. Select{' '}\n <strong>Reset Order</strong> from the menu above to fix.\n </>\n }\n />\n </Box>\n )}\n <DraggableList\n data={data}\n listIsUpdating={listIsUpdating}\n setListIsUpdating={setListIsUpdating}\n />\n </Box>\n </Stack>\n )\n}\n","import {useEffect, useMemo} from 'react'\nimport {useToast, Box, type ToastParams} from '@sanity/ui'\n\nimport {useSchema} from 'sanity'\nimport {Feedback} from 'sanity-plugin-utils'\nimport {DocumentListQuery} from './DocumentListQuery'\nimport {OrderableContext} from './OrderableContext'\n\nimport {ORDER_FIELD_NAME} from './helpers/constants'\n\nexport interface DocumentListWrapperProps {\n showIncrements: boolean\n type: string\n resetOrderTransaction: ToastParams\n // eslint-disable-next-line react/require-default-props\n filter?: string\n // eslint-disable-next-line react/require-default-props\n params?: Record<string, unknown>\n}\n\n// 1. Validate first that the schema has been configured for ordering\n// 2. Setup context for showIncrements\nexport function DocumentListWrapper({\n type,\n showIncrements,\n resetOrderTransaction,\n filter,\n params,\n}: DocumentListWrapperProps) {\n const toast = useToast()\n const schema = useSchema()\n\n useEffect(() => {\n if (resetOrderTransaction?.title && resetOrderTransaction?.status) {\n toast.push(resetOrderTransaction)\n }\n }, [resetOrderTransaction, toast])\n\n const schemaIsInvalid = useMemo(() => {\n // Option not passed\n if (!type) {\n return (\n <>\n No <code>type</code> was configured\n </>\n )\n }\n\n const typeSchema = schema.get(type)\n\n // Schema not found\n if (!typeSchema) {\n return (\n <>\n Schema <code>{type}</code> not found\n </>\n )\n }\n\n // Schema lacks an order field\n if (\n !('fields' in typeSchema) ||\n !typeSchema.fields.some((field) => field?.name === ORDER_FIELD_NAME)\n ) {\n return (\n <>\n Schema <code>{type}</code> must have an <code>{ORDER_FIELD_NAME}</code> field of type{' '}\n <code>string</code>\n </>\n )\n }\n\n // Schema's order field is not a string\n if (\n 'fields' in typeSchema &&\n typeSchema.fields.some(\n (field) => field?.name === ORDER_FIELD_NAME && field?.type?.name !== 'string',\n )\n ) {\n return (\n <>\n <code>{ORDER_FIELD_NAME}</code> field on Schema <code>{type}</code> must be{' '}\n <code>string</code> type\n </>\n )\n }\n\n return ''\n }, [type, schema])\n\n if (schemaIsInvalid) {\n return (\n <Box padding={2}>\n <Feedback description={schemaIsInvalid} tone=\"caution\" />\n </Box>\n )\n }\n\n return (\n <OrderableContext.Provider value={{showIncrements}}>\n <DocumentListQuery type={type} filter={filter} params={params} />\n </OrderableContext.Provider>\n )\n}\n","import {LexoRank} from 'lexorank'\nimport type {MultipleMutationResult, SanityClient} from '@sanity/client'\nimport {ORDER_FIELD_NAME} from './constants'\n\n// Function to wipe and re-do ordering with LexoRank\n// Will at least attempt to start with the current order\nexport async function resetOrder(\n type: string,\n client: SanityClient,\n): Promise<MultipleMutationResult | null> {\n const query = `*[_type == $type]|order(@[$order] asc)._id`\n const queryParams = {type, order: ORDER_FIELD_NAME}\n const documentIds = await client.fetch<Array<string>>(query, queryParams, {\n tag: 'orderable-document-list.reset-order',\n })\n\n if (documentIds.length === 0) {\n return null\n }\n\n let aLexoRank = LexoRank.min()\n\n const transaction = documentIds.reduce((trx, documentId) => {\n // Generate next rank before even the first document so there's room to move!\n aLexoRank = aLexoRank.genNext().genNext()\n\n return trx.patch(documentId, {\n set: {[ORDER_FIELD_NAME]: aLexoRank.toString()},\n })\n }, client.transaction())\n\n return transaction.commit({\n visibility: 'async',\n tag: 'orderable-document-list.reset-order',\n })\n}\n","import {Component} from 'react'\n\nimport type {SanityClient} from '@sanity/client'\nimport type {ToastParams} from '@sanity/ui'\nimport {DocumentListWrapper} from './DocumentListWrapper'\nimport {resetOrder} from './helpers/resetOrder'\n\nexport interface OrderableDocumentListProps {\n options: {\n type: string\n client: SanityClient\n filter?: string\n params?: Record<string, unknown>\n }\n}\n\ninterface State {\n showIncrements: boolean\n resetOrderTransaction: ToastParams\n}\n\n// Must use a Class Component here so the actionHandlers can be called\nexport class OrderableDocumentList extends Component<OrderableDocumentListProps, State> {\n constructor(props: OrderableDocumentListProps) {\n super(props)\n this.state = {\n showIncrements: false,\n resetOrderTransaction: {},\n }\n }\n\n actionHandlers = {\n showIncrements: () => {\n this.setState((state) => ({\n showIncrements: !state.showIncrements,\n }))\n },\n\n resetOrder: async () => {\n this.setState(() => ({\n resetOrderTransaction: {\n status: `info`,\n title: `Reordering started...`,\n closable: true,\n },\n }))\n\n const update = await resetOrder(this.props.options.type, this.props.options.client)\n\n const reorderWasSuccessful = update?.results?.length\n\n this.setState(() => ({\n resetOrderTransaction: {\n status: reorderWasSuccessful ? `success` : `info`,\n title: reorderWasSuccessful\n ? `Reordered ${update.results.length === 1 ? `Document` : `Documents`}`\n : `Reordering failed`,\n closable: true,\n },\n }))\n },\n }\n\n render() {\n const type = this?.props?.options?.type\n if (!type) {\n return null\n }\n return (\n <DocumentListWrapper\n filter={this?.props?.options?.filter}\n params={this?.props?.options?.params}\n type={type}\n showIncrements={this.state.showIncrements}\n resetOrderTransaction={this.state.resetOrderTransaction}\n />\n )\n }\n}\n","import {GenerateIcon, SortIcon} from '@sanity/icons'\nimport type {ConfigContext} from 'sanity'\n\nimport type {ComponentType} from 'react'\nimport {StructureBuilder, type ListItem, type MenuItem} from 'sanity/structure'\nimport {OrderableDocumentList} from '../OrderableDocumentList'\nimport {API_VERSION} from '../helpers/constants'\n\nexport interface OrderableListConfig {\n type: string\n id?: string\n title?: string\n icon?: ComponentType\n params?: Record<string, unknown>\n filter?: string\n menuItems?: MenuItem[]\n createIntent?: boolean\n context: ConfigContext\n S: StructureBuilder\n}\n\nexport function orderableDocumentListDeskItem(config: OrderableListConfig): ListItem {\n if (!config?.type || !config.context || !config.S) {\n throw new Error(`\n type, context and S (StructureBuilder) must be provided.\n context and S are available when configuring structure.\n Example: orderableDocumentListDeskItem({type: 'category'})\n `)\n }\n\n const {type, filter, menuItems = [], createIntent, params, title, icon, id, context, S} = config\n const {schema, getClient} = context\n const client = getClient({apiVersion: API_VERSION})\n\n const listTitle = title ?? `Orderable ${type}`\n const listId = id ?? `orderable-${type}`\n const listIcon = icon ?? SortIcon\n const typeTitle = schema.get(type)?.title ?? type\n\n if (createIntent !== false) {\n menuItems.push(\n S.menuItem()\n .title(`Create new ${typeTitle}`)\n .intent({type: 'create', params: {type}})\n .serialize(),\n )\n }\n return S.listItem()\n .title(listTitle)\n .id(listId)\n .icon(listIcon)\n .schemaType(type)\n .child(\n Object.assign(\n S.documentTypeList(type)\n .canHandleIntent(() => !!createIntent)\n .serialize(),\n {\n // Prevents the component from re-rendering when switching documents\n __preserveInstance: true,\n // Prevents the component from NOT re-rendering when switching listItems\n key: listId,\n\n type: 'component',\n component: OrderableDocumentList,\n options: {type, filter, params, client},\n menuItems: [\n ...menuItems,\n S.menuItem().title(`Reset Order`).icon(GenerateIcon).action(`resetOrder`).serialize(),\n S.menuItem()\n .title(`Toggle Increments`)\n .icon(SortIcon)\n .action(`showIncrements`)\n .serialize(),\n ],\n },\n ),\n )\n .serialize()\n}\n"],"names":[],"mappings":";;;;;;;;;AAAa,MAAA,mBAAmB,aAEnB,cAAc;ACGpB,SAAS,YACd,mBAAmB,IACnB,kBAAmC,SAC3B;AACR,QAAM,cAAc,mBAAmB,SAAS,MAAM,gBAAgB,IAAI,SAAS,IAAI;AAIvF,UAFE,oBAAoB,WAAW,YAAY,QAAU,EAAA,QAAY,IAAA,YAAY,QAAQ,EAAE,QAAQ,GAErF,SAAS;AACvB;ACFa,MAAA,iBAAiB,CAAC,WAA8C;AAC3E,MAAI,CAAC,QAAQ;AACX,UAAM,IAAI;AAAA,MACR;AAAA;AAAA;AAAA;AAAA,IAIF;AAGF,QAAM,EAAC,MAAM,kBAAkB,SAAS,GAAG,KAAQ,IAAA;AACnD,SAAO,YAAY;AAAA,IACjB,OAAO;AAAA,IACP,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,GAAG;AAAA,IACH,MAAM;AAAA,IACN,MAAM;AAAA,IACN,cAAc,OAAO,GAAG,EAAC,gBAAe;AACtC,YAAM,YAAY,oBAAoB,WAAW,QAAQ,QAEnD,mBAAmB,MAAM,UAAU,EAAC,YAAY,YAAW,CAAC,EAAE;AAAA,QAClE,qCAAqC,SAAS;AAAA,QAC9C,EAAC,MAAM,OAAO,iBAAgB;AAAA,QAC9B,EAAC,KAAK,8CAA6C;AAAA,MACrD;AACO,aAAA,YAAY,kBAAkB,eAAe;AAAA,IAAA;AAAA,EACtD,CACD;AACH,GCtCa,oBAAkC;AAAA,EAC7C,OAAO;AAAA,EACP,MAAM;AAAA,EACN,IAAI,CAAC,EAAC,OAAO,kBAAkB,WAAW,MAAM,CAAA;AAClD,GCDa,mBAAmB,cAAqC,EAAE;ACkBhE,SAAS,SAAS;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAkB;AACV,QAAA,EAAC,eAAkB,IAAA,WAAW,gBAAgB,GAC9C,SAAS,aACT,SAAS,iBACT,EAAC,WAAW,YAAY,qBAAoB,QAE5C,aAAa,iBAAiB,aAAa,CAAC,IAAI,CAAC,GAAG,MAAM,IAC1D,UAAU,eAAe,IAAI,OAAO,eAAe,IAAI,IAAI,QAAQ,WAAW,EAAE,GAChF,WAAW,WAAW,iBAAiB,WAAW,aAAa,GAE/D,OAAO;AAAA,IACX,MACE,SAAuB,WAAkC;AACvD,iCAAQ,WAAW,EAAA,GAAG,WAAW,SAAS,IAAI,KAAK;AAAA,IACrD;AAAA,IACF,CAAC,WAAW,IAAI,GAAG;AAAA,EACrB;AAGE,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,sBAAoB;AAAA,MAEpB,IAAI;AAAA,MACJ,WAAQ;AAAA,MACR,WAAQ;AAAA,MACR,QAAQ;AAAA,MACR;AAAA,MACA;AAAA,MACA,QAAO;AAAA,MACP,UAAU;AAAA,MACV,MAAK;AAAA,MACL,OAAM;AAAA,MACN,MAAM;AAAA,MAEN,UAAA,qBAAC,MAAK,EAAA,OAAM,UACV,UAAA;AAAA,QAAA,oBAAC,OAAI,UAAU,GAAG,OAAO,EAAC,YAAY,KACpC,UAAC,oBAAA,MAAA,EAAK,MAAM,GACV,UAAA,oBAAC,kBAAe,QAAO,OAAA,CAAO,EAChC,CAAA,GACF;AAAA,QACC,kBACC,qBAAC,MAAK,EAAA,OAAO,EAAC,YAAY,EAAC,GAAG,OAAM,UAAS,KAAK,GAAG,cAAc,GACjE,UAAA;AAAA,UAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,SAAS;AAAA,cACT,MAAK;AAAA,cAEL,SAAS,MAAM,UAAU,OAAO,QAAQ,IAAI,IAAI,KAAK,QAAQ;AAAA,cAC7D,UAAU;AAAA,cACV,MAAM;AAAA,YAAA;AAAA,UACR;AAAA,UACA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,SAAS;AAAA,cACT,MAAK;AAAA,cACL,UAAU;AAAA,cAEV,SAAS,MAAM,UAAU,OAAO,QAAQ,GAAG,IAAI,KAAK,QAAQ;AAAA,cAC5D,MAAM;AAAA,YAAA;AAAA,UAAA;AAAA,QACR,GACF;AAAA,QAED,oBAAA,KAAA,EAAI,OAAO,EAAC,OAAO,OAAA,GAClB,UAAA,oBAAC,MAAK,EAAA,MAAM,GAAG,OAAM,UACnB,UAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,QAAO;AAAA,YACP,OAAO;AAAA,YACP,YAAY,OAAO,IAAI,IAAI,KAAK;AAAA,UAAA;AAAA,WAEpC,EACF,CAAA;AAAA,QACC,aACC,oBAAC,MAAK,EAAA,MAAK,WAAU,aAAa,GAAG,QAAQ,GAC3C,UAAA,oBAAC,eAAc,EAAA,OAAO,WAAW,EACnC,CAAA;AAAA,MAAA,EAEJ,CAAA;AAAA,IAAA;AAAA,EACF;AAEJ;ACjFA,SAAS,oBAAoB,GAA4B,GAA4B;AAC/E,SAAA,CAAC,EAAE,gBAAgB,KAAK,CAAC,EAAE,gBAAgB,IACtC,IACE,EAAE,gBAAgB,IAAI,EAAE,gBAAgB,IAC1C,KACE,EAAE,gBAAgB,IAAI,EAAE,gBAAgB,IAC1C,IAEF;AACT;AAEO,MAAM,mBAAmB,CAAC;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAkC;AAC1B,QAAA,aAAa,OAAO,OACpB,WAAW,YAAY,OACvB,aAAa,aAAa,UAC1B,gBAAgB,SAAS,OAAO,CAAC,SAAS,YAAY,SAAS,KAAK,GAAG,CAAC,GACxE,UAAU;AAAA,IACd;AAAA,IACA,cAAc,WAAW,IAAI,eAAe,GAAG,cAAc,MAAM;AAAA,IACnE,aAAa,OAAO;AAAA,IACpB;AAAA,IACA,GAAG,aAAa,CAAC,OAAO,WAAW,CAAC;AAAA,EAAA,EACpC,KAAK,GAAG,GAEJ,EAAC,KAAK,SAAA,IAAY,SAAS;AAAA,IAI/B,CAAC,KAAK,KAAK,aAAa;AAElB,UAAA,YAAY,SAAS,IAAI,GAAG;AAC9B,eAAO,EAAC,KAAK,IAAI,KAAK,UAAU,IAAI,SAAQ;AAI9C,UAAI,aAAa,UAAU;AACnB,cAAA,YAAY,WAAW,GACvB,WAAW,SAAS,SAAS,IAAI,gBAAgB,IACnD,SAAS,MAAM,SAAS,SAAS,IAAI,gBAAgB,CAAW,IAChE,SAAS,IAEP,GAAA,UAAU,SAAS,MAAM,SAAS,QAAQ,EAAE,gBAAgB,CAAW,GAEvE,YAAY,WAAW,GACvB,WAAW,SAAS,SAAS,IAAI,gBAAgB,IACnD,SAAS,MAAM,SAAS,SAAS,IAAI,gBAAgB,CAAW,IAChE,SAAS,IAAI;AAEb,YAAA,cAAc,aAAa,SAAS,QAAQ,OAAO,IAAI,QAAQ,QAAQ,QAAQ;AAGnF,iBAAS,gBAAgB,GAAG,gBAAgB,cAAc,QAAQ,iBAAiB;AACjF,wBAAc,aAAa,EAAE,gBAAgB,IAAI,YAAY,SAAS,GACtE,cAAc,aAAa,YAAY,QAAQ,OAAO,IAAI,YAAY,QAAQ,QAAQ;AAGjF,eAAA;AAAA;AAAA;AAAA,UAGL,KAAK,aACD,CAAC,GAAG,IAAI,KAAK,GAAG,eAAe,GAAG,IAClC,CAAC,GAAG,IAAI,KAAK,KAAK,GAAG,aAAa;AAAA,UACtC,UAAU;AAAA,QACZ;AAAA,MAAA;AAGK,aAAA,EAAC,KAAK,CAAC,GAAG,IAAI,KAAK,GAAG,GAAG,UAAU,IAAI,SAAQ;AAAA,IACxD;AAAA,IACA,EAAC,KAAK,IAAI,UAAU,CAAE,EAAA;AAAA,EAGlB,GAAA,UAAU,SAAS,QAAQ,CAAC,QAAQ;AACxC,UAAM,aAA0C;AAAA,MAC9C;AAAA,QACE,IAAI;AAAA,QACJ;AAAA,UACE,KAAK;AAAA,YACH,CAAC,gBAAgB,GAAG,IAAI,gBAAgB;AAAA,UAAA;AAAA,QAC1C;AAAA,MACF;AAAA,IAEJ;AAGI,WAAA,IAAI,IAAI,WAAW,SAAS,KAAK,IAAI,gBACvC,WAAW,KAAK;AAAA,MACd,IAAI,IAAI,QAAQ,WAAW,EAAE;AAAA,MAC7B;AAAA,QACE,KAAK;AAAA,UACH,CAAC,gBAAgB,GAAG,IAAI,gBAAgB;AAAA,QAAA;AAAA,MAC1C;AAAA,IAEH,CAAA,GAGI;AAAA,EAAA,CACR;AAKD,SAAO,EAAC,UAFU,IAAI,KAAK,mBAAmB,GAEjB,SAAS,QAAO;AAC/C;ACpIO,SAAS,kBAAgC;AAC9C,SAAO,UAAU,EAAC,YAAY,aAAY;AAC5C;ACoBA,MAAM,eAAe,CACnB,gBACA,oBACmB;AAAA,EACnB,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,SAAS,iBAAiB,MAAM;AAAA,EAChC,eAAe,iBAAiB,SAAS;AAAA,EACzC,GAAG;AACL,IAEM,WAAW,CAAC,aAA0B;AAC1C,QAAM,EAAC,aAAa,YAAY,YAAY,WAAc,IAAA;AAE1D,MAAI,WAAmB,QAAA;AACnB,MAAA,cAAc,WAAmB,QAAA;AACrC,MAAI,YAAoB,QAAA;AAG1B;AAEO,SAAS,cAAc,EAAC,MAAM,gBAAgB,qBAAwC;AACrF,QAAA,QAAQ,YACR,SAAS,cAAA,GACT,EAAC,YAAY,iBAAgB,IAAI,QAEjC,aAAa,iBAAiB,aAAa,CAAC,IAAI,CAAC,GAAG,MAAM,IAG1D,CAAC,aAAa,cAAc,IAAI,SAAoC,IAAI;AAG9E,YAAU,MAAM;AACT,sBAAgB,eAAe,IAAI;AAAA,EAAA,GAEvC,CAAC,IAAI,CAAC;AAET,QAAM,CAAC,YAAY,aAAa,IAAI,SAAS,EAAE,GACzC,CAAC,aAAa,cAAc,IAAI,SAAmB,aAAa,CAAC,UAAU,IAAI,EAAE,GAEjF,gBAAgB,YAAY,MAAM,eAAe,CAAE,CAAA,GAAG,CAAC,cAAc,CAAC,GAEtE,eAAe;AAAA,IACnB,CAAC,WAAmB,OAAe,gBAA4B;AAC7D,YAAM,aAAa,YAAY,SAAS,SAAS,GAC3C,iBAAiB,YAAY,UAE7B,mBADiB,UAAU,WAAW,QAAQ,KAAK,MAAM,KACrB,YAAY,UAAU,YAAY;AAE5E,UAAI,aAAa,CAAC;AAKd,UAAA,CAAC,kBAAkB,CAAC;AACf,eAAA,eAAe,CAAC,SAAS,CAAC;AAUnC,UANI,kBACF,YAAY,eAKV,GAAA,kBAAkB,CAAC,YAAY;AACjC,cAAM,iBAAiB,YAAY,YAAY,SAAS,CAAC,GACnD,oBAAoB,YAAY,UAAU,CAAC,SAAS,KAAK,QAAQ,cAAc,GAE/E,gBAAgB,QAAQ,oBAAoB,QAAQ,mBACpD,eAAe,QAAQ,oBAAoB,QAAQ,mBAEnD,aAAa,YAChB,OAAO,CAAC,MAAM,cAAc,YAAY,iBAAiB,YAAY,YAAY,EACjF,IAAI,CAAC,SAAS,KAAK,GAAG;AAEzB,qBAAa,CAAC,GAAG,aAAa,GAAG,YAAY,SAAS;AAAA,MACjD,MAAI,cAET,aAAa,YAAY,OAAO,CAAC,OAAO,OAAO,SAAS,IAGxD,aAAa,CAAC,GAAG,aAAa,SAAS;AAGzC,aAAO,eAAe,UAAU;AAAA,IAClC;AAAA,IACA,CAAC,gBAAgB,aAAa,WAAW;AAAA,EAGrC,GAAA,SAAS,mBAET,kBAAkB;AAAA,IACtB,OAAO,SAAsC,YAAoB;AACzD,YAAA,cAAc,OAAO,YAAY;AAE/B,cAAA,QAAQ,CAAC,CAAC,OAAO,GAAG,MAAM,YAAY,MAAM,OAAO,GAAG,CAAC;AAE3D,UAAA;AACI,cAAA,UAAU,MAAM,YAAY,OAAO;AAAA,UACvC,YAAY;AAAA,UACZ,KAAK;AAAA,QAAA,CACN;AACa,sBAAA,GACd,cAAc,EAAE,GAChB,kBAAkB,EAAK,GACvB,MAAM,KAAK;AAAA,UACT,OAAO,GACL,QAAQ,QAAQ,WAAW,IAAI,eAAe,GAAG,QAAQ,QAAQ,MAAM,YACzE;AAAA,UACA,QAAQ;AAAA,UACR,aAAa;AAAA,QAAA,CACd;AAAA,MAAA,QACW;AACZ,sBAAc,EAAE,GAChB,kBAAkB,EAAK,GACvB,MAAM,KAAK;AAAA,UACT,OAAO;AAAA,UACP,QAAQ;AAAA,QAAA,CACT;AAAA,MAAA;AAAA,IAEL;AAAA,IACA,CAAC,QAAQ,eAAe,eAAe,mBAAmB,KAAK;AAAA,KAG3D,gBAAgB;AAAA,IACpB,CAAC,QAAgC,aAAwC;AACvE,oBAAc,EAAE;AAEhB,YAAM,EAAC,QAAQ,aAAa,YAAW,IAAI,UAAU,CAAC;AAGlD,UAAA,QAAQ,UAAU,aAAa,SAG/B,CAAC,UAAU,UAAU,CAAC,YAAa;AAGvC,YAAM,cAAc,aAAa,SAAS,cAAc,CAAC,WAAW;AAGhE,UAAA,CAAC,aAAa,OAAQ;AAGR,wBAAA,EAAI,GACtB,eAAe,WAAW;AAE1B,YAAM,EAAC,UAAU,SAAS,QAAA,IAAW,iBAAiB;AAAA,QACpD;AAAA,QACA,aAAa;AAAA,QACb;AAAA,QACA;AAAA,MAAA,CACD;AAGG,gBAAU,UACZ,eAAe,QAAQ,GAIrB,SAAS,UACX,gBAAgB,SAAS,OAAO;AAAA,IAEpC;AAAA,IACA,CAAC,aAAa,eAAe,gBAAgB,iBAAiB,iBAAiB;AAAA,KAG3E,kBAAkB;AAAA,IACtB,CAAC,UAAiC;AAChC,YAAM,KAAK,MAAM;AACA,kBAAY,SAAS,EAAE,KAGzB,cAAc,GAE7B,cAAc,EAAE;AAAA,IAClB;AAAA,IACA,CAAC,aAAa,eAAe,aAAa;AAAA,KAItC,iBAAiB;AAAA,IACrB,CAAC,WAAmB,SAAiB,IAAY,aAOxC,cANQ;AAAA,MACb,aAAa;AAAA,MACb,QAAQ,EAAC,OAAO,UAAS;AAAA,MACzB,aAAa,EAAC,OAAO,QAAO;AAAA,OAGa,QAAQ;AAAA,IAErD,CAAC,aAAa;AAAA,KAGV,kBAAkB;AAAA,IACtB,CAAC,UAAyB;AACpB,YAAM,QAAQ,YAChB,cAAc;AAAA,IAElB;AAAA,IACA,CAAC,aAAa;AAAA,EAChB;AAEA,YAAU,OACR,OAAO,iBAAiB,WAAW,eAAe,GAE3C,MAAM;AACJ,WAAA,oBAAoB,WAAW,eAAe;AAAA,EAAA,IAEtD,CAAC,eAAe,CAAC;AAGd,QAAA,kBAAkB,QAAQ,MAAM;AACpC,QAAI,CAAC,YAAY,OAAQ,QAAO,CAAC;AAEjC,UAAM,aAAa,YAAY,IAAI,CAAC,SAAS,KAAK,gBAAgB,CAAC;AAE5D,WAAA,WAAW,OAAO,CAAC,MAAM,UAAU,WAAW,QAAQ,IAAI,MAAM,KAAK;AAAA,EAC3E,GAAA,CAAC,WAAW,CAAC,GAEV,YAAY;AAAA,IAChB,CAAC,WAAuB,cAAc,QAAQ,WAAW;AAAA,IACzD,CAAC,aAAa,aAAa;AAAA,EAC7B;AAEA,6BACG,iBAAgB,EAAA,aAAa,iBAAiB,WAC7C,UAAA,oBAAC,aAAU,aAAY,oBACpB,UAAC,CAAA,kCACC,OAAK,EAAA,GAAG,SAAS,gBAAgB,KAAK,SAAS,UAC7C,UAAA;AAAA,IAAY,YAAA,IAAI,CAAC,MAAM,UACtB;AAAA,MAAC;AAAA,MAAA;AAAA,QAEC,aAAa,KAAK;AAAA,QAClB;AAAA,QAGC,UAAA,CAAC,eAAe,kBAAkB;AAC3B,gBAAA,aAAa,YAAY,SAAS,KAAK,GAAG,GAC1C,aAAa,cAAc,YAC3B,aAAa,GAAQ,CAAC,cAAc,cAAc,aAClD,aAAa,kBAAkB,YAC/B,aAAqB,CAAC,KAAK,gBAAgB,GAC3C,cAAc,gBAAgB,SAAS,KAAK,gBAAgB,CAAC,GAC7D,OAAO,SAAS,EAAC,aAAa,YAAY,YAAY,YAAW,GACjE,gBAAgB,YAAY,QAE5B,YAAY,cAAc,gBAAgB,IAAI,gBAAgB;AAGlE,iBAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,KAAK,cAAc;AAAA,cAClB,GAAG,cAAc;AAAA,cACjB,GAAG,cAAc;AAAA,cAClB,OACE,aACI,EAAC,SAAS,KAAK,eAAe,OAAM,IACpC,aAAa,cAAc,eAAe,OAAO,UAAU;AAAA,cAGjE,UAAA,oBAAC,KAAI,EAAA,eAAe,GAClB,UAAA;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC;AAAA,kBACA,QAAQ,aAAa,IAAI;AAAA,kBACzB,QAAQ;AAAA,kBAER,SAAS,CAAC,MAAM,aAAa,KAAK,KAAK,OAAO,EAAE,WAAW;AAAA,kBAE3D,UAAA;AAAA,oBAAC;AAAA,oBAAA;AAAA,sBACC,KAAK;AAAA,sBACL,UAAU;AAAA,sBACV,WAAW;AAAA,sBACX;AAAA,sBACA,SAAS,UAAU;AAAA,sBACnB,QAAQ,UAAU,YAAY,SAAS;AAAA,sBACvC;AAAA,oBAAA;AAAA,kBAAA;AAAA,gBACF;AAAA,cAAA,EAEJ,CAAA;AAAA,YAAA;AAAA,UACF;AAAA,QAAA;AAAA,MAEJ;AAAA,MAjDK,GAAG,KAAK,GAAG,IAAI,KAAK,gBAAgB,CAAC;AAAA,IAAA,CAmD7C;AAAA,IACA,SAAS;AAAA,EAAA,EACZ,CAAA,EAEJ,CAAA,GACF;AAEJ;AC7SA,MAAM,iBAAiB,CAAC;AAEjB,SAAS,kBAAkB,EAAC,MAAM,QAAQ,SAAS,kBAAyC;AAC3F,QAAA,CAAC,gBAAgB,iBAAiB,IAAI,SAAS,EAAK,GACpD,CAAC,MAAM,OAAO,IAAI,SAA2C,CAAA,CAAE,GAE/D,QAAQ,oBAAoB,SAAS,MAAM,MAAM,KAAK,EAAE;AAAA,kBAC9C,gBAAgB;AAAA,MAE1B,cAAc;AAAA,IAClB,GAAG;AAAA,IACH;AAAA,IACA,OAAO;AAAA,EAAA,GAGH;AAAA,IACJ,MAAM;AAAA,IACN;AAAA,IACA;AAAA,EAAA,IACE,kBAA6C,OAAO;AAAA,IACtD,QAAQ;AAAA,IACR,cAAc,CAAA;AAAA,EAAC,CAChB,GAEK,YAAuC;AAE7C,YAAU,MAAM;AACd,QAAI,WAAW;AACP,YAAA,oBAAoB,UAAU,OAAkC,CAAC,KAAK,QACrE,IAAI,IAAI,WAAW,SAAS,KAOjC,IAAI,eAAe,UAAU,KAAK,CAAC,QAAQ,IAAI,QAAQ,IAAI,IAAI,QAAQ,WAAW,EAAE,CAAC,GAE9E,CAAC,GAAG,KAAK,GAAG,KAPI,UAAU,KAAK,CAAC,QAAQ,IAAI,QAAQ,UAAU,IAAI,GAAG,EAAE,IACtD,MAAM,CAAC,GAAG,KAAK,GAAG,GAOzC,EAAE;AAEL,cAAQ,iBAAiB;AAAA,IAC3B;AACE,cAAQ,CAAA,CAAE;AAAA,EAAA,GAEX,CAAC,SAAS,CAAC;AAEd,QAAM,qBAAqB;AAAA,IACzB,MAAO,MAAM,SAAS,KAAK,OAAO,CAAC,QAAQ,CAAC,IAAI,gBAAgB,CAAC,EAAE,SAAS;AAAA,IAC5E,CAAC,IAAI;AAAA,EACP;AAEA,SAAI,UAEC,oBAAA,MAAA,EAAK,OAAO,EAAC,OAAO,QAAQ,QAAQ,OAAM,GAAG,OAAM,UAAS,SAAQ,UACnE,UAAC,oBAAA,SAAA,EAAQ,GACX,IAIA,QAEC,oBAAA,KAAA,EAAI,SAAS,GACZ,UAAA,oBAAC,YAAS,MAAK,YAAW,OAAM,sBAAqB,aAAY,yBAAyB,CAAA,GAC5F,IAIA,CAAC,QAAQ,MAAM,UAAU,wBAExB,MAAK,EAAA,OAAM,UAAS,WAAU,UAAS,QAAO,QAAO,SAAQ,UAC5D,UAAA,oBAAC,aAAU,OAAO,GAChB,UAAC,oBAAA,KAAA,EAAI,UAAU,GAAG,UAAU,GAC1B,UAAC,oBAAA,MAAA,EAAK,OAAM,UAAS,OAAK,IAAC,UAAA,4BAAA,CAE3B,EACF,CAAA,GACF,EAAA,CACF,IAID,oBAAA,OAAA,EAAM,OAAO,GAAG,OAAO,EAAC,UAAU,QAAQ,QAAQ,UACjD,UAAC,qBAAA,KAAA,EAAI,SAAS,GACX,UAAA;AAAA,IAAA,qBAAqB,KACpB,oBAAC,KAAI,EAAA,cAAc,GACjB,UAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,aAEK,qBAAA,UAAA,EAAA,UAAA;AAAA,UAAA;AAAA,UAAmB;AAAA,UAAE,MAAM;AAAA,UAAO;AAAA,UAAiC;AAAA,UACpE,oBAAC,YAAO,UAAW,cAAA,CAAA;AAAA,UAAS;AAAA,QAAA,EAC9B,CAAA;AAAA,MAAA;AAAA,IAAA,GAGN;AAAA,IAEF;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,EAAA,CACF,EACF,CAAA;AAEJ;ACjGO,SAAS,oBAAoB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA6B;AAC3B,QAAM,QAAQ,YACR,SAAS,UAAU;AAEzB,YAAU,MAAM;AACV,2BAAuB,SAAS,uBAAuB,UACzD,MAAM,KAAK,qBAAqB;AAAA,EAAA,GAEjC,CAAC,uBAAuB,KAAK,CAAC;AAE3B,QAAA,kBAAkB,QAAQ,MAAM;AAEpC,QAAI,CAAC;AACH,aACI,qBAAA,UAAA,EAAA,UAAA;AAAA,QAAA;AAAA,QACG,oBAAC,UAAK,UAAI,OAAA,CAAA;AAAA,QAAO;AAAA,MAAA,GACtB;AAIE,UAAA,aAAa,OAAO,IAAI,IAAI;AAGlC,WAAK,aAUH,EAAE,YAAY,eACd,CAAC,WAAW,OAAO,KAAK,CAAC,UAAU,OAAO,SAAS,gBAAgB,IAG/D,qBAAA,UAAA,EAAA,UAAA;AAAA,MAAA;AAAA,MACO,oBAAC,UAAM,UAAK,KAAA,CAAA;AAAA,MAAO;AAAA,MAAc,oBAAC,UAAM,UAAiB,iBAAA,CAAA;AAAA,MAAO;AAAA,MAAe;AAAA,MACtF,oBAAC,UAAK,UAAM,SAAA,CAAA;AAAA,IAAA,EAAA,CACd,IAMF,YAAY,cACZ,WAAW,OAAO;AAAA,MAChB,CAAC,UAAU,OAAO,SAAS,oBAAoB,OAAO,MAAM,SAAS;AAAA,IAAA,IAKnE,qBAAA,UAAA,EAAA,UAAA;AAAA,MAAA,oBAAC,UAAM,UAAiB,iBAAA,CAAA;AAAA,MAAO;AAAA,MAAiB,oBAAC,UAAM,UAAK,KAAA,CAAA;AAAA,MAAO;AAAA,MAAS;AAAA,MAC5E,oBAAC,UAAK,UAAM,SAAA,CAAA;AAAA,MAAO;AAAA,IACrB,EAAA,CAAA,IAIG,KAlCD,qBAAA,UAAA,EAAA,UAAA;AAAA,MAAA;AAAA,MACO,oBAAC,UAAM,UAAK,KAAA,CAAA;AAAA,MAAO;AAAA,IAAA,GAC5B;AAAA,EAAA,GAiCH,CAAC,MAAM,MAAM,CAAC;AAEb,SAAA,kBAEC,oBAAA,KAAA,EAAI,SAAS,GACZ,UAAC,oBAAA,UAAA,EAAS,aAAa,iBAAiB,MAAK,UAAA,CAAU,EACzD,CAAA,wBAKD,iBAAiB,UAAjB,EAA0B,OAAO,EAAC,eAAA,GACjC,UAAA,oBAAC,mBAAkB,EAAA,MAAY,QAAgB,OAAA,CAAgB,EACjE,CAAA;AAEJ;ACjGsB,eAAA,WACpB,MACA,QACwC;AACxC,QAAM,QAAQ,8CACR,cAAc,EAAC,MAAM,OAAO,iBAAgB,GAC5C,cAAc,MAAM,OAAO,MAAqB,OAAO,aAAa;AAAA,IACxE,KAAK;AAAA,EAAA,CACN;AAED,MAAI,YAAY,WAAW;AAClB,WAAA;AAGL,MAAA,YAAY,SAAS,IAAI;AAW7B,SAToB,YAAY,OAAO,CAAC,KAAK,gBAE3C,YAAY,UAAU,QAAU,EAAA,QAAA,GAEzB,IAAI,MAAM,YAAY;AAAA,IAC3B,KAAK,EAAC,CAAC,gBAAgB,GAAG,UAAU,SAAU,EAAA;AAAA,EAC/C,CAAA,IACA,OAAO,YAAa,CAAA,EAEJ,OAAO;AAAA,IACxB,YAAY;AAAA,IACZ,KAAK;AAAA,EAAA,CACN;AACH;ACbO,MAAM,8BAA8B,UAA6C;AAAA,EACtF,YAAY,OAAmC;AACvC,UAAA,KAAK,GACX,KAAK,QAAQ;AAAA,MACX,gBAAgB;AAAA,MAChB,uBAAuB,CAAA;AAAA,IACzB;AAAA,EAAA;AAAA,EAGF,iBAAiB;AAAA,IACf,gBAAgB,MAAM;AACf,WAAA,SAAS,CAAC,WAAW;AAAA,QACxB,gBAAgB,CAAC,MAAM;AAAA,MAAA,EACvB;AAAA,IACJ;AAAA,IAEA,YAAY,YAAY;AACtB,WAAK,SAAS,OAAO;AAAA,QACnB,uBAAuB;AAAA,UACrB,QAAQ;AAAA,UACR,OAAO;AAAA,UACP,UAAU;AAAA,QAAA;AAAA,MACZ,EACA;AAEF,YAAM,SAAS,MAAM,WAAW,KAAK,MAAM,QAAQ,MAAM,KAAK,MAAM,QAAQ,MAAM,GAE5E,uBAAuB,QAAQ,SAAS;AAE9C,WAAK,SAAS,OAAO;AAAA,QACnB,uBAAuB;AAAA,UACrB,QAAQ,uBAAuB,YAAY;AAAA,UAC3C,OAAO,uBACH,aAAa,OAAO,QAAQ,WAAW,IAAI,aAAa,WAAW,KACnE;AAAA,UACJ,UAAU;AAAA,QAAA;AAAA,MACZ,EACA;AAAA,IAAA;AAAA,EAEN;AAAA,EAEA,SAAS;AACD,UAAA,OAAO,MAAM,OAAO,SAAS;AACnC,WAAK,OAIH;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,QAAQ,MAAM,OAAO,SAAS;AAAA,QAC9B,QAAQ,MAAM,OAAO,SAAS;AAAA,QAC9B;AAAA,QACA,gBAAgB,KAAK,MAAM;AAAA,QAC3B,uBAAuB,KAAK,MAAM;AAAA,MAAA;AAAA,IAAA,IAR7B;AAAA,EAAA;AAYb;ACzDO,SAAS,8BAA8B,QAAuC;AACnF,MAAI,CAAC,QAAQ,QAAQ,CAAC,OAAO,WAAW,CAAC,OAAO;AAC9C,UAAM,IAAI,MAAM;AAAA;AAAA;AAAA;AAAA,KAIf;AAGG,QAAA,EAAC,MAAM,QAAQ,YAAY,CAAA,GAAI,cAAc,QAAQ,OAAO,MAAM,IAAI,SAAS,MAAK,QACpF,EAAC,QAAQ,UAAS,IAAI,SACtB,SAAS,UAAU,EAAC,YAAY,YAAA,CAAY,GAE5C,YAAY,SAAS,aAAa,IAAI,IACtC,SAAS,MAAM,aAAa,IAAI,IAChC,WAAW,QAAQ,UACnB,YAAY,OAAO,IAAI,IAAI,GAAG,SAAS;AAEzC,SAAA,iBAAiB,MACnB,UAAU;AAAA,IACR,EAAE,SAAS,EACR,MAAM,cAAc,SAAS,EAAE,EAC/B,OAAO,EAAC,MAAM,UAAU,QAAQ,EAAC,OAAM,CAAA,EACvC,UAAU;AAAA,EAGV,GAAA,EAAE,SAAS,EACf,MAAM,SAAS,EACf,GAAG,MAAM,EACT,KAAK,QAAQ,EACb,WAAW,IAAI,EACf;AAAA,IACC,OAAO;AAAA,MACL,EAAE,iBAAiB,IAAI,EACpB,gBAAgB,MAAM,CAAC,CAAC,YAAY,EACpC,UAAU;AAAA,MACb;AAAA;AAAA,QAEE,oBAAoB;AAAA;AAAA,QAEpB,KAAK;AAAA,QAEL,MAAM;AAAA,QACN,WAAW;AAAA,QACX,SAAS,EAAC,MAAM,QAAQ,QAAQ,OAAM;AAAA,QACtC,WAAW;AAAA,UACT,GAAG;AAAA,UACH,EAAE,SAAA,EAAW,MAAM,aAAa,EAAE,KAAK,YAAY,EAAE,OAAO,YAAY,EAAE,UAAU;AAAA,UACpF,EAAE,SAAA,EACC,MAAM,mBAAmB,EACzB,KAAK,QAAQ,EACb,OAAO,gBAAgB,EACvB,UAAU;AAAA,QAAA;AAAA,MACf;AAAA,IACF;AAAA,IAGH,UAAU;AACf;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sanity/orderable-document-list",
3
- "version": "1.2.2",
3
+ "version": "1.3.0",
4
4
  "description": "Drag-and-drop Document Ordering without leaving the Editing surface",
5
5
  "keywords": [
6
6
  "sanity",
@@ -16,19 +16,19 @@
16
16
  },
17
17
  "license": "MIT",
18
18
  "author": "Sanity.io <hello@sanity.io>",
19
+ "sideEffects": false,
20
+ "type": "module",
19
21
  "exports": {
20
22
  ".": {
21
- "types": "./lib/index.d.ts",
22
23
  "source": "./src/index.ts",
23
- "require": "./lib/index.js",
24
- "import": "./lib/index.esm.js",
25
- "default": "./lib/index.esm.js"
24
+ "import": "./lib/index.js",
25
+ "require": "./lib/index.cjs",
26
+ "default": "./lib/index.js"
26
27
  },
27
28
  "./package.json": "./package.json"
28
29
  },
29
- "main": "./lib/index.js",
30
- "module": "./lib/index.esm.js",
31
- "source": "./src/index.ts",
30
+ "main": "./lib/index.cjs",
31
+ "module": "./lib/index.js",
32
32
  "types": "./lib/index.d.ts",
33
33
  "files": [
34
34
  "lib",
@@ -37,8 +37,8 @@
37
37
  "v2-incompatible.js"
38
38
  ],
39
39
  "scripts": {
40
- "prebuild": "npm run clean && plugin-kit verify-package --silent && pkg-utils",
41
- "build": "run-s clean && plugin-kit verify-package --silent && pkg-utils build --strict && pkg-utils --strict",
40
+ "build": "plugin-kit verify-package --silent && pkg-utils build --strict --check --clean",
41
+ "dev": "sanity dev",
42
42
  "clean": "rimraf lib",
43
43
  "compile": "tsc --noEmit",
44
44
  "format": "prettier --write --cache --ignore-unknown .",
@@ -46,7 +46,7 @@
46
46
  "lint": "eslint .",
47
47
  "lint:fix": "eslint . --fix",
48
48
  "prepare": "husky install",
49
- "prepublishOnly": "run-s build",
49
+ "prepublishOnly": "npm run build",
50
50
  "watch": "pkg-utils watch --strict"
51
51
  },
52
52
  "husky": {
@@ -54,54 +54,55 @@
54
54
  "pre-commit": "npm run lint:fix"
55
55
  }
56
56
  },
57
+ "browserslist": "extends @sanity/browserslist-config",
57
58
  "dependencies": {
58
- "@hello-pangea/dnd": "^16.2.0",
59
- "@sanity/icons": "^2.4.1",
60
- "@sanity/incompatible-plugin": "^1.0.4",
61
- "@sanity/ui": "^1.7.1",
59
+ "@hello-pangea/dnd": "^18.0.1",
60
+ "@sanity/icons": "^3.5.3",
61
+ "@sanity/incompatible-plugin": "^1.0.5",
62
+ "@sanity/ui": "^2.10.11",
62
63
  "lexorank": "^1.0.4",
63
- "prop-types": "^15.8.1",
64
- "sanity-plugin-utils": "^1.6.2"
64
+ "sanity-plugin-utils": "^1.6.7"
65
65
  },
66
66
  "devDependencies": {
67
- "@commitlint/cli": "^17.6.6",
68
- "@commitlint/config-conventional": "^17.6.6",
69
- "@sanity/pkg-utils": "^2.3.3",
70
- "@sanity/plugin-kit": "^3.1.7",
71
- "@sanity/semantic-release-preset": "^4.1.6",
72
- "@types/react": "^18.2.14",
67
+ "@commitlint/cli": "^19.6.1",
68
+ "@commitlint/config-conventional": "^19.6.0",
69
+ "@sanity/pkg-utils": "^6.12.0",
70
+ "@sanity/plugin-kit": "^4.0.18",
71
+ "@sanity/semantic-release-preset": "^5.0.0",
72
+ "@types/react": "^19",
73
73
  "@typescript-eslint/eslint-plugin": "^5.61.0",
74
74
  "@typescript-eslint/parser": "^5.61.0",
75
- "autoprefixer": "^10.3.6",
76
75
  "babel-eslint": "^10.1.0",
77
76
  "eslint": "^8.44.0",
78
77
  "eslint-config-prettier": "^8.8.0",
79
78
  "eslint-config-sanity": "^6.0.0",
80
- "eslint-plugin-prettier": "^4.2.1",
79
+ "eslint-plugin-prettier": "^5.2.1",
81
80
  "eslint-plugin-react": "^7.32.2",
82
81
  "eslint-plugin-react-hooks": "^4.6.0",
83
82
  "husky": "^8.0.3",
84
- "lint-staged": "^13.2.3",
85
- "npm-run-all": "^4.1.5",
86
- "prettier": "^2.8.8",
87
- "prettier-plugin-packagejson": "^2.4.4",
88
- "react": "^18.2.0",
89
- "react-dom": "^18.2.0",
90
- "react-is": "^18.2.0",
91
- "rimraf": "^5.0.1",
92
- "sanity": "^3.23.0",
93
- "semantic-release": "^22.0.6",
83
+ "lint-staged": "^15.4.3",
84
+ "prettier": "^3.4.2",
85
+ "prettier-plugin-packagejson": "^2.5.6",
86
+ "react": "^19",
87
+ "react-dom": "19",
88
+ "react-is": "^19",
89
+ "rimraf": "^6.0.1",
90
+ "sanity": "^3.74.1",
91
+ "semantic-release": "^24.2.0",
92
+ "styled-components": "^6.1.15",
94
93
  "typescript": "^5.1.6"
95
94
  },
96
95
  "peerDependencies": {
97
- "@sanity/ui": "^1.0 || ^2.0",
98
- "react": "^18",
99
- "react-dom": "^18",
96
+ "react": "^18 || ^19",
97
+ "react-dom": "^18 || ^19",
100
98
  "sanity": "^3.0.0",
101
- "styled-components": "^5.0 || ^6.0"
99
+ "styled-components": "^6.1"
100
+ },
101
+ "overrides": {
102
+ "conventional-changelog-conventionalcommits": ">= 8.0.0"
102
103
  },
103
104
  "engines": {
104
- "node": ">=14"
105
+ "node": ">=18"
105
106
  },
106
107
  "sanityExchangeUrl": "https://www.sanity.io/plugins/orderable-document-list"
107
108
  }
package/src/Document.tsx CHANGED
@@ -5,7 +5,7 @@ import {useSchema, SchemaType, PreviewCard, Preview} from 'sanity'
5
5
  import {usePaneRouter} from 'sanity/structure'
6
6
 
7
7
  import {OrderableContext} from './OrderableContext'
8
- import {SanityDocumentWithOrder} from './types'
8
+ import type {SanityDocumentWithOrder} from './types'
9
9
 
10
10
  export interface DocumentProps {
11
11
  doc: SanityDocumentWithOrder
@@ -14,7 +14,7 @@ export interface DocumentProps {
14
14
  index: number,
15
15
  nextIndex: number,
16
16
  docId: string,
17
- entities: SanityDocumentWithOrder[]
17
+ entities: SanityDocumentWithOrder[],
18
18
  ) => void
19
19
  index: number
20
20
  isFirst: boolean
@@ -22,7 +22,7 @@ export interface DocumentProps {
22
22
  dragBadge: number | false
23
23
  }
24
24
 
25
- export default function Document({
25
+ export function Document({
26
26
  doc,
27
27
  increment,
28
28
  entities,
@@ -45,7 +45,7 @@ export default function Document({
45
45
  function LinkComponent(linkProps: {children: ReactNode}) {
46
46
  return <ChildLink {...linkProps} childId={doc._id} />
47
47
  },
48
- [ChildLink, doc._id]
48
+ [ChildLink, doc._id],
49
49
  )
50
50
 
51
51
  return (
@@ -2,9 +2,9 @@ import {useEffect, useMemo, useState} from 'react'
2
2
  import {Box, Flex, Container, Spinner, Stack, Text} from '@sanity/ui'
3
3
 
4
4
  import {useListeningQuery, Feedback} from 'sanity-plugin-utils'
5
- import DraggableList from './DraggableList'
5
+ import {DraggableList} from './DraggableList'
6
6
  import {ORDER_FIELD_NAME} from './helpers/constants'
7
- import {SanityDocumentWithOrder} from './types'
7
+ import type {SanityDocumentWithOrder} from './types'
8
8
 
9
9
  export interface DocumentListQueryProps {
10
10
  type: string
@@ -14,11 +14,7 @@ export interface DocumentListQueryProps {
14
14
 
15
15
  const DEFAULT_PARAMS = {}
16
16
 
17
- export default function DocumentListQuery({
18
- type,
19
- filter,
20
- params = DEFAULT_PARAMS,
21
- }: DocumentListQueryProps) {
17
+ export function DocumentListQuery({type, filter, params = DEFAULT_PARAMS}: DocumentListQueryProps) {
22
18
  const [listIsUpdating, setListIsUpdating] = useState(false)
23
19
  const [data, setData] = useState<SanityDocumentWithOrder[] | null>([])
24
20
 
@@ -32,13 +28,15 @@ export default function DocumentListQuery({
32
28
  }
33
29
 
34
30
  const {
35
- data: queryData,
31
+ data: _queryData,
36
32
  loading,
37
33
  error,
38
34
  } = useListeningQuery<SanityDocumentWithOrder[]>(query, {
39
35
  params: queryParams,
40
36
  initialValue: [],
41
37
  })
38
+ // @ts-expect-error Should not be needed to "cast", but sanity-plugin-utils is not typed correctly
39
+ const queryData: SanityDocumentWithOrder[] = _queryData
42
40
 
43
41
  useEffect(() => {
44
42
  if (queryData) {
@@ -63,7 +61,7 @@ export default function DocumentListQuery({
63
61
 
64
62
  const unorderedDataCount = useMemo(
65
63
  () => (data?.length ? data.filter((doc) => !doc[ORDER_FIELD_NAME]).length : 0),
66
- [data]
64
+ [data],
67
65
  )
68
66
 
69
67
  if (loading) {
@@ -1,10 +1,9 @@
1
1
  import {useEffect, useMemo} from 'react'
2
- import {useToast} from '@sanity/ui'
2
+ import {useToast, Box, type ToastParams} from '@sanity/ui'
3
3
 
4
4
  import {useSchema} from 'sanity'
5
- import {Box, type ToastParams} from '@sanity/ui'
6
5
  import {Feedback} from 'sanity-plugin-utils'
7
- import DocumentListQuery from './DocumentListQuery'
6
+ import {DocumentListQuery} from './DocumentListQuery'
8
7
  import {OrderableContext} from './OrderableContext'
9
8
 
10
9
  import {ORDER_FIELD_NAME} from './helpers/constants'
@@ -21,7 +20,7 @@ export interface DocumentListWrapperProps {
21
20
 
22
21
  // 1. Validate first that the schema has been configured for ordering
23
22
  // 2. Setup context for showIncrements
24
- export default function DocumentListWrapper({
23
+ export function DocumentListWrapper({
25
24
  type,
26
25
  showIncrements,
27
26
  resetOrderTransaction,
@@ -75,7 +74,7 @@ export default function DocumentListWrapper({
75
74
  if (
76
75
  'fields' in typeSchema &&
77
76
  typeSchema.fields.some(
78
- (field) => field?.name === ORDER_FIELD_NAME && field?.type?.name !== 'string'
77
+ (field) => field?.name === ORDER_FIELD_NAME && field?.type?.name !== 'string',
79
78
  )
80
79
  ) {
81
80
  return (