This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | // Promise.withResolvers polyfill for Node.js 20 | |
| /* eslint-disable */ | |
| Promise.withResolvers || | |
| // @ts-expect-error | |
| (Promise.withResolvers = function withResolvers() { | |
| var a, | |
| b, | |
| c = new this(function (resolve, reject) { | |
| a = resolve; | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | /** | |
| * Typed Web Worker. | |
| * | |
| * type InputData = { name: string }; | |
| * type OutputData = { nameLength: number } | |
| * | |
| * // main.js | |
| * const worker = createTypedWorker<InputData, OutputData>(worker); | |
| * | |
| * // worker.js | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | import { pipe } from 'fp-ts/function'; | |
| import { lens } from 'monocle-ts'; | |
| import { memo, useLayoutEffect, useRef, useState } from 'react'; | |
| import { LayoutChangeEvent, Text, View } from 'react-native'; | |
| import { useTheme } from '../contexts/ThemeContext'; | |
| const isOverflown = ({ | |
| clientWidth, | |
| clientHeight, | |
| scrollWidth, | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | import { ColorSchemeName, Platform, StyleSheet, ViewStyle } from 'react-native'; | |
| // AFAIK, Android has a problem with negative margins. | |
| type RhythmSize = 'XXS' | 'XS' | 'Sm' | '' | 'Lg' | 'XL' | 'XXL'; | |
| type RhythmProp = | |
| | `${ | |
| | 'm' | |
| | 'p' | |
| | `${'m' | 'p'}${'l' | 'r' | 't' | 'b' | 'v' | 'h'}`}${RhythmSize}` | |
| | `${'w' | 'h' | `${'max' | 'min'}${'W' | 'H'}`}${RhythmSize}` | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | import Link, { LinkProps } from 'next/link'; | |
| import React, { | |
| forwardRef, | |
| ReactNode, | |
| useCallback, | |
| useMemo, | |
| useState, | |
| } from 'react'; | |
| import { | |
| StyleSheet, | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | import Link from 'next/link'; | |
| import React, { | |
| forwardRef, | |
| ReactNode, | |
| useCallback, | |
| useMemo, | |
| useState, | |
| } from 'react'; | |
| import { | |
| StyleSheet, | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | import { either } from 'fp-ts'; | |
| import { constVoid } from 'fp-ts/lib/function'; | |
| import { pipe } from 'fp-ts/lib/pipeable'; | |
| import * as t from 'io-ts'; | |
| import { useCallback } from 'react'; | |
| import { Api } from '../types'; | |
| import { useApi } from './useApi'; | |
| import { Form, useForm } from './useForm'; | |
| export const useMutation = < | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | import * as E from 'fp-ts/lib/Either'; | |
| import { absurd, constVoid } from 'fp-ts/lib/function'; | |
| import { pipe } from 'fp-ts/lib/pipeable'; | |
| import * as TE from 'fp-ts/lib/TaskEither'; | |
| import * as t from 'io-ts'; | |
| import { useCallback } from 'react'; | |
| import { Api, ApiError, FetchError } from '../types'; | |
| import { Form, useForm } from './useForm'; | |
| // Basically, every HTTP request is a mutation. | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | // Draft uses YuzuJS/setImmediate polyfill, which can be reduced to this code. | |
| // But it seems request requestAnimationFrame is good enough. | |
| // TODO: Will it work with queue fix? | |
| // // https://github.com/google/closure-library/blob/master/closure/goog/async/nexttick.js#L209 | |
| const setImmediate = (() => { | |
| const channel = new MessageChannel(); | |
| let head: any = {}; | |
| let tail = head; | |
| channel.port1.onmessage = () => { | |
| if (head.next !== undefined) { | 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | // https://github.com/facebook/fbjs/blob/master/packages/fbjs/src/core/resolveImmediate.js | |
| const resolvedPromise = Promise.resolve(); | |
| function throwNext(error: any) { | |
| setTimeout(() => { | |
| throw error; | |
| }, 0); | |
| } | 
NewerOlder