@citolab/qti-components 7.27.2 → 7.27.3
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/cdn/index.global.js +1 -1
- package/cdn/index.js +216 -202
- package/dist/base.js +1 -1
- package/dist/{chunk-QUWFDFGZ.js → chunk-3XXXAWMZ.js} +18 -18
- package/dist/{chunk-TORB5UN2.js → chunk-A7HX4462.js} +291 -242
- package/dist/chunk-A7HX4462.js.map +1 -0
- package/dist/{chunk-KY3II5OX.js → chunk-CSYOTHK2.js} +220 -189
- package/dist/chunk-CSYOTHK2.js.map +1 -0
- package/dist/{chunk-G5ZUC3OT.js → chunk-CVB5ISWF.js} +23 -23
- package/dist/chunk-CVB5ISWF.js.map +1 -0
- package/dist/{chunk-TZMDZQFG.js → chunk-D6EHVZG2.js} +467 -217
- package/dist/chunk-D6EHVZG2.js.map +1 -0
- package/dist/{chunk-DG5TP35K.js → chunk-DGIXWHK3.js} +5 -5
- package/dist/{chunk-DG5TP35K.js.map → chunk-DGIXWHK3.js.map} +1 -1
- package/dist/{chunk-GG36UR7F.js → chunk-PHCCFYNE.js} +12 -12
- package/dist/{chunk-GG36UR7F.js.map → chunk-PHCCFYNE.js.map} +1 -1
- package/dist/{chunk-75ME6QG5.js → chunk-WMPG7ULB.js} +17 -17
- package/dist/elements.js +3 -3
- package/dist/index.js +8 -8
- package/dist/interactions.d.ts +8 -7
- package/dist/interactions.js +3 -3
- package/dist/item.js +3 -3
- package/dist/processing.js +2 -2
- package/dist/qti-components-jsx.d.ts +202 -202
- package/dist/test.js +5 -5
- package/package.json +11 -11
- package/dist/chunk-G5ZUC3OT.js.map +0 -1
- package/dist/chunk-KY3II5OX.js.map +0 -1
- package/dist/chunk-TORB5UN2.js.map +0 -1
- package/dist/chunk-TZMDZQFG.js.map +0 -1
- /package/dist/{chunk-QUWFDFGZ.js.map → chunk-3XXXAWMZ.js.map} +0 -0
- /package/dist/{chunk-75ME6QG5.js.map → chunk-WMPG7ULB.js.map} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../qti-test/src/mixins/test-navigation.mixin.ts","../../qti-test/src/mixins/test-view.mixin.ts","../../qti-test/src/mixins/test-base.ts","../../qti-test/src/mixins/test-processing.mixin.ts","../../qti-test/src/components/qti-test/qti-test.ts","../../qti-test/src/components/qti-assessment-item-ref/qti-assessment-item-ref.ts","../../qti-test/src/components/qti-assessment-section/qti-assessment-section.ts","../../qti-test/src/components/qti-assessment-test/qti-assessment-test.ts","../../qti-test/src/components/qti-test-part/qti-test-part.ts","../../qti-test/src/components/qti-test-feedback/qti-test-feedback.ts","../../qti-test/src/components/test-navigation/test-navigation.ts","../../qti-test/src/components/styles.ts","../../qti-test/src/components/test-next/test-next.ts","../../qti-test/src/components/test-prev/test-prev.ts","../../qti-test/src/components/test-view-toggle/test-view.ts","../../qti-test/src/components/test-item-link/test-item-link.ts","../../qti-test/src/components/test-end-attempt/test-end-attempt.ts","../../qti-test/src/components/test-show-correct-response/test-show-correct-response.ts","../../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/src/lit-html.ts","../../../node_modules/.pnpm/@heximal+expressions@0.1.5/node_modules/@heximal/expressions/src/lib/constants.ts","../../../node_modules/.pnpm/@heximal+expressions@0.1.5/node_modules/@heximal/expressions/src/lib/tokenizer.ts","../../../node_modules/.pnpm/@heximal+expressions@0.1.5/node_modules/@heximal/expressions/src/lib/parser.ts","../../../node_modules/.pnpm/@heximal+expressions@0.1.5/node_modules/@heximal/expressions/src/lib/eval.ts","../../../node_modules/.pnpm/lit-html@3.3.1/node_modules/lit-html/src/private-ssr-support.ts","../../../node_modules/.pnpm/@heximal+templates@0.1.5/node_modules/@heximal/templates/src/index.ts","../../qti-test/src/components/test-paging-buttons-stamp/test-paging-buttons-stamp.ts","../../qti-test/src/components/test-container/test-container.ts","../../qti-test/src/components/test-print-item-variables/test-print-item-variables.ts","../../qti-test/src/components/test-section-buttons-stamp/test-section-buttons-stamp.ts","../../qti-test/src/components/test-section-link/test-section-link.ts","../../qti-test/src/components/test-print-context/test-print-context.ts","../../qti-test/src/components/test-stamp/test-stamp.ts","../../qti-test/src/components/test-scoring-buttons/test-scoring-buttons.ts","../../qti-test/src/components/test-view-toggle/test-view-toggle.ts","../../qti-test/src/components/test-scoring-feedback/test-scoring-feedback.ts","../../qti-test/src/components/test-check-item/test-check-item.ts"],"sourcesContent":["import { property } from 'lit/decorators.js';\n\nimport { qtiTransformItem } from '@qti-components/transformers';\n\nimport type { QtiAssessmentStimulusRefConnectedEvent } from '@qti-components/elements';\nimport type { QtiAssessmentItem } from '@qti-components/elements';\nimport type { transformItemApi, transformTestApi } from '@qti-components/transformers';\nimport type { QtiAssessmentItemRef } from '../components/qti-assessment-item-ref/qti-assessment-item-ref';\nimport type { QtiAssessmentSection } from '../components/qti-assessment-section/qti-assessment-section';\nimport type { QtiAssessmentTest } from '../components/qti-assessment-test/qti-assessment-test';\nimport type { TestBaseInterface } from './test-base';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport type PostLoadTransformCallback = (\n transformer: transformItemApi,\n itemRef: QtiAssessmentItemRef\n) => transformItemApi | Promise<transformItemApi>;\n\nexport type PostLoadTestTransformCallback = (\n transformer: transformTestApi,\n testElement: QtiAssessmentTest\n) => transformTestApi | Promise<transformTestApi>;\n\nexport interface NavigationError {\n message: string;\n details?: any;\n itemId?: string;\n sectionId?: string;\n}\n\ndeclare class TestNavigationInterface {}\n\n/**\n * Navigation mixin for QTI test components\n *\n * Provides comprehensive navigation functionality with:\n * - Efficient item/section loading with AbortController support\n * - Stimulus reference coordination and duplicate prevention\n * - Proper event timing and state management\n * - Error handling and edge case coverage\n */\nexport const TestNavigationMixin = <T extends Constructor<TestBaseInterface>>(superClass: T) => {\n abstract class TestNavigationClass extends superClass implements TestNavigationInterface {\n @property({ type: String }) navigate: 'item' | 'section' | null = null;\n @property({ type: Boolean, attribute: 'cache-transform' }) cacheTransform: boolean = false;\n @property({ type: Number }) requestTimeout: number = 30000;\n @property({ attribute: false }) postLoadTransformCallback: PostLoadTransformCallback | null = null;\n @property({ attribute: false }) postLoadTestTransformCallback: PostLoadTestTransformCallback | null = null;\n\n public _testElement: QtiAssessmentTest;\n\n // Navigation state tracking\n private _activeController: AbortController | null = null;\n private _loadResults: any[] = [];\n private _navigationId = 0;\n\n // Simple loading progress tracking\n private _loadingState = {\n expectedItems: 0,\n connectedItems: 0,\n expectedStimulus: 0,\n loadedStimulus: 0,\n isComplete: false\n };\n\n // Track loaded/loading stimulus hrefs to prevent duplicates\n private _loadedStimulusHrefs = new Set<string>();\n private _loadingStimulusHrefs = new Set<string>();\n\n constructor(...args: any[]) {\n super(...args);\n this._bindEventHandlers();\n }\n\n // ===========================================\n // PUBLIC API\n // ===========================================\n\n /**\n * Navigate to a specific item or section\n * @param type - Navigation type ('item' or 'section')\n * @param id - Target identifier (optional, falls back to first available)\n */\n public navigateTo(type: 'item' | 'section', id?: string): void {\n const targetId = id || this._getDefaultNavigationId(type);\n\n if (targetId) {\n this.dispatchEvent(\n new CustomEvent('qti-request-navigation', {\n detail: { type, id: targetId },\n bubbles: true,\n composed: true\n })\n );\n }\n }\n\n // ===========================================\n // EVENT HANDLER SETUP\n // ===========================================\n\n private _bindEventHandlers(): void {\n this.addEventListener('qti-request-navigation', this._handleNavigationRequest.bind(this));\n this.addEventListener('qti-assessment-test-connected', this._handleTestConnected.bind(this));\n this.addEventListener('qti-assessment-item-connected', this._handleItemConnected.bind(this));\n this.addEventListener('qti-assessment-stimulus-ref-connected', this._handleStimulusRefConnected.bind(this));\n }\n\n private _handleTestConnected(e: CustomEvent<QtiAssessmentTest>): void {\n this._testElement = e.detail;\n this._initializeNavigation();\n }\n\n /**\n * Handle item connection events - track connected items and discover stimulus references\n */\n private _handleItemConnected(e: CustomEvent<QtiAssessmentItemRef>): void {\n const itemRef = e.detail;\n\n // Increment connected items count\n this._loadingState.connectedItems++;\n\n // Count stimulus references in this item and add to expected\n const stimulusRefs = itemRef.querySelectorAll('qti-assessment-stimulus-ref');\n this._loadingState.expectedStimulus += stimulusRefs.length;\n\n this._checkLoadingComplete();\n }\n\n /**\n * Handle stimulus reference connection events with duplicate prevention\n */\n private async _handleStimulusRefConnected(e: QtiAssessmentStimulusRefConnectedEvent): Promise<void> {\n e.preventDefault();\n\n const { element, item } = e;\n console.info('Stimulus ref connected:', {\n identifier: element.identifier,\n href: element.href,\n item: item.identifier\n });\n\n // Check if this stimulus href is already loaded or currently loading\n if (this._loadedStimulusHrefs.has(element.href)) {\n console.info('Stimulus already loaded, skipping:', element.href);\n this._loadingState.loadedStimulus++;\n this._checkLoadingComplete();\n return;\n }\n\n if (this._loadingStimulusHrefs.has(element.href)) {\n console.info('Stimulus already loading, skipping duplicate:', element.href);\n this._loadingState.loadedStimulus++;\n this._checkLoadingComplete();\n return;\n }\n\n // Mark as currently loading\n this._loadingStimulusHrefs.add(element.href);\n console.info('Starting stimulus load:', element.href);\n\n try {\n await this._loadStimulusRef(element, item);\n this._loadedStimulusHrefs.add(element.href);\n this._loadingState.loadedStimulus++;\n console.info('Stimulus loaded successfully:', element.href);\n this._checkLoadingComplete();\n } catch (error) {\n if (error.name !== 'AbortError') {\n console.warn(`Failed to load stimulus ${element.identifier}:`, error);\n }\n // Still count as \"processed\" even if failed to avoid hanging\n this._loadingState.loadedStimulus++;\n this._checkLoadingComplete();\n } finally {\n // Remove from loading set regardless of outcome\n this._loadingStimulusHrefs.delete(element.href);\n }\n }\n\n // ===========================================\n // NAVIGATION FLOW\n // ===========================================\n\n private _getDefaultNavigationId(type: 'item' | 'section'): string | undefined {\n if (type === 'section') {\n return this._testElement?.querySelector<QtiAssessmentSection>('qti-assessment-section')?.identifier;\n }\n return (\n this.sessionContext?.navItemRefId ??\n this._testElement?.querySelector<QtiAssessmentItemRef>('qti-assessment-item-ref')?.identifier\n );\n }\n\n private _initializeNavigation(): void {\n if (!this.navigate) return;\n\n const id = this._getDefaultNavigationId(this.navigate);\n if (id) {\n this.navigateTo(this.navigate, id);\n }\n }\n\n /**\n * Main navigation request handler with proper lifecycle management\n */\n private async _handleNavigationRequest({ detail }: CustomEvent<{ type: 'item' | 'section'; id: string }>) {\n if (!detail?.id) return;\n\n this._cancelPreviousNavigation();\n const navigationId = ++this._navigationId;\n const controller = new AbortController();\n\n try {\n this._dispatchLoadingStarted(detail.type, detail.id);\n this._activeController = controller;\n\n await this._executeNavigation(detail.type, detail.id, navigationId, controller);\n } catch (error) {\n this._handleNavigationError(error, detail.type, detail.id);\n } finally {\n if (this._activeController === controller) {\n this._activeController = null;\n }\n this._dispatchLoadingEnded(detail.type, detail.id);\n }\n }\n\n private _handleNavigationError(error: any, type: string, id: string): void {\n if (error.name !== 'AbortError') {\n this._dispatchError(this._createNavigationError(error, type, id));\n }\n }\n\n private async _executeNavigation(\n type: 'item' | 'section',\n id: string,\n navigationId: number,\n controller: AbortController\n ): Promise<void> {\n if (type === 'item') {\n await this._navigateToItem(id, navigationId, controller);\n } else {\n await this._navigateToSection(id, navigationId, controller);\n }\n }\n\n /**\n * Navigate to specific item with simple state tracking\n */\n private async _navigateToItem(itemId: string, navigationId: number, controller: AbortController): Promise<void> {\n const itemRef = this._findItemRef(itemId);\n this._updateSessionContext(itemRef, itemId);\n\n this._resetLoadingState();\n this._loadingState.expectedItems = 1;\n\n await this._loadItems([itemId], navigationId, controller);\n await this._waitForLoadingComplete(navigationId, controller);\n if (this._isStaleNavigation(navigationId, controller)) return;\n\n this._dispatchTestLoaded(this._loadResults);\n }\n\n /**\n * Navigate to section with simple state tracking\n */\n private async _navigateToSection(\n sectionId: string,\n navigationId: number,\n controller: AbortController\n ): Promise<void> {\n const sectionEl = this._findSection(sectionId);\n const navPartId = sectionEl?.closest('qti-test-part')?.identifier;\n\n this.sessionContext = {\n ...this.sessionContext,\n navPartId,\n navSectionId: sectionId,\n navItemRefId: null\n };\n\n const itemIds = this._getSectionItemIds(sectionId);\n\n this._resetLoadingState();\n this._loadingState.expectedItems = itemIds.length;\n\n await this._loadItems(itemIds, navigationId, controller);\n await this._waitForLoadingComplete(navigationId, controller);\n if (this._isStaleNavigation(navigationId, controller)) return;\n\n this._dispatchTestLoaded(this._loadResults);\n }\n\n // ===========================================\n // LOADING STATE MANAGEMENT\n // ===========================================\n\n /**\n * Reset loading state for new navigation\n */\n private _resetLoadingState(): void {\n this._loadingState = {\n expectedItems: 0,\n connectedItems: 0,\n expectedStimulus: 0,\n loadedStimulus: 0,\n isComplete: false\n };\n\n // Clear stimulus tracking - start fresh for new navigation\n this._loadedStimulusHrefs.clear();\n this._loadingStimulusHrefs.clear();\n }\n\n /**\n * Check if loading is complete and dispatch events accordingly\n */\n private _checkLoadingComplete(): void {\n const allItemsConnected = this._loadingState.connectedItems >= this._loadingState.expectedItems;\n const allStimulusLoaded = this._loadingState.loadedStimulus >= this._loadingState.expectedStimulus;\n\n if (allItemsConnected && allStimulusLoaded && !this._loadingState.isComplete) {\n this._loadingState.isComplete = true;\n }\n }\n\n /**\n * Wait for loading to complete with simple polling\n */\n private async _waitForLoadingComplete(navigationId: number, controller: AbortController): Promise<void> {\n while (!this._loadingState.isComplete) {\n if (this._isStaleNavigation(navigationId, controller)) return;\n await new Promise(resolve => setTimeout(resolve, 10));\n }\n }\n\n /**\n * Get current loading progress for external consumption\n */\n public getLoadingProgress() {\n return { ...this._loadingState };\n }\n\n /**\n * Load stimulus reference with simple tracking\n */\n private async _loadStimulusRef(\n element: { identifier: string; href: string },\n item: { identifier: string }\n ): Promise<void> {\n console.info('Loading stimulus:', element.href);\n const stimulus = await this._loadStimulus(element.href);\n console.info('Stimulus loaded, applying content:', stimulus ? 'has content' : 'no content');\n this._applyStimulusContent(stimulus, element, item);\n }\n\n private _applyStimulusContent(\n stimulus: DocumentFragment | null,\n element: { identifier: string },\n item: { identifier: string }\n ): void {\n if (!stimulus) {\n console.warn('No stimulus content to apply');\n return;\n }\n\n const elements = stimulus.querySelectorAll('qti-stimulus-body, qti-stylesheet');\n console.info(`Found ${elements.length} stimulus elements to apply for ${element.identifier}`);\n\n if (elements.length === 0) {\n console.warn('No qti-stimulus-body or qti-stylesheet elements found in stimulus');\n return;\n }\n\n // Try multiple target selection strategies\n let targets: Element[] = [];\n\n // Strategy 1: Specific item and identifier\n const specificTarget = document.querySelector(\n `qti-assessment-item[identifier=\"${item.identifier}\"] [data-stimulus-idref=\"${element.identifier}\"]`\n );\n\n if (specificTarget) {\n targets.push(specificTarget);\n console.info('Found specific target:', specificTarget);\n } else {\n // Strategy 2: Any element with matching stimulus idref\n const allTargetsWithId = Array.from(this.querySelectorAll(`[data-stimulus-idref=\"${element.identifier}\"]`));\n\n if (allTargetsWithId.length > 0) {\n targets = allTargetsWithId;\n console.info('Found targets by identifier:', allTargetsWithId.length);\n } else {\n // Strategy 3: Any stimulus idref target (fallback)\n const allStimulusTargets = Array.from(this.querySelectorAll('[data-stimulus-idref]'));\n targets = allStimulusTargets;\n console.info('Using fallback targets:', allStimulusTargets.length);\n }\n }\n\n if (targets.length === 0) {\n console.warn('No targets found for stimulus content');\n return;\n }\n\n // Apply content to all targets\n targets.forEach((target, index) => {\n target.innerHTML = '';\n const clonedElements = Array.from(elements).map(el => el.cloneNode(true) as Element);\n target.append(...clonedElements);\n console.info(`Applied stimulus content to target ${index + 1}/${targets.length}`);\n });\n } // ===========================================\n // LOADING INFRASTRUCTURE\n // ===========================================\n\n /**\n * Cancel previous navigation and clean up all state\n */\n private _cancelPreviousNavigation(): void {\n if (this._activeController) {\n this._activeController.abort();\n console.info('Previous navigation request cancelled');\n }\n\n this._clearNavigationState();\n }\n\n private _clearNavigationState(): void {\n this._clearLoadedItems();\n this._resetLoadingState();\n this._loadResults = [];\n }\n\n /**\n * Load items with simple tracking\n */\n private async _loadItems(itemIds: string[], navigationId: number, controller: AbortController): Promise<void> {\n if (!this._testElement || itemIds.length === 0) return;\n\n const itemRefs = itemIds.map(id => this._findItemRef(id));\n this._clearLoadedItems();\n this._clearStimulusRef();\n\n const results = await Promise.all(itemRefs.map(ref => this._loadSingleItem(ref, navigationId, controller)));\n const validResults = results.filter(Boolean);\n\n if (this._isStaleNavigation(navigationId, controller)) return;\n\n validResults.forEach(({ itemRef, doc }) => {\n if (itemRef && doc) itemRef.xmlDoc = doc;\n });\n\n // Restore per-item state as early as possible (before iframe-based interactions initialize).\n // Some PCIs (including IMS conformance examples) only support restoration via getInstance(state),\n // so the state needs to be present on the provided itemContext at initial render time.\n validResults.forEach(({ itemRef }) => {\n const itemId = itemRef?.identifier;\n if (!itemRef || !itemId) return;\n\n const savedState = this.testContext.items.find(i => i.identifier === itemId)?.state;\n if (savedState === undefined) return;\n\n itemRef.updateComplete.then(() => {\n const assessmentItem = itemRef.assessmentItem as QtiAssessmentItem | null;\n if (!assessmentItem) return;\n assessmentItem.state = savedState;\n });\n });\n\n this._loadResults = validResults;\n }\n\n private async _loadSingleItem(itemRef: QtiAssessmentItemRef, navigationId: number, controller: AbortController) {\n try {\n let transformer = await qtiTransformItem(this.cacheTransform).load(itemRef.href, controller.signal);\n\n if (this.postLoadTransformCallback) {\n transformer = await this.postLoadTransformCallback(transformer, itemRef);\n }\n\n if (this._isStaleNavigation(navigationId, controller)) {\n return null;\n }\n\n return { itemRef, doc: transformer.htmlDoc() };\n } catch (error) {\n if (error.name === 'AbortError') {\n console.info(`Item load for ${itemRef.identifier} was aborted`);\n throw error;\n }\n console.warn(`Failed to load item ${itemRef.identifier}:`, error);\n return null;\n }\n }\n\n private async _loadStimulus(href: string): Promise<DocumentFragment | null> {\n const transformer = await qtiTransformItem().load(href, this._activeController?.signal);\n return transformer.htmlDoc();\n }\n\n // ===========================================\n // UTILITIES\n // ===========================================\n\n private _findItemRef(itemId: string): QtiAssessmentItemRef {\n const itemRef = this._testElement?.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${itemId}\"]`\n );\n\n if (!itemRef) {\n throw new Error(`Item with identifier \"${itemId}\" not found`);\n }\n\n return itemRef;\n }\n\n private _findSection(sectionId: string): QtiAssessmentSection | null {\n return (\n this._testElement?.querySelector<QtiAssessmentSection>(`qti-assessment-section[identifier=\"${sectionId}\"]`) ||\n null\n );\n }\n\n private _updateSessionContext(itemRef: QtiAssessmentItemRef, itemId: string): void {\n const navPartId = itemRef.closest('qti-test-part')?.identifier;\n const navSectionId = itemRef.closest('qti-assessment-section')?.identifier;\n\n this.sessionContext = {\n ...this.sessionContext,\n navPartId,\n navSectionId,\n navItemRefId: itemId\n };\n }\n\n private _getSectionItemIds(sectionId: string): string[] {\n return Array.from(\n this._testElement.querySelectorAll<QtiAssessmentItemRef>(\n `qti-assessment-section[identifier=\"${sectionId}\"] > qti-assessment-item-ref`\n )\n )\n .map(ref => ref.identifier)\n .filter(Boolean);\n }\n\n private _clearLoadedItems(): void {\n const itemRefs = this._testElement?.querySelectorAll<QtiAssessmentItemRef>('qti-assessment-item-ref');\n Array.from(itemRefs || []).forEach(element => {\n element.xmlDoc = null;\n });\n }\n\n private _clearStimulusRef(): void {\n this.querySelectorAll('[data-stimulus-idref]').forEach(el => (el.innerHTML = ''));\n }\n\n private _isStaleNavigation(navigationId: number, controller: AbortController): boolean {\n return controller.signal.aborted || navigationId !== this._navigationId;\n }\n\n private _createNavigationError(error: any, type: string, id: string): NavigationError {\n return {\n message: error.message || `Failed to load ${type}: ${id}`,\n details: error,\n itemId: type === 'item' ? id : undefined,\n sectionId: type === 'section' ? id : undefined\n };\n }\n\n // ===========================================\n // EVENT DISPATCHING\n // ===========================================\n\n private _dispatchLoadingStarted(type: string, id: string): void {\n this.dispatchEvent(\n new CustomEvent('qti-navigation-loading-started', {\n detail: { type, id },\n bubbles: true,\n composed: true\n })\n );\n }\n\n private _dispatchLoadingEnded(type: string, id: string): void {\n this.dispatchEvent(\n new CustomEvent('qti-navigation-loading-ended', {\n detail: { type, id },\n bubbles: true,\n composed: true\n })\n );\n }\n\n private _dispatchError(error: NavigationError): void {\n this.dispatchEvent(\n new CustomEvent('qti-navigation-error', {\n detail: error,\n bubbles: true,\n composed: true\n })\n );\n }\n\n private _dispatchTestLoaded(results: any[]): void {\n requestAnimationFrame(() => {\n this.dispatchEvent(\n new CustomEvent('qti-test-loaded', {\n detail: results.map(({ itemRef }) => ({\n identifier: itemRef?.identifier,\n element: itemRef\n })),\n bubbles: true,\n composed: true\n })\n );\n });\n }\n }\n\n return TestNavigationClass as Constructor<TestNavigationInterface> & T;\n};\n","import type { View } from '@qti-components/base';\nimport type { QtiAssessmentItemRef } from '../components/qti-assessment-item-ref/qti-assessment-item-ref';\nimport type { QtiAssessmentItem } from '@qti-components/elements';\nimport type { TestBaseInterface } from './test-base';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ndeclare class TestViewInterface {}\n\nexport const TestViewMixin = <T extends Constructor<TestBaseInterface>>(superClass: T) => {\n abstract class TestViewClass extends superClass implements TestViewInterface {\n constructor(...args: any[]) {\n super(...args);\n this.sessionContext = { ...this.sessionContext, view: 'candidate' };\n\n this.addEventListener('on-test-switch-view', (e: CustomEvent<View>) => {\n this.sessionContext = { ...this.sessionContext, view: e.detail };\n this._updateElementView();\n });\n this.addEventListener('qti-assessment-test-connected', () => {\n this._updateElementView();\n });\n this.addEventListener('qti-assessment-item-connected', (e: CustomEvent) => {\n this._updateElementView();\n this._setCorrectResponseVisibility(e.detail);\n });\n }\n\n willUpdate(changedProperties: Map<string | number | symbol, unknown>) {\n super.willUpdate(changedProperties);\n if (changedProperties.has('sessionContext')) {\n this._updateElementView();\n }\n }\n\n // Method to handle view updates for elements based on the current context view\n private _updateElementView() {\n if (this._testElement) {\n const viewElements = Array.from(this._testElement.querySelectorAll('[view]'));\n\n viewElements.forEach((element: HTMLElement) => {\n element.classList.toggle('show', element.getAttribute('view') === this.sessionContext.view);\n });\n\n const assessmentItemRef = this._testElement.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${this.sessionContext.navItemRefId}\"]`\n );\n const assessmentItem = assessmentItemRef?.assessmentItem;\n\n if (assessmentItem) {\n assessmentItem.showCorrectResponse(this.sessionContext.view === 'scorer');\n }\n }\n }\n\n // Event handler for connected QTI assessment items\n private _setCorrectResponseVisibility(assessmentItem: QtiAssessmentItem): void {\n assessmentItem.showCorrectResponse(this.sessionContext.view === 'scorer');\n }\n }\n\n return TestViewClass as Constructor<TestViewInterface> & T;\n};\n","import { provide } from '@lit/context';\nimport { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { INITIAL_TEST_CONTEXT, testContext } from '@qti-components/base';\nimport { INITIAL_SESSION_CONTEXT, type SessionContext, sessionContext } from '@qti-components/base';\n\nimport type { QtiAssessmentItem } from '@qti-components/elements';\nimport type { QtiAssessmentItemRef } from '../components/qti-assessment-item-ref/qti-assessment-item-ref';\nimport type { QtiAssessmentTest } from '../components/qti-assessment-test/qti-assessment-test';\nimport type { ItemContext } from '@qti-components/base';\nimport type { TestContext } from '@qti-components/base';\nimport type { OutcomeVariable, VariableDeclaration, VariableValue } from '@qti-components/base';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport interface TestBaseInterface extends LitElement {\n testContext: Readonly<TestContext>;\n sessionContext: Readonly<SessionContext>;\n _testElement: QtiAssessmentTest;\n updateItemVariables(itemRefID: string, variables: VariableValue<string | string[] | null>[]): void;\n}\n\nexport const TestBaseMixin = <T extends Constructor<LitElement>>(superClass: T) => {\n abstract class TestBaseClass extends superClass implements TestBaseInterface {\n @property({ attribute: false, type: Object })\n @provide({ context: testContext })\n public testContext: Readonly<TestContext> = INITIAL_TEST_CONTEXT;\n\n @property({ attribute: false, type: Object })\n @provide({ context: sessionContext })\n public sessionContext: Readonly<SessionContext> = INITIAL_SESSION_CONTEXT;\n\n public _testElement: QtiAssessmentTest;\n\n constructor(...args: any[]) {\n super(...args);\n this._initializeEventListeners();\n }\n\n updateItemVariables(itemRefID: string, variables: VariableValue<string | string[] | null>[]): void {\n // Update variables in the testContext for the specified itemRefID\n const itemContext = this.testContext.items.find(item => item.identifier === itemRefID);\n if (itemContext) {\n itemContext.variables = itemContext.variables.map(variable => {\n const updatedVariable = variables.find(v => v.identifier === variable.identifier);\n return updatedVariable ? { ...variable, ...updatedVariable } : variable;\n });\n }\n // if the qti-assessment-item-ref has a qti-assessment-item, then update this item as well\n const itemRef = this._testElement.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${itemRefID}\"]`\n );\n if (itemRef && itemRef.assessmentItem) {\n itemRef.assessmentItem.variables = variables;\n }\n }\n\n private _initializeEventListeners(): void {\n /**\n * When the test is connected, the items are updated in the test context.\n * An existing context item is updated with the itemRef properties if nessesary.\n */\n this.addEventListener('qti-assessment-test-connected', (e: CustomEvent<QtiAssessmentTest>) => {\n this.testContext = INITIAL_TEST_CONTEXT; // new test, new test context!\n this.sessionContext = INITIAL_SESSION_CONTEXT; // new test, new session context!\n if (this.testContext && this.testContext.items.length > 0) return;\n\n this._testElement = e.detail;\n const items = Array.from(this._testElement.querySelectorAll('qti-assessment-item-ref')).map(itemRef => {\n return {\n href: itemRef.href,\n identifier: itemRef.identifier,\n category: itemRef.category,\n variables: [\n {\n identifier: 'completionStatus',\n value: 'not_attempted',\n type: 'outcome'\n } as OutcomeVariable\n ]\n };\n });\n this.testContext = { ...this.testContext, items };\n });\n\n this.addEventListener('qti-assessment-item-connected', (e: CustomEvent<QtiAssessmentItem>) => {\n const assessmentItem = e.detail as QtiAssessmentItem;\n const assessmentRefId = assessmentItem.closest('qti-assessment-item-ref')?.identifier;\n if (assessmentRefId) {\n assessmentItem.assessmentItemRefId = assessmentRefId;\n }\n this._updateItemInTestContext(e.detail);\n });\n\n this.addEventListener('qti-item-context-updated', (e: CustomEvent<{ itemContext: ItemContext }>) => {\n // const assessmentitem = e.composedPath()[0] as QtiAssessmentItem;\n this._updateItemVariablesInTestContext(\n e.detail.itemContext.identifier,\n e.detail.itemContext.variables,\n e.detail.itemContext.state\n );\n });\n }\n\n private _updateItemVariablesInTestContext(\n identifier: string,\n variables: readonly VariableDeclaration<string | string[] | null>[],\n state?: ItemContext['state']\n ): void {\n // Update the test context with modified variables for the specified item\n this.testContext = {\n ...this.testContext, // Spread existing test context properties\n items: this.testContext.items.map(itemContext => {\n // If the item identifier doesn't match, keep it unchanged\n if (itemContext.identifier !== identifier) {\n return itemContext;\n }\n\n // Update the matching item with new variables\n return {\n ...itemContext, // Keep other properties of the item context\n variables: variables.map(variable => {\n // Find a matching variable in the current item context\n const matchingVariable = itemContext.variables.find(v => v.identifier === variable.identifier);\n\n // Merge matching variable with the new one, or use the new variable if no match\n return matchingVariable ? { ...matchingVariable, ...variable } : variable;\n }),\n ...(state !== undefined ? { state: state ? { ...state } : undefined } : {})\n };\n })\n };\n this.dispatchEvent(\n new CustomEvent('qti-test-context-updated', { detail: this.testContext, bubbles: false, composed: false })\n );\n }\n\n /**\n * Updates the variables of an assessment item in the test context.\n * - Matches the assessment item with the corresponding test context item.\n * - If the item is not found, logs a warning.\n * - Updates variables in the test context if exactly one variable exists.\n * - Otherwise, syncs the assessment item's variables with the test context.\n *\n * @param assessmentItem - The assessment item to update.\n */\n private _updateItemInTestContext = (assessmentItem: QtiAssessmentItem): void => {\n const context = (assessmentItem as any)._context;\n const identifier = context.identifier;\n const fullVariables = context.variables;\n\n // console.log(this._testContext);\n // Find the corresponding item in the test context by identifier\n const itemContext = this.testContext.items.find(i => i?.identifier === identifier);\n\n if (!itemContext) {\n console.warn(`Item IDs between assessment.xml and item.xml should match: ${identifier} is not found!`);\n return;\n }\n\n // Update variables in the test context or sync them to the assessment item\n if (itemContext.variables?.length === 1) {\n // The loaded qti-assessment-item itself has variables which are not in test context yet.\n this._updateItemVariablesInTestContext(identifier, fullVariables);\n } else {\n const newVariables = [...assessmentItem.variables];\n // Sync the assessment item's variables with the test context\n for (const variable of itemContext.variables) {\n const currentVariable = newVariables.find(v => v.identifier === variable.identifier);\n if (currentVariable) {\n currentVariable.value = variable.value;\n } else {\n newVariables.push(variable);\n }\n }\n assessmentItem.variables = newVariables;\n }\n };\n }\n\n return TestBaseClass as Constructor<TestBaseInterface> & T;\n};\n\n// Keep the old abstract class for backwards compatibility during migration\nexport abstract class TestBase extends TestBaseMixin(LitElement) {}\n","import type { QtiOutcomeProcessing } from '../components/qti-outcome-processing/qti-outcome-processing';\nimport type { OutcomeVariable, VariableDeclaration } from '@qti-components/base';\nimport type { TestBaseInterface } from './test-base';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ndeclare class TestProcessingInterface {\n updateOutcomeVariable(identifier: string, value: string | string[] | undefined): void;\n getOutcome(identifier: string): Readonly<OutcomeVariable>;\n getVariable(identifier: string): Readonly<VariableDeclaration<string | string[] | null>>;\n outcomeProcessing(): boolean;\n}\nexport const TestProcessingMixin = <T extends Constructor<TestBaseInterface>>(superClass: T) => {\n abstract class TestProcessingElement extends superClass implements TestProcessingInterface {\n constructor(...args: any[]) {\n super(...args);\n this.addEventListener('qti-register-variable', (e: CustomEvent<{ variable: any }>) => {\n this.testContext = {\n ...this.testContext,\n testOutcomeVariables: [...(this.testContext.testOutcomeVariables || []), e.detail.variable]\n };\n e.stopPropagation();\n });\n // wordt aangeroepen vanuit de processingtemplate\n this.addEventListener(\n 'qti-set-outcome-value',\n (e: CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>) => {\n const { outcomeIdentifier, value } = e.detail;\n this.updateOutcomeVariable(outcomeIdentifier, value);\n e.stopPropagation();\n }\n );\n }\n\n outcomeProcessing(): boolean {\n const outcomeProcessor = this.querySelector('qti-outcome-processing') as unknown as QtiOutcomeProcessing;\n if (!outcomeProcessor) return false;\n outcomeProcessor?.process();\n return true;\n }\n\n /* --------------------------- ENABLED WHEN UNIT TESTING OUTCOME PROCESSING ------------------------------------ */\n\n public updateOutcomeVariable(identifier: string, value: string | string[] | undefined) {\n const outcomeVariable = this.getOutcome(identifier);\n if (!outcomeVariable) {\n console.warn(`Can not set qti-outcome-identifier: ${identifier}, it is not available`);\n return;\n }\n this.testContext = {\n ...this.testContext,\n testOutcomeVariables: this.testContext.testOutcomeVariables?.map(v => {\n if (v.identifier !== identifier) {\n return v;\n }\n return {\n ...v,\n value: outcomeVariable.cardinality === 'single' ? value : [...v.value, value as string]\n };\n })\n };\n }\n\n public getOutcome(identifier: string): Readonly<OutcomeVariable> {\n return this.getVariable(identifier) as OutcomeVariable;\n }\n public getVariable(identifier: string): Readonly<VariableDeclaration<string | string[] | null>> {\n return this.testContext.testOutcomeVariables?.find(v => v.identifier === identifier) || null;\n }\n /* --------------------------- ENABLED WHEN UNIT TESTING OUTCOME PROCESSING ------------------------------------ */\n }\n\n return TestProcessingElement as Constructor<TestProcessingInterface> & T;\n};\n","import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { TestNavigationMixin, TestViewMixin } from '../../mixins';\nimport { TestBaseMixin } from '../../mixins/test-base';\nimport { TestProcessingMixin } from '../../mixins/test-processing.mixin';\n\nimport type { IQtiTest } from '../../types/iqti-test';\n\n/**\n * `<qti-test>` is a custom element designed for rendering and interacting with QTI (Question and Test Interoperability) tests.\n *\n * This component leverages several mixins to provide functionality for loading, navigating, processing, and displaying QTI test assessments.\n *\n * ### Example Usage\n *\n * Minimal example including navigation:\n *\n * ```html\n * <qti-test>\n * <test-navigation>\n * <test-container test-url=\"./path/to/assessment.xml\"></test-container>\n * <nav class=\"flex\">\n * <test-prev></test-prev>\n * <test-next></test-next>\n * </nav>\n * </test-navigation>\n * </qti-test>\n * ```\n *\n * Use the following file structure\n * A qti-test loads a QTI3.0 assessmenttest.xml file from a package folder.\n *\n * ```plaintext\n * Root/\n * ├── index.html\n * └── /assets/api/examples/\n * ├── assessmenttest.xml\n * └── imsmanifest.xml\n *\n * ```\n *\n * ### Test components\n *\n * Use test components inside the qti-test component for added functionality.\n * ### Test next\n * `<test-next> | TestNext`\n *\n * ### Test prev\n *\n * `<test-prev> | TestPrev`\n * ### Test components\n *\n * You can use normal class names to style the elements.\n * And you can use the `test-prev` and `test-next` elements to navigate through the test.\n *\n */\n@customElement('qti-test')\nexport class QtiTest extends TestNavigationMixin(TestViewMixin(TestProcessingMixin(TestBaseMixin(LitElement)))) {\n // TODO: Properly implement IQtiTest interface\n // export class QtiTest extends TestLoaderMixin(TestNavigationMixin(TestViewMixin(TestBase))) {\n\n /**\n * Renders the component's template.\n * Provides a default `<slot>` for content projection.\n */\n override async connectedCallback(): Promise<void> {\n super.connectedCallback();\n await this.updateComplete;\n this.dispatchEvent(new CustomEvent('qti-test-connected', { detail: this }));\n }\n\n override render() {\n return html`<slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'qti-test': QtiTest;\n }\n}\n","import { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { QtiAssessmentItem } from '@qti-components/elements';\nimport type { TemplateFunction } from '@heximal/templates';\n\n// Converter function to interpret \"true\" and \"false\" as booleans\nconst stringToBooleanConverter = {\n fromAttribute(value: string): boolean {\n return value === 'true';\n },\n toAttribute(value: boolean): string {\n return value ? 'true' : 'false';\n }\n};\n\n// @customElement('qti-assessment-item-ref')\nexport class QtiAssessmentItemRef extends LitElement {\n @property({ type: String }) category?: string;\n @property({ type: String }) identifier?: string;\n @property({ type: Boolean, converter: stringToBooleanConverter }) required?: boolean;\n @property({ type: Boolean, converter: stringToBooleanConverter }) fixed?: boolean;\n @property({ type: String }) href?: string;\n\n // @consume({ context: computedContext, subscribe: true })\n // private computedContext: ComputedContext;\n\n weigths: Map<string, number> = new Map();\n\n @property({ type: Object, attribute: false })\n xmlDoc!: DocumentFragment; // the XMLDocument\n\n protected override createRenderRoot(): HTMLElement | DocumentFragment {\n return this;\n }\n\n get assessmentItem(): QtiAssessmentItem | null {\n return this.renderRoot?.querySelector('qti-assessment-item');\n }\n\n myTemplate: TemplateFunction;\n\n override async connectedCallback(): Promise<void> {\n super.connectedCallback();\n\n /*\n searches for the template element to use in the qti-test component\n can be used to render extra things for an item, like a bookmark, index nummer\n put this in your test-container component\n <template item-ref>\n <div>Extra content</div>\n </template>\n */\n // const templateElement = ((this.getRootNode() as any).host as HTMLElement)\n // .closest('qti-test')\n // .querySelector<HTMLTemplateElement>('template[item-ref]');\n\n // if (templateElement) this.myTemplate = prepareTemplate(templateElement);\n\n await this.updateComplete;\n\n this.dispatchEvent(\n new CustomEvent('qti-assessment-item-ref-connected', {\n bubbles: true,\n composed: true,\n detail: { identifier: this.identifier, href: this.href, category: this.category }\n })\n );\n }\n\n override render() {\n return this.myTemplate ? this.myTemplate({ xmlDoc: this.xmlDoc }) : this.xmlDoc;\n }\n}\n\nif (!customElements.get('qti-assessment-item-ref')) {\n customElements.define('qti-assessment-item-ref', QtiAssessmentItemRef);\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'qti-assessment-item-ref': QtiAssessmentItemRef;\n }\n}\n","import { consume } from '@lit/context';\nimport { html, LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { testContext } from '@qti-components/base';\n\nimport type { TestContext } from '@qti-components/base';\n\n// https://www.imsglobal.org/sites/default/files/spec/qti/v3/info/index.html#Root_AssessmentSection\n\nconst stringToBooleanConverter = {\n fromAttribute(value: string): boolean {\n return value === 'true';\n },\n toAttribute(value: boolean): string {\n return value ? 'true' : 'false';\n }\n};\n\nexport class QtiAssessmentSection extends LitElement {\n @property({ type: String }) identifier: string;\n @property({ type: String }) required: string;\n @property({ type: Boolean, converter: stringToBooleanConverter }) fixed: boolean;\n\n override get title(): string {\n return this.#title;\n }\n override set title(value: string) {\n this.#title = value;\n this.removeAttribute('title');\n this.setAttribute('data-title', value);\n }\n @property({ type: Boolean, converter: stringToBooleanConverter }) visible: boolean;\n @property({ type: Boolean, converter: stringToBooleanConverter, attribute: 'keep-together' }) keepTogether: boolean;\n\n @consume({ context: testContext, subscribe: true })\n public _testContext?: TestContext;\n\n #title = '';\n\n override async connectedCallback(): Promise<void> {\n this.#title = this.getAttribute('title') || '';\n super.connectedCallback();\n await this.updateComplete;\n this.dispatchEvent(\n new Event('qti-assessment-section-connected', {\n bubbles: true,\n composed: true\n })\n );\n }\n\n override render() {\n return html`<slot name=\"qti-rubric-block\"></slot><slot></slot>`;\n }\n}\n\nif (!customElements.get('qti-assessment-section')) {\n customElements.define('qti-assessment-section', QtiAssessmentSection);\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'qti-assessment-section': QtiAssessmentSection;\n }\n}\n","import { consume } from '@lit/context';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { testContext } from '@qti-components/base';\n\nimport type { TestContext } from '@qti-components/base';\n\n@customElement('qti-assessment-test')\nexport class QtiAssessmentTest extends LitElement {\n @property({ type: String }) identifier: string;\n @property({ type: String })\n override get title(): string {\n return this.#title;\n }\n override set title(value: string) {\n this.#title = value;\n this.removeAttribute('title');\n this.setAttribute('data-title', value);\n }\n\n @consume({ context: testContext, subscribe: true })\n public _testContext?: TestContext;\n #title = '';\n\n override async connectedCallback(): Promise<void> {\n super.connectedCallback();\n await this.updateComplete;\n this.dispatchEvent(\n new CustomEvent('qti-assessment-test-connected', {\n detail: this,\n bubbles: true,\n composed: true\n })\n );\n }\n\n override render() {\n return html` <slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'qti-assessment-test': QtiAssessmentTest;\n }\n}\n","import { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n@customElement('qti-test-part')\nexport class QtiTestPart extends LitElement {\n @property({ type: String }) identifier: string = '';\n override get title(): string {\n return this.#title;\n }\n override set title(value: string) {\n this.#title = value;\n this.removeAttribute('title');\n this.setAttribute('data-title', value);\n }\n @property({ type: String }) class: string = '';\n\n @property({ type: String, attribute: 'navigation-mode' })\n navigationMode: 'linear' | 'nonlinear' = 'nonlinear';\n\n @property({ type: String, attribute: 'submission-mode' })\n submissionMode: 'individual' | 'simultaneous' = 'individual';\n\n #title = '';\n\n override async connectedCallback(): Promise<void> {\n super.connectedCallback();\n await this.updateComplete;\n this.dispatchEvent(\n new Event('qti-test-part-connected', {\n bubbles: true,\n composed: true\n })\n );\n }\n\n override render() {\n return html` <slot></slot>`;\n }\n}\n\nif (!customElements.get('qti-test-part')) {\n customElements.define('qti-test-part', QtiTestPart);\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'qti-test-part': QtiTestPart;\n }\n}\n","import { customElement } from 'lit/decorators.js';\nimport { css, html } from 'lit';\n\nimport { QtiModalFeedback } from '@qti-components/elements';\n\n@customElement('qti-test-feedback')\nexport class QtiTestFeedback extends QtiModalFeedback {\n static override styles = css`\n :host {\n color: gray;\n }\n `;\n override render() {\n return html``;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'qti-test-feedback': QtiTestFeedback;\n }\n}\n","import { consume, provide } from '@lit/context';\nimport { html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { computedContext } from '@qti-components/base';\nimport { configContext } from '@qti-components/base';\nimport { testContext } from '@qti-components/base';\nimport { sessionContext } from '@qti-components/base';\nimport { qtiContext } from '@qti-components/base';\n\nimport type { QtiAssessmentItem } from '@qti-components/elements';\nimport type { QtiContext } from '@qti-components/base';\nimport type { OutcomeVariable } from '@qti-components/base';\nimport type { ComputedContext } from '@qti-components/base';\nimport type { PropertyValues } from 'lit';\nimport type { QtiAssessmentItemRef } from '../qti-assessment-item-ref/qti-assessment-item-ref';\nimport type { QtiAssessmentSection } from '../qti-assessment-section/qti-assessment-section';\nimport type { QtiAssessmentTest } from '../qti-assessment-test/qti-assessment-test';\nimport type { QtiTestPart } from '../qti-test-part/qti-test-part';\nimport type { ConfigContext } from '@qti-components/base';\nimport type { SessionContext } from '@qti-components/base';\nimport type { TestContext } from '@qti-components/base';\n\ntype CustomEventMap = {\n 'test-end-attempt': CustomEvent;\n 'test-show-correct-response': CustomEvent<{ value: boolean }>;\n};\n\ndeclare global {\n interface GlobalEventHandlersEventMap extends CustomEventMap {}\n}\n\n@customElement('test-navigation')\nexport class TestNavigation extends LitElement {\n @property({ type: String }) identifier: string | undefined = undefined;\n\n @state()\n public initContext: { identifier: string; [key: string]: any }[] = [];\n\n @state()\n @provide({ context: qtiContext })\n public qtiContext: QtiContext = {\n QTI_CONTEXT: {\n testIdentifier: '',\n candidateIdentifier: '',\n environmentIdentifier: 'default'\n }\n };\n\n @state()\n @provide({ context: configContext })\n public configContext: ConfigContext = {};\n\n @state()\n @consume({ context: testContext, subscribe: true })\n protected _testContext?: TestContext;\n\n @state()\n @consume({ context: sessionContext, subscribe: true })\n protected _sessionContext?: SessionContext;\n\n @state()\n @provide({ context: computedContext })\n protected computedContext: ComputedContext;\n\n @property({ type: Boolean, attribute: 'auto-score-items' }) autoScoreItems = false;\n\n // @state()\n // private stampContext: {\n // view?: View;\n // test?: unknown;\n // activeTestpart?: unknown;\n // activeSection?: unknown;\n // activeItem?: unknown;\n // } = {\n // view: 'candidate',\n // activeItem: {},\n // activeSection: {\n // items: []\n // },\n // activeTestpart: {\n // items: []\n // },\n // test: {}\n // };\n // @property({ type: Boolean, reflect: true }) public debug = false;\n\n #testElement: QtiAssessmentTest;\n\n constructor() {\n super();\n this.addEventListener('qti-assessment-test-connected', this.#handleTestConnected.bind(this));\n this.addEventListener('qti-assessment-item-connected', this.#handleItemConnected.bind(this));\n\n this.addEventListener('qti-interaction-changed', this.#handleInteractionChanged.bind(this));\n\n this.addEventListener('test-end-attempt', this.#handleTestEndAttempt.bind(this));\n this.addEventListener('test-show-correct-response', this.#handleTestShowCorrectResponse.bind(this));\n this.addEventListener('test-show-candidate-correction', this.#handleTestShowCandidateCorrection.bind(this));\n this.addEventListener('test-update-outcome-variable', this.#handleTestUpdateOutcomeVariable.bind(this));\n }\n\n /**\n * Handles the 'test-end-attempt' event.\n * @private\n * @listens TestNavigation#test-end-attempt\n * @param {CustomEvent} event - The custom event object.\n */\n #handleTestEndAttempt(_event: CustomEvent) {\n const qtiItemEl = this.#testElement.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${this._sessionContext.navItemRefId}\"]`\n );\n const qtiAssessmentItemEl = qtiItemEl.assessmentItem;\n const reportValidityAfterScoring = this.configContext?.reportValidityAfterScoring === true ? true : false;\n qtiAssessmentItemEl.processResponse(true, reportValidityAfterScoring);\n }\n\n // protected createRenderRoot(): HTMLElement | DocumentFragment {\n // return this;\n // }\n\n // myTemplate: TemplateFunction;\n\n // connectedCallback(): void {\n // super.connectedCallback();\n // const templateElement = this.querySelector<HTMLTemplateElement>('template');\n // if (!templateElement) {\n // this.myTemplate = null;\n // return;\n // }\n // this.myTemplate = prepareTemplate(templateElement);\n // }\n\n /**\n * Handles the 'test-show-correct-response' event.\n * @private\n * @listens TestNavigation#test-show-correct-response\n * @param {CustomEvent} event - The custom event object.\n */\n #handleTestShowCorrectResponse(event: CustomEvent) {\n const qtiItemEl = this.#testElement.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${this._sessionContext.navItemRefId}\"]`\n );\n const qtiAssessmentItemEl = qtiItemEl.assessmentItem;\n if (!qtiAssessmentItemEl) return;\n qtiAssessmentItemEl.showCorrectResponse(event.detail);\n }\n\n /**\n * Handles the 'test-show-candidate-correction' event.\n * @private\n * @listens TestNavigation#test-show-candidate-correction\n * @param {CustomEvent} event - The custom event object.\n */\n #handleTestShowCandidateCorrection(event: CustomEvent) {\n const qtiItemEl = this.#testElement.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${this._sessionContext.navItemRefId}\"]`\n );\n const qtiAssessmentItemEl = qtiItemEl.assessmentItem;\n qtiAssessmentItemEl.showCandidateCorrection(event.detail);\n }\n\n #handleTestUpdateOutcomeVariable(event: CustomEvent) {\n const qtiItemEl = this.#testElement.querySelector<QtiAssessmentItemRef>(\n `qti-assessment-item-ref[identifier=\"${event.detail.assessmentItemRefId}\"]`\n );\n const qtiAssessmentItemEl = qtiItemEl.assessmentItem;\n qtiAssessmentItemEl.setOutcomeVariable(event.detail.outcomeVariableId, event.detail.value);\n }\n\n #handleInteractionChanged(_event: CustomEvent) {\n if (this.autoScoreItems) {\n const assessmentItem = (_event.composedPath()[0] as HTMLElement).closest<QtiAssessmentItem>(\n 'qti-assessment-item'\n );\n const scoreOutcomeIdentifier = assessmentItem.variables.find(v => v.identifier === 'SCORE') as OutcomeVariable;\n if (\n scoreOutcomeIdentifier &&\n scoreOutcomeIdentifier.externalScored === null &&\n assessmentItem.adaptive === 'false'\n ) {\n const reportValidityAfterScoring = this.configContext?.reportValidityAfterScoring === true ? true : false;\n assessmentItem.processResponse(true, reportValidityAfterScoring);\n }\n }\n }\n\n override render() {\n // return this.myTemplate ? this.myTemplate(this.stampContext) : nothing;\n return html`<slot></slot>`;\n }\n\n /* PK: on test connected we can build the computed context */\n #handleTestConnected(event: CustomEvent) {\n this.#testElement = event.detail as QtiAssessmentTest;\n // Set the testIdentifier in qtiContext if not already set\n if (!this.qtiContext.QTI_CONTEXT?.testIdentifier) {\n const currentContext = this.qtiContext.QTI_CONTEXT || {\n testIdentifier: '',\n candidateIdentifier: 'not set',\n environmentIdentifier: 'default'\n };\n this.qtiContext = {\n QTI_CONTEXT: {\n ...currentContext,\n testIdentifier: this.#testElement.identifier,\n environmentIdentifier: currentContext.environmentIdentifier || 'default'\n }\n };\n }\n\n // Process qti-context-declaration elements to get default values\n const contextDeclarations = this.#testElement.querySelectorAll('qti-context-declaration[identifier=\"QTI_CONTEXT\"]');\n\n contextDeclarations.forEach(declaration => {\n const defaultValues = this.#extractDefaultValues(declaration);\n if (Object.keys(defaultValues).length > 0) {\n // Merge default values with current context, but don't override existing runtime values\n this.qtiContext = {\n QTI_CONTEXT: {\n ...defaultValues, // Default values first\n ...this.qtiContext.QTI_CONTEXT // Runtime values override defaults\n }\n };\n }\n });\n\n const testPartElements = Array.from(this.#testElement?.querySelectorAll<QtiTestPart>(`qti-test-part`) || []);\n this.computedContext = {\n identifier: this.#testElement.identifier,\n title: this.#testElement.title,\n view: this._sessionContext?.view,\n testParts: testPartElements.map(testPart => {\n const sectionElements = [...testPart.querySelectorAll<QtiAssessmentSection>(`qti-assessment-section`)];\n return {\n active: false,\n identifier: testPart.identifier,\n navigationMode: testPart.navigationMode,\n submissionMode: testPart.submissionMode,\n sections: sectionElements.map(section => {\n const itemElements = [...section.querySelectorAll<QtiAssessmentItemRef>(`qti-assessment-item-ref`)];\n return {\n active: false,\n identifier: section.identifier,\n title: section.title,\n items: itemElements.map(item => ({\n ...this.initContext?.find(i => i.identifier === item.identifier),\n active: false,\n identifier: item.identifier,\n categories: item.category ? item.category?.split(' ') : [],\n href: item.href,\n variables: [] as OutcomeVariable[]\n }))\n };\n })\n };\n })\n };\n }\n\n /**\n * Extract default values from a qti-context-declaration element\n */\n #extractDefaultValues(declaration: Element): Record<string, any> {\n const defaultValues: Record<string, any> = {};\n\n const defaultValueElement = declaration.querySelector('qti-default-value');\n if (!defaultValueElement) {\n return defaultValues;\n }\n\n const valueElements = defaultValueElement.querySelectorAll('qti-value[field-identifier]');\n valueElements.forEach(valueElement => {\n const fieldIdentifier = valueElement.getAttribute('field-identifier');\n const baseType = valueElement.getAttribute('base-type') || 'string';\n const textContent = valueElement.textContent?.trim() || '';\n\n if (fieldIdentifier) {\n // Convert value based on base-type\n let value: any = textContent;\n switch (baseType) {\n case 'integer':\n value = parseInt(textContent, 10);\n break;\n case 'float':\n case 'duration':\n value = parseFloat(textContent);\n break;\n case 'boolean':\n value = textContent.toLowerCase() === 'true';\n break;\n case 'string':\n default:\n value = textContent;\n break;\n }\n\n defaultValues[fieldIdentifier] = value;\n }\n });\n\n return defaultValues;\n }\n\n /* PK: on item connected we can add item only properties in the xml */\n #handleItemConnected(event: CustomEvent) {\n const itemElement = event.detail as QtiAssessmentItem;\n\n this.computedContext = {\n ...this.computedContext,\n testParts: this.computedContext.testParts.map(testPart => {\n return {\n ...testPart,\n sections: testPart.sections.map(section => {\n return {\n ...section,\n items: section.items.map(item => {\n if (item.identifier !== itemElement.parentElement.getAttribute('identifier')) {\n return item;\n }\n\n const scoreOutcome = itemElement.querySelector<HTMLElement>(\n \"qti-outcome-declaration[identifier='SCORE']\"\n );\n // const scoreOutcome = item.variables.find(vr => vr.identifier == 'SCORE') as OutcomeVariable;\n const externalScored = scoreOutcome?.getAttribute('externalScored');\n\n const responseDeclarations = itemElement.querySelectorAll<HTMLElement>('qti-response-declaration');\n const containsCorrectResponse = Array.from(responseDeclarations).some((r: HTMLElement) =>\n r.querySelector('qti-correct-response')\n );\n // check if every responseDeclaration has a correctResponse\n const containsMapping = Array.from(responseDeclarations).some((r: HTMLElement) => {\n const mapping = r.querySelector('qti-mapping');\n const areaMapping = r.querySelector('qti-area-mapping');\n return mapping?.querySelector('qti-map-entry') || areaMapping?.querySelector('qti-area-map-entry');\n });\n\n const hasCorrectResponse = containsCorrectResponse || containsMapping;\n\n const hasResponseProcessing = itemElement.querySelector('qti-response-processing') ? true : false;\n\n return {\n ...item,\n assessmentItemIdentifier: itemElement.getAttribute('identifier'),\n label: itemElement.getAttribute('label'),\n title: itemElement.title,\n externalScored,\n adaptive: itemElement.adaptive == 'true' || false,\n timeDependent: itemElement.timeDependent == 'true' || false,\n variables: itemElement.variables,\n hasCorrectResponse,\n hasResponseProcessing\n };\n })\n };\n })\n };\n })\n };\n }\n\n /* PK: on every change of the candidate we will recomputed the computedContext */\n protected override willUpdate(_changedProperties: PropertyValues): void {\n if (!this.computedContext) return;\n\n let itemIndex = 1;\n this.computedContext = {\n ...this.computedContext,\n view: this._sessionContext?.view,\n testParts: this.computedContext.testParts.map(testPart => {\n return {\n ...testPart,\n active: this._sessionContext?.navPartId === testPart.identifier || false,\n sections: testPart.sections.map(section => {\n return {\n ...section,\n active: this._sessionContext?.navSectionId === section.identifier || false,\n completed: section.items.every(\n item =>\n this._testContext.items\n .find(i => i.identifier === item.identifier)\n ?.variables.find(v => v.identifier === 'completionStatus').value === 'completed'\n ),\n\n items: section.items.map(item => {\n const itemContext = this._testContext?.items.find(i => i.identifier === item.identifier);\n const computedItem = {\n ...item,\n ...itemContext,\n ...this.initContext?.find(i => i.identifier === item.identifier)\n };\n\n const rawscore = computedItem.variables?.find(vr => vr.identifier == 'SCORE')?.value;\n\n const score = rawscore === undefined || rawscore === null ? null : parseFloat(rawscore?.toString());\n\n const completionStatus = computedItem.variables?.find(v => v.identifier === 'completionStatus')\n ?.value as string;\n\n const response = computedItem.variables?.find(v => v.identifier === 'RESPONSE')?.value || '';\n const numAttempts = computedItem.variables?.find(v => v.identifier === 'numAttempts')?.value || 0;\n\n const active = this._sessionContext?.navItemRefId === computedItem.identifier || false;\n\n // Computed and opiniated\n // const type = item.categories.includes(this.configContext?.infoItemCategory) ? 'info' : 'regular';\n // const correct = (type == 'regular' && score !== undefined && !isNaN(score) && score > 0) || false;\n // const incorrect = (type == 'regular' && score !== undefined && !isNaN(score) && score <= 0) || false;\n // const completed = completionStatus === 'completed';\n\n const index = item.categories.includes(this.configContext?.infoItemCategory) ? null : itemIndex++;\n const rawMaxScore = item.variables?.find(vr => vr.identifier == 'MAXSCORE')?.value;\n const maxScore =\n rawMaxScore === undefined || rawMaxScore === null ? null : parseFloat(rawMaxScore?.toString());\n\n return {\n ...computedItem,\n completionStatus,\n numAttempts,\n score,\n response,\n index,\n // type,\n active,\n // correct,\n maxScore\n // incorrect,\n // completed\n };\n })\n };\n })\n };\n })\n };\n\n // const activeTestPart = this.computedContext.testParts.find(testPart => testPart.active);\n // const activeSection = activeTestPart?.sections.find(section => section.active);\n // const activeItem = activeSection?.items.find(item => item.active);\n // const { variables, ...augmentedItem } = activeItem || {};\n\n // if (!activeTestPart || !activeSection || !activeItem) {\n // this.stampContext = null;\n // return;\n // }\n\n // const augmentedTestPart = {\n // ...activeTestPart,\n // items: activeTestPart.sections.flatMap(section => section.items.map(({ variables, ...rest }) => rest)),\n // sections: activeTestPart.sections.map(section => ({\n // ...section,\n // items: section.items.map(({ variables, ...rest }) => rest)\n // }))\n // };\n\n // const augmentedSection = { ...activeSection, items: activeSection.items.map(({ variables, ...rest }) => rest) };\n // const { testParts, ...activeTest } = this.computedContext;\n\n // this.stampContext = {\n // view: this.computedContext.view,\n // activeItem: augmentedItem,\n // activeSection: augmentedSection,\n // activeTestpart: augmentedTestPart,\n // test: activeTest\n // };\n\n this.dispatchEvent(\n new CustomEvent('qti-computed-context-updated', {\n detail: this.computedContext,\n bubbles: true\n })\n );\n }\n}\n","// /* eslint-disable lit-plugin(no-invalid-css) */\nimport { css } from 'lit';\n\nexport const form = css`\n display: inline-flex;\n align-items: center;\n cursor: pointer;\n padding: 0.5rem 1rem;\n border-radius: 0.25rem;\n user-select: none;\n`;\n\nexport const btn = css`\n background-color: lightgray;\n ${form};\n`;\n\nexport const dis = css`\n cursor: not-allowed;\n opacity: 0.8;\n`;\n\nexport const ind = css`\n ${form};\n border: 1px solid gray;\n`;\n","import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { consume } from '@lit/context';\n\nimport { watch } from '@qti-components/utilities';\nimport { computedContext } from '@qti-components/base';\n\nimport * as styles from '../styles';\n\nimport type { ComputedContext, ComputedItem } from '@qti-components/base';\n\n/**\n * Represents a custom element for navigating to the next test item.\n *\n * @remarks\n * This element provides functionality for navigating to the next test item.\n *\n * @example\n * ```html\n * <test-next></test-next>\n * ```\n */\n@customElement('test-next')\nexport class TestNext extends LitElement {\n @property({ type: Boolean, reflect: true, attribute: 'disabled' })\n public _internalDisabled = true;\n\n @consume({ context: computedContext, subscribe: true })\n protected computedContext: ComputedContext;\n\n sectionItems: ComputedItem[];\n itemIndex: number;\n\n @watch('computedContext')\n _handleTestElementChange(_oldValue: ComputedContext, newValue: ComputedContext) {\n if (newValue) {\n this._internalDisabled = false;\n }\n }\n\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n #internals: ElementInternals;\n\n constructor() {\n super();\n\n this.#internals = this.attachInternals();\n this.#internals.role = 'button';\n this.#internals.ariaLabel = 'Next item';\n\n this.addEventListener('click', e => {\n e.preventDefault();\n if (!this._internalDisabled) this._requestItem(this.sectionItems[this.itemIndex + 1].identifier);\n });\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.checkDisabled();\n }\n\n override willUpdate(_changedProperties: Map<string | number | symbol, unknown>) {\n if (!this.computedContext) return;\n const testPart = this.computedContext?.testParts.find(testPart => testPart.active);\n if (!testPart) return;\n this.sectionItems = testPart.sections.flatMap(section => section.items);\n this.itemIndex = this.sectionItems.findIndex(item => item.active);\n this.checkDisabled();\n }\n\n checkDisabled() {\n this._internalDisabled =\n !this.computedContext || this.itemIndex < 0 || this.itemIndex >= this.sectionItems?.length - 1;\n }\n\n protected _requestItem(identifier: string): void {\n this.dispatchEvent(\n new CustomEvent('qti-request-navigation', {\n composed: true,\n bubbles: true,\n detail: {\n type: 'item',\n id: identifier\n }\n })\n );\n }\n\n override render() {\n return html`<slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-next': TestNext;\n }\n}\n","import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { consume } from '@lit/context';\n\nimport { watch } from '@qti-components/utilities';\nimport { computedContext } from '@qti-components/base';\n\nimport * as styles from '../styles';\n\nimport type { ComputedContext, ComputedItem } from '@qti-components/base';\n\n/**\n * Represents a custom element for navigating to the previous test item.\n *\n * @remarks\n * This element provides functionality for navigating to the previous test item.\n *\n * @example\n * ```html\n * <test-prev></test-prev>\n * ```\n */\n@customElement('test-prev')\nexport class TestPrev extends LitElement {\n @property({ type: Boolean, reflect: true, attribute: 'disabled' })\n public _internalDisabled = true;\n\n @consume({ context: computedContext, subscribe: true })\n private computedContext: ComputedContext;\n\n sectionItems: ComputedItem[];\n itemIndex: number;\n\n @watch('computedContext')\n _handleTestElementChange(_oldValue: ComputedContext, newValue: ComputedContext) {\n if (newValue) {\n this._internalDisabled = false;\n }\n }\n\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n\n constructor() {\n super();\n\n this.addEventListener('click', e => {\n e.preventDefault();\n if (!this._internalDisabled) this._requestItem(this.sectionItems[this.itemIndex - 1].identifier);\n });\n }\n\n override willUpdate(_changedProperties: Map<string | number | symbol, unknown>) {\n if (!this.computedContext) return;\n const testPart = this.computedContext?.testParts.find(testPart => testPart.active);\n if (!testPart) return;\n this.sectionItems = testPart.sections.flatMap(section => section.items);\n this.itemIndex = this.sectionItems.findIndex(item => item.active);\n this.checkDisabled();\n }\n\n checkDisabled() {\n this._internalDisabled = !this.computedContext || this.itemIndex === 0 || this.itemIndex === -1;\n }\n\n protected _requestItem(identifier: string): void {\n this.dispatchEvent(\n new CustomEvent('qti-request-navigation', {\n composed: true,\n bubbles: true,\n detail: {\n type: 'item',\n id: identifier\n }\n })\n );\n }\n\n override render() {\n return html`<slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-previous': TestPrev;\n }\n}\n","import { html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { consume } from '@lit/context';\n\nimport { watch } from '@qti-components/utilities';\nimport { sessionContext } from '@qti-components/base';\n\nimport type { SessionContext } from '@qti-components/base';\n\n@customElement('test-view')\nexport class TestView extends LitElement {\n static DEFAULT_VIEW_OPTIONS = ['author', 'candidate', 'proctor', 'scorer', 'testConstructor', 'tutor'];\n\n @consume({ context: sessionContext, subscribe: true })\n private sessionContext: SessionContext;\n\n /** label accompanying the select view dropdown */\n @property({ type: String })\n label = 'view';\n\n /** The options to display in the dropdown, default: ['author', 'candidate', 'proctor', 'scorer', 'testConstructor', 'tutor'] */\n @property({ type: String, attribute: 'view-options' }) viewOptions: string;\n @watch('viewOptions', { waitUntilFirstUpdate: true })\n protected _handleViewOptionsChange = () => {\n this.#updateViewOptions();\n };\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.#updateViewOptions();\n }\n\n @state()\n private _viewOptions: string[] = TestView.DEFAULT_VIEW_OPTIONS;\n\n #updateViewOptions() {\n if (this.viewOptions) {\n const options = this.viewOptions.split(',').map(opt => opt.trim());\n this._viewOptions = options.filter(opt => TestView.DEFAULT_VIEW_OPTIONS.includes(opt));\n } else {\n this._viewOptions = TestView.DEFAULT_VIEW_OPTIONS;\n }\n }\n\n protected _switchView(view: string) {\n this.dispatchEvent(\n new CustomEvent('on-test-switch-view', {\n composed: true,\n bubbles: true,\n detail: view\n })\n );\n }\n\n override render() {\n return html`\n <label part=\"label\" for=\"viewSelect\">${this.label}</label>\n <select\n part=\"select\"\n id=\"viewSelect\"\n @change=${(e: Event) => {\n const el = e.target as HTMLSelectElement;\n this._switchView(el.value);\n }}\n >\n ${this._viewOptions.map(\n v => html`<option value=\"${v}\" ?selected=${v === this.sessionContext.view}>${v}</option>`\n )}\n </select>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-view': TestView;\n }\n}\n","import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport * as styles from '../styles';\n\n@customElement('test-item-link')\nexport class TestItemLink extends LitElement {\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n\n @property({ type: String, attribute: 'item-id' })\n private itemId: string = null;\n\n constructor() {\n super();\n this.addEventListener('click', () => this._requestItem(this.itemId));\n }\n\n protected _requestItem(identifier: string): void {\n this.dispatchEvent(\n new CustomEvent('qti-request-navigation', {\n composed: true,\n bubbles: true,\n detail: {\n type: 'item',\n id: identifier\n }\n })\n );\n }\n\n override render() {\n return html` <slot></slot> `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-item-link': TestItemLink;\n }\n}\n","import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport * as styles from '../styles';\n\n@customElement('test-end-attempt')\nexport class TestEndAttempt extends LitElement {\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n\n constructor() {\n super();\n this.addEventListener('click', () => this.dispatchEvent(new CustomEvent('test-end-attempt', { bubbles: true })));\n }\n\n override render() {\n return html` <slot></slot> `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-end-attempt': TestEndAttempt;\n }\n}\n","import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { consume } from '@lit/context';\n\nimport { computedContext } from '@qti-components/base';\n\nimport * as styles from '../styles';\n\nimport type { ComputedContext } from '@qti-components/base';\n\n/**\n * @deprecated test-show-correct-response is deprecated and will be removed in the future.\n */\n@customElement('test-show-correct-response')\nexport class TestShowCorrectResponse extends LitElement {\n @consume({ context: computedContext, subscribe: true })\n public computedContext?: ComputedContext;\n\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n\n @property({ type: Boolean, reflect: true }) shown = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: String }) showCorrectText = 'Show correct response';\n @property({ type: String }) hideCorrectText = 'Hide correct response';\n @property({ type: String }) noCorrectResponseText = 'No correct response specified';\n\n #previousActiveItem?: unknown; // Store previous active item reference\n\n override willUpdate(_changedProperties: Map<string | number | symbol, unknown>) {\n const activeItem = this.computedContext?.testParts\n .flatMap(testPart => testPart.sections.flatMap(section => section.items))\n .find(item => item.active);\n\n // If active item changed, reset shown before the update\n if (this.#previousActiveItem !== activeItem) {\n this.shown = false;\n this.#previousActiveItem = activeItem; // Update previous active item\n }\n\n if (activeItem) {\n const containsCorrectResponse = !!activeItem?.variables?.some(v => (v as any)['correctResponse']);\n const containsMapping = !!activeItem?.variables?.some(v => {\n return (v as any)['mapping']?.mapEntries?.length > 0 || (v as any)['areaMapping']?.areaMapEntries?.length > 0;\n });\n this.disabled = !containsCorrectResponse && !containsMapping;\n } else {\n this.disabled = true;\n }\n }\n #toggleState() {\n if (this.disabled) return;\n this.shown = !this.shown;\n\n this.dispatchEvent(\n new CustomEvent('test-show-correct-response', {\n detail: this.shown,\n bubbles: true\n })\n );\n }\n\n #getDisplayedText(): string {\n return this.disabled ? this.noCorrectResponseText : this.shown ? this.hideCorrectText : this.showCorrectText;\n }\n\n override render() {\n return html` <div @click=\"${this.#toggleState}\">${this.#getDisplayedText()}</div> `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-show-correct-response': TestShowCorrectResponse;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n// IMPORTANT: these imports must be type-only\nimport type {Directive, DirectiveResult, PartInfo} from './directive.js';\nimport type {TrustedHTML, TrustedTypesWindow} from 'trusted-types/lib/index.js';\n\nconst DEV_MODE = true;\nconst ENABLE_EXTRA_SECURITY_HOOKS = true;\nconst ENABLE_SHADYDOM_NOPATCH = true;\nconst NODE_MODE = false;\n\n// Allows minifiers to rename references to globalThis\nconst global = globalThis;\n\n/**\n * Contains types that are part of the unstable debug API.\n *\n * Everything in this API is not stable and may change or be removed in the future,\n * even on patch releases.\n */\n// eslint-disable-next-line @typescript-eslint/no-namespace\nexport namespace LitUnstable {\n /**\n * When Lit is running in dev mode and `window.emitLitDebugLogEvents` is true,\n * we will emit 'lit-debug' events to window, with live details about the update and render\n * lifecycle. These can be useful for writing debug tooling and visualizations.\n *\n * Please be aware that running with window.emitLitDebugLogEvents has performance overhead,\n * making certain operations that are normally very cheap (like a no-op render) much slower,\n * because we must copy data and dispatch events.\n */\n // eslint-disable-next-line @typescript-eslint/no-namespace\n export namespace DebugLog {\n export type Entry =\n | TemplatePrep\n | TemplateInstantiated\n | TemplateInstantiatedAndUpdated\n | TemplateUpdating\n | BeginRender\n | EndRender\n | CommitPartEntry\n | SetPartValue;\n export interface TemplatePrep {\n kind: 'template prep';\n template: Template;\n strings: TemplateStringsArray;\n clonableTemplate: HTMLTemplateElement;\n parts: TemplatePart[];\n }\n export interface BeginRender {\n kind: 'begin render';\n id: number;\n value: unknown;\n container: HTMLElement | DocumentFragment;\n options: RenderOptions | undefined;\n part: ChildPart | undefined;\n }\n export interface EndRender {\n kind: 'end render';\n id: number;\n value: unknown;\n container: HTMLElement | DocumentFragment;\n options: RenderOptions | undefined;\n part: ChildPart;\n }\n export interface TemplateInstantiated {\n kind: 'template instantiated';\n template: Template | CompiledTemplate;\n instance: TemplateInstance;\n options: RenderOptions | undefined;\n fragment: Node;\n parts: Array<Part | undefined>;\n values: unknown[];\n }\n export interface TemplateInstantiatedAndUpdated {\n kind: 'template instantiated and updated';\n template: Template | CompiledTemplate;\n instance: TemplateInstance;\n options: RenderOptions | undefined;\n fragment: Node;\n parts: Array<Part | undefined>;\n values: unknown[];\n }\n export interface TemplateUpdating {\n kind: 'template updating';\n template: Template | CompiledTemplate;\n instance: TemplateInstance;\n options: RenderOptions | undefined;\n parts: Array<Part | undefined>;\n values: unknown[];\n }\n export interface SetPartValue {\n kind: 'set part';\n part: Part;\n value: unknown;\n valueIndex: number;\n values: unknown[];\n templateInstance: TemplateInstance;\n }\n\n export type CommitPartEntry =\n | CommitNothingToChildEntry\n | CommitText\n | CommitNode\n | CommitAttribute\n | CommitProperty\n | CommitBooleanAttribute\n | CommitEventListener\n | CommitToElementBinding;\n\n export interface CommitNothingToChildEntry {\n kind: 'commit nothing to child';\n start: ChildNode;\n end: ChildNode | null;\n parent: Disconnectable | undefined;\n options: RenderOptions | undefined;\n }\n\n export interface CommitText {\n kind: 'commit text';\n node: Text;\n value: unknown;\n options: RenderOptions | undefined;\n }\n\n export interface CommitNode {\n kind: 'commit node';\n start: Node;\n parent: Disconnectable | undefined;\n value: Node;\n options: RenderOptions | undefined;\n }\n\n export interface CommitAttribute {\n kind: 'commit attribute';\n element: Element;\n name: string;\n value: unknown;\n options: RenderOptions | undefined;\n }\n\n export interface CommitProperty {\n kind: 'commit property';\n element: Element;\n name: string;\n value: unknown;\n options: RenderOptions | undefined;\n }\n\n export interface CommitBooleanAttribute {\n kind: 'commit boolean attribute';\n element: Element;\n name: string;\n value: boolean;\n options: RenderOptions | undefined;\n }\n\n export interface CommitEventListener {\n kind: 'commit event listener';\n element: Element;\n name: string;\n value: unknown;\n oldListener: unknown;\n options: RenderOptions | undefined;\n // True if we're removing the old event listener (e.g. because settings changed, or value is nothing)\n removeListener: boolean;\n // True if we're adding a new event listener (e.g. because first render, or settings changed)\n addListener: boolean;\n }\n\n export interface CommitToElementBinding {\n kind: 'commit to element binding';\n element: Element;\n value: unknown;\n options: RenderOptions | undefined;\n }\n }\n}\n\ninterface DebugLoggingWindow {\n // Even in dev mode, we generally don't want to emit these events, as that's\n // another level of cost, so only emit them when DEV_MODE is true _and_ when\n // window.emitLitDebugEvents is true.\n emitLitDebugLogEvents?: boolean;\n}\n\n/**\n * Useful for visualizing and logging insights into what the Lit template system is doing.\n *\n * Compiled out of prod mode builds.\n */\nconst debugLogEvent = DEV_MODE\n ? (event: LitUnstable.DebugLog.Entry) => {\n const shouldEmit = (global as unknown as DebugLoggingWindow)\n .emitLitDebugLogEvents;\n if (!shouldEmit) {\n return;\n }\n global.dispatchEvent(\n new CustomEvent<LitUnstable.DebugLog.Entry>('lit-debug', {\n detail: event,\n })\n );\n }\n : undefined;\n// Used for connecting beginRender and endRender events when there are nested\n// renders when errors are thrown preventing an endRender event from being\n// called.\nlet debugLogRenderId = 0;\n\nlet issueWarning: (code: string, warning: string) => void;\n\nif (DEV_MODE) {\n global.litIssuedWarnings ??= new Set();\n\n /**\n * Issue a warning if we haven't already, based either on `code` or `warning`.\n * Warnings are disabled automatically only by `warning`; disabling via `code`\n * can be done by users.\n */\n issueWarning = (code: string, warning: string) => {\n warning += code\n ? ` See https://lit.dev/msg/${code} for more information.`\n : '';\n if (\n !global.litIssuedWarnings!.has(warning) &&\n !global.litIssuedWarnings!.has(code)\n ) {\n console.warn(warning);\n global.litIssuedWarnings!.add(warning);\n }\n };\n\n queueMicrotask(() => {\n issueWarning(\n 'dev-mode',\n `Lit is in dev mode. Not recommended for production!`\n );\n });\n}\n\nconst wrap =\n ENABLE_SHADYDOM_NOPATCH &&\n global.ShadyDOM?.inUse &&\n global.ShadyDOM?.noPatch === true\n ? (global.ShadyDOM!.wrap as <T extends Node>(node: T) => T)\n : <T extends Node>(node: T) => node;\n\nconst trustedTypes = (global as unknown as TrustedTypesWindow).trustedTypes;\n\n/**\n * Our TrustedTypePolicy for HTML which is declared using the html template\n * tag function.\n *\n * That HTML is a developer-authored constant, and is parsed with innerHTML\n * before any untrusted expressions have been mixed in. Therefor it is\n * considered safe by construction.\n */\nconst policy = trustedTypes\n ? trustedTypes.createPolicy('lit-html', {\n createHTML: (s) => s,\n })\n : undefined;\n\n/**\n * Used to sanitize any value before it is written into the DOM. This can be\n * used to implement a security policy of allowed and disallowed values in\n * order to prevent XSS attacks.\n *\n * One way of using this callback would be to check attributes and properties\n * against a list of high risk fields, and require that values written to such\n * fields be instances of a class which is safe by construction. Closure's Safe\n * HTML Types is one implementation of this technique (\n * https://github.com/google/safe-html-types/blob/master/doc/safehtml-types.md).\n * The TrustedTypes polyfill in API-only mode could also be used as a basis\n * for this technique (https://github.com/WICG/trusted-types).\n *\n * @param node The HTML node (usually either a #text node or an Element) that\n * is being written to. Note that this is just an exemplar node, the write\n * may take place against another instance of the same class of node.\n * @param name The name of an attribute or property (for example, 'href').\n * @param type Indicates whether the write that's about to be performed will\n * be to a property or a node.\n * @return A function that will sanitize this class of writes.\n */\nexport type SanitizerFactory = (\n node: Node,\n name: string,\n type: 'property' | 'attribute'\n) => ValueSanitizer;\n\n/**\n * A function which can sanitize values that will be written to a specific kind\n * of DOM sink.\n *\n * See SanitizerFactory.\n *\n * @param value The value to sanitize. Will be the actual value passed into\n * the lit-html template literal, so this could be of any type.\n * @return The value to write to the DOM. Usually the same as the input value,\n * unless sanitization is needed.\n */\nexport type ValueSanitizer = (value: unknown) => unknown;\n\nconst identityFunction: ValueSanitizer = (value: unknown) => value;\nconst noopSanitizer: SanitizerFactory = (\n _node: Node,\n _name: string,\n _type: 'property' | 'attribute'\n) => identityFunction;\n\n/** Sets the global sanitizer factory. */\nconst setSanitizer = (newSanitizer: SanitizerFactory) => {\n if (!ENABLE_EXTRA_SECURITY_HOOKS) {\n return;\n }\n if (sanitizerFactoryInternal !== noopSanitizer) {\n throw new Error(\n `Attempted to overwrite existing lit-html security policy.` +\n ` setSanitizeDOMValueFactory should be called at most once.`\n );\n }\n sanitizerFactoryInternal = newSanitizer;\n};\n\n/**\n * Only used in internal tests, not a part of the public API.\n */\nconst _testOnlyClearSanitizerFactoryDoNotCallOrElse = () => {\n sanitizerFactoryInternal = noopSanitizer;\n};\n\nconst createSanitizer: SanitizerFactory = (node, name, type) => {\n return sanitizerFactoryInternal(node, name, type);\n};\n\n// Added to an attribute name to mark the attribute as bound so we can find\n// it easily.\nconst boundAttributeSuffix = '$lit$';\n\n// This marker is used in many syntactic positions in HTML, so it must be\n// a valid element name and attribute name. We don't support dynamic names (yet)\n// but this at least ensures that the parse tree is closer to the template\n// intention.\nconst marker = `lit$${Math.random().toFixed(9).slice(2)}$`;\n\n// String used to tell if a comment is a marker comment\nconst markerMatch = '?' + marker;\n\n// Text used to insert a comment marker node. We use processing instruction\n// syntax because it's slightly smaller, but parses as a comment node.\nconst nodeMarker = `<${markerMatch}>`;\n\nconst d =\n NODE_MODE && global.document === undefined\n ? ({\n createTreeWalker() {\n return {};\n },\n } as unknown as Document)\n : document;\n\n// Creates a dynamic marker. We never have to search for these in the DOM.\nconst createMarker = () => d.createComment('');\n\n// https://tc39.github.io/ecma262/#sec-typeof-operator\ntype Primitive = null | undefined | boolean | number | string | symbol | bigint;\nconst isPrimitive = (value: unknown): value is Primitive =>\n value === null || (typeof value != 'object' && typeof value != 'function');\nconst isArray = Array.isArray;\nconst isIterable = (value: unknown): value is Iterable<unknown> =>\n isArray(value) ||\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n typeof (value as any)?.[Symbol.iterator] === 'function';\n\nconst SPACE_CHAR = `[ \\t\\n\\f\\r]`;\nconst ATTR_VALUE_CHAR = `[^ \\t\\n\\f\\r\"'\\`<>=]`;\nconst NAME_CHAR = `[^\\\\s\"'>=/]`;\n\n// These regexes represent the five parsing states that we care about in the\n// Template's HTML scanner. They match the *end* of the state they're named\n// after.\n// Depending on the match, we transition to a new state. If there's no match,\n// we stay in the same state.\n// Note that the regexes are stateful. We utilize lastIndex and sync it\n// across the multiple regexes used. In addition to the five regexes below\n// we also dynamically create a regex to find the matching end tags for raw\n// text elements.\n\n/**\n * End of text is: `<` followed by:\n * (comment start) or (tag) or (dynamic tag binding)\n */\nconst textEndRegex = /<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g;\nconst COMMENT_START = 1;\nconst TAG_NAME = 2;\nconst DYNAMIC_TAG_NAME = 3;\n\nconst commentEndRegex = /-->/g;\n/**\n * Comments not started with <!--, like </{, can be ended by a single `>`\n */\nconst comment2EndRegex = />/g;\n\n/**\n * The tagEnd regex matches the end of the \"inside an opening\" tag syntax\n * position. It either matches a `>`, an attribute-like sequence, or the end\n * of the string after a space (attribute-name position ending).\n *\n * See attributes in the HTML spec:\n * https://www.w3.org/TR/html5/syntax.html#elements-attributes\n *\n * \" \\t\\n\\f\\r\" are HTML space characters:\n * https://infra.spec.whatwg.org/#ascii-whitespace\n *\n * So an attribute is:\n * * The name: any character except a whitespace character, (\"), ('), \">\",\n * \"=\", or \"/\". Note: this is different from the HTML spec which also excludes control characters.\n * * Followed by zero or more space characters\n * * Followed by \"=\"\n * * Followed by zero or more space characters\n * * Followed by:\n * * Any character except space, ('), (\"), \"<\", \">\", \"=\", (`), or\n * * (\") then any non-(\"), or\n * * (') then any non-(')\n */\nconst tagEndRegex = new RegExp(\n `>|${SPACE_CHAR}(?:(${NAME_CHAR}+)(${SPACE_CHAR}*=${SPACE_CHAR}*(?:${ATTR_VALUE_CHAR}|(\"|')|))|$)`,\n 'g'\n);\nconst ENTIRE_MATCH = 0;\nconst ATTRIBUTE_NAME = 1;\nconst SPACES_AND_EQUALS = 2;\nconst QUOTE_CHAR = 3;\n\nconst singleQuoteAttrEndRegex = /'/g;\nconst doubleQuoteAttrEndRegex = /\"/g;\n/**\n * Matches the raw text elements.\n *\n * Comments are not parsed within raw text elements, so we need to search their\n * text content for marker strings.\n */\nconst rawTextElement = /^(?:script|style|textarea|title)$/i;\n\n/** TemplateResult types */\nconst HTML_RESULT = 1;\nconst SVG_RESULT = 2;\nconst MATHML_RESULT = 3;\n\ntype ResultType = typeof HTML_RESULT | typeof SVG_RESULT | typeof MATHML_RESULT;\n\n// TemplatePart types\n// IMPORTANT: these must match the values in PartType\nconst ATTRIBUTE_PART = 1;\nconst CHILD_PART = 2;\nconst PROPERTY_PART = 3;\nconst BOOLEAN_ATTRIBUTE_PART = 4;\nconst EVENT_PART = 5;\nconst ELEMENT_PART = 6;\nconst COMMENT_PART = 7;\n\n/**\n * The return type of the template tag functions, {@linkcode html} and\n * {@linkcode svg} when it hasn't been compiled by @lit-labs/compiler.\n *\n * A `TemplateResult` object holds all the information about a template\n * expression required to render it: the template strings, expression values,\n * and type of template (html or svg).\n *\n * `TemplateResult` objects do not create any DOM on their own. To create or\n * update DOM you need to render the `TemplateResult`. See\n * [Rendering](https://lit.dev/docs/components/rendering) for more information.\n *\n */\nexport type UncompiledTemplateResult<T extends ResultType = ResultType> = {\n // This property needs to remain unminified.\n ['_$litType$']: T;\n strings: TemplateStringsArray;\n values: unknown[];\n};\n\n/**\n * This is a template result that may be either uncompiled or compiled.\n *\n * In the future, TemplateResult will be this type. If you want to explicitly\n * note that a template result is potentially compiled, you can reference this\n * type and it will continue to behave the same through the next major version\n * of Lit. This can be useful for code that wants to prepare for the next\n * major version of Lit.\n */\nexport type MaybeCompiledTemplateResult<T extends ResultType = ResultType> =\n | UncompiledTemplateResult<T>\n | CompiledTemplateResult;\n\n/**\n * The return type of the template tag functions, {@linkcode html} and\n * {@linkcode svg}.\n *\n * A `TemplateResult` object holds all the information about a template\n * expression required to render it: the template strings, expression values,\n * and type of template (html or svg).\n *\n * `TemplateResult` objects do not create any DOM on their own. To create or\n * update DOM you need to render the `TemplateResult`. See\n * [Rendering](https://lit.dev/docs/components/rendering) for more information.\n *\n * In Lit 4, this type will be an alias of\n * MaybeCompiledTemplateResult, so that code will get type errors if it assumes\n * that Lit templates are not compiled. When deliberately working with only\n * one, use either {@linkcode CompiledTemplateResult} or\n * {@linkcode UncompiledTemplateResult} explicitly.\n */\nexport type TemplateResult<T extends ResultType = ResultType> =\n UncompiledTemplateResult<T>;\n\nexport type HTMLTemplateResult = TemplateResult<typeof HTML_RESULT>;\n\nexport type SVGTemplateResult = TemplateResult<typeof SVG_RESULT>;\n\nexport type MathMLTemplateResult = TemplateResult<typeof MATHML_RESULT>;\n\n/**\n * A TemplateResult that has been compiled by @lit-labs/compiler, skipping the\n * prepare step.\n */\nexport interface CompiledTemplateResult {\n // This is a factory in order to make template initialization lazy\n // and allow ShadyRenderOptions scope to be passed in.\n // This property needs to remain unminified.\n ['_$litType$']: CompiledTemplate;\n values: unknown[];\n}\n\nexport interface CompiledTemplate extends Omit<Template, 'el'> {\n // el is overridden to be optional. We initialize it on first render\n el?: HTMLTemplateElement;\n\n // The prepared HTML string to create a template element from.\n // The type is a TemplateStringsArray to guarantee that the value came from\n // source code, preventing a JSON injection attack.\n h: TemplateStringsArray;\n}\n\n/**\n * Generates a template literal tag function that returns a TemplateResult with\n * the given result type.\n */\nconst tag =\n <T extends ResultType>(type: T) =>\n (strings: TemplateStringsArray, ...values: unknown[]): TemplateResult<T> => {\n // Warn against templates octal escape sequences\n // We do this here rather than in render so that the warning is closer to the\n // template definition.\n if (DEV_MODE && strings.some((s) => s === undefined)) {\n console.warn(\n 'Some template strings are undefined.\\n' +\n 'This is probably caused by illegal octal escape sequences.'\n );\n }\n if (DEV_MODE) {\n // Import static-html.js results in a circular dependency which g3 doesn't\n // handle. Instead we know that static values must have the field\n // `_$litStatic$`.\n if (\n values.some((val) => (val as {_$litStatic$: unknown})?.['_$litStatic$'])\n ) {\n issueWarning(\n '',\n `Static values 'literal' or 'unsafeStatic' cannot be used as values to non-static templates.\\n` +\n `Please use the static 'html' tag function. See https://lit.dev/docs/templates/expressions/#static-expressions`\n );\n }\n }\n return {\n // This property needs to remain unminified.\n ['_$litType$']: type,\n strings,\n values,\n };\n };\n\n/**\n * Interprets a template literal as an HTML template that can efficiently\n * render to and update a container.\n *\n * ```ts\n * const header = (title: string) => html`<h1>${title}</h1>`;\n * ```\n *\n * The `html` tag returns a description of the DOM to render as a value. It is\n * lazy, meaning no work is done until the template is rendered. When rendering,\n * if a template comes from the same expression as a previously rendered result,\n * it's efficiently updated instead of replaced.\n */\nexport const html = tag(HTML_RESULT);\n\n/**\n * Interprets a template literal as an SVG fragment that can efficiently render\n * to and update a container.\n *\n * ```ts\n * const rect = svg`<rect width=\"10\" height=\"10\"></rect>`;\n *\n * const myImage = html`\n * <svg viewBox=\"0 0 10 10\" xmlns=\"http://www.w3.org/2000/svg\">\n * ${rect}\n * </svg>`;\n * ```\n *\n * The `svg` *tag function* should only be used for SVG fragments, or elements\n * that would be contained **inside** an `<svg>` HTML element. A common error is\n * placing an `<svg>` *element* in a template tagged with the `svg` tag\n * function. The `<svg>` element is an HTML element and should be used within a\n * template tagged with the {@linkcode html} tag function.\n *\n * In LitElement usage, it's invalid to return an SVG fragment from the\n * `render()` method, as the SVG fragment will be contained within the element's\n * shadow root and thus not be properly contained within an `<svg>` HTML\n * element.\n */\nexport const svg = tag(SVG_RESULT);\n\n/**\n * Interprets a template literal as MathML fragment that can efficiently render\n * to and update a container.\n *\n * ```ts\n * const num = mathml`<mn>1</mn>`;\n *\n * const eq = html`\n * <math>\n * ${num}\n * </math>`;\n * ```\n *\n * The `mathml` *tag function* should only be used for MathML fragments, or\n * elements that would be contained **inside** a `<math>` HTML element. A common\n * error is placing a `<math>` *element* in a template tagged with the `mathml`\n * tag function. The `<math>` element is an HTML element and should be used\n * within a template tagged with the {@linkcode html} tag function.\n *\n * In LitElement usage, it's invalid to return an MathML fragment from the\n * `render()` method, as the MathML fragment will be contained within the\n * element's shadow root and thus not be properly contained within a `<math>`\n * HTML element.\n */\nexport const mathml = tag(MATHML_RESULT);\n\n/**\n * A sentinel value that signals that a value was handled by a directive and\n * should not be written to the DOM.\n */\nexport const noChange = Symbol.for('lit-noChange');\n\n/**\n * A sentinel value that signals a ChildPart to fully clear its content.\n *\n * ```ts\n * const button = html`${\n * user.isAdmin\n * ? html`<button>DELETE</button>`\n * : nothing\n * }`;\n * ```\n *\n * Prefer using `nothing` over other falsy values as it provides a consistent\n * behavior between various expression binding contexts.\n *\n * In child expressions, `undefined`, `null`, `''`, and `nothing` all behave the\n * same and render no nodes. In attribute expressions, `nothing` _removes_ the\n * attribute, while `undefined` and `null` will render an empty string. In\n * property expressions `nothing` becomes `undefined`.\n */\nexport const nothing = Symbol.for('lit-nothing');\n\n/**\n * The cache of prepared templates, keyed by the tagged TemplateStringsArray\n * and _not_ accounting for the specific template tag used. This means that\n * template tags cannot be dynamic - they must statically be one of html, svg,\n * or attr. This restriction simplifies the cache lookup, which is on the hot\n * path for rendering.\n */\nconst templateCache = new WeakMap<TemplateStringsArray, Template>();\n\n/**\n * Object specifying options for controlling lit-html rendering. Note that\n * while `render` may be called multiple times on the same `container` (and\n * `renderBefore` reference node) to efficiently update the rendered content,\n * only the options passed in during the first render are respected during\n * the lifetime of renders to that unique `container` + `renderBefore`\n * combination.\n */\nexport interface RenderOptions {\n /**\n * An object to use as the `this` value for event listeners. It's often\n * useful to set this to the host component rendering a template.\n */\n host?: object;\n /**\n * A DOM node before which to render content in the container.\n */\n renderBefore?: ChildNode | null;\n /**\n * Node used for cloning the template (`importNode` will be called on this\n * node). This controls the `ownerDocument` of the rendered DOM, along with\n * any inherited context. Defaults to the global `document`.\n */\n creationScope?: {importNode(node: Node, deep?: boolean): Node};\n /**\n * The initial connected state for the top-level part being rendered. If no\n * `isConnected` option is set, `AsyncDirective`s will be connected by\n * default. Set to `false` if the initial render occurs in a disconnected tree\n * and `AsyncDirective`s should see `isConnected === false` for their initial\n * render. The `part.setConnected()` method must be used subsequent to initial\n * render to change the connected state of the part.\n */\n isConnected?: boolean;\n}\n\nconst walker = d.createTreeWalker(\n d,\n 129 /* NodeFilter.SHOW_{ELEMENT|COMMENT} */\n);\n\nlet sanitizerFactoryInternal: SanitizerFactory = noopSanitizer;\n\n//\n// Classes only below here, const variable declarations only above here...\n//\n// Keeping variable declarations and classes together improves minification.\n// Interfaces and type aliases can be interleaved freely.\n//\n\n// Type for classes that have a `_directive` or `_directives[]` field, used by\n// `resolveDirective`\nexport interface DirectiveParent {\n _$parent?: DirectiveParent;\n _$isConnected: boolean;\n __directive?: Directive;\n __directives?: Array<Directive | undefined>;\n}\n\nfunction trustFromTemplateString(\n tsa: TemplateStringsArray,\n stringFromTSA: string\n): TrustedHTML {\n // A security check to prevent spoofing of Lit template results.\n // In the future, we may be able to replace this with Array.isTemplateObject,\n // though we might need to make that check inside of the html and svg\n // functions, because precompiled templates don't come in as\n // TemplateStringArray objects.\n if (!isArray(tsa) || !tsa.hasOwnProperty('raw')) {\n let message = 'invalid template strings array';\n if (DEV_MODE) {\n message = `\n Internal Error: expected template strings to be an array\n with a 'raw' field. Faking a template strings array by\n calling html or svg like an ordinary function is effectively\n the same as calling unsafeHtml and can lead to major security\n issues, e.g. opening your code up to XSS attacks.\n If you're using the html or svg tagged template functions normally\n and still seeing this error, please file a bug at\n https://github.com/lit/lit/issues/new?template=bug_report.md\n and include information about your build tooling, if any.\n `\n .trim()\n .replace(/\\n */g, '\\n');\n }\n throw new Error(message);\n }\n return policy !== undefined\n ? policy.createHTML(stringFromTSA)\n : (stringFromTSA as unknown as TrustedHTML);\n}\n\n/**\n * Returns an HTML string for the given TemplateStringsArray and result type\n * (HTML or SVG), along with the case-sensitive bound attribute names in\n * template order. The HTML contains comment markers denoting the `ChildPart`s\n * and suffixes on bound attributes denoting the `AttributeParts`.\n *\n * @param strings template strings array\n * @param type HTML or SVG\n * @return Array containing `[html, attrNames]` (array returned for terseness,\n * to avoid object fields since this code is shared with non-minified SSR\n * code)\n */\nconst getTemplateHtml = (\n strings: TemplateStringsArray,\n type: ResultType\n): [TrustedHTML, Array<string>] => {\n // Insert makers into the template HTML to represent the position of\n // bindings. The following code scans the template strings to determine the\n // syntactic position of the bindings. They can be in text position, where\n // we insert an HTML comment, attribute value position, where we insert a\n // sentinel string and re-write the attribute name, or inside a tag where\n // we insert the sentinel string.\n const l = strings.length - 1;\n // Stores the case-sensitive bound attribute names in the order of their\n // parts. ElementParts are also reflected in this array as undefined\n // rather than a string, to disambiguate from attribute bindings.\n const attrNames: Array<string> = [];\n let html =\n type === SVG_RESULT ? '<svg>' : type === MATHML_RESULT ? '<math>' : '';\n\n // When we're inside a raw text tag (not it's text content), the regex\n // will still be tagRegex so we can find attributes, but will switch to\n // this regex when the tag ends.\n let rawTextEndRegex: RegExp | undefined;\n\n // The current parsing state, represented as a reference to one of the\n // regexes\n let regex = textEndRegex;\n\n for (let i = 0; i < l; i++) {\n const s = strings[i];\n // The index of the end of the last attribute name. When this is\n // positive at end of a string, it means we're in an attribute value\n // position and need to rewrite the attribute name.\n // We also use a special value of -2 to indicate that we encountered\n // the end of a string in attribute name position.\n let attrNameEndIndex = -1;\n let attrName: string | undefined;\n let lastIndex = 0;\n let match!: RegExpExecArray | null;\n\n // The conditions in this loop handle the current parse state, and the\n // assignments to the `regex` variable are the state transitions.\n while (lastIndex < s.length) {\n // Make sure we start searching from where we previously left off\n regex.lastIndex = lastIndex;\n match = regex.exec(s);\n if (match === null) {\n break;\n }\n lastIndex = regex.lastIndex;\n if (regex === textEndRegex) {\n if (match[COMMENT_START] === '!--') {\n regex = commentEndRegex;\n } else if (match[COMMENT_START] !== undefined) {\n // We started a weird comment, like </{\n regex = comment2EndRegex;\n } else if (match[TAG_NAME] !== undefined) {\n if (rawTextElement.test(match[TAG_NAME])) {\n // Record if we encounter a raw-text element. We'll switch to\n // this regex at the end of the tag.\n rawTextEndRegex = new RegExp(`</${match[TAG_NAME]}`, 'g');\n }\n regex = tagEndRegex;\n } else if (match[DYNAMIC_TAG_NAME] !== undefined) {\n if (DEV_MODE) {\n throw new Error(\n 'Bindings in tag names are not supported. Please use static templates instead. ' +\n 'See https://lit.dev/docs/templates/expressions/#static-expressions'\n );\n }\n regex = tagEndRegex;\n }\n } else if (regex === tagEndRegex) {\n if (match[ENTIRE_MATCH] === '>') {\n // End of a tag. If we had started a raw-text element, use that\n // regex\n regex = rawTextEndRegex ?? textEndRegex;\n // We may be ending an unquoted attribute value, so make sure we\n // clear any pending attrNameEndIndex\n attrNameEndIndex = -1;\n } else if (match[ATTRIBUTE_NAME] === undefined) {\n // Attribute name position\n attrNameEndIndex = -2;\n } else {\n attrNameEndIndex = regex.lastIndex - match[SPACES_AND_EQUALS].length;\n attrName = match[ATTRIBUTE_NAME];\n regex =\n match[QUOTE_CHAR] === undefined\n ? tagEndRegex\n : match[QUOTE_CHAR] === '\"'\n ? doubleQuoteAttrEndRegex\n : singleQuoteAttrEndRegex;\n }\n } else if (\n regex === doubleQuoteAttrEndRegex ||\n regex === singleQuoteAttrEndRegex\n ) {\n regex = tagEndRegex;\n } else if (regex === commentEndRegex || regex === comment2EndRegex) {\n regex = textEndRegex;\n } else {\n // Not one of the five state regexes, so it must be the dynamically\n // created raw text regex and we're at the close of that element.\n regex = tagEndRegex;\n rawTextEndRegex = undefined;\n }\n }\n\n if (DEV_MODE) {\n // If we have a attrNameEndIndex, which indicates that we should\n // rewrite the attribute name, assert that we're in a valid attribute\n // position - either in a tag, or a quoted attribute value.\n console.assert(\n attrNameEndIndex === -1 ||\n regex === tagEndRegex ||\n regex === singleQuoteAttrEndRegex ||\n regex === doubleQuoteAttrEndRegex,\n 'unexpected parse state B'\n );\n }\n\n // We have four cases:\n // 1. We're in text position, and not in a raw text element\n // (regex === textEndRegex): insert a comment marker.\n // 2. We have a non-negative attrNameEndIndex which means we need to\n // rewrite the attribute name to add a bound attribute suffix.\n // 3. We're at the non-first binding in a multi-binding attribute, use a\n // plain marker.\n // 4. We're somewhere else inside the tag. If we're in attribute name\n // position (attrNameEndIndex === -2), add a sequential suffix to\n // generate a unique attribute name.\n\n // Detect a binding next to self-closing tag end and insert a space to\n // separate the marker from the tag end:\n const end =\n regex === tagEndRegex && strings[i + 1].startsWith('/>') ? ' ' : '';\n html +=\n regex === textEndRegex\n ? s + nodeMarker\n : attrNameEndIndex >= 0\n ? (attrNames.push(attrName!),\n s.slice(0, attrNameEndIndex) +\n boundAttributeSuffix +\n s.slice(attrNameEndIndex)) +\n marker +\n end\n : s + marker + (attrNameEndIndex === -2 ? i : end);\n }\n\n const htmlResult: string | TrustedHTML =\n html +\n (strings[l] || '<?>') +\n (type === SVG_RESULT ? '</svg>' : type === MATHML_RESULT ? '</math>' : '');\n\n // Returned as an array for terseness\n return [trustFromTemplateString(strings, htmlResult), attrNames];\n};\n\n/** @internal */\nexport type {Template};\nclass Template {\n /** @internal */\n el!: HTMLTemplateElement;\n\n parts: Array<TemplatePart> = [];\n\n constructor(\n // This property needs to remain unminified.\n {strings, ['_$litType$']: type}: UncompiledTemplateResult,\n options?: RenderOptions\n ) {\n let node: Node | null;\n let nodeIndex = 0;\n let attrNameIndex = 0;\n const partCount = strings.length - 1;\n const parts = this.parts;\n\n // Create template element\n const [html, attrNames] = getTemplateHtml(strings, type);\n this.el = Template.createElement(html, options);\n walker.currentNode = this.el.content;\n\n // Re-parent SVG or MathML nodes into template root\n if (type === SVG_RESULT || type === MATHML_RESULT) {\n const wrapper = this.el.content.firstChild!;\n wrapper.replaceWith(...wrapper.childNodes);\n }\n\n // Walk the template to find binding markers and create TemplateParts\n while ((node = walker.nextNode()) !== null && parts.length < partCount) {\n if (node.nodeType === 1) {\n if (DEV_MODE) {\n const tag = (node as Element).localName;\n // Warn if `textarea` includes an expression and throw if `template`\n // does since these are not supported. We do this by checking\n // innerHTML for anything that looks like a marker. This catches\n // cases like bindings in textarea there markers turn into text nodes.\n if (\n /^(?:textarea|template)$/i!.test(tag) &&\n (node as Element).innerHTML.includes(marker)\n ) {\n const m =\n `Expressions are not supported inside \\`${tag}\\` ` +\n `elements. See https://lit.dev/msg/expression-in-${tag} for more ` +\n `information.`;\n if (tag === 'template') {\n throw new Error(m);\n } else issueWarning('', m);\n }\n }\n // TODO (justinfagnani): for attempted dynamic tag names, we don't\n // increment the bindingIndex, and it'll be off by 1 in the element\n // and off by two after it.\n if ((node as Element).hasAttributes()) {\n for (const name of (node as Element).getAttributeNames()) {\n if (name.endsWith(boundAttributeSuffix)) {\n const realName = attrNames[attrNameIndex++];\n const value = (node as Element).getAttribute(name)!;\n const statics = value.split(marker);\n const m = /([.?@])?(.*)/.exec(realName)!;\n parts.push({\n type: ATTRIBUTE_PART,\n index: nodeIndex,\n name: m[2],\n strings: statics,\n ctor:\n m[1] === '.'\n ? PropertyPart\n : m[1] === '?'\n ? BooleanAttributePart\n : m[1] === '@'\n ? EventPart\n : AttributePart,\n });\n (node as Element).removeAttribute(name);\n } else if (name.startsWith(marker)) {\n parts.push({\n type: ELEMENT_PART,\n index: nodeIndex,\n });\n (node as Element).removeAttribute(name);\n }\n }\n }\n // TODO (justinfagnani): benchmark the regex against testing for each\n // of the 3 raw text element names.\n if (rawTextElement.test((node as Element).tagName)) {\n // For raw text elements we need to split the text content on\n // markers, create a Text node for each segment, and create\n // a TemplatePart for each marker.\n const strings = (node as Element).textContent!.split(marker);\n const lastIndex = strings.length - 1;\n if (lastIndex > 0) {\n (node as Element).textContent = trustedTypes\n ? (trustedTypes.emptyScript as unknown as '')\n : '';\n // Generate a new text node for each literal section\n // These nodes are also used as the markers for child parts\n for (let i = 0; i < lastIndex; i++) {\n (node as Element).append(strings[i], createMarker());\n // Walk past the marker node we just added\n walker.nextNode();\n parts.push({type: CHILD_PART, index: ++nodeIndex});\n }\n // Note because this marker is added after the walker's current\n // node, it will be walked to in the outer loop (and ignored), so\n // we don't need to adjust nodeIndex here\n (node as Element).append(strings[lastIndex], createMarker());\n }\n }\n } else if (node.nodeType === 8) {\n const data = (node as Comment).data;\n if (data === markerMatch) {\n parts.push({type: CHILD_PART, index: nodeIndex});\n } else {\n let i = -1;\n while ((i = (node as Comment).data.indexOf(marker, i + 1)) !== -1) {\n // Comment node has a binding marker inside, make an inactive part\n // The binding won't work, but subsequent bindings will\n parts.push({type: COMMENT_PART, index: nodeIndex});\n // Move to the end of the match\n i += marker.length - 1;\n }\n }\n }\n nodeIndex++;\n }\n\n if (DEV_MODE) {\n // If there was a duplicate attribute on a tag, then when the tag is\n // parsed into an element the attribute gets de-duplicated. We can detect\n // this mismatch if we haven't precisely consumed every attribute name\n // when preparing the template. This works because `attrNames` is built\n // from the template string and `attrNameIndex` comes from processing the\n // resulting DOM.\n if (attrNames.length !== attrNameIndex) {\n throw new Error(\n `Detected duplicate attribute bindings. This occurs if your template ` +\n `has duplicate attributes on an element tag. For example ` +\n `\"<input ?disabled=\\${true} ?disabled=\\${false}>\" contains a ` +\n `duplicate \"disabled\" attribute. The error was detected in ` +\n `the following template: \\n` +\n '`' +\n strings.join('${...}') +\n '`'\n );\n }\n }\n\n // We could set walker.currentNode to another node here to prevent a memory\n // leak, but every time we prepare a template, we immediately render it\n // and re-use the walker in new TemplateInstance._clone().\n debugLogEvent &&\n debugLogEvent({\n kind: 'template prep',\n template: this,\n clonableTemplate: this.el,\n parts: this.parts,\n strings,\n });\n }\n\n // Overridden via `litHtmlPolyfillSupport` to provide platform support.\n /** @nocollapse */\n static createElement(html: TrustedHTML, _options?: RenderOptions) {\n const el = d.createElement('template');\n el.innerHTML = html as unknown as string;\n return el;\n }\n}\n\nexport interface Disconnectable {\n _$parent?: Disconnectable;\n _$disconnectableChildren?: Set<Disconnectable>;\n // Rather than hold connection state on instances, Disconnectables recursively\n // fetch the connection state from the RootPart they are connected in via\n // getters up the Disconnectable tree via _$parent references. This pushes the\n // cost of tracking the isConnected state to `AsyncDirectives`, and avoids\n // needing to pass all Disconnectables (parts, template instances, and\n // directives) their connection state each time it changes, which would be\n // costly for trees that have no AsyncDirectives.\n _$isConnected: boolean;\n}\n\nfunction resolveDirective(\n part: ChildPart | AttributePart | ElementPart,\n value: unknown,\n parent: DirectiveParent = part,\n attributeIndex?: number\n): unknown {\n // Bail early if the value is explicitly noChange. Note, this means any\n // nested directive is still attached and is not run.\n if (value === noChange) {\n return value;\n }\n let currentDirective =\n attributeIndex !== undefined\n ? (parent as AttributePart).__directives?.[attributeIndex]\n : (parent as ChildPart | ElementPart | Directive).__directive;\n const nextDirectiveConstructor = isPrimitive(value)\n ? undefined\n : // This property needs to remain unminified.\n (value as DirectiveResult)['_$litDirective$'];\n if (currentDirective?.constructor !== nextDirectiveConstructor) {\n // This property needs to remain unminified.\n currentDirective?.['_$notifyDirectiveConnectionChanged']?.(false);\n if (nextDirectiveConstructor === undefined) {\n currentDirective = undefined;\n } else {\n currentDirective = new nextDirectiveConstructor(part as PartInfo);\n currentDirective._$initialize(part, parent, attributeIndex);\n }\n if (attributeIndex !== undefined) {\n ((parent as AttributePart).__directives ??= [])[attributeIndex] =\n currentDirective;\n } else {\n (parent as ChildPart | Directive).__directive = currentDirective;\n }\n }\n if (currentDirective !== undefined) {\n value = resolveDirective(\n part,\n currentDirective._$resolve(part, (value as DirectiveResult).values),\n currentDirective,\n attributeIndex\n );\n }\n return value;\n}\n\nexport type {TemplateInstance};\n/**\n * An updateable instance of a Template. Holds references to the Parts used to\n * update the template instance.\n */\nclass TemplateInstance implements Disconnectable {\n _$template: Template;\n _$parts: Array<Part | undefined> = [];\n\n /** @internal */\n _$parent: ChildPart;\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n\n constructor(template: Template, parent: ChildPart) {\n this._$template = template;\n this._$parent = parent;\n }\n\n // Called by ChildPart parentNode getter\n get parentNode() {\n return this._$parent.parentNode;\n }\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n // This method is separate from the constructor because we need to return a\n // DocumentFragment and we don't want to hold onto it with an instance field.\n _clone(options: RenderOptions | undefined) {\n const {\n el: {content},\n parts: parts,\n } = this._$template;\n const fragment = (options?.creationScope ?? d).importNode(content, true);\n walker.currentNode = fragment;\n\n let node = walker.nextNode()!;\n let nodeIndex = 0;\n let partIndex = 0;\n let templatePart = parts[0];\n\n while (templatePart !== undefined) {\n if (nodeIndex === templatePart.index) {\n let part: Part | undefined;\n if (templatePart.type === CHILD_PART) {\n part = new ChildPart(\n node as HTMLElement,\n node.nextSibling,\n this,\n options\n );\n } else if (templatePart.type === ATTRIBUTE_PART) {\n part = new templatePart.ctor(\n node as HTMLElement,\n templatePart.name,\n templatePart.strings,\n this,\n options\n );\n } else if (templatePart.type === ELEMENT_PART) {\n part = new ElementPart(node as HTMLElement, this, options);\n }\n this._$parts.push(part);\n templatePart = parts[++partIndex];\n }\n if (nodeIndex !== templatePart?.index) {\n node = walker.nextNode()!;\n nodeIndex++;\n }\n }\n // We need to set the currentNode away from the cloned tree so that we\n // don't hold onto the tree even if the tree is detached and should be\n // freed.\n walker.currentNode = d;\n return fragment;\n }\n\n _update(values: Array<unknown>) {\n let i = 0;\n for (const part of this._$parts) {\n if (part !== undefined) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'set part',\n part,\n value: values[i],\n valueIndex: i,\n values,\n templateInstance: this,\n });\n if ((part as AttributePart).strings !== undefined) {\n (part as AttributePart)._$setValue(values, part as AttributePart, i);\n // The number of values the part consumes is part.strings.length - 1\n // since values are in between template spans. We increment i by 1\n // later in the loop, so increment it by part.strings.length - 2 here\n i += (part as AttributePart).strings!.length - 2;\n } else {\n part._$setValue(values[i]);\n }\n }\n i++;\n }\n }\n}\n\n/*\n * Parts\n */\ntype AttributeTemplatePart = {\n readonly type: typeof ATTRIBUTE_PART;\n readonly index: number;\n readonly name: string;\n readonly ctor: typeof AttributePart;\n readonly strings: ReadonlyArray<string>;\n};\ntype ChildTemplatePart = {\n readonly type: typeof CHILD_PART;\n readonly index: number;\n};\ntype ElementTemplatePart = {\n readonly type: typeof ELEMENT_PART;\n readonly index: number;\n};\ntype CommentTemplatePart = {\n readonly type: typeof COMMENT_PART;\n readonly index: number;\n};\n\n/**\n * A TemplatePart represents a dynamic part in a template, before the template\n * is instantiated. When a template is instantiated Parts are created from\n * TemplateParts.\n */\ntype TemplatePart =\n | ChildTemplatePart\n | AttributeTemplatePart\n | ElementTemplatePart\n | CommentTemplatePart;\n\nexport type Part =\n | ChildPart\n | AttributePart\n | PropertyPart\n | BooleanAttributePart\n | ElementPart\n | EventPart;\n\nexport type {ChildPart};\nclass ChildPart implements Disconnectable {\n readonly type = CHILD_PART;\n readonly options: RenderOptions | undefined;\n _$committedValue: unknown = nothing;\n /** @internal */\n __directive?: Directive;\n /** @internal */\n _$startNode: ChildNode;\n /** @internal */\n _$endNode: ChildNode | null;\n private _textSanitizer: ValueSanitizer | undefined;\n /** @internal */\n _$parent: Disconnectable | undefined;\n /**\n * Connection state for RootParts only (i.e. ChildPart without _$parent\n * returned from top-level `render`). This field is unused otherwise. The\n * intention would be clearer if we made `RootPart` a subclass of `ChildPart`\n * with this field (and a different _$isConnected getter), but the subclass\n * caused a perf regression, possibly due to making call sites polymorphic.\n * @internal\n */\n __isConnected: boolean;\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n // ChildParts that are not at the root should always be created with a\n // parent; only RootChildNode's won't, so they return the local isConnected\n // state\n return this._$parent?._$isConnected ?? this.__isConnected;\n }\n\n // The following fields will be patched onto ChildParts when required by\n // AsyncDirective\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n /** @internal */\n _$notifyConnectionChanged?(\n isConnected: boolean,\n removeFromParent?: boolean,\n from?: number\n ): void;\n /** @internal */\n _$reparentDisconnectables?(parent: Disconnectable): void;\n\n constructor(\n startNode: ChildNode,\n endNode: ChildNode | null,\n parent: TemplateInstance | ChildPart | undefined,\n options: RenderOptions | undefined\n ) {\n this._$startNode = startNode;\n this._$endNode = endNode;\n this._$parent = parent;\n this.options = options;\n // Note __isConnected is only ever accessed on RootParts (i.e. when there is\n // no _$parent); the value on a non-root-part is \"don't care\", but checking\n // for parent would be more code\n this.__isConnected = options?.isConnected ?? true;\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n // Explicitly initialize for consistent class shape.\n this._textSanitizer = undefined;\n }\n }\n\n /**\n * The parent node into which the part renders its content.\n *\n * A ChildPart's content consists of a range of adjacent child nodes of\n * `.parentNode`, possibly bordered by 'marker nodes' (`.startNode` and\n * `.endNode`).\n *\n * - If both `.startNode` and `.endNode` are non-null, then the part's content\n * consists of all siblings between `.startNode` and `.endNode`, exclusively.\n *\n * - If `.startNode` is non-null but `.endNode` is null, then the part's\n * content consists of all siblings following `.startNode`, up to and\n * including the last child of `.parentNode`. If `.endNode` is non-null, then\n * `.startNode` will always be non-null.\n *\n * - If both `.endNode` and `.startNode` are null, then the part's content\n * consists of all child nodes of `.parentNode`.\n */\n get parentNode(): Node {\n let parentNode: Node = wrap(this._$startNode).parentNode!;\n const parent = this._$parent;\n if (\n parent !== undefined &&\n parentNode?.nodeType === 11 /* Node.DOCUMENT_FRAGMENT */\n ) {\n // If the parentNode is a DocumentFragment, it may be because the DOM is\n // still in the cloned fragment during initial render; if so, get the real\n // parentNode the part will be committed into by asking the parent.\n parentNode = (parent as ChildPart | TemplateInstance).parentNode;\n }\n return parentNode;\n }\n\n /**\n * The part's leading marker node, if any. See `.parentNode` for more\n * information.\n */\n get startNode(): Node | null {\n return this._$startNode;\n }\n\n /**\n * The part's trailing marker node, if any. See `.parentNode` for more\n * information.\n */\n get endNode(): Node | null {\n return this._$endNode;\n }\n\n _$setValue(value: unknown, directiveParent: DirectiveParent = this): void {\n if (DEV_MODE && this.parentNode === null) {\n throw new Error(\n `This \\`ChildPart\\` has no \\`parentNode\\` and therefore cannot accept a value. This likely means the element containing the part was manipulated in an unsupported way outside of Lit's control such that the part's marker nodes were ejected from DOM. For example, setting the element's \\`innerHTML\\` or \\`textContent\\` can do this.`\n );\n }\n value = resolveDirective(this, value, directiveParent);\n if (isPrimitive(value)) {\n // Non-rendering child values. It's important that these do not render\n // empty text nodes to avoid issues with preventing default <slot>\n // fallback content.\n if (value === nothing || value == null || value === '') {\n if (this._$committedValue !== nothing) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit nothing to child',\n start: this._$startNode,\n end: this._$endNode,\n parent: this._$parent,\n options: this.options,\n });\n this._$clear();\n }\n this._$committedValue = nothing;\n } else if (value !== this._$committedValue && value !== noChange) {\n this._commitText(value);\n }\n // This property needs to remain unminified.\n } else if ((value as TemplateResult)['_$litType$'] !== undefined) {\n this._commitTemplateResult(value as TemplateResult);\n } else if ((value as Node).nodeType !== undefined) {\n if (DEV_MODE && this.options?.host === value) {\n this._commitText(\n `[probable mistake: rendered a template's host in itself ` +\n `(commonly caused by writing \\${this} in a template]`\n );\n console.warn(\n `Attempted to render the template host`,\n value,\n `inside itself. This is almost always a mistake, and in dev mode `,\n `we render some warning text. In production however, we'll `,\n `render it, which will usually result in an error, and sometimes `,\n `in the element disappearing from the DOM.`\n );\n return;\n }\n this._commitNode(value as Node);\n } else if (isIterable(value)) {\n this._commitIterable(value);\n } else {\n // Fallback, will render the string representation\n this._commitText(value);\n }\n }\n\n private _insert<T extends Node>(node: T) {\n return wrap(wrap(this._$startNode).parentNode!).insertBefore(\n node,\n this._$endNode\n );\n }\n\n private _commitNode(value: Node): void {\n if (this._$committedValue !== value) {\n this._$clear();\n if (\n ENABLE_EXTRA_SECURITY_HOOKS &&\n sanitizerFactoryInternal !== noopSanitizer\n ) {\n const parentNodeName = this._$startNode.parentNode?.nodeName;\n if (parentNodeName === 'STYLE' || parentNodeName === 'SCRIPT') {\n let message = 'Forbidden';\n if (DEV_MODE) {\n if (parentNodeName === 'STYLE') {\n message =\n `Lit does not support binding inside style nodes. ` +\n `This is a security risk, as style injection attacks can ` +\n `exfiltrate data and spoof UIs. ` +\n `Consider instead using css\\`...\\` literals ` +\n `to compose styles, and do dynamic styling with ` +\n `css custom properties, ::parts, <slot>s, ` +\n `and by mutating the DOM rather than stylesheets.`;\n } else {\n message =\n `Lit does not support binding inside script nodes. ` +\n `This is a security risk, as it could allow arbitrary ` +\n `code execution.`;\n }\n }\n throw new Error(message);\n }\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit node',\n start: this._$startNode,\n parent: this._$parent,\n value: value,\n options: this.options,\n });\n this._$committedValue = this._insert(value);\n }\n }\n\n private _commitText(value: unknown): void {\n // If the committed value is a primitive it means we called _commitText on\n // the previous render, and we know that this._$startNode.nextSibling is a\n // Text node. We can now just replace the text content (.data) of the node.\n if (\n this._$committedValue !== nothing &&\n isPrimitive(this._$committedValue)\n ) {\n const node = wrap(this._$startNode).nextSibling as Text;\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n if (this._textSanitizer === undefined) {\n this._textSanitizer = createSanitizer(node, 'data', 'property');\n }\n value = this._textSanitizer(value);\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit text',\n node,\n value,\n options: this.options,\n });\n (node as Text).data = value as string;\n } else {\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n const textNode = d.createTextNode('');\n this._commitNode(textNode);\n // When setting text content, for security purposes it matters a lot\n // what the parent is. For example, <style> and <script> need to be\n // handled with care, while <span> does not. So first we need to put a\n // text node into the document, then we can sanitize its content.\n if (this._textSanitizer === undefined) {\n this._textSanitizer = createSanitizer(textNode, 'data', 'property');\n }\n value = this._textSanitizer(value);\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit text',\n node: textNode,\n value,\n options: this.options,\n });\n textNode.data = value as string;\n } else {\n this._commitNode(d.createTextNode(value as string));\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit text',\n node: wrap(this._$startNode).nextSibling as Text,\n value,\n options: this.options,\n });\n }\n }\n this._$committedValue = value;\n }\n\n private _commitTemplateResult(\n result: TemplateResult | CompiledTemplateResult\n ): void {\n // This property needs to remain unminified.\n const {values, ['_$litType$']: type} = result;\n // If $litType$ is a number, result is a plain TemplateResult and we get\n // the template from the template cache. If not, result is a\n // CompiledTemplateResult and _$litType$ is a CompiledTemplate and we need\n // to create the <template> element the first time we see it.\n const template: Template | CompiledTemplate =\n typeof type === 'number'\n ? this._$getTemplate(result as UncompiledTemplateResult)\n : (type.el === undefined &&\n (type.el = Template.createElement(\n trustFromTemplateString(type.h, type.h[0]),\n this.options\n )),\n type);\n\n if ((this._$committedValue as TemplateInstance)?._$template === template) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'template updating',\n template,\n instance: this._$committedValue as TemplateInstance,\n parts: (this._$committedValue as TemplateInstance)._$parts,\n options: this.options,\n values,\n });\n (this._$committedValue as TemplateInstance)._update(values);\n } else {\n const instance = new TemplateInstance(template as Template, this);\n const fragment = instance._clone(this.options);\n debugLogEvent &&\n debugLogEvent({\n kind: 'template instantiated',\n template,\n instance,\n parts: instance._$parts,\n options: this.options,\n fragment,\n values,\n });\n instance._update(values);\n debugLogEvent &&\n debugLogEvent({\n kind: 'template instantiated and updated',\n template,\n instance,\n parts: instance._$parts,\n options: this.options,\n fragment,\n values,\n });\n this._commitNode(fragment);\n this._$committedValue = instance;\n }\n }\n\n // Overridden via `litHtmlPolyfillSupport` to provide platform support.\n /** @internal */\n _$getTemplate(result: UncompiledTemplateResult) {\n let template = templateCache.get(result.strings);\n if (template === undefined) {\n templateCache.set(result.strings, (template = new Template(result)));\n }\n return template;\n }\n\n private _commitIterable(value: Iterable<unknown>): void {\n // For an Iterable, we create a new InstancePart per item, then set its\n // value to the item. This is a little bit of overhead for every item in\n // an Iterable, but it lets us recurse easily and efficiently update Arrays\n // of TemplateResults that will be commonly returned from expressions like:\n // array.map((i) => html`${i}`), by reusing existing TemplateInstances.\n\n // If value is an array, then the previous render was of an\n // iterable and value will contain the ChildParts from the previous\n // render. If value is not an array, clear this part and make a new\n // array for ChildParts.\n if (!isArray(this._$committedValue)) {\n this._$committedValue = [];\n this._$clear();\n }\n\n // Lets us keep track of how many items we stamped so we can clear leftover\n // items from a previous render\n const itemParts = this._$committedValue as ChildPart[];\n let partIndex = 0;\n let itemPart: ChildPart | undefined;\n\n for (const item of value) {\n if (partIndex === itemParts.length) {\n // If no existing part, create a new one\n // TODO (justinfagnani): test perf impact of always creating two parts\n // instead of sharing parts between nodes\n // https://github.com/lit/lit/issues/1266\n itemParts.push(\n (itemPart = new ChildPart(\n this._insert(createMarker()),\n this._insert(createMarker()),\n this,\n this.options\n ))\n );\n } else {\n // Reuse an existing part\n itemPart = itemParts[partIndex];\n }\n itemPart._$setValue(item);\n partIndex++;\n }\n\n if (partIndex < itemParts.length) {\n // itemParts always have end nodes\n this._$clear(\n itemPart && wrap(itemPart._$endNode!).nextSibling,\n partIndex\n );\n // Truncate the parts array so _value reflects the current state\n itemParts.length = partIndex;\n }\n }\n\n /**\n * Removes the nodes contained within this Part from the DOM.\n *\n * @param start Start node to clear from, for clearing a subset of the part's\n * DOM (used when truncating iterables)\n * @param from When `start` is specified, the index within the iterable from\n * which ChildParts are being removed, used for disconnecting directives\n * in those Parts.\n *\n * @internal\n */\n _$clear(\n start: ChildNode | null = wrap(this._$startNode).nextSibling,\n from?: number\n ) {\n this._$notifyConnectionChanged?.(false, true, from);\n while (start !== this._$endNode) {\n // The non-null assertion is safe because if _$startNode.nextSibling is\n // null, then _$endNode is also null, and we would not have entered this\n // loop.\n const n = wrap(start!).nextSibling;\n wrap(start!).remove();\n start = n;\n }\n }\n\n /**\n * Implementation of RootPart's `isConnected`. Note that this method\n * should only be called on `RootPart`s (the `ChildPart` returned from a\n * top-level `render()` call). It has no effect on non-root ChildParts.\n * @param isConnected Whether to set\n * @internal\n */\n setConnected(isConnected: boolean) {\n if (this._$parent === undefined) {\n this.__isConnected = isConnected;\n this._$notifyConnectionChanged?.(isConnected);\n } else if (DEV_MODE) {\n throw new Error(\n 'part.setConnected() may only be called on a ' +\n 'RootPart returned from render().'\n );\n }\n }\n}\n\n/**\n * A top-level `ChildPart` returned from `render` that manages the connected\n * state of `AsyncDirective`s created throughout the tree below it.\n */\nexport interface RootPart extends ChildPart {\n /**\n * Sets the connection state for `AsyncDirective`s contained within this root\n * ChildPart.\n *\n * lit-html does not automatically monitor the connectedness of DOM rendered;\n * as such, it is the responsibility of the caller to `render` to ensure that\n * `part.setConnected(false)` is called before the part object is potentially\n * discarded, to ensure that `AsyncDirective`s have a chance to dispose of\n * any resources being held. If a `RootPart` that was previously\n * disconnected is subsequently re-connected (and its `AsyncDirective`s should\n * re-connect), `setConnected(true)` should be called.\n *\n * @param isConnected Whether directives within this tree should be connected\n * or not\n */\n setConnected(isConnected: boolean): void;\n}\n\nexport type {AttributePart};\nclass AttributePart implements Disconnectable {\n readonly type:\n | typeof ATTRIBUTE_PART\n | typeof PROPERTY_PART\n | typeof BOOLEAN_ATTRIBUTE_PART\n | typeof EVENT_PART = ATTRIBUTE_PART;\n readonly element: HTMLElement;\n readonly name: string;\n readonly options: RenderOptions | undefined;\n\n /**\n * If this attribute part represents an interpolation, this contains the\n * static strings of the interpolation. For single-value, complete bindings,\n * this is undefined.\n */\n readonly strings?: ReadonlyArray<string>;\n /** @internal */\n _$committedValue: unknown | Array<unknown> = nothing;\n /** @internal */\n __directives?: Array<Directive | undefined>;\n /** @internal */\n _$parent: Disconnectable;\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n\n protected _sanitizer: ValueSanitizer | undefined;\n\n get tagName() {\n return this.element.tagName;\n }\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n constructor(\n element: HTMLElement,\n name: string,\n strings: ReadonlyArray<string>,\n parent: Disconnectable,\n options: RenderOptions | undefined\n ) {\n this.element = element;\n this.name = name;\n this._$parent = parent;\n this.options = options;\n if (strings.length > 2 || strings[0] !== '' || strings[1] !== '') {\n this._$committedValue = new Array(strings.length - 1).fill(new String());\n this.strings = strings;\n } else {\n this._$committedValue = nothing;\n }\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n this._sanitizer = undefined;\n }\n }\n\n /**\n * Sets the value of this part by resolving the value from possibly multiple\n * values and static strings and committing it to the DOM.\n * If this part is single-valued, `this._strings` will be undefined, and the\n * method will be called with a single value argument. If this part is\n * multi-value, `this._strings` will be defined, and the method is called\n * with the value array of the part's owning TemplateInstance, and an offset\n * into the value array from which the values should be read.\n * This method is overloaded this way to eliminate short-lived array slices\n * of the template instance values, and allow a fast-path for single-valued\n * parts.\n *\n * @param value The part value, or an array of values for multi-valued parts\n * @param valueIndex the index to start reading values from. `undefined` for\n * single-valued parts\n * @param noCommit causes the part to not commit its value to the DOM. Used\n * in hydration to prime attribute parts with their first-rendered value,\n * but not set the attribute, and in SSR to no-op the DOM operation and\n * capture the value for serialization.\n *\n * @internal\n */\n _$setValue(\n value: unknown | Array<unknown>,\n directiveParent: DirectiveParent = this,\n valueIndex?: number,\n noCommit?: boolean\n ) {\n const strings = this.strings;\n\n // Whether any of the values has changed, for dirty-checking\n let change = false;\n\n if (strings === undefined) {\n // Single-value binding case\n value = resolveDirective(this, value, directiveParent, 0);\n change =\n !isPrimitive(value) ||\n (value !== this._$committedValue && value !== noChange);\n if (change) {\n this._$committedValue = value;\n }\n } else {\n // Interpolation case\n const values = value as Array<unknown>;\n value = strings[0];\n\n let i, v;\n for (i = 0; i < strings.length - 1; i++) {\n v = resolveDirective(this, values[valueIndex! + i], directiveParent, i);\n\n if (v === noChange) {\n // If the user-provided value is `noChange`, use the previous value\n v = (this._$committedValue as Array<unknown>)[i];\n }\n change ||=\n !isPrimitive(v) || v !== (this._$committedValue as Array<unknown>)[i];\n if (v === nothing) {\n value = nothing;\n } else if (value !== nothing) {\n value += (v ?? '') + strings[i + 1];\n }\n // We always record each value, even if one is `nothing`, for future\n // change detection.\n (this._$committedValue as Array<unknown>)[i] = v;\n }\n }\n if (change && !noCommit) {\n this._commitValue(value);\n }\n }\n\n /** @internal */\n _commitValue(value: unknown) {\n if (value === nothing) {\n (wrap(this.element) as Element).removeAttribute(this.name);\n } else {\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n if (this._sanitizer === undefined) {\n this._sanitizer = sanitizerFactoryInternal(\n this.element,\n this.name,\n 'attribute'\n );\n }\n value = this._sanitizer(value ?? '');\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit attribute',\n element: this.element,\n name: this.name,\n value,\n options: this.options,\n });\n (wrap(this.element) as Element).setAttribute(\n this.name,\n (value ?? '') as string\n );\n }\n }\n}\n\nexport type {PropertyPart};\nclass PropertyPart extends AttributePart {\n override readonly type = PROPERTY_PART;\n\n /** @internal */\n override _commitValue(value: unknown) {\n if (ENABLE_EXTRA_SECURITY_HOOKS) {\n if (this._sanitizer === undefined) {\n this._sanitizer = sanitizerFactoryInternal(\n this.element,\n this.name,\n 'property'\n );\n }\n value = this._sanitizer(value);\n }\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit property',\n element: this.element,\n name: this.name,\n value,\n options: this.options,\n });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (this.element as any)[this.name] = value === nothing ? undefined : value;\n }\n}\n\nexport type {BooleanAttributePart};\nclass BooleanAttributePart extends AttributePart {\n override readonly type = BOOLEAN_ATTRIBUTE_PART;\n\n /** @internal */\n override _commitValue(value: unknown) {\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit boolean attribute',\n element: this.element,\n name: this.name,\n value: !!(value && value !== nothing),\n options: this.options,\n });\n (wrap(this.element) as Element).toggleAttribute(\n this.name,\n !!value && value !== nothing\n );\n }\n}\n\ntype EventListenerWithOptions = EventListenerOrEventListenerObject &\n Partial<AddEventListenerOptions>;\n\n/**\n * An AttributePart that manages an event listener via add/removeEventListener.\n *\n * This part works by adding itself as the event listener on an element, then\n * delegating to the value passed to it. This reduces the number of calls to\n * add/removeEventListener if the listener changes frequently, such as when an\n * inline function is used as a listener.\n *\n * Because event options are passed when adding listeners, we must take case\n * to add and remove the part as a listener when the event options change.\n */\nexport type {EventPart};\nclass EventPart extends AttributePart {\n override readonly type = EVENT_PART;\n\n constructor(\n element: HTMLElement,\n name: string,\n strings: ReadonlyArray<string>,\n parent: Disconnectable,\n options: RenderOptions | undefined\n ) {\n super(element, name, strings, parent, options);\n\n if (DEV_MODE && this.strings !== undefined) {\n throw new Error(\n `A \\`<${element.localName}>\\` has a \\`@${name}=...\\` listener with ` +\n 'invalid content. Event listeners in templates must have exactly ' +\n 'one expression and no surrounding text.'\n );\n }\n }\n\n // EventPart does not use the base _$setValue/_resolveValue implementation\n // since the dirty checking is more complex\n /** @internal */\n override _$setValue(\n newListener: unknown,\n directiveParent: DirectiveParent = this\n ) {\n newListener =\n resolveDirective(this, newListener, directiveParent, 0) ?? nothing;\n if (newListener === noChange) {\n return;\n }\n const oldListener = this._$committedValue;\n\n // If the new value is nothing or any options change we have to remove the\n // part as a listener.\n const shouldRemoveListener =\n (newListener === nothing && oldListener !== nothing) ||\n (newListener as EventListenerWithOptions).capture !==\n (oldListener as EventListenerWithOptions).capture ||\n (newListener as EventListenerWithOptions).once !==\n (oldListener as EventListenerWithOptions).once ||\n (newListener as EventListenerWithOptions).passive !==\n (oldListener as EventListenerWithOptions).passive;\n\n // If the new value is not nothing and we removed the listener, we have\n // to add the part as a listener.\n const shouldAddListener =\n newListener !== nothing &&\n (oldListener === nothing || shouldRemoveListener);\n\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit event listener',\n element: this.element,\n name: this.name,\n value: newListener,\n options: this.options,\n removeListener: shouldRemoveListener,\n addListener: shouldAddListener,\n oldListener,\n });\n if (shouldRemoveListener) {\n this.element.removeEventListener(\n this.name,\n this,\n oldListener as EventListenerWithOptions\n );\n }\n if (shouldAddListener) {\n this.element.addEventListener(\n this.name,\n this,\n newListener as EventListenerWithOptions\n );\n }\n this._$committedValue = newListener;\n }\n\n handleEvent(event: Event) {\n if (typeof this._$committedValue === 'function') {\n this._$committedValue.call(this.options?.host ?? this.element, event);\n } else {\n (this._$committedValue as EventListenerObject).handleEvent(event);\n }\n }\n}\n\nexport type {ElementPart};\nclass ElementPart implements Disconnectable {\n readonly type = ELEMENT_PART;\n\n /** @internal */\n __directive?: Directive;\n\n // This is to ensure that every Part has a _$committedValue\n _$committedValue: undefined;\n\n /** @internal */\n _$parent!: Disconnectable;\n\n /** @internal */\n _$disconnectableChildren?: Set<Disconnectable> = undefined;\n\n options: RenderOptions | undefined;\n\n constructor(\n public element: Element,\n parent: Disconnectable,\n options: RenderOptions | undefined\n ) {\n this._$parent = parent;\n this.options = options;\n }\n\n // See comment in Disconnectable interface for why this is a getter\n get _$isConnected() {\n return this._$parent._$isConnected;\n }\n\n _$setValue(value: unknown): void {\n debugLogEvent &&\n debugLogEvent({\n kind: 'commit to element binding',\n element: this.element,\n value,\n options: this.options,\n });\n resolveDirective(this, value);\n }\n}\n\n/**\n * END USERS SHOULD NOT RELY ON THIS OBJECT.\n *\n * Private exports for use by other Lit packages, not intended for use by\n * external users.\n *\n * We currently do not make a mangled rollup build of the lit-ssr code. In order\n * to keep a number of (otherwise private) top-level exports mangled in the\n * client side code, we export a _$LH object containing those members (or\n * helper methods for accessing private fields of those members), and then\n * re-export them for use in lit-ssr. This keeps lit-ssr agnostic to whether the\n * client-side code is being used in `dev` mode or `prod` mode.\n *\n * This has a unique name, to disambiguate it from private exports in\n * lit-element, which re-exports all of lit-html.\n *\n * @private\n */\nexport const _$LH = {\n // Used in lit-ssr\n _boundAttributeSuffix: boundAttributeSuffix,\n _marker: marker,\n _markerMatch: markerMatch,\n _HTML_RESULT: HTML_RESULT,\n _getTemplateHtml: getTemplateHtml,\n // Used in tests and private-ssr-support\n _TemplateInstance: TemplateInstance,\n _isIterable: isIterable,\n _resolveDirective: resolveDirective,\n _ChildPart: ChildPart,\n _AttributePart: AttributePart,\n _BooleanAttributePart: BooleanAttributePart,\n _EventPart: EventPart,\n _PropertyPart: PropertyPart,\n _ElementPart: ElementPart,\n};\n\n// Apply polyfills if available\nconst polyfillSupport = DEV_MODE\n ? global.litHtmlPolyfillSupportDevMode\n : global.litHtmlPolyfillSupport;\npolyfillSupport?.(Template, ChildPart);\n\n// IMPORTANT: do not change the property name or the assignment expression.\n// This line will be used in regexes to search for lit-html usage.\n(global.litHtmlVersions ??= []).push('3.3.1');\nif (DEV_MODE && global.litHtmlVersions.length > 1) {\n queueMicrotask(() => {\n issueWarning!(\n 'multiple-versions',\n `Multiple versions of Lit loaded. ` +\n `Loading multiple versions is not recommended.`\n );\n });\n}\n\n/**\n * Renders a value, usually a lit-html TemplateResult, to the container.\n *\n * This example renders the text \"Hello, Zoe!\" inside a paragraph tag, appending\n * it to the container `document.body`.\n *\n * ```js\n * import {html, render} from 'lit';\n *\n * const name = \"Zoe\";\n * render(html`<p>Hello, ${name}!</p>`, document.body);\n * ```\n *\n * @param value Any [renderable\n * value](https://lit.dev/docs/templates/expressions/#child-expressions),\n * typically a {@linkcode TemplateResult} created by evaluating a template tag\n * like {@linkcode html} or {@linkcode svg}.\n * @param container A DOM container to render to. The first render will append\n * the rendered value to the container, and subsequent renders will\n * efficiently update the rendered value if the same result type was\n * previously rendered there.\n * @param options See {@linkcode RenderOptions} for options documentation.\n * @see\n * {@link https://lit.dev/docs/libraries/standalone-templates/#rendering-lit-html-templates| Rendering Lit HTML Templates}\n */\nexport const render = (\n value: unknown,\n container: HTMLElement | DocumentFragment,\n options?: RenderOptions\n): RootPart => {\n if (DEV_MODE && container == null) {\n // Give a clearer error message than\n // Uncaught TypeError: Cannot read properties of null (reading\n // '_$litPart$')\n // which reads like an internal Lit error.\n throw new TypeError(`The container to render into may not be ${container}`);\n }\n const renderId = DEV_MODE ? debugLogRenderId++ : 0;\n const partOwnerNode = options?.renderBefore ?? container;\n // This property needs to remain unminified.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let part: ChildPart = (partOwnerNode as any)['_$litPart$'];\n debugLogEvent &&\n debugLogEvent({\n kind: 'begin render',\n id: renderId,\n value,\n container,\n options,\n part,\n });\n if (part === undefined) {\n const endNode = options?.renderBefore ?? null;\n // This property needs to remain unminified.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (partOwnerNode as any)['_$litPart$'] = part = new ChildPart(\n container.insertBefore(createMarker(), endNode),\n endNode,\n undefined,\n options ?? {}\n );\n }\n part._$setValue(value);\n debugLogEvent &&\n debugLogEvent({\n kind: 'end render',\n id: renderId,\n value,\n container,\n options,\n part,\n });\n return part as RootPart;\n};\n\nif (ENABLE_EXTRA_SECURITY_HOOKS) {\n render.setSanitizer = setSanitizer;\n render.createSanitizer = createSanitizer;\n if (DEV_MODE) {\n render._testOnlyClearSanitizerFactoryDoNotCallOrElse =\n _testOnlyClearSanitizerFactoryDoNotCallOrElse;\n }\n}\n","/*\n * @license\n * Portions Copyright (c) 2013, the Dart project authors.\n */\n\nexport const KEYWORDS = ['this'];\nexport const UNARY_OPERATORS = ['+', '-', '!'];\nexport const BINARY_OPERATORS = [\n '=',\n '+',\n '-',\n '*',\n '/',\n '%',\n '^',\n '==',\n '!=',\n '>',\n '<',\n '>=',\n '<=',\n '||',\n '&&',\n '??',\n '&',\n '===',\n '!==',\n '|',\n '|>',\n];\n\nexport const PRECEDENCE: Record<string, number> = {\n '!': 0,\n ':': 0,\n ',': 0,\n ')': 0,\n ']': 0,\n '}': 0,\n\n '|>': 1,\n '?': 2,\n '??': 3,\n '||': 4,\n '&&': 5,\n '|': 6,\n '^': 7,\n '&': 8,\n\n // equality\n '!=': 9,\n '==': 9,\n '!==': 9,\n '===': 9,\n\n // relational\n '>=': 10,\n '>': 10,\n '<=': 10,\n '<': 10,\n\n // additive\n '+': 11,\n '-': 11,\n\n // multiplicative\n '%': 12,\n '/': 12,\n '*': 12,\n\n // postfix\n '(': 13,\n '[': 13,\n '.': 13,\n '{': 13, // not sure this is correct\n};\n\nexport const POSTFIX_PRECEDENCE = 13;\n","/*\n * @license\n * Portions Copyright (c) 2013, the Dart project authors.\n */\n\nimport {KEYWORDS, POSTFIX_PRECEDENCE, PRECEDENCE} from './constants.js';\n\nconst TWO_CHAR_OPS = ['==', '!=', '<=', '>=', '||', '&&', '??', '|>'];\nconst THREE_CHAR_OPS = ['===', '!=='];\n\nexport interface Token {\n kind: Kind;\n value: string;\n precedence: number;\n}\n\nexport enum Kind {\n STRING = 1,\n IDENTIFIER = 2,\n DOT = 3,\n COMMA = 4,\n COLON = 5,\n INTEGER = 6,\n DECIMAL = 7,\n OPERATOR = 8,\n GROUPER = 9,\n KEYWORD = 10,\n ARROW = 11,\n}\n\nexport const token = (kind: Kind, value: string, precedence: number = 0) => ({\n kind,\n value,\n precedence,\n});\n\nconst isWhitespace = (ch: number) =>\n ch === 9 /* \\t */ ||\n ch === 10 /* \\n */ ||\n ch === 13 /* \\r */ ||\n ch === 32; /* space */\n\n// TODO(justinfagnani): allow code points > 127\nconst isIdentOrKeywordStart = (ch: number) =>\n ch === 95 /* _ */ ||\n ch === 36 /* $ */ ||\n // ch &= ~32 puts ch into the range [65,90] [A-Z] only if ch was already in\n // the that range or in the range [97,122] [a-z]. We must mutate ch only after\n // checking other characters, thus the comma operator.\n ((ch &= ~32), 65 /* A */ <= ch && ch <= 90); /* Z */\n\n// TODO(justinfagnani): allow code points > 127\nconst isIdentifier = (ch: number) => isIdentOrKeywordStart(ch) || isNumber(ch);\n\nconst isKeyword = (str: string) => KEYWORDS.indexOf(str) !== -1;\n\nconst isQuote = (ch: number) => ch === 34 /* \" */ || ch === 39; /* ' */\n\nconst isNumber = (ch: number) => 48 /* 0 */ <= ch && ch <= 57; /* 9 */\n\nconst isOperator = (ch: number) =>\n ch === 43 /* + */ ||\n ch === 45 /* - */ ||\n ch === 42 /* * */ ||\n ch === 47 /* / */ ||\n ch === 33 /* ! */ ||\n ch === 38 /* & */ ||\n ch === 37 /* % */ ||\n ch === 60 /* < */ ||\n ch === 61 /* = */ ||\n ch === 62 /* > */ ||\n ch === 63 /* ? */ ||\n ch === 94 /* ^ */ ||\n ch === 124; /* | */\n\nconst _isGrouper = (ch: number) =>\n ch === 40 /* ( */ ||\n ch === 41 /* ) */ ||\n ch === 91 /* [ */ ||\n ch === 93 /* ] */ ||\n ch === 123 /* { */ ||\n ch === 125; /* } */\n\nconst escapeString = (str: string) =>\n str.replace(/\\\\(.)/g, (_match, group) => {\n switch (group) {\n case 'n':\n return '\\n';\n case 'r':\n return '\\r';\n case 't':\n return '\\t';\n case 'b':\n return '\\b';\n case 'f':\n return '\\f';\n default:\n return group;\n }\n });\n\nexport class Tokenizer {\n #input: string;\n #index = -1;\n #tokenStart = 0;\n #next?: number;\n\n constructor(input: string) {\n this.#input = input;\n this.#advance();\n }\n\n nextToken() {\n while (isWhitespace(this.#next!)) {\n this.#advance(true);\n }\n if (isQuote(this.#next!)) return this.#tokenizeString();\n if (isIdentOrKeywordStart(this.#next!)) {\n return this.#tokenizeIdentOrKeyword();\n }\n if (isNumber(this.#next!)) return this.#tokenizeNumber();\n if (this.#next === 46 /* . */) return this.#tokenizeDot();\n if (this.#next === 44 /* , */) return this.#tokenizeComma();\n if (this.#next === 58 /* : */) return this.#tokenizeColon();\n if (isOperator(this.#next!)) return this.#tokenizeOperator();\n if (_isGrouper(this.#next!)) return this.#tokenizeGrouper();\n // no match, should be end of input\n this.#advance();\n if (this.#next !== undefined) {\n throw new Error(`Expected end of input, got ${this.#next}`);\n }\n return undefined;\n }\n\n #advance(resetTokenStart?: boolean) {\n this.#index++;\n if (this.#index < this.#input.length) {\n this.#next = this.#input.charCodeAt(this.#index);\n if (resetTokenStart === true) {\n this.#tokenStart = this.#index;\n }\n } else {\n this.#next = undefined;\n }\n }\n\n #getValue(lookahead: number = 0) {\n const v = this.#input.substring(this.#tokenStart, this.#index + lookahead);\n if (lookahead === 0) {\n this.#clearValue();\n }\n return v;\n }\n\n #clearValue() {\n this.#tokenStart = this.#index;\n }\n\n #tokenizeString() {\n const _us = 'unterminated string';\n const quoteChar = this.#next;\n this.#advance(true);\n while (this.#next !== quoteChar) {\n if (this.#next === undefined) throw new Error(_us);\n if (this.#next === 92 /* \\ */) {\n this.#advance();\n if (this.#next === undefined) throw new Error(_us);\n }\n this.#advance();\n }\n const t = token(Kind.STRING, escapeString(this.#getValue()));\n this.#advance();\n return t;\n }\n\n #tokenizeIdentOrKeyword() {\n // This do/while loops assumes isIdentifier(this._next!), so it must only\n // be called if isIdentOrKeywordStart(this._next!) has returned true.\n do {\n this.#advance();\n } while (isIdentifier(this.#next!));\n const value = this.#getValue();\n const kind = isKeyword(value) ? Kind.KEYWORD : Kind.IDENTIFIER;\n return token(kind, value);\n }\n\n #tokenizeNumber() {\n // This do/while loops assumes isNumber(this._next!), so it must only\n // be called if isNumber(this._next!) has returned true.\n do {\n this.#advance();\n } while (isNumber(this.#next!));\n if (this.#next === 46 /* . */) return this.#tokenizeDot();\n return token(Kind.INTEGER, this.#getValue());\n }\n\n #tokenizeDot() {\n this.#advance();\n if (isNumber(this.#next!)) return this.#tokenizeFraction();\n this.#clearValue();\n return token(Kind.DOT, '.', POSTFIX_PRECEDENCE);\n }\n\n #tokenizeComma() {\n this.#advance(true);\n return token(Kind.COMMA, ',');\n }\n\n #tokenizeColon() {\n this.#advance(true);\n return token(Kind.COLON, ':');\n }\n\n #tokenizeFraction() {\n // This do/while loops assumes isNumber(this._next!), so it must only\n // be called if isNumber(this._next!) has returned true.\n do {\n this.#advance();\n } while (isNumber(this.#next!));\n return token(Kind.DECIMAL, this.#getValue());\n }\n\n #tokenizeOperator() {\n this.#advance();\n let op = this.#getValue(2);\n\n if (THREE_CHAR_OPS.indexOf(op) !== -1) {\n this.#advance();\n this.#advance();\n } else {\n op = this.#getValue(1);\n if (op === '=>') {\n this.#advance();\n return token(Kind.ARROW, op);\n }\n if (TWO_CHAR_OPS.indexOf(op) !== -1) {\n this.#advance();\n }\n }\n op = this.#getValue();\n return token(Kind.OPERATOR, op, PRECEDENCE[op]);\n }\n\n #tokenizeGrouper() {\n const value = String.fromCharCode(this.#next!);\n const t = token(Kind.GROUPER, value, PRECEDENCE[value]);\n this.#advance(true);\n return t;\n }\n}\n","/*\n * @license\n * Portions Copyright (c) 2013, the Dart project authors.\n */\n\nimport {ID, Invoke, Expression} from './ast.js';\nimport {AstFactory} from './ast_factory.js';\nimport {\n BINARY_OPERATORS,\n KEYWORDS,\n POSTFIX_PRECEDENCE,\n UNARY_OPERATORS,\n} from './constants.js';\nimport {Kind, Token, Tokenizer} from './tokenizer.js';\n\nexport const parse = <E extends Expression>(\n expr: string,\n astFactory: AstFactory<E>,\n): E | undefined => new Parser<E>(expr, astFactory).parse();\n\nexport class Parser<N extends Expression> {\n #kind?: Kind;\n #tokenizer: Tokenizer;\n #ast: AstFactory<N>;\n #token?: Token;\n #value?: string;\n\n constructor(input: string, astFactory: AstFactory<N>) {\n this.#tokenizer = new Tokenizer(input);\n this.#ast = astFactory;\n }\n\n parse(): N | undefined {\n this.#advance();\n return this.#parseExpression();\n }\n\n #advance(kind?: Kind, value?: string) {\n if (!this._matches(kind, value)) {\n throw new Error(\n `Expected kind ${kind} (${value}), was ${this.#token?.kind} (${this.#token?.value})`,\n );\n }\n const t = this.#tokenizer.nextToken();\n this.#token = t;\n this.#kind = t?.kind;\n this.#value = t?.value;\n }\n\n _matches(kind?: Kind, value?: string) {\n return !((kind && this.#kind !== kind) || (value && this.#value !== value));\n }\n\n #parseExpression(): N | undefined {\n if (!this.#token) return this.#ast.empty();\n const expr = this.#parseUnary();\n return expr === undefined ? undefined : this.#parsePrecedence(expr, 0);\n }\n\n // #parsePrecedence and #parseBinary implement the precedence climbing\n // algorithm as described in:\n // http://en.wikipedia.org/wiki/Operator-precedence_parser#Precedence_climbing_method\n #parsePrecedence(left: N | undefined, precedence: number) {\n if (left === undefined) {\n throw new Error('Expected left to be defined.');\n }\n while (this.#token) {\n if (this._matches(Kind.GROUPER, '(')) {\n const args = this.#parseArguments();\n left = this.#ast.invoke(left, undefined, args);\n } else if (this._matches(Kind.GROUPER, '[')) {\n const indexExpr = this.#parseIndex();\n left = this.#ast.index(left, indexExpr);\n } else if (this._matches(Kind.DOT)) {\n this.#advance();\n const right = this.#parseUnary();\n left = this.#makeInvokeOrGetter(left, right);\n } else if (this._matches(Kind.KEYWORD)) {\n break;\n } else if (\n this._matches(Kind.OPERATOR) &&\n this.#token.precedence >= precedence\n ) {\n left =\n this.#value === '?'\n ? this.#parseTernary(left)\n : this.#parseBinary(left, this.#token);\n } else {\n break;\n }\n }\n return left;\n }\n\n #makeInvokeOrGetter(left: N, right: N | undefined) {\n if (right === undefined) {\n throw new Error('expected identifier');\n }\n if (right.type === 'ID') {\n return this.#ast.getter(left, (right as ID).value);\n } else if (\n right.type === 'Invoke' &&\n (right as Invoke).receiver.type === 'ID'\n ) {\n const method = (right as Invoke).receiver as ID;\n return this.#ast.invoke(\n left,\n method.value,\n (right as Invoke).arguments as any,\n );\n } else {\n throw new Error(`expected identifier: ${right}`);\n }\n }\n\n #parseBinary(left: N, op: Token) {\n if (BINARY_OPERATORS.indexOf(op.value) === -1) {\n throw new Error(`unknown operator: ${op.value}`);\n }\n this.#advance();\n let right = this.#parseUnary();\n while (\n (this.#kind === Kind.OPERATOR ||\n this.#kind === Kind.DOT ||\n this.#kind === Kind.GROUPER) &&\n this.#token!.precedence > op.precedence\n ) {\n right = this.#parsePrecedence(right, this.#token!.precedence);\n }\n return this.#ast.binary(left, op.value, right);\n }\n\n #parseUnary(): N | undefined {\n if (this._matches(Kind.OPERATOR)) {\n const value = this.#value;\n this.#advance();\n // handle unary + and - on numbers as part of the literal, not as a\n // unary operator\n if (value === '+' || value === '-') {\n if (this._matches(Kind.INTEGER)) {\n return this.#parseInteger(value);\n } else if (this._matches(Kind.DECIMAL)) {\n return this.#parseDecimal(value);\n }\n }\n if (UNARY_OPERATORS.indexOf(value!) === -1)\n throw new Error(`unexpected token: ${value}`);\n const expr = this.#parsePrecedence(\n this.#parsePrimary(),\n POSTFIX_PRECEDENCE,\n );\n return this.#ast.unary(value!, expr);\n }\n return this.#parsePrimary();\n }\n\n #parseTernary(condition: N) {\n this.#advance(Kind.OPERATOR, '?');\n const trueExpr = this.#parseExpression();\n this.#advance(Kind.COLON);\n const falseExpr = this.#parseExpression();\n return this.#ast.ternary(condition, trueExpr, falseExpr);\n }\n\n #parsePrimary() {\n switch (this.#kind) {\n case Kind.KEYWORD:\n const keyword = this.#value!;\n if (keyword === 'this') {\n this.#advance();\n // TODO(justin): return keyword node\n return this.#ast.id(keyword);\n } else if (KEYWORDS.indexOf(keyword) !== -1) {\n throw new Error(`unexpected keyword: ${keyword}`);\n }\n throw new Error(`unrecognized keyword: ${keyword}`);\n case Kind.IDENTIFIER:\n return this.#parseInvokeOrIdentifier();\n case Kind.STRING:\n return this.#parseString();\n case Kind.INTEGER:\n return this.#parseInteger();\n case Kind.DECIMAL:\n return this.#parseDecimal();\n case Kind.GROUPER:\n if (this.#value === '(') {\n return this.#parseParenOrFunction();\n } else if (this.#value === '{') {\n return this.#parseMap();\n } else if (this.#value === '[') {\n return this.#parseList();\n }\n return undefined;\n case Kind.COLON:\n throw new Error('unexpected token \":\"');\n default:\n return undefined;\n }\n }\n\n #parseList() {\n const items: (N | undefined)[] = [];\n do {\n this.#advance();\n if (this._matches(Kind.GROUPER, ']')) break;\n items.push(this.#parseExpression());\n } while (this._matches(Kind.COMMA));\n this.#advance(Kind.GROUPER, ']');\n return this.#ast.list(items);\n }\n\n #parseMap() {\n const entries: {[key: string]: N | undefined} = {};\n do {\n this.#advance();\n if (this._matches(Kind.GROUPER, '}')) break;\n const key = this.#value!;\n if (this._matches(Kind.STRING) || this._matches(Kind.IDENTIFIER)) {\n this.#advance();\n }\n this.#advance(Kind.COLON);\n entries[key] = this.#parseExpression();\n } while (this._matches(Kind.COMMA));\n this.#advance(Kind.GROUPER, '}');\n return this.#ast.map(entries);\n }\n\n #parseInvokeOrIdentifier() {\n const value = this.#value;\n if (value === 'true') {\n this.#advance();\n return this.#ast.literal(true);\n }\n if (value === 'false') {\n this.#advance();\n return this.#ast.literal(false);\n }\n if (value === 'null') {\n this.#advance();\n return this.#ast.literal(null);\n }\n if (value === 'undefined') {\n this.#advance();\n return this.#ast.literal(undefined);\n }\n const identifier = this.#parseIdentifier();\n const args = this.#parseArguments();\n return !args ? identifier : this.#ast.invoke(identifier, undefined, args);\n }\n\n #parseIdentifier() {\n if (!this._matches(Kind.IDENTIFIER)) {\n throw new Error(`expected identifier: ${this.#value}`);\n }\n const value = this.#value;\n this.#advance();\n return this.#ast.id(value!);\n }\n\n #parseArguments() {\n if (!this._matches(Kind.GROUPER, '(')) {\n return undefined;\n }\n const args: Array<N | undefined> = [];\n do {\n this.#advance();\n if (this._matches(Kind.GROUPER, ')')) {\n break;\n }\n const expr = this.#parseExpression();\n args.push(expr);\n } while (this._matches(Kind.COMMA));\n this.#advance(Kind.GROUPER, ')');\n return args;\n }\n\n #parseIndex() {\n // console.assert(this.#matches(Kind.GROUPER, '['));\n this.#advance();\n const expr = this.#parseExpression();\n this.#advance(Kind.GROUPER, ']');\n return expr;\n }\n\n #parseParenOrFunction() {\n const expressions = this.#parseArguments();\n if (this._matches(Kind.ARROW)) {\n this.#advance();\n const body = this.#parseExpression();\n const params = expressions?.map((e) => (e as ID).value) ?? [];\n return this.#ast.arrowFunction(params, body);\n } else {\n return this.#ast.paren(expressions![0]);\n }\n }\n\n #parseString() {\n const value = this.#ast.literal(this.#value!);\n this.#advance();\n return value;\n }\n\n #parseInteger(prefix: string = '') {\n const value = this.#ast.literal(parseInt(`${prefix}${this.#value}`, 10));\n this.#advance();\n return value;\n }\n\n #parseDecimal(prefix: string = '') {\n const value = this.#ast.literal(parseFloat(`${prefix}${this.#value}`));\n this.#advance();\n return value;\n }\n}\n","/*\n * @license\n * Portions Copyright (c) 2013, the Dart project authors.\n */\n\nimport * as ast from './ast.js';\nimport {AstFactory} from './ast_factory.js';\n\nconst {hasOwn, fromEntries} = Object;\n\nconst _BINARY_OPERATORS: Record<string, (a: any, b: any) => any> = {\n '+': (a: any, b: any) => a + b,\n '-': (a: any, b: any) => a - b,\n '*': (a: any, b: any) => a * b,\n '/': (a: any, b: any) => a / b,\n '%': (a: any, b: any) => a % b,\n '==': (a: any, b: any) => a == b,\n '!=': (a: any, b: any) => a != b,\n '===': (a: any, b: any) => a === b,\n '!==': (a: any, b: any) => a !== b,\n '>': (a: any, b: any) => a > b,\n '>=': (a: any, b: any) => a >= b,\n '<': (a: any, b: any) => a < b,\n '<=': (a: any, b: any) => a <= b,\n '||': (a: any, b: any) => a || b,\n '&&': (a: any, b: any) => a && b,\n '??': (a: any, b: any) => a ?? b,\n '|': (a: any, f: (a: any) => any) => f(a),\n '|>': (a: any, f: (a: any) => any) => f(a),\n};\n\nconst _UNARY_OPERATORS: Record<string, (a: any) => any> = {\n '+': (a: any) => a,\n '-': (a: any) => -a,\n '!': (a: any) => !a,\n};\n\nexport interface Scope {\n [key: string]: any;\n}\n\nexport interface Evaluatable {\n evaluate(scope: Scope): any;\n getIds(idents: string[]): string[];\n}\n\nexport type Expression =\n | Literal\n | Empty\n | ID\n | Unary\n | Binary\n | Getter\n | Invoke\n | Index\n | Ternary\n | Map\n | List\n | ArrowFunction;\n\nexport interface Literal extends Evaluatable {\n type: 'Literal';\n value: ast.LiteralValue;\n}\nexport interface Empty extends Evaluatable {\n type: 'Empty';\n}\nexport interface ID extends Evaluatable {\n type: 'ID';\n value: string;\n}\nexport interface Unary extends Evaluatable {\n type: 'Unary';\n operator: string;\n child: Expression;\n}\nexport interface Binary extends Evaluatable {\n type: 'Binary';\n operator: string;\n left: Expression;\n right: Expression;\n}\nexport interface Getter extends Evaluatable {\n type: 'Getter';\n receiver: Expression;\n name: string;\n}\nexport interface Invoke extends Evaluatable {\n type: 'Invoke';\n receiver: Expression;\n method: string | undefined;\n arguments: Array<Expression> | undefined;\n}\nexport interface Index extends Evaluatable {\n type: 'Index';\n receiver: Expression;\n argument: Expression;\n}\nexport interface Ternary extends Evaluatable {\n type: 'Ternary';\n condition: Expression;\n trueExpr: Expression;\n falseExpr: Expression;\n}\nexport interface Map extends Evaluatable {\n type: 'Map';\n entries: {[key: string]: Expression | undefined} | undefined;\n}\nexport interface List extends Evaluatable {\n type: 'List';\n items: Array<Expression> | undefined;\n}\nexport interface ArrowFunction extends Evaluatable {\n type: 'ArrowFunction';\n params: Array<string>;\n body: Expression;\n}\n\nexport class EvalAstFactory implements AstFactory<Expression> {\n empty(): Empty {\n // TODO(justinfagnani): return null instead?\n return {\n type: 'Empty',\n evaluate(scope) {\n return scope;\n },\n getIds(idents) {\n return idents;\n },\n };\n }\n\n // TODO(justinfagnani): just use a JS literal?\n literal(v: string): Literal {\n return {\n type: 'Literal',\n value: v,\n evaluate(_scope) {\n return this.value;\n },\n getIds(idents) {\n return idents;\n },\n };\n }\n\n id(v: string): ID {\n return {\n type: 'ID',\n value: v,\n evaluate(scope) {\n // TODO(justinfagnani): this prevents access to properties named 'this'\n if (this.value === 'this') return scope;\n return scope?.[this.value];\n },\n getIds(idents) {\n idents.push(this.value);\n return idents;\n },\n };\n }\n\n unary(op: string, expr: Expression): Unary {\n const f = _UNARY_OPERATORS[op];\n return {\n type: 'Unary',\n operator: op,\n child: expr,\n evaluate(scope) {\n return f(this.child.evaluate(scope));\n },\n getIds(idents) {\n return this.child.getIds(idents);\n },\n };\n }\n\n binary(l: Expression, op: string, r: Expression): Binary {\n const f = _BINARY_OPERATORS[op];\n return {\n type: 'Binary',\n operator: op,\n left: l,\n right: r,\n evaluate(scope) {\n if (this.operator === '=') {\n if (\n this.left.type !== 'ID' &&\n this.left.type !== 'Getter' &&\n this.left.type !== 'Index'\n ) {\n throw new Error(`Invalid assignment target: ${this.left}`);\n }\n const value = this.right.evaluate(scope);\n let receiver: object | undefined = undefined;\n let property!: string;\n if (this.left.type === 'Getter') {\n receiver = this.left.receiver.evaluate(scope);\n property = this.left.name;\n } else if (this.left.type === 'Index') {\n receiver = this.left.receiver.evaluate(scope);\n property = this.left.argument.evaluate(scope);\n } else if (this.left.type === 'ID') {\n // TODO: the id could be a parameter\n receiver = scope;\n property = this.left.value;\n }\n return receiver === undefined\n ? undefined\n : ((receiver as any)[property] = value);\n }\n return f(this.left.evaluate(scope), this.right.evaluate(scope));\n },\n getIds(idents) {\n this.left.getIds(idents);\n this.right.getIds(idents);\n return idents;\n },\n };\n }\n\n getter(g: Expression, n: string): Getter {\n return {\n type: 'Getter',\n receiver: g,\n name: n,\n evaluate(scope) {\n return this.receiver.evaluate(scope)?.[this.name];\n },\n getIds(idents) {\n this.receiver.getIds(idents);\n return idents;\n },\n };\n }\n\n invoke(receiver: Expression, method: string, args: Expression[]): Invoke {\n if (method != null && typeof method !== 'string') {\n throw new Error('method not a string');\n }\n return {\n type: 'Invoke',\n receiver: receiver,\n method: method,\n arguments: args,\n evaluate(scope) {\n const receiver = this.receiver.evaluate(scope);\n // TODO(justinfagnani): this might be wrong in cases where we're\n // invoking a top-level function rather than a method. If method is\n // defined on a nested scope, then we should probably set _this to null.\n const _this = this.method ? receiver : (scope?.['this'] ?? scope);\n const f = this.method ? receiver?.[method] : receiver;\n const args = this.arguments ?? [];\n const argValues = args.map((a) => a?.evaluate(scope));\n return f?.apply?.(_this, argValues);\n },\n getIds(idents) {\n this.receiver.getIds(idents);\n this.arguments?.forEach((a) => a?.getIds(idents));\n return idents;\n },\n };\n }\n\n paren(e: Expression): Expression {\n return e;\n }\n\n index(e: Expression, a: Expression): Index {\n return {\n type: 'Index',\n receiver: e,\n argument: a,\n evaluate(scope) {\n return this.receiver.evaluate(scope)?.[this.argument.evaluate(scope)];\n },\n getIds(idents) {\n this.receiver.getIds(idents);\n return idents;\n },\n };\n }\n\n ternary(c: Expression, t: Expression, f: Expression): Ternary {\n return {\n type: 'Ternary',\n condition: c,\n trueExpr: t,\n falseExpr: f,\n evaluate(scope) {\n const c = this.condition.evaluate(scope);\n if (c) {\n return this.trueExpr.evaluate(scope);\n } else {\n return this.falseExpr.evaluate(scope);\n }\n },\n getIds(idents) {\n this.condition.getIds(idents);\n this.trueExpr.getIds(idents);\n this.falseExpr.getIds(idents);\n return idents;\n },\n };\n }\n\n map(entries: {[key: string]: Expression} | undefined): Map {\n return {\n type: 'Map',\n entries: entries,\n evaluate(scope) {\n const map = {};\n if (entries && this.entries) {\n for (const key in entries) {\n const val = this.entries[key];\n if (val) {\n (map as any)[key] = val.evaluate(scope);\n }\n }\n }\n return map;\n },\n getIds(idents) {\n if (entries && this.entries) {\n for (const key in entries) {\n const val = this.entries[key];\n if (val) {\n val.getIds(idents);\n }\n }\n }\n return idents;\n },\n };\n }\n\n // TODO(justinfagnani): if the list is deeply literal\n list(l: Array<Expression> | undefined): List {\n return {\n type: 'List',\n items: l,\n evaluate(scope) {\n return this.items?.map((a) => a?.evaluate(scope));\n },\n getIds(idents) {\n this.items?.forEach((i) => i?.getIds(idents));\n return idents;\n },\n };\n }\n\n arrowFunction(params: string[], body: Expression): Expression {\n return {\n type: 'ArrowFunction',\n params,\n body,\n evaluate(scope) {\n const params = this.params;\n const body = this.body;\n return function (...args: any[]) {\n // Create a nested scope for the function body with a proxy to getting\n // and setting parameters on a paramsObj, and setting other\n // identifiers on the scope. Without a proxy, attempting to set\n // properties on the outer scope would actually set them on the\n // inner scope due to JavaScript's assignment semantics.\n const paramsObj = fromEntries(params.map((p, i) => [p, args[i]]));\n const newScope = new Proxy(scope ?? {}, {\n set(target, prop, value) {\n if (hasOwn(paramsObj, prop)) {\n paramsObj[prop as string] = value;\n }\n return (target[prop as string] = value);\n },\n get(target, prop) {\n if (hasOwn(paramsObj, prop)) {\n return paramsObj[prop as string];\n }\n return target[prop as string];\n },\n });\n return body.evaluate(newScope);\n };\n },\n getIds(idents) {\n // Only return the _free_ variables in the body. Since arrow function\n // parameters are the only way to introduce new variable names, we can\n // assume that any variable in the body that isn't a parameter is free.\n return this.body\n .getIds(idents)\n .filter((id) => !this.params.includes(id));\n },\n };\n }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nimport {\n Directive,\n PartInfo,\n DirectiveClass,\n DirectiveResult,\n} from './directive.js';\nimport {\n _$LH as p,\n AttributePart,\n noChange,\n Part,\n Disconnectable,\n} from './lit-html.js';\n\nimport type {\n PropertyPart,\n ChildPart,\n BooleanAttributePart,\n EventPart,\n ElementPart,\n TemplateInstance,\n} from './lit-html.js';\n\n// Contains either the minified or unminified `_$resolve` Directive method name.\nlet resolveMethodName: Extract<keyof Directive, '_$resolve'> | null = null;\n\n/**\n * END USERS SHOULD NOT RELY ON THIS OBJECT.\n *\n * We currently do not make a mangled rollup build of the lit-ssr code. In order\n * to keep a number of (otherwise private) top-level exports mangled in the\n * client side code, we export a _$LH object containing those members (or\n * helper methods for accessing private fields of those members), and then\n * re-export them for use in lit-ssr. This keeps lit-ssr agnostic to whether the\n * client-side code is being used in `dev` mode or `prod` mode.\n * @private\n */\nexport const _$LH = {\n boundAttributeSuffix: p._boundAttributeSuffix,\n marker: p._marker,\n markerMatch: p._markerMatch,\n HTML_RESULT: p._HTML_RESULT,\n getTemplateHtml: p._getTemplateHtml,\n overrideDirectiveResolve: (\n directiveClass: new (part: PartInfo) => Directive & {render(): unknown},\n resolveOverrideFn: (directive: Directive, values: unknown[]) => unknown\n ) =>\n class extends directiveClass {\n override _$resolve(\n this: Directive,\n _part: Part,\n values: unknown[]\n ): unknown {\n return resolveOverrideFn(this, values);\n }\n },\n patchDirectiveResolve: (\n directiveClass: typeof Directive,\n resolveOverrideFn: (\n this: Directive,\n _part: Part,\n values: unknown[]\n ) => unknown\n ) => {\n if (directiveClass.prototype._$resolve.name !== resolveOverrideFn.name) {\n resolveMethodName ??= directiveClass.prototype._$resolve\n .name as NonNullable<typeof resolveMethodName>;\n for (\n let proto = directiveClass.prototype;\n proto !== Object.prototype;\n proto = Object.getPrototypeOf(proto)\n ) {\n if (proto.hasOwnProperty(resolveMethodName)) {\n proto[resolveMethodName] = resolveOverrideFn;\n return;\n }\n }\n // Nothing was patched which indicates an error. The most likely error is\n // that somehow both minified and unminified lit code passed through this\n // codepath. This is possible as lit-labs/ssr contains its own lit-html\n // module as a dependency for server rendering client Lit code. If a\n // client contains multiple duplicate Lit modules with minified and\n // unminified exports, we currently cannot handle both.\n throw new Error(\n `Internal error: It is possible that both dev mode and production mode` +\n ` Lit was mixed together during SSR. Please comment on the issue: ` +\n `https://github.com/lit/lit/issues/4527`\n );\n }\n },\n setDirectiveClass(value: DirectiveResult, directiveClass: DirectiveClass) {\n // This property needs to remain unminified.\n value['_$litDirective$'] = directiveClass;\n },\n getAttributePartCommittedValue: (\n part: AttributePart,\n value: unknown,\n index: number | undefined\n ) => {\n // Use the part setter to resolve directives/concatenate multiple parts\n // into a final value (captured by passing in a commitValue override)\n let committedValue: unknown = noChange;\n // Note that _commitValue need not be in `stableProperties` because this\n // method is only run on `AttributePart`s created by lit-ssr using the same\n // version of the library as this file\n part._commitValue = (value: unknown) => (committedValue = value);\n part._$setValue(value, part, index);\n return committedValue;\n },\n connectedDisconnectable: (props?: object): Disconnectable => ({\n ...props,\n _$isConnected: true,\n }),\n resolveDirective: p._resolveDirective,\n AttributePart: p._AttributePart,\n PropertyPart: p._PropertyPart as typeof PropertyPart,\n BooleanAttributePart: p._BooleanAttributePart as typeof BooleanAttributePart,\n EventPart: p._EventPart as typeof EventPart,\n ElementPart: p._ElementPart as typeof ElementPart,\n TemplateInstance: p._TemplateInstance as typeof TemplateInstance,\n isIterable: p._isIterable,\n ChildPart: p._ChildPart as typeof ChildPart,\n};\n","import {\n render as renderLit,\n TemplateInstance,\n nothing,\n CompiledTemplate,\n CompiledTemplateResult,\n RenderOptions,\n} from 'lit-html';\n\nimport {parse, Parser, EvalAstFactory} from '@heximal/expressions';\nimport type {Expression, Scope} from '@heximal/expressions/lib/eval';\n\nimport {_$LH} from 'lit-html/private-ssr-support.js';\nconst {AttributePart, PropertyPart, BooleanAttributePart, EventPart} = _$LH;\n\nconst astFactory = new EvalAstFactory();\nconst expressionCache = new Map<string, Expression | undefined>();\n\nconst toCamelCase = (s: string) =>\n s.replace(/-(-|\\w)/g, (_, p1: string) => p1.toUpperCase());\n\n/**\n * Gets the value from a string that contains a delimted expression: {{ ... }}\n */\nconst getSingleValue = (s: string, model: any) => {\n let ast = expressionCache.get(s);\n if (ast === undefined) {\n if (expressionCache.has(s)) {\n return undefined;\n }\n s = s.trim();\n if (s.startsWith('{{') && s.endsWith('}}')) {\n const expression = s.substring(2, s.length - 2).trim();\n ast = new Parser(expression, astFactory).parse();\n expressionCache.set(s, ast);\n }\n }\n return ast?.evaluate(model);\n};\n\nexport interface TemplateFunction {\n (model: object): unknown;\n}\n\n/**\n * A Renderer is responsible for rendering a block call, like\n * <template name=\"foo\">\n */\n// TODO: rename to BlockRenderer?\nexport interface Renderer {\n (model: any, handlers: TemplateHandlers, renderers: Renderers): unknown;\n}\n\nexport interface Renderers {\n [name: string]: Renderer;\n}\n\n/**\n * A TemplateHandlers is responsible for rendering control flow like\n * <template type=\"if\" if=\"{{x}}\">\n */\nexport type TemplateHandler = (\n template: HTMLTemplateElement,\n model: object,\n handlers: TemplateHandlers,\n renderers: Renderers,\n) => unknown;\n\nexport interface TemplateHandlers {\n [name: string]: TemplateHandler;\n}\n\nexport const ifHandler: TemplateHandler = (\n template: HTMLTemplateElement,\n model: object,\n handlers: TemplateHandlers,\n renderers: Renderers,\n) => {\n const ifAttribute = template.getAttribute('if');\n if (ifAttribute !== null && getSingleValue(ifAttribute, model)) {\n return evaluateTemplate(template, model, handlers, renderers);\n }\n return undefined;\n};\n\nconst bindingRegex = /(?<!\\\\){{(.*?)(?:(?<!\\\\)}})/g;\n\nconst hasEscapedBindingMarkers = (s: string) => /(?:\\\\{{)|(?:\\\\}})/g.test(s);\n\nconst unescapeBindingMarkers = (s: string) =>\n s.replaceAll(/\\\\{{/g, '{{').replace(/\\\\}}/g, '}}');\n\nexport const repeatHandler: TemplateHandler = (\n template: HTMLTemplateElement,\n model: object & {this?: unknown},\n handlers: TemplateHandlers,\n renderers: Renderers,\n) => {\n const repeatAttribute = template.getAttribute('repeat');\n if (repeatAttribute !== null) {\n const items = getSingleValue(repeatAttribute, model);\n if (!items[Symbol.iterator]) {\n return nothing;\n }\n const litTemplate = getLitTemplate(template);\n\n let index = -1;\n const result = [];\n for (const item of items) {\n index++;\n const itemModel = Object.create(model);\n itemModel.item = item;\n itemModel.index = index;\n itemModel['this'] = model['this'] ?? model;\n\n const values = [];\n for (const part of litTemplate.parts) {\n const value = part.update(itemModel, handlers, renderers);\n if (part.type === 1) {\n values.push(...(value as Iterable<unknown>));\n } else {\n values.push(value);\n }\n }\n const templateResult: CompiledTemplateResult = {\n _$litType$: litTemplate,\n values,\n };\n result.push(templateResult);\n }\n return result;\n }\n return undefined;\n};\n\nexport const defaultHandlers = <TemplateHandlers>{\n if: ifHandler,\n repeat: repeatHandler,\n};\n\n/**\n * @returns {Function} a template function of the form (model) => TemplateResult\n */\nexport const prepareTemplate = (\n template: HTMLTemplateElement,\n handlers: TemplateHandlers = defaultHandlers,\n renderers: Renderers = {},\n superTemplate?: HTMLTemplateElement,\n): TemplateFunction => {\n const litTemplate = getLitTemplate(template);\n const templateRenderers = litTemplate.renderers;\n if (superTemplate) {\n const superLitTemplate = getLitTemplate(superTemplate);\n const superRenderers = superLitTemplate.renderers;\n const superCallRenderer = templateRenderers['super'];\n\n if (superCallRenderer !== undefined) {\n // Explicit super call\n\n // render the sub template with:\n renderers = {\n // sub template's own renderes\n ...templateRenderers,\n // passed-in renderers\n ...renderers,\n // a super call renderer\n super: (model, handlers, renderers) => {\n // This renderer delegates to the super block in the sub template,\n // which in turn delegates back to the super renderer below, but with\n // the inner blocks of the super call.\n // when the super call goes, render with:\n renderers = {\n // super template's own blocks\n ...superRenderers,\n // passed-in renderers\n ...renderers,\n // sub template's overrides will be added by the inner super call\n super: (model, handlers, renderers) => {\n return evaluateTemplate(\n superTemplate,\n model,\n handlers,\n renderers,\n );\n },\n };\n return superCallRenderer(model, handlers, renderers);\n },\n };\n } else {\n // Implicit super call\n\n // Wrap the whole template in an implicit super call by rendering the\n // super template first, but using the block renderers from this template.\n // Render the super template with:\n renderers = {\n // super template's own blocks\n ...superRenderers,\n // sub template's overrides\n ...templateRenderers,\n // passed-in renderers\n ...renderers,\n };\n template = superTemplate;\n }\n } else {\n // No super call\n renderers = {\n // template's named blocks\n ...templateRenderers,\n // passed-in renderers\n ...renderers,\n };\n }\n return (model) => evaluateTemplate(template, model, handlers, renderers);\n};\n\nexport interface HeximalRenderOptions {\n renderers?: Renderers;\n extends?: HTMLTemplateElement;\n}\n\n/**\n * Renders a template element containing a Heximal template.\n *\n * This is a convenience function wrapper around:\n *\n * ```\n * import {render} from 'lit';\n * const templateFn = prepareTemplate(templateEl);\n * render(templateFn(model), container);\n * ```\n */\nexport const render = (\n template: HTMLTemplateElement,\n container: HTMLElement,\n model: any,\n handlers: TemplateHandlers = defaultHandlers,\n options: RenderOptions = {},\n) => {\n const litTemplate = prepareTemplate(template, handlers);\n renderLit(litTemplate(model), container, options);\n};\n\n/**\n * Evaluates the given template and returns its result\n *\n * @param template\n * @param model\n * @param handlers\n * @param renderers\n * @returns\n */\nexport const evaluateTemplate = (\n template: HTMLTemplateElement,\n model: any,\n handlers: TemplateHandlers = defaultHandlers,\n renderers: Renderers = {},\n) => {\n const litTemplate = getLitTemplate(template);\n const values: Array<unknown> = [];\n for (const part of litTemplate.parts) {\n const value = part.update(model, handlers, renderers);\n if (part.type === 1) {\n values.push(...(value as Iterable<unknown>));\n } else {\n values.push(value);\n }\n }\n const templateResult: CompiledTemplateResult = {\n _$litType$: litTemplate,\n values,\n };\n return templateResult;\n};\n\ntype TemplatePart = TemplateInstance['_$template']['parts'][0];\n\ntype HeximalTemplatePart = TemplatePart & {\n update: PartUpdater;\n};\n\ntype PartUpdater = (\n model: object,\n handlers: TemplateHandlers,\n blocks: Renderers,\n) => unknown;\n\ninterface HeximalTemplate extends CompiledTemplate {\n parts: Array<HeximalTemplatePart>;\n renderers: Renderers;\n}\n\nconst litTemplateCache = new Map<HTMLTemplateElement, HeximalTemplate>();\n\nexport const getLitTemplate = (\n template: HTMLTemplateElement,\n): HeximalTemplate => {\n let litTemplate = litTemplateCache.get(template);\n if (litTemplate === undefined) {\n litTemplateCache.set(template, (litTemplate = makeLitTemplate(template)));\n }\n return litTemplate;\n};\n\nconst makeLitTemplate = (template: HTMLTemplateElement): HeximalTemplate => {\n const litTemplate: HeximalTemplate = {\n h: undefined as unknown as TemplateStringsArray,\n el: template.cloneNode(true) as HTMLTemplateElement,\n parts: [],\n renderers: {},\n };\n const walker = document.createTreeWalker(\n litTemplate.el!.content,\n NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_TEXT | NodeFilter.SHOW_COMMENT,\n );\n let node: Node | null = walker.currentNode;\n let nodeIndex = -1;\n const elementsToRemove = [];\n\n while ((node = walker.nextNode()) !== null) {\n if (node.nodeType === Node.COMMENT_NODE) {\n nodeIndex++;\n } else if (node.nodeType === Node.ELEMENT_NODE) {\n nodeIndex++;\n const element = node as Element;\n if (element.tagName === 'TEMPLATE') {\n const type = element.getAttribute('type');\n const name = element.getAttribute('name');\n const call = element.getAttribute('call');\n\n if (call !== null || type !== null || name !== null) {\n element.parentNode!.insertBefore(document.createComment(''), element);\n elementsToRemove.push(element);\n let update: PartUpdater;\n\n if (call !== null) {\n // This is a sub-template call, like <template call=\"foo\">\n const templateName = call.trim();\n const templateNameIsExpression =\n templateName.startsWith('{{') && templateName.endsWith('}}');\n\n update = (\n model: object,\n handlers: TemplateHandlers,\n renderers: Renderers,\n ) => {\n const dataAttr = element.getAttribute('data');\n const data =\n dataAttr === null ? undefined : getSingleValue(dataAttr, model);\n\n const renderer = templateNameIsExpression\n ? getSingleValue(templateName, model)\n : renderers[call];\n return renderer?.(data, handlers, renderers);\n };\n } else if (type !== null) {\n // This is a control-flow call, like if/repeat\n update = (\n model: object,\n handlers: TemplateHandlers,\n renderers: Renderers,\n ) => {\n const handler = handlers[type];\n return handler?.(\n element as HTMLTemplateElement,\n model,\n handlers,\n renderers,\n );\n };\n } else {\n // This is a named block\n if (name === 'super') {\n litTemplate.renderers['super'] = (\n model: any,\n handlers: TemplateHandlers,\n renderers: Renderers,\n ) => {\n // Instead of rendering this block, delegate to a passed in\n // 'super' renderer which will actually render the late-bound\n // super template. We pass that renderer the child blocks from\n // this block for block overrides.\n const superRenderer = renderers['super'];\n const superCallTemplate = getLitTemplate(\n element as HTMLTemplateElement,\n );\n renderers = {\n ...renderers,\n ...superCallTemplate.renderers,\n };\n return superRenderer(model, handlers, renderers);\n };\n } else {\n // The renderer renders the contents of the named block\n litTemplate.renderers[name!] = (\n model: any,\n handlers: TemplateHandlers,\n renderers: Renderers,\n ) => {\n return evaluateTemplate(\n element as HTMLTemplateElement,\n model,\n handlers,\n renderers,\n );\n };\n }\n // The updater runs when the template is evaluated and functions as\n // a template _call_. It looks for a named renderer, which might be\n // the renderer function above if the block is not overridden.\n update = (\n model: object,\n handlers: TemplateHandlers,\n renderers: Renderers,\n ) => {\n const renderer = renderers[name!];\n return renderer?.(model, handlers, renderers);\n };\n }\n litTemplate.parts.push({\n type: 2, // text binding\n index: nodeIndex,\n update,\n });\n // Template with call, type, or name attributes are removed from the\n // DOM, so they can't have attribute bindings.\n continue;\n }\n }\n const attributeNames = element.getAttributeNames();\n for (const attributeName of attributeNames) {\n const attributeValue = element.getAttribute(attributeName)!;\n // TODO: use alternative to negative lookbehind\n // (but it's so convenient!)\n const splitValue = attributeValue.split(bindingRegex);\n if (splitValue.length === 1) {\n if (hasEscapedBindingMarkers(attributeValue)) {\n element.setAttribute(\n attributeName,\n unescapeBindingMarkers(attributeValue),\n );\n }\n continue;\n }\n element.removeAttribute(attributeName);\n let name = attributeName;\n let ctor = AttributePart;\n const prefix = attributeName[0];\n if (prefix === '.') {\n name = toCamelCase(attributeName.substring(1));\n ctor = PropertyPart;\n } else if (prefix === '?') {\n name = attributeName.substring(1);\n ctor = BooleanAttributePart;\n } else if (prefix === '@') {\n name = toCamelCase(attributeName.substring(1));\n ctor = EventPart;\n }\n\n const strings = [unescapeBindingMarkers(splitValue[0])];\n const exprs: Array<Expression> = [];\n for (let i = 1; i < splitValue.length; i += 2) {\n const exprText = splitValue[i];\n exprs.push(parse(exprText, astFactory) as Expression);\n strings.push(unescapeBindingMarkers(splitValue[i + 1]));\n }\n\n litTemplate.parts.push({\n type: 1, // attribute binding\n index: nodeIndex,\n name,\n strings,\n ctor,\n update: (\n model: object,\n _handlers: TemplateHandlers,\n _renderers: Renderers,\n ) => {\n return exprs.map((expr) => expr.evaluate(model));\n },\n });\n }\n } else if (node.nodeType === Node.TEXT_NODE) {\n let textNode = node as Text;\n const text = textNode.textContent!;\n const strings = text.split(bindingRegex);\n if (strings.length > 1) {\n textNode.textContent = unescapeBindingMarkers(strings[0]);\n } else if (hasEscapedBindingMarkers(text)) {\n textNode.textContent = unescapeBindingMarkers(text);\n }\n for (let i = 1; i < strings.length; i += 2) {\n const exprText = strings[i];\n const expr = parse(exprText, astFactory) as Expression;\n litTemplate.parts.push({\n type: 2,\n index: ++nodeIndex,\n update: (model: unknown, _handlers: TemplateHandlers) =>\n expr.evaluate(model as Scope),\n });\n const newTextNode = new Text(strings[i + 1].replace('\\\\{{', '{{'));\n textNode.parentNode!.insertBefore(newTextNode, textNode.nextSibling);\n textNode.parentNode!.insertBefore(\n document.createComment(''),\n textNode.nextSibling,\n );\n textNode = newTextNode;\n // This TreeWalker isn't configured to walk comment nodes, but this\n // node will be returned next time through the loop. This is the easiest\n // way to get the walker to proceed to the next successor after the\n // marker, even when the marker doesn't have a nextSibling\n walker.currentNode = newTextNode;\n }\n }\n }\n for (const e of elementsToRemove) {\n e.remove();\n }\n return litTemplate;\n};\n","import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { prepareTemplate } from '@heximal/templates';\nimport { consume } from '@lit/context';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { ComputedContext } from '@qti-components/base';\nimport type { TemplateFunction } from '@heximal/templates';\n\n/**\n * @deprecated test-paging-buttons-stamp is deprecated and will be removed in the future.\n */\n@customElement('test-paging-buttons-stamp')\nexport class TestPagingButtonsStamp extends LitElement {\n @consume({ context: computedContext, subscribe: true })\n private computedContext: ComputedContext;\n\n myTemplate: TemplateFunction;\n #internals: ElementInternals;\n\n protected override createRenderRoot(): HTMLElement | DocumentFragment {\n return this;\n }\n\n constructor() {\n super();\n this.#internals = this.attachInternals();\n this.#internals.ariaLabel = 'pagination';\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n const templateElement = this.querySelector<HTMLTemplateElement>('template');\n this.myTemplate = prepareTemplate(templateElement);\n }\n\n override render() {\n if (!this.computedContext) return html``;\n const items = this.computedContext.testParts.flatMap(testPart =>\n testPart.sections.flatMap(section => section.items)\n );\n\n return html` ${items.map(item => this.myTemplate({ item, view: this.computedContext.view }))} `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-paging-buttons-stamp': TestPagingButtonsStamp;\n }\n}\n","import { LitElement, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { until } from 'lit/directives/until.js';\n\nimport { watch } from '@qti-components/utilities';\nimport { qtiTransformTest } from '@qti-components/transformers';\n\n// eslint-disable-next-line import/no-relative-packages\nimport itemCss from '../../../../qti-theme/src/item.css?inline';\n\n/**\n * `<test-container>` is a custom element designed for hosting the qti-assessment-item.\n * The `qti-assessment-test` will be placed inside the shadow DOM of this element.\n * The element loads the test from the provided URL and renders it inside the shadow DOM.\n *\n * ```html\n * <qti-test>\n * <test-navigation>\n * <test-container class=\"m-4 bg-white\" test-url=\"./path/to/assessmenttest.xml\"></test-container>\n * </test-navigation>\n * </qti-test>\n * ```\n */\n@customElement('test-container')\nexport class TestContainer extends LitElement {\n /** URL of the item to load */\n @property({ type: String, attribute: 'test-url' })\n testURL: string = null;\n\n /** A parsed HTML document */\n @state()\n testDoc: DocumentFragment = null;\n\n /** The raw XML string */\n @state()\n testXML: string = null;\n\n /** Template content if provided */\n #templateContent: unknown = null;\n\n /** Callback function to transform the test after loading */\n // @property({ type: Function }) postLoadTestTransformCallback: PostLoadTestTransformCallback | null = null;\n\n @watch('testURL', { waitUntilFirstUpdate: true })\n protected async handleTestURLChange() {\n if (!this.testURL) return;\n try {\n let api = await qtiTransformTest().load(this.testURL);\n // Apply external transformation if provided\n const qtiTest = this.closest('qti-test') as any; // Type assertion to access mixin properties\n if (qtiTest?.postLoadTestTransformCallback) {\n // Create a temporary document to get the test element reference\n const tempDoc = api.htmlDoc();\n const testElement = tempDoc.querySelector('qti-assessment-test') as any;\n\n if (testElement) {\n // Apply the callback with the test element\n api = await qtiTest.postLoadTestTransformCallback(api, testElement);\n }\n }\n\n this.testDoc = api.htmlDoc();\n } catch (error) {\n console.error('Error loading or parsing XML:', error);\n }\n }\n\n @watch('testXML', { waitUntilFirstUpdate: true })\n protected handleTestXMLChange() {\n if (!this.testXML) return;\n try {\n this.testDoc = qtiTransformTest().parse(this.testXML).htmlDoc();\n } catch (error) {\n console.error('Error parsing XML:', error);\n }\n }\n\n override async connectedCallback(): Promise<void> {\n super.connectedCallback();\n this.#initializeTemplateContent();\n this.#applyStyles();\n if (this.testURL) {\n this.handleTestURLChange();\n }\n if (this.testXML) {\n this.handleTestXMLChange();\n }\n }\n\n #initializeTemplateContent() {\n const template = this.querySelector('template') as HTMLTemplateElement;\n this.#templateContent = template ? template.content : html``;\n }\n\n #applyStyles() {\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(itemCss);\n this.shadowRoot.adoptedStyleSheets = [sheet];\n }\n\n override render() {\n return html`\n ${this.#templateContent}\n <slot></slot>\n ${until(this.testDoc, html`<span>Loading...</span>`)}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-container': TestContainer;\n }\n}\n","import { html, css, LitElement } from 'lit';\nimport { consume } from '@lit/context';\nimport { customElement } from 'lit/decorators.js';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { ResponseVariable } from '@qti-components/base';\nimport type { ComputedContext } from '@qti-components/base';\n\n@customElement('test-print-item-variables')\nexport class TestPrintVariables extends LitElement {\n @consume({ context: computedContext, subscribe: true })\n public computedContext?: ComputedContext;\n\n static override styles = css`\n table {\n width: 100%;\n border-collapse: collapse;\n margin: 20px 0;\n font-size: 14px;\n text-align: left;\n }\n th,\n td {\n border: 1px solid #ddd;\n padding: 8px;\n }\n th {\n background-color: #f4f4f4;\n font-weight: bold;\n }\n h3 {\n margin-top: 20px;\n font-size: 16px;\n }\n `;\n\n override render() {\n const activeItem = this.computedContext?.testParts\n .flatMap(testPart => testPart.sections.flatMap(section => section.items))\n .find(item => item.active);\n\n if (!activeItem || !activeItem.variables) return html``;\n\n const responseVariables: ResponseVariable[] = activeItem.variables.filter(v => v.type === 'response');\n const outcomeVariables = activeItem.variables.filter(v => v.type === 'outcome');\n\n const renderTable = (variables: ResponseVariable[], title: string) => html`\n <h3>${title}</h3>\n <table>\n <thead>\n <tr>\n <th>Identifier</th>\n <th>Value</th>\n <th>Cardinality</th>\n <th>Base Type</th>\n <th>Correct Response / Mappings</th>\n </tr>\n </thead>\n <tbody>\n ${variables.map(v => {\n const correctResponse = v.correctResponse\n ? Array.isArray(v.correctResponse)\n ? v.correctResponse.join(', ')\n : v.correctResponse\n : '';\n\n const mapEntries = v.mapping?.mapEntries?.map(m => `${m.mapKey}=${m.mappedValue}pt`).join(', ') || '';\n\n const areaMapEntries =\n v.areaMapping?.areaMapEntries?.map(m => `${m.shape}(${m.coords})=${m.mappedValue}pt`).join(', ') || '';\n\n return html`\n <tr>\n <td>${v.identifier}</td>\n <td>${Array.isArray(v.value) ? v.value.join(', ') : v.value}</td>\n <td>${v.cardinality}</td>\n <td>${v.baseType}</td>\n <td>${correctResponse || mapEntries || areaMapEntries}</td>\n </tr>\n `;\n })}\n </tbody>\n </table>\n `;\n\n return html`\n ${renderTable(responseVariables, 'Response Variables')} ${renderTable(outcomeVariables, 'Outcome Variables')}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-print-item-variables': TestPrintVariables;\n }\n}\n","import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { prepareTemplate } from '@heximal/templates';\nimport { consume } from '@lit/context';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { ComputedContext } from '@qti-components/base';\nimport type { TemplateFunction } from '@heximal/templates';\n\n/**\n * @deprecated test-section-buttons-stamp is deprecated and will be removed in the future.\n */\n@customElement('test-section-buttons-stamp')\nexport class TestSectionButtonsStamp extends LitElement {\n @consume({ context: computedContext, subscribe: true })\n private computedContext: ComputedContext;\n\n myTemplate: TemplateFunction;\n #internals: ElementInternals;\n\n protected override createRenderRoot(): HTMLElement | DocumentFragment {\n return this;\n }\n\n constructor() {\n super();\n this.#internals = this.attachInternals();\n this.#internals.ariaLabel = 'pagination';\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n const templateElement = this.querySelector<HTMLTemplateElement>('template');\n this.myTemplate = prepareTemplate(templateElement);\n }\n\n override render() {\n if (!this.computedContext) return html``;\n const sections = this.computedContext.testParts.flatMap(testPart => testPart.sections);\n\n return html` ${sections.map(item => this.myTemplate({ item }))} `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-section-buttons-stamp': TestSectionButtonsStamp;\n }\n}\n","import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport * as styles from '../styles';\n\n@customElement('test-section-link')\nexport class TestSectionLink extends LitElement {\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n\n @property({ type: String, attribute: 'section-id' })\n private sectionId: string = null;\n\n #requestItem(identifier: string) {\n this.dispatchEvent(\n new CustomEvent('qti-request-navigation', {\n composed: true,\n bubbles: true,\n detail: {\n type: 'section',\n id: identifier\n }\n })\n );\n }\n\n constructor() {\n super();\n this.addEventListener('click', () => this.#requestItem(this.sectionId));\n }\n\n override render() {\n return html` <slot></slot> `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-section-link': TestSectionLink;\n }\n}\n","import { html, LitElement } from 'lit';\nimport { consume } from '@lit/context';\nimport { customElement, state } from 'lit/decorators.js';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { ComputedContext } from '@qti-components/base';\n\n@customElement('test-print-context')\nexport class TestPrintContext extends LitElement {\n @state()\n @consume({ context: computedContext, subscribe: true })\n public computedContext?: ComputedContext;\n\n override render() {\n return html` <small><pre>${JSON.stringify(this.computedContext, null, 2)}</pre></small> `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-print-context': TestPrintContext;\n }\n}\n","import { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { prepareTemplate } from '@heximal/templates';\nimport { consume } from '@lit/context';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { View } from '@qti-components/base';\nimport type { PropertyValues } from 'lit';\nimport type { ComputedContext } from '@qti-components/base';\nimport type { TemplateFunction } from '@heximal/templates';\n\n/**\n * A custom web component that renders a test stamp using the Lit framework.\n * This component is deprecated and will be removed in the future.\n * @customElement\n * @extends {LitElement}\n */\n@customElement('test-stamp')\nexport class TestStamp extends LitElement {\n /**\n * Indicates whether the component is in debug mode.\n * When set to `true`, the available objects and properties (i.e.: stampContext) is displayed.\n */\n @property({ type: Boolean, reflect: true })\n public debug = false;\n\n @state()\n @consume({ context: computedContext, subscribe: true })\n private computedContext: ComputedContext;\n\n @state()\n private stampContext: {\n view?: View;\n test?: unknown;\n activeTestpart?: unknown;\n activeSection?: unknown;\n activeItem?: unknown;\n } = {\n view: 'candidate',\n activeItem: {},\n activeSection: {\n items: []\n },\n activeTestpart: {\n items: [],\n sections: []\n },\n test: {}\n };\n\n myTemplate: TemplateFunction;\n\n protected override createRenderRoot(): HTMLElement | DocumentFragment {\n return this;\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n const templateElement = this.querySelector<HTMLTemplateElement>('template');\n if (!templateElement) {\n this.myTemplate = null;\n return;\n }\n this.myTemplate = prepareTemplate(templateElement);\n }\n\n protected override willUpdate(_changedProperties: PropertyValues): void {\n if (!this.computedContext) {\n return;\n }\n const activeTestPart = this.computedContext.testParts.find(testPart => testPart.active);\n const activeSection = activeTestPart?.sections.find(section => section.active);\n const activeItem = activeSection?.items.find(item => item.active);\n const { variables, ...augmentedItem } = activeItem || {};\n\n if (!activeTestPart || !activeSection || !activeItem) {\n return;\n }\n\n const augmentedTestPart = {\n ...activeTestPart,\n items: activeTestPart.sections.flatMap(section => section.items.map(({ variables, ...rest }) => rest)),\n sections: activeTestPart.sections.map(section => ({\n ...section,\n items: section.items.map(({ variables, ...rest }) => rest)\n }))\n };\n\n const augmentedSection = { ...activeSection, items: activeSection.items.map(({ variables, ...rest }) => rest) };\n const { testParts, ...activeTest } = this.computedContext;\n\n this.stampContext = {\n view: this.computedContext.view,\n activeItem: augmentedItem,\n activeSection: augmentedSection,\n activeTestpart: augmentedTestPart,\n test: activeTest\n };\n this.dispatchEvent(\n new CustomEvent('qti-stamp-context-updated', {\n detail: this.stampContext,\n bubbles: true\n })\n );\n }\n\n override render() {\n // if (!this.stampContext) return nothing;\n return html` ${this.debug ? html`<small><pre>${JSON.stringify(this.stampContext, null, 2)}</pre></small>` : nothing}\n ${this.myTemplate ? this.myTemplate(this.stampContext) : nothing}`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-stamp': TestStamp;\n }\n}\n","import { html, LitElement, nothing } from 'lit';\nimport { consume } from '@lit/context';\nimport { customElement, property } from 'lit/decorators.js';\nimport { prepareTemplate } from '@heximal/templates';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { TemplateFunction } from '@heximal/templates';\nimport type { OutcomeVariable } from '@qti-components/base';\nimport type { ComputedContext } from '@qti-components/base';\n\n@customElement('test-scoring-buttons')\nexport class TestScoringButtons extends LitElement {\n @property({ type: String, attribute: 'view' }) view = ''; // is only an attribute, but this is here because.. react\n @property({ type: Boolean }) disabled: boolean = false;\n myTemplate: TemplateFunction | null = null;\n\n protected override createRenderRoot(): HTMLElement | DocumentFragment {\n return this;\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n const templateElement = this.querySelector<HTMLTemplateElement>('template');\n if (!templateElement) {\n this.myTemplate = null;\n return;\n }\n this.myTemplate = prepareTemplate(templateElement);\n }\n\n @consume({ context: computedContext, subscribe: true })\n protected computedContext?: ComputedContext;\n\n #changeOutcomeScore(value: number) {\n const testPart = this.computedContext?.testParts.find(testPart => testPart.active);\n const sectionItems = testPart.sections.flatMap(section => section.items);\n const currentItemIdentifier = sectionItems.find(item => item.active)?.identifier;\n\n this.dispatchEvent(\n new CustomEvent('test-update-outcome-variable', {\n detail: {\n assessmentItemRefId: currentItemIdentifier,\n outcomeVariableId: 'SCORE',\n value\n },\n bubbles: true\n })\n );\n }\n\n override render() {\n const activeItem = this.computedContext?.testParts\n .flatMap(testPart => testPart.sections.flatMap(section => section.items))\n .find(item => item.active);\n\n if (!activeItem || !activeItem.variables) return html``;\n\n const maxScore = activeItem.variables.find(vr => vr.identifier == 'MAXSCORE')?.value;\n const scoreOutcome = activeItem.variables.find(vr => vr.identifier == 'SCORE') as OutcomeVariable;\n\n const score = scoreOutcome?.value;\n\n const disabled = !(scoreOutcome?.externalScored === 'human');\n\n if (!maxScore || !scoreOutcome) return nothing;\n const scores = [...Array(Number(maxScore) + 1).keys()];\n\n return html`${this.myTemplate ? this.myTemplate({ scores, score, disabled }) : nothing}`;\n }\n\n constructor() {\n super();\n this.addEventListener('click', e => {\n const target = e.target as HTMLInputElement;\n const value = parseFloat(target.value);\n if (target.tagName === 'INPUT') {\n this.#changeOutcomeScore(value);\n }\n });\n\n // return maxScore\n // ? html`\n // <form part=\"form\">\n // ${[...Array(Number(maxScore) + 1).keys()].map(itemIndex => {\n // const identifier = `scoring-buttons${itemIndex}${activeItem.identifier}`;\n // return html` <input\n // part=\"input\"\n // type=\"radio\"\n // ?disabled=${this.disabled}\n // .checked=${itemIndex === Number(score)}\n // @change=${() => this._changeOutcomeScore(itemIndex)}\n // id=${identifier}\n // name=${`scoring-buttons-${activeItem.identifier}`}\n // value=${itemIndex}\n // />\n\n // <label part=\"label\" for=${identifier}>${itemIndex}</label>`;\n // })}\n // </form>\n // <slot></slot>\n // `\n // : nothing;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-scoring-buttons': TestScoringButtons;\n }\n}\n","import { consume } from '@lit/context';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { prepareTemplate } from '@heximal/templates';\n\nimport { sessionContext } from '@qti-components/base';\n\nimport type { PropertyValues } from 'lit';\nimport type { SessionContext } from '@qti-components/base';\n\n@customElement('test-view-toggle')\nexport class TestViewToggle extends LitElement {\n myTemplate: any;\n\n protected override createRenderRoot(): HTMLElement | DocumentFragment {\n return this;\n }\n\n @consume({ context: sessionContext, subscribe: true })\n private sessionContext: SessionContext;\n\n override connectedCallback(): void {\n super.connectedCallback();\n const templateElement = this.querySelector<HTMLTemplateElement>('template');\n if (!templateElement) {\n this.myTemplate = null;\n return;\n }\n this.myTemplate = prepareTemplate(templateElement);\n }\n\n _switchView(view: string) {\n this.dispatchEvent(\n new CustomEvent('on-test-switch-view', {\n composed: true,\n bubbles: true,\n detail: view\n })\n );\n }\n\n protected override firstUpdated(_changedProperties: PropertyValues): void {\n this.addEventListener('click', () => {\n if (this.sessionContext?.view === 'scorer') {\n this._switchView('candidate');\n } else {\n this._switchView('scorer');\n }\n });\n }\n\n override render() {\n return html`${this.myTemplate\n ? this.myTemplate({\n view: this.sessionContext?.view\n })\n : nothing}`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-view-toggle': TestViewToggle;\n }\n}\n","import { consume } from '@lit/context';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { computedContext } from '@qti-components/base';\n\nimport type { View } from '@qti-components/base';\nimport type { OutcomeVariable } from '@qti-components/base';\nimport type { ComputedContext } from '@qti-components/base';\n\n@customElement('test-scoring-feedback')\nexport class TestScoringFeedback extends LitElement {\n @consume({ context: computedContext, subscribe: true })\n protected computedContext?: ComputedContext;\n\n @property({ type: String, attribute: 'view' })\n public view: View = null;\n\n override render() {\n const activeItem = this.computedContext?.testParts\n .flatMap(testPart => testPart.sections.flatMap(section => section.items))\n .find(item => item.active);\n\n if (!activeItem || !activeItem.variables) return html``;\n\n if ((activeItem as any)['category'] === 'dep-informational') return html`<div>${this.dataset.informational}</div>`;\n\n const completionStatus = activeItem?.variables.find(v => v.identifier === 'completionStatus')?.value;\n const scoreOutcome = activeItem?.variables.find(vr => vr.identifier == 'SCORE') as OutcomeVariable;\n\n const score = parseFloat(scoreOutcome?.value as string);\n const externalScored = (activeItem as any)['externalScored'];\n\n const feedbackText = () => {\n if (completionStatus !== 'completed') {\n return this.dataset.textNoResponse;\n }\n\n if (!externalScored && score !== undefined && !Number.isNaN(score)) {\n return score > 0 ? this.dataset.textCorrect : this.dataset.textIncorrect;\n }\n\n if (externalScored === 'externalMachine') {\n return Number.isNaN(score) || score === undefined\n ? this.dataset.scoreUnknown\n : `We hebben je antwoord ${score === 0 ? 'geen punten' : score == 1 ? 'één punt' : `${score} punten`} gegeven. Je kunt je score zelf aanpassen als je denkt dat dat niet klopt.`;\n }\n\n if (externalScored === 'human') {\n return Number.isNaN(score) ? '' : 'Deze score heb je zelf toegekend.';\n }\n\n return this.dataset.inProgress;\n };\n\n return html`<div>${feedbackText()}</div>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-scoring-feedback': TestScoringFeedback;\n }\n}\n","import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport * as styles from '../styles';\n\nimport type { QtiTest } from '../qti-test/qti-test';\nimport type { TestContainer } from '../test-container/test-container';\n\n@customElement('test-check-item')\nexport class TestCheckItem extends LitElement {\n static override styles = css`\n :host {\n ${styles.btn};\n }\n :host([disabled]) {\n ${styles.dis};\n }\n `;\n\n constructor() {\n super();\n this.addEventListener('click', () => {\n this.dispatchEvent(new CustomEvent('test-end-attempt', { bubbles: true }));\n this.dispatchEvent(\n new CustomEvent('test-show-correct-response', {\n detail: true,\n bubbles: true\n })\n );\n const qtiTest = this.closest<QtiTest>('qti-test');\n const testContainer = qtiTest.querySelector<TestContainer>('test-container');\n\n const viewElements = Array.from(testContainer.shadowRoot.querySelectorAll('[view]'));\n\n viewElements.forEach((element: HTMLElement) => {\n element.classList.toggle('show', true);\n });\n });\n }\n\n override render() {\n return html` <slot></slot> `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-check-item': TestCheckItem;\n }\n}\n"],"mappings":"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","names":["e","i","e","i","v","e","e","v","i","i","stringToBooleanConverter","i","i","_title","i","i","v","r","i","e","testPart","i","e","testPart","i","e","v","i","i","i","v","global","globalThis","trustedTypes","policy","createPolicy","createHTML","s","boundAttributeSuffix","marker","Math","random","toFixed","slice","markerMatch","nodeMarker","d","document","createTreeWalker","createMarker","createComment","isPrimitive","value","isArray","Array","isIterable","Symbol","iterator","SPACE_CHAR","textEndRegex","commentEndRegex","comment2EndRegex","tagEndRegex","RegExp","singleQuoteAttrEndRegex","doubleQuoteAttrEndRegex","rawTextElement","tag","type","strings","values","_$litType$","html","svg","mathml","noChange","for","nothing","templateCache","WeakMap","walker","trustFromTemplateString","tsa","stringFromTSA","hasOwnProperty","Error","getTemplateHtml","l","length","attrNames","rawTextEndRegex","regex","i","attrName","match","attrNameEndIndex","lastIndex","exec","test","end","startsWith","push","Template","constructor","options","node","this","parts","nodeIndex","attrNameIndex","partCount","el","createElement","currentNode","content","wrapper","firstChild","replaceWith","childNodes","nextNode","nodeType","hasAttributes","name","getAttributeNames","endsWith","realName","statics","getAttribute","split","m","index","ctor","PropertyPart","BooleanAttributePart","EventPart","AttributePart","removeAttribute","tagName","textContent","emptyScript","append","data","indexOf","_options","innerHTML","resolveDirective","part","parent","attributeIndex","currentDirective","__directives","__directive","nextDirectiveConstructor","_$initialize","_$resolve","TemplateInstance","template","_$parts","_$disconnectableChildren","_$template","_$parent","parentNode","_$isConnected","fragment","creationScope","importNode","partIndex","templatePart","ChildPart","nextSibling","ElementPart","_$setValue","__isConnected","startNode","endNode","_$committedValue","_$startNode","_$endNode","isConnected","directiveParent","_$clear","_commitText","_commitTemplateResult","_commitNode","_commitIterable","insertBefore","_insert","createTextNode","result","_$getTemplate","h","_update","instance","_clone","get","set","itemParts","itemPart","item","start","from","_$notifyConnectionChanged","n","remove","element","fill","String","valueIndex","noCommit","change","v","_commitValue","setAttribute","toggleAttribute","super","newListener","oldListener","shouldRemoveListener","capture","once","passive","shouldAddListener","removeEventListener","addEventListener","event","call","host","handleEvent","_$LH","_boundAttributeSuffix","_marker","_markerMatch","_HTML_RESULT","_getTemplateHtml","_TemplateInstance","_isIterable","_resolveDirective","_ChildPart","_AttributePart","_BooleanAttributePart","_EventPart","_PropertyPart","_ElementPart","polyfillSupport","litHtmlPolyfillSupport","litHtmlVersions","Kind","v","t","astFactory","t","e","a","b","f","v","l","r","g","n","receiver","args","e","c","t","i","params","body","p","resolveMethodName","_$LH","boundAttributeSuffix","p","_boundAttributeSuffix","marker","_marker","markerMatch","_markerMatch","HTML_RESULT","_HTML_RESULT","getTemplateHtml","_getTemplateHtml","overrideDirectiveResolve","directiveClass","resolveOverrideFn","_part","values","this","patchDirectiveResolve","prototype","_$resolve","name","proto","Object","getPrototypeOf","hasOwnProperty","Error","value","getAttributePartCommittedValue","part","index","committedValue","noChange","_commitValue","_$setValue","connectedDisconnectable","props","_$isConnected","resolveDirective","_resolveDirective","AttributePart","_AttributePart","PropertyPart","_PropertyPart","BooleanAttributePart","_BooleanAttributePart","EventPart","_EventPart","ElementPart","_ElementPart","TemplateInstance","_TemplateInstance","isIterable","_isIterable","ChildPart","_ChildPart","i","s","_","handlers","renderers","model","i","e","_internals","i","i","i","v","m","_internals","i","i","i","i","variables","i","e","testPart","i","i","v","i"]}
|