diff --git a/docs/assets/search.js b/docs/assets/search.js index 41af0bc0..7813593d 100644 --- a/docs/assets/search.js +++ b/docs/assets/search.js @@ -1 +1 @@ -window.searchData = "data:application/octet-stream;base64,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"; \ No newline at end of file +window.searchData = "data:application/octet-stream;base64,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"; \ No newline at end of file diff --git a/docs/classes/BoardState.html b/docs/classes/BoardState.html index a226a108..45e5026f 100644 --- a/docs/classes/BoardState.html +++ b/docs/classes/BoardState.html @@ -1,4 +1,4 @@ -BoardState | goban

Class BoardState

Hierarchy (view full)

Implements

Constructors

constructor +BoardState | goban

Class BoardState

Hierarchy (view full)

Implements

Constructors

Properties

black_prisoners board board_is_repeating @@ -25,23 +25,23 @@ default to 19x19 if no board is provided.

Any state matrices (board, removal, etc..) provided will be cloned and must have the same dimensionality.

-

Parameters

Returns BoardState

Properties

black_prisoners: number
board_is_repeating: boolean
goban_callback?: GobanBase
height: number = 19
removal: boolean[][]
white_prisoners: number
width: number = 19

Methods

  • Returns true if the .board field from the other board is equal to this one

    -

    Parameters

    Returns boolean

Properties

black_prisoners: number
board_is_repeating: boolean
goban_callback?: GobanBase
height: number = 19
removal: boolean[][]
white_prisoners: number
width: number = 19

Methods

  • Returns true if the .board field from the other board is equal to this one

    +

    Parameters

    Returns boolean

  • Computes scoring locations for the board. If area_scoring is true, we will use area scoring rules, otherwise we will use territory scoring rules (which implies omitting territory in seki).

    -

    Parameters

    • area_scoring: boolean

    Returns ScoringLocations

  • Sets a position as being removed or not removed. If emit_stone_removal_updated is set to false, the "stone-removal.updated" event will not be emitted, and it is up to the caller to emit this event appropriately.

    -

    Parameters

    • x: number
    • y: number
    • removed: boolean
    • emit_stone_removal_updated: boolean = true

    Returns void

  • Toggles a group of stones for removal or restoration.

    +

    Parameters

    • x: number
    • y: number
    • removed: boolean
    • emit_stone_removal_updated: boolean = true

    Returns void

  • Toggles a group of stones for removal or restoration.

    By default, if we are marking a group for removal but the group is almost certainly alive (two eyes, etc), this will result in a no-op, unless force_removal is set to true.

    -

    Parameters

    • x: number
    • y: number
    • force_removal: boolean = false

    Returns {
        group: RawStoneString;
        removed: boolean;
    }

\ No newline at end of file +

Parameters

  • x: number
  • y: number
  • force_removal: boolean = false

Returns {
    group: RawStoneString;
    removed: boolean;
}

\ No newline at end of file diff --git a/docs/classes/ConditionalMoveTree.html b/docs/classes/ConditionalMoveTree.html index 106527a3..5be10424 100644 --- a/docs/classes/ConditionalMoveTree.html +++ b/docs/classes/ConditionalMoveTree.html @@ -1,4 +1,4 @@ -ConditionalMoveTree | goban

Class ConditionalMoveTree

Constructors

constructor +ConditionalMoveTree | goban

Class ConditionalMoveTree

Constructors

Properties

Constructors

Properties

children: {
    [move: string]: ConditionalMoveTree;
}

Type declaration

move: null | string

Methods

\ No newline at end of file +

Constructors

Properties

children: {
    [move: string]: ConditionalMoveTree;
}

Type declaration

move: null | string

Methods

\ No newline at end of file diff --git a/docs/classes/Goban.html b/docs/classes/Goban.html index 30e5be44..ba4fe9a4 100644 --- a/docs/classes/Goban.html +++ b/docs/classes/Goban.html @@ -2,7 +2,7 @@ classes, types, and enums.

You can't create an instance of a Goban directly, you have to create an instance of one of the renderers, such as GobanSVG.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

__board_redraw_pen_layer_timer: any = null
__clock_timer?: Timeout
__draw_state: string[][]
__last_pt: {
    i: number;
    j: number;
    valid: boolean;
} = ...

Type declaration

  • i: number
  • j: number
  • valid: boolean
__update_move_tree: any = null
analysis_move_counter: number
analysis_removal_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
analysis_removal_state?: boolean
analysis_scoring_color?: string
analysis_scoring_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
bounded_height: number
bounded_width: number
bounds: GobanBounds
chat_log: GobanChatLog = []
circle_radius: number
clock_should_be_paused_for_move_submission: boolean = false
colored_circles?: (undefined | ColoredCircle)[][]
conditional_path: string = ""
conditional_starting_color: "black" | "white" | "invalid" = "invalid"
conditional_tree: ConditionalMoveTree = ...
config: GobanConfig
connectToReviewSent?: boolean
current_cmove?: ConditionalMoveTree
currently_my_cmove: boolean = false
dirty_redraw: any = null
disconnectedFromGame: boolean = true
display_width?: number
done_loading_review: boolean = false
dont_draw_last_move: boolean
double_click_submit: boolean
draw_bottom_labels: boolean
draw_left_labels: boolean
draw_right_labels: boolean
draw_top_labels: boolean
edit_color?: "black" | "white"
engine: GobanEngine
errorHandler: ((e) => void)

Type declaration

    • (e): void
    • Parameters

      • e: Error

      Returns void

game_id: number
game_type: string
getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
goban_id: number = ++last_goban_id

Base fields *

-
heatmap?: NumberMatrix
height: number
highlight_movetree_moves: boolean
interactive: boolean
isInPushedAnalysis: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerController: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerOwner: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

label_character: string
label_mark: string = "[UNSET]"
last_clock?: AdHocClock
last_emitted_clock?: JGOFClockWithTransmitting
last_hover_square?: JGOFIntersection
last_move?: MoveTree
last_move_radius: number
last_paused_by_player_state: null | boolean = null
last_paused_state: null | boolean = null
last_phase?: GobanEnginePhase
last_review_message: ReviewMessage
last_sound_played_for_a_stone_placement?: string
last_stone_sound: number
leavePushedAnalysis: (() => void)

Type declaration

    • (): void
    • Returns void

marked_analysis_score?: boolean[][]
move_selected?: JGOFIntersection
no_display: boolean
onError?: ((error) => void)

Type declaration

    • (error): void
    • Parameters

      • error: Error

      Returns void

on_game_screen: boolean
one_click_submit: boolean
original_square_size: number | ((goban) => number) | "auto"

Type declaration

    • (goban): number
    • Parameters

      Returns number

parent: HTMLElement
pause_control?: AdHocPauseControl
paused_since?: number
pen_marks: any[]
player_id: number
preloaded_data?: GobanConfig
previous_mode: string
puzzle_autoplace_delay: number
restrict_moves_to_movetree: boolean
review_had_gamedata: boolean
review_id: number
scoring_mode: boolean | "stalling-scoring-mode"
sendLatencyTimer?: Timeout
sent_timed_out_message: boolean = false
shift_key_is_down: boolean
show_move_numbers: boolean
show_variation_move_numbers: boolean
showing_scores: boolean = false
socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
square_size: number = 10
stalling_score_estimate?: StallingScoreEstimate
stone_placement_enabled: boolean
stone_removal_auto_scoring_done?: boolean = false
variation_stone_opacity: number
visual_undo_request_indicator: boolean
width: number
THEMES: ThemesInterface = THEMES
THEMES_SORTED: {
    black: GobanTheme[];
    board: GobanTheme[];
    white: GobanTheme[];
    [key: string]: GobanTheme[];
} = THEMES_SORTED

Type declaration

setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any +

Constructors

Properties

__board_redraw_pen_layer_timer: any = null
__clock_timer?: Timeout
__draw_state: string[][]
__last_pt: {
    i: number;
    j: number;
    valid: boolean;
} = ...

Type declaration

  • i: number
  • j: number
  • valid: boolean
__update_move_tree: any = null
analysis_move_counter: number
analysis_removal_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
analysis_removal_state?: boolean
analysis_scoring_color?: string
analysis_scoring_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
bounded_height: number
bounded_width: number
bounds: GobanBounds
chat_log: GobanChatLog = []
circle_radius: number
clock_should_be_paused_for_move_submission: boolean = false
colored_circles?: (undefined | ColoredCircle)[][]
conditional_path: string = ""
conditional_starting_color: "black" | "white" | "invalid" = "invalid"
conditional_tree: ConditionalMoveTree = ...
config: GobanConfig
connectToReviewSent?: boolean
current_cmove?: ConditionalMoveTree
currently_my_cmove: boolean = false
dirty_redraw: any = null
disconnectedFromGame: boolean = true
display_width?: number
done_loading_review: boolean = false
dont_draw_last_move: boolean
double_click_submit: boolean
draw_bottom_labels: boolean
draw_left_labels: boolean
draw_right_labels: boolean
draw_top_labels: boolean
edit_color?: "black" | "white"
engine: GobanEngine
errorHandler: ((e) => void)

Type declaration

    • (e): void
    • Parameters

      • e: Error

      Returns void

game_id: number
game_type: string
getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
goban_id: number = ++last_goban_id

Base fields *

+
heatmap?: NumberMatrix
height: number
highlight_movetree_moves: boolean
interactive: boolean
isInPushedAnalysis: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerController: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerOwner: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

label_character: string
label_mark: string = "[UNSET]"
last_clock?: AdHocClock
last_emitted_clock?: JGOFClockWithTransmitting
last_hover_square?: JGOFIntersection
last_move?: MoveTree
last_move_radius: number
last_paused_by_player_state: null | boolean = null
last_paused_state: null | boolean = null
last_phase?: GobanEnginePhase
last_review_message: ReviewMessage
last_sound_played_for_a_stone_placement?: string
last_stone_sound: number
leavePushedAnalysis: (() => void)

Type declaration

    • (): void
    • Returns void

marked_analysis_score?: boolean[][]
move_selected?: JGOFIntersection
no_display: boolean
onError?: ((error) => void)

Type declaration

    • (error): void
    • Parameters

      • error: Error

      Returns void

on_game_screen: boolean
one_click_submit: boolean
original_square_size: number | ((goban) => number) | "auto"

Type declaration

    • (goban): number
    • Parameters

      Returns number

parent: HTMLElement
pause_control?: AdHocPauseControl
paused_since?: number
pen_marks: any[]
player_id: number
preloaded_data?: GobanConfig
previous_mode: string
puzzle_autoplace_delay: number
restrict_moves_to_movetree: boolean
review_had_gamedata: boolean
review_id: number
scoring_mode: boolean | "stalling-scoring-mode"
sendLatencyTimer?: Timeout
sent_timed_out_message: boolean = false
shift_key_is_down: boolean
show_move_numbers: boolean
show_variation_move_numbers: boolean
showing_scores: boolean = false
socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
square_size: number = 10
stalling_score_estimate?: StallingScoreEstimate
stone_placement_enabled: boolean
stone_removal_auto_scoring_done?: boolean = false
variation_stone_opacity: number
visual_undo_request_indicator: boolean
width: number
THEMES: ThemesInterface = THEMES
THEMES_SORTED: {
    black: GobanTheme[];
    board: GobanTheme[];
    white: GobanTheme[];
    [key: string]: GobanTheme[];
} = THEMES_SORTED

Type declaration

setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

      -

      Parameters

      Returns void

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

Methods

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

Methods

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/docs/classes/GobanBase.html b/docs/classes/GobanBase.html index 3d6bc769..7ff681e5 100644 --- a/docs/classes/GobanBase.html +++ b/docs/classes/GobanBase.html @@ -2,7 +2,7 @@ classes, types, and enums.

You can't create an instance of a Goban directly, you have to create an instance of one of the renderers, such as GobanSVG.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

Constructors

Properties

_destroyed: boolean = false
engine: GobanEngine
goban_id: number = ++last_goban_id

Base fields *

-
setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any +

Constructors

Properties

_destroyed: boolean = false
engine: GobanEngine
goban_id: number = ++last_goban_id

Base fields *

+
setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

      -

      Parameters

      Returns void

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

Methods

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

Methods

\ No newline at end of file +

Parameters

Returns JGOFMove

\ No newline at end of file diff --git a/docs/classes/GobanCanvas.html b/docs/classes/GobanCanvas.html index 2fffc660..f5eaa2ea 100644 --- a/docs/classes/GobanCanvas.html +++ b/docs/classes/GobanCanvas.html @@ -2,7 +2,7 @@ classes, types, and enums.

You can't create an instance of a Goban directly, you have to create an instance of one of the renderers, such as GobanSVG.

-

Hierarchy (view full)

Implements

Constructors

Hierarchy (view full)

Implements

Constructors

Properties

__board_redraw_pen_layer_timer: any = null
__borders_initialized: boolean = false
__clock_timer?: Timeout
__draw_state: string[][]
__last_pt: {
    i: number;
    j: number;
    valid: boolean;
} = ...

Type declaration

  • i: number
  • j: number
  • valid: boolean
__set_board_height: number = -1
__set_board_width: number = -1
__update_move_tree: any = null
analysis_move_counter: number
analysis_removal_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
analysis_removal_state?: boolean
autoplaying_puzzle_move: boolean = false
board: HTMLCanvasElement
bounded_height: number
bounded_width: number
bounds: GobanBounds
byoyomi_label: string = ""
chat_log: GobanChatLog = []
circle_radius: number
clock_should_be_paused_for_move_submission: boolean = false
colored_circles?: (undefined | ColoredCircle)[][]
conditional_path: string = ""
conditional_starting_color: "black" | "white" | "invalid" = "invalid"
conditional_tree: ConditionalMoveTree = ...
config: GobanConfig
connectToReviewSent?: boolean
ctx: CanvasRenderingContext2D
current_cmove?: ConditionalMoveTree
current_pen_mark?: {
    color: string;
    points: [number, number];
}

Type declaration

  • color: string
  • points: [number, number]
currently_my_cmove: boolean = false
dirty_redraw: any = null
disconnectedFromGame: boolean = true
display_width?: number
done_loading_review: boolean = false
dont_draw_last_move: boolean
double_click_submit: boolean
draw_bottom_labels: boolean
draw_left_labels: boolean
draw_right_labels: boolean
draw_top_labels: boolean
drawing_enabled: boolean = true
edit_color?: "black" | "white"
engine: GobanEngine
errorHandler: ((e) => void)

Type declaration

    • (e): void
    • Parameters

      • e: Error

      Returns void

game_id: number
game_type: string
getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
goban_id: number = ++last_goban_id

Base fields *

-
handleShiftKey: ((ev) => void)

Type declaration

    • (ev): void
    • Parameters

      • ev: KeyboardEvent

      Returns void

heatmap?: NumberMatrix
height: number
highlight_movetree_moves: boolean
interactive: boolean
isInPushedAnalysis: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerController: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerOwner: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

label_character: string
label_mark: string = "[UNSET]"
labeling_mode?: "put" | "clear"
last_clock?: AdHocClock
last_emitted_clock?: JGOFClockWithTransmitting
last_hover_square?: JGOFIntersection
last_label_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
last_move?: MoveTree
last_move_opacity: number = 1
last_move_radius: number
last_paused_by_player_state: null | boolean = null
last_paused_state: null | boolean = null
last_pen_position?: [number, number]
last_phase?: GobanEnginePhase
last_review_message: ReviewMessage
last_sound_played_for_a_stone_placement?: string
last_stone_sound: number
leavePushedAnalysis: (() => void)

Type declaration

    • (): void
    • Returns void

marked_analysis_score?: boolean[][]
message_div?: HTMLDivElement
message_td?: HTMLElement
message_text?: HTMLDivElement
message_timeout?: number
metrics: GobanMetrics = ...
move_selected?: JGOFIntersection
move_tree_canvas?: HTMLCanvasElement
move_tree_container?: HTMLElement
move_tree_inner_container?: HTMLDivElement
no_display: boolean
onError?: ((error) => void)

Type declaration

    • (error): void
    • Parameters

      • error: Error

      Returns void

on_game_screen: boolean
one_click_submit: boolean
original_square_size: number | ((goban) => number) | "auto"

Type declaration

    • (goban): number
    • Parameters

      Returns number

parent: HTMLElement
pause_control?: AdHocPauseControl
paused_since?: number
pen_ctx?: CanvasRenderingContext2D
pen_layer?: HTMLCanvasElement
pen_marks: any[]
player_id: number
preloaded_data?: GobanConfig
previous_mode: string
puzzle_autoplace_delay: number
ready_to_draw: boolean = false
restrict_moves_to_movetree: boolean
review_had_gamedata: boolean
review_id: number
scoring_mode: boolean | "stalling-scoring-mode"
sendLatencyTimer?: Timeout
sent_timed_out_message: boolean = false
shadow_ctx?: CanvasRenderingContext2D
shadow_layer?: HTMLCanvasElement
shift_key_is_down: boolean
show_move_numbers: boolean
show_variation_move_numbers: boolean
showing_scores: boolean = false
socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
square_size: number = 10
stalling_score_estimate?: StallingScoreEstimate
stone_placement_enabled: boolean
stone_removal_auto_scoring_done?: boolean = false
theme_black: GobanTheme
theme_black_stones: any[] = []
theme_black_text_color: string = HOT_PINK
theme_blank_text_color: string = HOT_PINK
theme_board: GobanTheme
theme_faded_line_color: string = HOT_PINK
theme_faded_star_color: string = HOT_PINK
theme_line_color: string = ""
theme_star_color: string = ""
theme_stone_radius: number = 10
theme_white: GobanTheme
theme_white_stones: any[] = []
theme_white_text_color: string = HOT_PINK
themes: GobanSelectedThemes = ...
title_div?: HTMLElement
variation_stone_opacity: number
visual_undo_request_indicator: boolean
width: number
THEMES: ThemesInterface = THEMES
THEMES_SORTED: {
    black: GobanTheme[];
    board: GobanTheme[];
    white: GobanTheme[];
    [key: string]: GobanTheme[];
} = THEMES_SORTED

Type declaration

setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any +

Constructors

Properties

__board_redraw_pen_layer_timer: any = null
__borders_initialized: boolean = false
__clock_timer?: Timeout
__draw_state: string[][]
__last_pt: {
    i: number;
    j: number;
    valid: boolean;
} = ...

Type declaration

  • i: number
  • j: number
  • valid: boolean
__set_board_height: number = -1
__set_board_width: number = -1
__update_move_tree: any = null
analysis_move_counter: number
analysis_removal_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
analysis_removal_state?: boolean
autoplaying_puzzle_move: boolean = false
board: HTMLCanvasElement
bounded_height: number
bounded_width: number
bounds: GobanBounds
byoyomi_label: string = ""
chat_log: GobanChatLog = []
circle_radius: number
clock_should_be_paused_for_move_submission: boolean = false
colored_circles?: (undefined | ColoredCircle)[][]
conditional_path: string = ""
conditional_starting_color: "black" | "white" | "invalid" = "invalid"
conditional_tree: ConditionalMoveTree = ...
config: GobanConfig
connectToReviewSent?: boolean
ctx: CanvasRenderingContext2D
current_cmove?: ConditionalMoveTree
current_pen_mark?: {
    color: string;
    points: [number, number];
}

Type declaration

  • color: string
  • points: [number, number]
currently_my_cmove: boolean = false
dirty_redraw: any = null
disconnectedFromGame: boolean = true
display_width?: number
done_loading_review: boolean = false
dont_draw_last_move: boolean
double_click_submit: boolean
draw_bottom_labels: boolean
draw_left_labels: boolean
draw_right_labels: boolean
draw_top_labels: boolean
drawing_enabled: boolean = true
edit_color?: "black" | "white"
engine: GobanEngine
errorHandler: ((e) => void)

Type declaration

    • (e): void
    • Parameters

      • e: Error

      Returns void

game_id: number
game_type: string
getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
goban_id: number = ++last_goban_id

Base fields *

+
handleShiftKey: ((ev) => void)

Type declaration

    • (ev): void
    • Parameters

      • ev: KeyboardEvent

      Returns void

heatmap?: NumberMatrix
height: number
highlight_movetree_moves: boolean
interactive: boolean
isInPushedAnalysis: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerController: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerOwner: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

label_character: string
label_mark: string = "[UNSET]"
labeling_mode?: "put" | "clear"
last_clock?: AdHocClock
last_emitted_clock?: JGOFClockWithTransmitting
last_hover_square?: JGOFIntersection
last_label_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
last_move?: MoveTree
last_move_opacity: number = 1
last_move_radius: number
last_paused_by_player_state: null | boolean = null
last_paused_state: null | boolean = null
last_pen_position?: [number, number]
last_phase?: GobanEnginePhase
last_review_message: ReviewMessage
last_sound_played_for_a_stone_placement?: string
last_stone_sound: number
leavePushedAnalysis: (() => void)

Type declaration

    • (): void
    • Returns void

marked_analysis_score?: boolean[][]
message_div?: HTMLDivElement
message_td?: HTMLElement
message_text?: HTMLDivElement
message_timeout?: number
metrics: GobanMetrics = ...
move_selected?: JGOFIntersection
move_tree_canvas?: HTMLCanvasElement
move_tree_container?: HTMLElement
move_tree_inner_container?: HTMLDivElement
no_display: boolean
onError?: ((error) => void)

Type declaration

    • (error): void
    • Parameters

      • error: Error

      Returns void

on_game_screen: boolean
one_click_submit: boolean
original_square_size: number | ((goban) => number) | "auto"

Type declaration

    • (goban): number
    • Parameters

      Returns number

parent: HTMLElement
pause_control?: AdHocPauseControl
paused_since?: number
pen_ctx?: CanvasRenderingContext2D
pen_layer?: HTMLCanvasElement
pen_marks: any[]
player_id: number
preloaded_data?: GobanConfig
previous_mode: string
puzzle_autoplace_delay: number
ready_to_draw: boolean = false
restrict_moves_to_movetree: boolean
review_had_gamedata: boolean
review_id: number
scoring_mode: boolean | "stalling-scoring-mode"
sendLatencyTimer?: Timeout
sent_timed_out_message: boolean = false
shadow_ctx?: CanvasRenderingContext2D
shadow_layer?: HTMLCanvasElement
shift_key_is_down: boolean
show_move_numbers: boolean
show_variation_move_numbers: boolean
showing_scores: boolean = false
socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
square_size: number = 10
stalling_score_estimate?: StallingScoreEstimate
stone_placement_enabled: boolean
stone_removal_auto_scoring_done?: boolean = false
theme_black: GobanTheme
theme_black_stones: any[] = []
theme_black_text_color: string = HOT_PINK
theme_blank_text_color: string = HOT_PINK
theme_board: GobanTheme
theme_faded_line_color: string = HOT_PINK
theme_faded_star_color: string = HOT_PINK
theme_line_color: string = ""
theme_star_color: string = ""
theme_stone_radius: number = 10
theme_white: GobanTheme
theme_white_stones: any[] = []
theme_white_text_color: string = HOT_PINK
themes: GobanSelectedThemes = ...
title_div?: HTMLElement
variation_stone_opacity: number
visual_undo_request_indicator: boolean
width: number
THEMES: ThemesInterface = THEMES
THEMES_SORTED: {
    black: GobanTheme[];
    board: GobanTheme[];
    white: GobanTheme[];
    [key: string]: GobanTheme[];
} = THEMES_SORTED

Type declaration

setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

      -

      Parameters

      Returns void

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

Methods

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

Methods

\ No newline at end of file +

Returns void

\ No newline at end of file diff --git a/docs/classes/GobanEngine.html b/docs/classes/GobanEngine.html index adedf5a5..54f73f90 100644 --- a/docs/classes/GobanEngine.html +++ b/docs/classes/GobanEngine.html @@ -1,4 +1,4 @@ -GobanEngine | goban

Class GobanEngine

Hierarchy (view full)

Constructors

constructor +GobanEngine | goban

Class GobanEngine

Hierarchy (view full)

Constructors

Properties

_cur_move: MoveTree
_cur_review_move: undefined | MoveTree
_last_official_move: MoveTree
_outcome: string = ""
_phase: GobanEnginePhase = "play"
_rules: GobanEngineRules = "japanese"
_strict_seki_mode: boolean = false
_undo_requested?: number
_winner?: number | "black" | "white"
aga_handicap_scoring: boolean = false
allow_ko: boolean = false
allow_self_capture: boolean = false
allow_superko: boolean = false
automatic_stone_removal: boolean = false
black_prisoners: number
board_is_repeating: boolean
decoded_moves: JGOFMove[] = []
disable_analysis: boolean = false
dontStoreBoardHistory: boolean
free_handicap_placement: boolean = false
game_id: number = NaN
goban_callback?: GobanBase
group_ids?: number[]
handicap: number = NaN
handicap_rank_difference?: number
height: number = 19
initial_state: GobanEngineInitialState = ...
komi: number = NaN
latencies?: {
    [player_id: string]: number;
}

Type declaration

  • [player_id: string]: number
loading_sgf: boolean = false
move_before_jump?: MoveTree
move_tree: MoveTree
move_tree_layout_dirty: boolean = false
move_tree_layout_hash: {
    [coords: string]: MoveTree;
} = {}

Type declaration

move_tree_layout_vector: number[] = []
name: string = ""
needs_sealing?: JGOFSealingIntersection[]
parentEventEmitter?: EventEmitter<GobanEvents, any>
player_pool: {
    [id: number]: GobanEnginePlayerEntry;
}

Type declaration

players: {
    black: GobanEnginePlayerEntry;
    white: GobanEnginePlayerEntry;
} = ...

Type declaration

puzzle_collection: number = NaN
puzzle_description: string = "[missing puzzle description]"
puzzle_opponent_move_mode: PuzzleOpponentMoveMode = "manual"
puzzle_player_move_mode: PuzzlePlayerMoveMode = "free"
puzzle_rank: number = NaN
puzzle_type: string = "[missing puzzle type]"
removal: boolean[][]
rengo?: boolean
rengo_casual_mode: boolean
rengo_teams?: {
    [colour: string]: GobanEnginePlayerEntry[];
}

Type declaration

review_id?: number
score_handicap: boolean = false
score_prisoners: boolean = false
score_stones: boolean = false
score_territory: boolean = false
score_territory_in_seki: boolean = false
stalling_score_estimate?: StallingScoreEstimate
superko_algorithm: GobanEngineSuperKoAlgorithm = "psk"
territory_included_in_sgf: boolean = false
throw_all_errors?: boolean
time_control: JGOFTimeControl = ...
white_prisoners: number
width: number = 19

Accessors

  • get winner(): undefined | number | "black" | "white"
  • Returns undefined | number | "black" | "white"

  • set winner(winner): void
  • Parameters

    • winner: undefined | number | "black" | "white"

    Returns void

Methods

  • Returns {
        black: string;
        white: string;
    }

    • black: string
    • white: string
  • Computes the score of the current board state.

    +

Constructors

Properties

_cur_move: MoveTree
_cur_review_move: undefined | MoveTree
_last_official_move: MoveTree
_outcome: string = ""
_phase: GobanEnginePhase = "play"
_rules: GobanEngineRules = "japanese"
_strict_seki_mode: boolean = false
_undo_requested?: number
_winner?: number | "black" | "white"
aga_handicap_scoring: boolean = false
allow_ko: boolean = false
allow_self_capture: boolean = false
allow_superko: boolean = false
automatic_stone_removal: boolean = false
black_prisoners: number
board_is_repeating: boolean
decoded_moves: JGOFMove[] = []
disable_analysis: boolean = false
dontStoreBoardHistory: boolean
free_handicap_placement: boolean = false
game_id: number = NaN
goban_callback?: GobanBase
group_ids?: number[]
handicap: number = NaN
handicap_rank_difference?: number
height: number = 19
initial_state: GobanEngineInitialState = ...
komi: number = NaN
latencies?: {
    [player_id: string]: number;
}

Type declaration

  • [player_id: string]: number
loading_sgf: boolean = false
move_before_jump?: MoveTree
move_tree: MoveTree
move_tree_layout_dirty: boolean = false
move_tree_layout_hash: {
    [coords: string]: MoveTree;
} = {}

Type declaration

move_tree_layout_vector: number[] = []
name: string = ""
needs_sealing?: JGOFSealingIntersection[]
parentEventEmitter?: EventEmitter<GobanEvents, any>
player_pool: {
    [id: number]: GobanEnginePlayerEntry;
}

Type declaration

players: {
    black: GobanEnginePlayerEntry;
    white: GobanEnginePlayerEntry;
} = ...

Type declaration

puzzle_collection: number = NaN
puzzle_description: string = "[missing puzzle description]"
puzzle_opponent_move_mode: PuzzleOpponentMoveMode = "manual"
puzzle_player_move_mode: PuzzlePlayerMoveMode = "free"
puzzle_rank: number = NaN
puzzle_type: string = "[missing puzzle type]"
removal: boolean[][]
rengo?: boolean
rengo_casual_mode: boolean
rengo_teams?: {
    [colour: string]: GobanEnginePlayerEntry[];
}

Type declaration

review_id?: number
score_handicap: boolean = false
score_prisoners: boolean = false
score_stones: boolean = false
score_territory: boolean = false
score_territory_in_seki: boolean = false
stalling_score_estimate?: StallingScoreEstimate
superko_algorithm: GobanEngineSuperKoAlgorithm = "psk"
territory_included_in_sgf: boolean = false
throw_all_errors?: boolean
time_control: JGOFTimeControl = ...
white_prisoners: number
width: number = 19

Accessors

  • get winner(): undefined | number | "black" | "white"
  • Returns undefined | number | "black" | "white"

  • set winner(winner): void
  • Parameters

    • winner: undefined | number | "black" | "white"

    Returns void

Methods

  • Returns {
        black: string;
        white: string;
    }

    • black: string
    • white: string
  • Computes the score of the current board state.

    If only_prisoners is true, we return the same data structure for convenience, but only the prisoners will be counted, other sources of points will be zero.

    -

    Parameters

    • Optional only_prisoners: boolean

    Returns Score

  • Decodes a move string like "A11" into a move object like {x: 0, y: 10}. Also handles the special cases like ".." and "pass" which map to {x: -1, y: -1}.

    -

    Parameters

    • coordinates: string

    Returns JGOFMove

  • Parameters

    • from_turn: number
    • moves: string | AdHocPackedMove
    • Optional cb: ((x, y, edited, color) => void)
        • (x, y, edited, color): void
        • Parameters

          • x: number
          • y: number
          • edited: boolean
          • color: number

          Returns void

    Returns MoveTree[]

  • Returns a move string from the given official move number (aka branch point)

    -

    Returns {
        from: number;
        moves: string;
    }

    • from: number
    • moves: string
  • Parameters

    • from_turn: number
    • moves: string | AdHocPackedMove
    • Optional cb: ((x, y, edited, color) => void)
        • (x, y, edited, color): void
        • Parameters

          • x: number
          • y: number
          • edited: boolean
          • color: number

          Returns void

    Returns MoveTree[]

  • Returns a move string from the given official move number (aka branch point)

    +

    Returns {
        from: number;
        moves: string;
    }

    • from: number
    • moves: string
  • returns true if our current move is our last official move

    -

    Returns boolean

  • returns true if our current move is our last official move

    +

    Returns boolean

  • Returns the number of stones removed. If you want the coordinates of the stones removed, pass in a removed_stones array to append the moves to.

    -

    Parameters

    • x: number
    • y: number
    • Optional checkForKo: boolean
    • Optional errorOnSuperKo: boolean
    • Optional dontCheckForSuperKo: boolean
    • Optional dontCheckForSelfCapture: boolean
    • Optional isTrunkMove: boolean
    • Optional removed_stones: JGOFIntersection[]

    Returns number

  • Parameters

    • Optional player_id: number

    Returns "black" | "white" | "invalid"

  • Encodes an x,y pair or a move object like {x: 0, y: 0} into a move string like "A1"

    -

    Parameters

    Returns string

  • Parameters

    • x: number
    • y: number

    Returns string

  • Saves our current move as our last official move

    -

    Returns void

  • Parameters

    • x: number
    • y: number
    • Optional needs_sealing: boolean

    Returns void

  • Sets a position as being removed or not removed. If +

    Parameters

    • x: number
    • y: number
    • Optional checkForKo: boolean
    • Optional errorOnSuperKo: boolean
    • Optional dontCheckForSuperKo: boolean
    • Optional dontCheckForSelfCapture: boolean
    • Optional isTrunkMove: boolean
    • Optional removed_stones: JGOFIntersection[]

    Returns number

  • Parameters

    • Optional player_id: number

    Returns "black" | "white" | "invalid"

  • Encodes an x,y pair or a move object like {x: 0, y: 0} into a move string like "A1"

    +

    Parameters

    Returns string

  • Parameters

    • x: number
    • y: number

    Returns string

  • Saves our current move as our last official move

    +

    Returns void

  • Parameters

    • x: number
    • y: number
    • Optional needs_sealing: boolean

    Returns void

  • Sets a position as being removed or not removed. If emit_stone_removal_updated is set to false, the "stone-removal.updated" event will not be emitted, and it is up to the caller to emit this event appropriately.

    -

    Parameters

    • x: number
    • y: number
    • removed: boolean
    • emit_stone_removal_updated: boolean = true

    Returns void

  • Toggles a group of stones for removal or restoration.

    +

    Parameters

    • x: number
    • y: number
    • removed: boolean
    • emit_stone_removal_updated: boolean = true

    Returns void

  • Toggles a group of stones for removal or restoration.

    By default, if we are marking a group for removal but the group is almost certainly alive (two eyes, etc), this will result in a no-op, unless force_removal is set to true.

    -

    Parameters

    • x: number
    • y: number
    • force_removal: boolean = false

    Returns {
        group: RawStoneString;
        removed: boolean;
    }

\ No newline at end of file +

Parameters

Returns GobanEngineConfig

\ No newline at end of file diff --git a/docs/classes/GobanError.html b/docs/classes/GobanError.html index efc1921b..6489adba 100644 --- a/docs/classes/GobanError.html +++ b/docs/classes/GobanError.html @@ -1,2 +1,2 @@ -GobanError | goban

Class GobanError

Hierarchy (view full)

Constructors

Constructors

\ No newline at end of file +GobanError | goban

Class GobanError

Hierarchy (view full)

Constructors

Constructors

\ No newline at end of file diff --git a/docs/classes/GobanInteractive.html b/docs/classes/GobanInteractive.html index ee5746fa..77d5da6d 100644 --- a/docs/classes/GobanInteractive.html +++ b/docs/classes/GobanInteractive.html @@ -1,7 +1,7 @@ GobanInteractive | goban

Class GobanInteractiveAbstract

This class serves as a functionality layer encapsulating core interactions we do with a Goban, we have it as a separate base class simply to help with code organization and to keep our Goban class size down.

-

Hierarchy (view full)

Constructors

Hierarchy (view full)

Constructors

Properties

__board_redraw_pen_layer_timer: any = null
__clock_timer?: Timeout
__draw_state: string[][]
__last_pt: {
    i: number;
    j: number;
    valid: boolean;
} = ...

Type declaration

  • i: number
  • j: number
  • valid: boolean
__update_move_tree: any = null
_analyze_subtool: string = "alternate"
_analyze_tool: AnalysisTool = "stone"
_mode: GobanModes = "play"
_review_controller_id?: number
_review_owner_id?: number
_score_estimator: null | ScoreEstimator = null
_submit_move?: (() => void)

Type declaration

    • (): void
    • Returns void

_title: string = "play"
analysis_move_counter: number
analysis_removal_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
analysis_removal_state?: boolean
bounded_height: number
bounded_width: number
bounds: GobanBounds
chat_log: GobanChatLog = []
circle_radius: number
clock_should_be_paused_for_move_submission: boolean = false
colored_circles?: (undefined | ColoredCircle)[][]
conditional_path: string = ""
conditional_starting_color: "black" | "white" | "invalid" = "invalid"
conditional_tree: ConditionalMoveTree = ...
config: GobanConfig
current_cmove?: ConditionalMoveTree
currently_my_cmove: boolean = false
dirty_redraw: any = null
disconnectedFromGame: boolean = true
display_width?: number
done_loading_review: boolean = false
dont_draw_last_move: boolean
double_click_submit: boolean
draw_bottom_labels: boolean
draw_left_labels: boolean
draw_right_labels: boolean
draw_top_labels: boolean
edit_color?: "black" | "white"
engine: GobanEngine
errorHandler: ((e) => void)

Type declaration

    • (e): void
    • Parameters

      • e: Error

      Returns void

game_id: number
game_type: string
getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
goban_id: number = ++last_goban_id

Base fields *

-
heatmap?: NumberMatrix
height: number
highlight_movetree_moves: boolean
interactive: boolean
isInPushedAnalysis: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerController: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerOwner: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

label_character: string
label_mark: string = "[UNSET]"
last_clock?: AdHocClock
last_emitted_captured_stones: JGOFIntersection[] = []
last_emitted_clock?: JGOFClockWithTransmitting
last_hover_square?: JGOFIntersection
last_move?: MoveTree
last_move_radius: number
last_paused_by_player_state: null | boolean = null
last_paused_state: null | boolean = null
last_phase?: GobanEnginePhase
last_review_message: ReviewMessage
last_sound_played_for_a_stone_placement?: string
last_stone_sound: number
leavePushedAnalysis: (() => void)

Type declaration

    • (): void
    • Returns void

marked_analysis_score?: boolean[][]
move_selected?: JGOFIntersection
no_display: boolean
onError?: ((error) => void)

Type declaration

    • (error): void
    • Parameters

      • error: Error

      Returns void

on_game_screen: boolean
one_click_submit: boolean
original_square_size: number | ((goban) => number) | "auto"

Type declaration

    • (goban): number
    • Parameters

      Returns number

pause_control?: AdHocPauseControl
paused_since?: number
pen_marks: any[]
player_id: number
preloaded_data?: GobanConfig
previous_mode: string
puzzle_autoplace_delay: number
restrict_moves_to_movetree: boolean
review_had_gamedata: boolean
review_id: number
scoring_mode: boolean | "stalling-scoring-mode"
sendLatencyTimer?: Timeout
sent_timed_out_message: boolean
shift_key_is_down: boolean
show_move_numbers: boolean
show_variation_move_numbers: boolean
showing_scores: boolean = false
square_size: number = 10
stalling_score_estimate?: StallingScoreEstimate
stone_placement_enabled: boolean
stone_removal_auto_scoring_done?: boolean = false
variation_stone_opacity: number
visual_undo_request_indicator: boolean
width: number
setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any +

Constructors

Properties

__board_redraw_pen_layer_timer: any = null
__clock_timer?: Timeout
__draw_state: string[][]
__last_pt: {
    i: number;
    j: number;
    valid: boolean;
} = ...

Type declaration

  • i: number
  • j: number
  • valid: boolean
__update_move_tree: any = null
_analyze_subtool: string = "alternate"
_analyze_tool: AnalysisTool = "stone"
_mode: GobanModes = "play"
_review_controller_id?: number
_review_owner_id?: number
_score_estimator: null | ScoreEstimator = null
_submit_move?: (() => void)

Type declaration

    • (): void
    • Returns void

_title: string = "play"
analysis_move_counter: number
analysis_removal_last_position: {
    i: number;
    j: number;
} = ...

Type declaration

  • i: number
  • j: number
analysis_removal_state?: boolean
bounded_height: number
bounded_width: number
bounds: GobanBounds
chat_log: GobanChatLog = []
circle_radius: number
clock_should_be_paused_for_move_submission: boolean = false
colored_circles?: (undefined | ColoredCircle)[][]
conditional_path: string = ""
conditional_starting_color: "black" | "white" | "invalid" = "invalid"
conditional_tree: ConditionalMoveTree = ...
config: GobanConfig
current_cmove?: ConditionalMoveTree
currently_my_cmove: boolean = false
dirty_redraw: any = null
disconnectedFromGame: boolean = true
display_width?: number
done_loading_review: boolean = false
dont_draw_last_move: boolean
double_click_submit: boolean
draw_bottom_labels: boolean
draw_left_labels: boolean
draw_right_labels: boolean
draw_top_labels: boolean
edit_color?: "black" | "white"
engine: GobanEngine
errorHandler: ((e) => void)

Type declaration

    • (e): void
    • Parameters

      • e: Error

      Returns void

game_id: number
game_type: string
getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
goban_id: number = ++last_goban_id

Base fields *

+
heatmap?: NumberMatrix
height: number
highlight_movetree_moves: boolean
interactive: boolean
isInPushedAnalysis: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerController: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

isPlayerOwner: (() => boolean)

Type declaration

    • (): boolean
    • Returns boolean

label_character: string
label_mark: string = "[UNSET]"
last_clock?: AdHocClock
last_emitted_captured_stones: JGOFIntersection[] = []
last_emitted_clock?: JGOFClockWithTransmitting
last_hover_square?: JGOFIntersection
last_move?: MoveTree
last_move_radius: number
last_paused_by_player_state: null | boolean = null
last_paused_state: null | boolean = null
last_phase?: GobanEnginePhase
last_review_message: ReviewMessage
last_sound_played_for_a_stone_placement?: string
last_stone_sound: number
leavePushedAnalysis: (() => void)

Type declaration

    • (): void
    • Returns void

marked_analysis_score?: boolean[][]
move_selected?: JGOFIntersection
no_display: boolean
onError?: ((error) => void)

Type declaration

    • (error): void
    • Parameters

      • error: Error

      Returns void

on_game_screen: boolean
one_click_submit: boolean
original_square_size: number | ((goban) => number) | "auto"

Type declaration

    • (goban): number
    • Parameters

      Returns number

pause_control?: AdHocPauseControl
paused_since?: number
pen_marks: any[]
player_id: number
preloaded_data?: GobanConfig
previous_mode: string
puzzle_autoplace_delay: number
restrict_moves_to_movetree: boolean
review_had_gamedata: boolean
review_id: number
scoring_mode: boolean | "stalling-scoring-mode"
sendLatencyTimer?: Timeout
sent_timed_out_message: boolean
shift_key_is_down: boolean
show_move_numbers: boolean
show_variation_move_numbers: boolean
showing_scores: boolean = false
square_size: number = 10
stalling_score_estimate?: StallingScoreEstimate
stone_placement_enabled: boolean
stone_removal_auto_scoring_done?: boolean = false
variation_stone_opacity: number
visual_undo_request_indicator: boolean
width: number
setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

Type declaration

    • (newCallbacks): void
    • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

      -

      Parameters

      Returns void

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

  • get destroyed(): boolean
  • Returns boolean

Methods

  • Decodes any of the various ways we express moves that we've accumulated over the years into +

    Parameters

    Returns void

setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

Type declaration

    • (_catalog, _debug_mode?): void
    • Parameters

      Returns void

Accessors

  • get destroyed(): boolean
  • Returns boolean

Methods

  • Decodes a move string like "A11" into a move object like {x: 0, y: 10}. Also handles the special cases like ".." and "pass" which map to {x: -1, y: -1}.

    -

    Parameters

    • coordinates: string

    Returns JGOFMove

  • Parameters

    • x: number
    • y: number
    • mark: string
    • Optional drawSquare: boolean

    Returns void

  • Parameters

    • perGameSettingAppliesToNonPlayers: boolean = false

    Returns boolean

  • Parameters

    • x: number
    • y: number
    • mark: string
    • Optional drawSquare: boolean

    Returns void

  • Parameters

    • perGameSettingAppliesToNonPlayers: boolean = false

    Returns boolean

  • Goban calls some abstract methods as part of the construction process. Because our subclasses might (and do) need to do some of their own config before these are called, we set this function to be called by our subclass after it's done it's own internal config stuff.

    -

    Returns GobanEngine

  • Parameters

    • colored_marks: {
          [key: string]: {
              color: string;
              move: string;
          };
      }
      • [key: string]: {
            color: string;
            move: string;
        }
        • color: string
        • move: string

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string
    • Optional drawSquare: boolean

    Returns void

  • Called when a location is marked or unmarked for removal

    -

    Parameters

    • x: number
    • y: number
    • removed: boolean
    • emit_stone_removal_updated: boolean = true

    Returns void

  • Parameters

    • Optional set_override: "letters" | "numbers"

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string
    • Optional drawSquare: boolean

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string | number
    • Optional dont_draw: boolean

    Returns void

  • Parameters

    • coordinates: string
    • mark: string | number
    • Optional dont_draw: boolean

    Returns void

  • Parameters

    • colored_marks: {
          [key: string]: {
              color: string;
              move: string;
          };
      }
      • [key: string]: {
            color: string;
            move: string;
        }
        • color: string
        • move: string

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string
    • Optional drawSquare: boolean

    Returns void

  • Called when a location is marked or unmarked for removal

    +

    Parameters

    • x: number
    • y: number
    • removed: boolean
    • emit_stone_removal_updated: boolean = true

    Returns void

  • Parameters

    • Optional set_override: "letters" | "numbers"

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string
    • Optional drawSquare: boolean

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string | number
    • Optional dont_draw: boolean

    Returns void

  • Parameters

    • coordinates: string
    • mark: string | number
    • Optional dont_draw: boolean

    Returns void

  • This is a callback that gets called by GobanEngine.getState to save and board state as it pushes and pops state. Our renderers can override this to save state they need.

    -

    Parameters

    • marks: {
          [mark: string]: string;
      }
      • [mark: string]: string
    • Optional dont_draw: boolean

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string
    • drawSquare: boolean = true

    Returns void

  • Parameters

    • Optional dont_jump_to_official_move: boolean

    Returns boolean

  • Parameters

    • x: number
    • y: number
    • mark: string | number
    • Optional dont_draw: boolean

    Returns void

  • Parameters

    • msg_id: MessageID
    • Optional parameters: {
          [key: string]: any;
      }
      • [key: string]: any
    • Optional timeout: number

    Returns void

  • Parameters

    • x: number
    • y: number
    • mark: string | number
    • Optional force_label: boolean
    • Optional force_put: boolean

    Returns boolean

  • Parameters

    • x: number
    • y: number
    • anti_slip: boolean = true

    Returns {
        i: number;
        j: number;
        valid: boolean;
    }

    • i: number
    • j: number
    • valid: boolean
\ No newline at end of file +

Parameters

Returns void

\ No newline at end of file diff --git a/docs/classes/GobanMoveError.html b/docs/classes/GobanMoveError.html index e963f853..ef2e02a4 100644 --- a/docs/classes/GobanMoveError.html +++ b/docs/classes/GobanMoveError.html @@ -1,6 +1,6 @@ -GobanMoveError | goban

Class GobanMoveError

Hierarchy (view full)

Constructors

constructor +GobanMoveError | goban

Class GobanMoveError

Hierarchy (view full)

Constructors

Properties

coords: string
game_id: number
move_number: number
\ No newline at end of file +

Constructors

Properties

coords: string
game_id: number
move_number: number
\ No newline at end of file diff --git a/docs/classes/GobanSocket.html b/docs/classes/GobanSocket.html index 9ba24af8..a0569caf 100644 --- a/docs/classes/GobanSocket.html +++ b/docs/classes/GobanSocket.html @@ -8,7 +8,7 @@
  • Optional promise support for sends
  • Latency tracking (doubling as keep alive)
  • -

    Type Parameters

    Hierarchy

    Constructors

    Type Parameters

    Hierarchy

    Constructors

    Properties

    authentication?: DataArgument<SendProtocol["authenticate"]>
    callbacks: Map<number, ((data?, error?) => void)> = ...

    Type declaration

      • (data?, error?): void
      • Parameters

        Returns void

    clock_drift: number = 0.0
    current_ping_interval: number
    last_request_id: number = 0
    latency: number = 0.0
    manually_disconnected: boolean = false
    ping_timer?: Timeout
    promises_in_flight: Map<number, {
        args: any[];
        command: string;
        reject: ((...args) => void);
        resolve: ((...args) => void);
    }> = ...

    Type declaration

    • args: any[]
    • command: string
    • reject: ((...args) => void)
        • (...args): void
        • Parameters

          • Rest ...args: any[]

          Returns void

    • resolve: ((...args) => void)
        • (...args): void
        • Parameters

          • Rest ...args: any[]

          Returns void

    reconnect_tries: number = 0
    reconnecting: boolean = false
    send_queue: (() => void)[] = []

    Type declaration

      • (): void
      • Returns void

    socket: WebSocket
    timeout_timer?: Timeout
    url: string

    Accessors

    Methods

    \ No newline at end of file +

    Constructors

    Properties

    authentication?: DataArgument<SendProtocol["authenticate"]>
    callbacks: Map<number, ((data?, error?) => void)> = ...

    Type declaration

      • (data?, error?): void
      • Parameters

        Returns void

    clock_drift: number = 0.0
    current_ping_interval: number
    last_request_id: number = 0
    latency: number = 0.0
    manually_disconnected: boolean = false
    ping_timer?: Timeout
    promises_in_flight: Map<number, {
        args: any[];
        command: string;
        reject: ((...args) => void);
        resolve: ((...args) => void);
    }> = ...

    Type declaration

    • args: any[]
    • command: string
    • reject: ((...args) => void)
        • (...args): void
        • Parameters

          • Rest ...args: any[]

          Returns void

    • resolve: ((...args) => void)
        • (...args): void
        • Parameters

          • Rest ...args: any[]

          Returns void

    reconnect_tries: number = 0
    reconnecting: boolean = false
    send_queue: (() => void)[] = []

    Type declaration

      • (): void
      • Returns void

    socket: WebSocket
    timeout_timer?: Timeout
    url: string

    Accessors

    Methods

    \ No newline at end of file diff --git a/docs/classes/GobanTheme.html b/docs/classes/GobanTheme.html index c276646a..7f644d26 100644 --- a/docs/classes/GobanTheme.html +++ b/docs/classes/GobanTheme.html @@ -1,9 +1,10 @@ -GobanTheme | goban

    Class GobanTheme

    Constructors

    constructor +GobanTheme | goban

    Class GobanTheme

    Constructors

    Properties

    name: string
    parent?: GobanTheme
    styles: {
        [style_name: string]: string;
    } = {}

    Type declaration

    • [style_name: string]: string

    Accessors

    Methods

    • Parameters

      • ctx: CanvasRenderingContext2D
      • _shadow_ctx: null | CanvasRenderingContext2D
      • _stone: any
      • cx: number
      • cy: number
      • radius: number

      Returns void

    • Parameters

      • cell: SVGGraphicsElement
      • shadow_cell: undefined | SVGGraphicsElement
      • stone: string
      • cx: number
      • cy: number
      • radius: number

      Returns [SVGElement, undefined | SVGElement]

    • Parameters

      • cell: SVGGraphicsElement
      • shadow_cell: undefined | SVGGraphicsElement
      • stone: string
      • cx: number
      • cy: number
      • radius: number
      • shadow_circle_color: string

      Returns [SVGElement, undefined | SVGElement]

    • Parameters

      • shadow_cell: undefined | SVGGraphicsElement
      • cx: number
      • cy: number
      • radius: number
      • color: string

      Returns undefined | SVGElement

    • Parameters

      • ctx: CanvasRenderingContext2D
      • _shadow_ctx: null | CanvasRenderingContext2D
      • _stone: any
      • cx: number
      • cy: number
      • radius: number

      Returns void

    • Parameters

      • cell: SVGGraphicsElement
      • shadow_cell: undefined | SVGGraphicsElement
      • stone: string
      • cx: number
      • cy: number
      • radius: number

      Returns [SVGElement, undefined | SVGElement]

    • Parameters

      • _radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns any

    • Parameters

      • defs: SVGDefsElement
      • radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns string[]

    • Parameters

      • _radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns any

    • Parameters

      • defs: SVGDefsElement
      • radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns string[]

    \ No newline at end of file +

    Constructors

    Properties

    name: string
    parent?: GobanTheme
    styles: {
        [style_name: string]: string;
    } = {}

    Type declaration

    • [style_name: string]: string

    Accessors

    Methods

    • Parameters

      • ctx: CanvasRenderingContext2D
      • _shadow_ctx: null | CanvasRenderingContext2D
      • _stone: any
      • cx: number
      • cy: number
      • radius: number

      Returns void

    • Parameters

      • cell: SVGGraphicsElement
      • shadow_cell: undefined | SVGGraphicsElement
      • stone: string
      • cx: number
      • cy: number
      • radius: number

      Returns [SVGElement, undefined | SVGElement]

    • Parameters

      • cell: SVGGraphicsElement
      • shadow_cell: undefined | SVGGraphicsElement
      • stone: string
      • cx: number
      • cy: number
      • radius: number
      • shadow_circle_color: string

      Returns [SVGElement, undefined | SVGElement]

    • Parameters

      • shadow_cell: undefined | SVGGraphicsElement
      • cx: number
      • cy: number
      • radius: number
      • color: string

      Returns undefined | SVGElement

    • Parameters

      • ctx: CanvasRenderingContext2D
      • _shadow_ctx: null | CanvasRenderingContext2D
      • _stone: any
      • cx: number
      • cy: number
      • radius: number

      Returns void

    • Parameters

      • cell: SVGGraphicsElement
      • shadow_cell: undefined | SVGGraphicsElement
      • stone: string
      • cx: number
      • cy: number
      • radius: number

      Returns [SVGElement, undefined | SVGElement]

    • Parameters

      • _radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns any

    • Parameters

      • defs: SVGDefsElement
      • radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns string[]

    • Parameters

      • _radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns any

    • Parameters

      • defs: SVGDefsElement
      • radius: number
      • _seed: number
      • _deferredRenderCallback: (() => void)
          • (): void
          • Returns void

      Returns string[]

    \ No newline at end of file diff --git a/docs/classes/MoveTree.html b/docs/classes/MoveTree.html index 96b7383e..e28c46fc 100644 --- a/docs/classes/MoveTree.html +++ b/docs/classes/MoveTree.html @@ -1,4 +1,4 @@ -MoveTree | goban

    Class MoveTree

    Constructors

    constructor +MoveTree | goban

    Class MoveTree

    Constructors

    Properties

    active_path_number: number = 0
    branches: MoveTree[]
    chat_log?: MoveTreeChatLine[]
    correct_answer: boolean = false
    edited: boolean
    engine: GobanEngine
    hint_next?: MoveTree
    id: number
    isobranch_hash?: string
    isobranches: any
    label: string = "[unset]"
    label_metrics?: any
    layout_cx: number = 0
    layout_cy: number = 0
    layout_x: number = 0
    layout_y: number = 0
    line_color: number
    marks?: MarkInterface[][]
    move_number: number
    parent: null | MoveTree
    pen_marks: MoveTreePenMarks = []
    played_by: undefined | number
    player_update: undefined | JGOFPlayerSummary
    pretty_coordinates: string
    stashed_marks: MarkInterface[][][] = []
    text: string
    trunk: boolean
    trunk_next?: MoveTree
    wrong_answer: boolean = false
    x: number
    y: number
    active_path_number: number = 0

    ** Layout & Rendering ***

    -
    current_line_color: number = 0
    isobranch_colors: {
        strong: string;
        weak: string;
    } = ...

    Type declaration

    • strong: string
    • weak: string
    line_colors: string[] = ...
    stone_padding: 3 = 3
    stone_radius: 11 = 11
    stone_square_size: number = ...

    Accessors

    • get stoneColor(): "black" | "white" | "empty"
    • Returns "black" | "white" | "empty"

    Methods

    • Calls a callback for each positions that has a mark on it

      -

      Parameters

      • fn: ((i, j) => void)
          • (i, j): void
          • Parameters

            • i: number
            • j: number

            Returns void

      Returns void

    • Returns true if there are any marks that have been set

      -

      Returns boolean

    • Parameters

      • x: number
      • min_y: number
      • layout_hash: {
            [coords: string]: MoveTree;
        }
      • line_color: number

      Returns number

    • Loads the state of this MoveTree node from a MoveTreeJson object

      -

      Parameters

      Returns void

    • Recomputes the isobranches for the entire tree. This needs to be called on the root node.

      -

      Returns void

    • Saves the current marks in our stash, restore them with popMarks

      -

      Returns void

    \ No newline at end of file +

    Constructors

    Properties

    active_path_number: number = 0
    branches: MoveTree[]
    chat_log?: MoveTreeChatLine[]
    correct_answer: boolean = false
    edited: boolean
    engine: GobanEngine
    hint_next?: MoveTree
    id: number
    isobranch_hash?: string
    isobranches: any
    label: string = "[unset]"
    label_metrics?: any
    layout_cx: number = 0
    layout_cy: number = 0
    layout_x: number = 0
    layout_y: number = 0
    line_color: number
    marks?: MarkInterface[][]
    move_number: number
    parent: null | MoveTree
    pen_marks: MoveTreePenMarks = []
    played_by: undefined | number
    player_update: undefined | JGOFPlayerSummary
    pretty_coordinates: string
    stashed_marks: MarkInterface[][][] = []
    text: string
    trunk: boolean
    trunk_next?: MoveTree
    wrong_answer: boolean = false
    x: number
    y: number
    active_path_number: number = 0

    ** Layout & Rendering ***

    +
    current_line_color: number = 0
    isobranch_colors: {
        strong: string;
        weak: string;
    } = ...

    Type declaration

    • strong: string
    • weak: string
    line_colors: string[] = ...
    stone_padding: 3 = 3
    stone_radius: 11 = 11
    stone_square_size: number = ...

    Accessors

    • get stoneColor(): "black" | "white" | "empty"
    • Returns "black" | "white" | "empty"

    Methods

    • Calls a callback for each positions that has a mark on it

      +

      Parameters

      • fn: ((i, j) => void)
          • (i, j): void
          • Parameters

            • i: number
            • j: number

            Returns void

      Returns void

    • Returns true if there are any marks that have been set

      +

      Returns boolean

    • Parameters

      • x: number
      • min_y: number
      • layout_hash: {
            [coords: string]: MoveTree;
        }
      • line_color: number

      Returns number

    • Loads the state of this MoveTree node from a MoveTreeJson object

      +

      Parameters

      Returns void

    • Recomputes the isobranches for the entire tree. This needs to be called on the root node.

      +

      Returns void

    • Saves the current marks in our stash, restore them with popMarks

      +

      Returns void

    \ No newline at end of file diff --git a/docs/classes/SVGRenderer.html b/docs/classes/SVGRenderer.html index 23d550db..d752a96f 100644 --- a/docs/classes/SVGRenderer.html +++ b/docs/classes/SVGRenderer.html @@ -2,7 +2,7 @@ classes, types, and enums.

    You can't create an instance of a Goban directly, you have to create an instance of one of the renderers, such as GobanSVG.

    -

    Hierarchy (view full)

    Implements

    Constructors

    Hierarchy (view full)

    Implements

    Constructors

    Properties

    __board_redraw_pen_layer_timer: any = null
    __clock_timer?: Timeout
    __draw_state: string[][]
    __last_pt: {
        i: number;
        j: number;
        valid: boolean;
    } = ...

    Type declaration

    • i: number
    • j: number
    • valid: boolean
    __set_board_height: number = -1
    __set_board_width: number = -1
    __update_move_tree: any = null
    analysis_move_counter: number
    analysis_removal_last_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    analysis_removal_state?: boolean
    autoplaying_puzzle_move: boolean = false
    bounded_height: number
    bounded_width: number
    bounds: GobanBounds
    byoyomi_label: string = ""
    chat_log: GobanChatLog = []
    circle_radius: number
    clock_should_be_paused_for_move_submission: boolean = false
    colored_circles?: (undefined | ColoredCircle)[][]
    conditional_path: string = ""
    conditional_starting_color: "black" | "white" | "invalid" = "invalid"
    conditional_tree: ConditionalMoveTree = ...
    config: GobanConfig
    connectToReviewSent?: boolean
    coordinate_labels_layer?: SVGGraphicsElement
    current_cmove?: ConditionalMoveTree
    current_pen_mark?: {
        color: string;
        points: [number, number];
    }

    Type declaration

    • color: string
    • points: [number, number]
    currently_my_cmove: boolean = false
    dirty_redraw: any = null
    disconnectedFromGame: boolean = true
    display_width?: number
    done_loading_review: boolean = false
    dont_draw_last_move: boolean
    double_click_submit: boolean
    draw_bottom_labels: boolean
    draw_left_labels: boolean
    draw_right_labels: boolean
    draw_top_labels: boolean
    drawing_enabled: boolean = true
    edit_color?: "black" | "white"
    engine: GobanEngine
    errorHandler: ((e) => void)

    Type declaration

      • (e): void
      • Parameters

        • e: Error

        Returns void

    event_layer: HTMLDivElement
    game_id: number
    game_type: string
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    goban_id: number = ++last_goban_id

    Base fields *

    -
    grid: SVGGraphicsElement[][] = []
    grid_layer?: SVGGraphicsElement
    handleShiftKey: ((ev) => void)

    Type declaration

      • (ev): void
      • Parameters

        • ev: KeyboardEvent

        Returns void

    heatmap?: NumberMatrix
    height: number
    highlight_movetree_moves: boolean
    interactive: boolean
    isInPushedAnalysis: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    label_character: string
    label_mark: string = "[UNSET]"
    labeling_mode?: "put" | "clear"
    last_clock?: AdHocClock
    last_emitted_clock?: JGOFClockWithTransmitting
    last_hover_square?: JGOFIntersection
    last_label_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    last_move?: MoveTree
    last_move_opacity: number = 1
    last_move_radius: number
    last_paused_by_player_state: null | boolean = null
    last_paused_state: null | boolean = null
    last_pen_position?: [number, number]
    last_phase?: GobanEnginePhase
    last_review_message: ReviewMessage
    last_sound_played_for_a_stone_placement?: string
    last_stone_sound: number
    leavePushedAnalysis: (() => void)

    Type declaration

      • (): void
      • Returns void

    lines_layer?: SVGGraphicsElement
    marked_analysis_score?: boolean[][]
    message_div?: HTMLDivElement
    message_td?: HTMLElement
    message_text?: HTMLDivElement
    message_timeout?: number
    metrics: GobanMetrics = ...
    move_selected?: JGOFIntersection
    move_tree_container?: HTMLElement
    move_tree_inner_container?: HTMLDivElement
    move_tree_svg?: SVGElement
    no_display: boolean
    onError?: ((error) => void)

    Type declaration

      • (error): void
      • Parameters

        • error: Error

        Returns void

    on_game_screen: boolean
    one_click_submit: boolean
    original_square_size: number | ((goban) => number) | "auto"

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    parent: HTMLElement
    pause_control?: AdHocPauseControl
    paused_since?: number
    pen_layer?: SVGGraphicsElement
    pen_marks: any[]
    player_id: number
    preloaded_data?: GobanConfig
    previous_mode: string
    puzzle_autoplace_delay: number
    ready_to_draw: boolean = false
    restrict_moves_to_movetree: boolean
    review_had_gamedata: boolean
    review_id: number
    scoring_mode: boolean | "stalling-scoring-mode"
    sendLatencyTimer?: Timeout
    sent_timed_out_message: boolean = false
    shadow_grid: (undefined | SVGElement)[][] = []
    shadow_layer?: SVGGraphicsElement
    shift_key_is_down: boolean
    show_move_numbers: boolean
    show_variation_move_numbers: boolean
    showing_scores: boolean = false
    socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
    square_size: number = 10
    stalling_score_estimate?: StallingScoreEstimate
    stone_placement_enabled: boolean
    stone_removal_auto_scoring_done?: boolean = false
    svg: SVGElement
    svg_defs: SVGDefsElement
    theme_black: GobanTheme
    theme_black_stones: any[] = []
    theme_black_text_color: string = HOT_PINK
    theme_blank_text_color: string = HOT_PINK
    theme_board: GobanTheme
    theme_faded_line_color: string = HOT_PINK
    theme_faded_star_color: string = HOT_PINK
    theme_line_color: string = ""
    theme_star_color: string = ""
    theme_stone_radius: number = 10
    theme_white: GobanTheme
    theme_white_stones: any[] = []
    theme_white_text_color: string = HOT_PINK
    themes: GobanSelectedThemes = ...
    title_div?: HTMLElement
    variation_stone_opacity: number
    visual_undo_request_indicator: boolean
    width: number
    THEMES: ThemesInterface = THEMES
    THEMES_SORTED: {
        black: GobanTheme[];
        board: GobanTheme[];
        white: GobanTheme[];
        [key: string]: GobanTheme[];
    } = THEMES_SORTED

    Type declaration

    setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

    Type declaration

      • (newCallbacks): void
      • Set's callback functions to be called in various situations. You can set any +

    Constructors

    Properties

    __board_redraw_pen_layer_timer: any = null
    __clock_timer?: Timeout
    __draw_state: string[][]
    __last_pt: {
        i: number;
        j: number;
        valid: boolean;
    } = ...

    Type declaration

    • i: number
    • j: number
    • valid: boolean
    __set_board_height: number = -1
    __set_board_width: number = -1
    __update_move_tree: any = null
    analysis_move_counter: number
    analysis_removal_last_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    analysis_removal_state?: boolean
    autoplaying_puzzle_move: boolean = false
    bounded_height: number
    bounded_width: number
    bounds: GobanBounds
    byoyomi_label: string = ""
    chat_log: GobanChatLog = []
    circle_radius: number
    clock_should_be_paused_for_move_submission: boolean = false
    colored_circles?: (undefined | ColoredCircle)[][]
    conditional_path: string = ""
    conditional_starting_color: "black" | "white" | "invalid" = "invalid"
    conditional_tree: ConditionalMoveTree = ...
    config: GobanConfig
    connectToReviewSent?: boolean
    coordinate_labels_layer?: SVGGraphicsElement
    current_cmove?: ConditionalMoveTree
    current_pen_mark?: {
        color: string;
        points: [number, number];
    }

    Type declaration

    • color: string
    • points: [number, number]
    currently_my_cmove: boolean = false
    dirty_redraw: any = null
    disconnectedFromGame: boolean = true
    display_width?: number
    done_loading_review: boolean = false
    dont_draw_last_move: boolean
    double_click_submit: boolean
    draw_bottom_labels: boolean
    draw_left_labels: boolean
    draw_right_labels: boolean
    draw_top_labels: boolean
    drawing_enabled: boolean = true
    edit_color?: "black" | "white"
    engine: GobanEngine
    errorHandler: ((e) => void)

    Type declaration

      • (e): void
      • Parameters

        • e: Error

        Returns void

    event_layer: HTMLDivElement
    game_id: number
    game_type: string
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    goban_id: number = ++last_goban_id

    Base fields *

    +
    grid: SVGGraphicsElement[][] = []
    grid_layer?: SVGGraphicsElement
    handleShiftKey: ((ev) => void)

    Type declaration

      • (ev): void
      • Parameters

        • ev: KeyboardEvent

        Returns void

    heatmap?: NumberMatrix
    height: number
    highlight_movetree_moves: boolean
    interactive: boolean
    isInPushedAnalysis: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    label_character: string
    label_mark: string = "[UNSET]"
    labeling_mode?: "put" | "clear"
    last_clock?: AdHocClock
    last_emitted_clock?: JGOFClockWithTransmitting
    last_hover_square?: JGOFIntersection
    last_label_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    last_move?: MoveTree
    last_move_opacity: number = 1
    last_move_radius: number
    last_paused_by_player_state: null | boolean = null
    last_paused_state: null | boolean = null
    last_pen_position?: [number, number]
    last_phase?: GobanEnginePhase
    last_review_message: ReviewMessage
    last_sound_played_for_a_stone_placement?: string
    last_stone_sound: number
    leavePushedAnalysis: (() => void)

    Type declaration

      • (): void
      • Returns void

    lines_layer?: SVGGraphicsElement
    marked_analysis_score?: boolean[][]
    message_div?: HTMLDivElement
    message_td?: HTMLElement
    message_text?: HTMLDivElement
    message_timeout?: number
    metrics: GobanMetrics = ...
    move_selected?: JGOFIntersection
    move_tree_container?: HTMLElement
    move_tree_inner_container?: HTMLDivElement
    move_tree_svg?: SVGElement
    no_display: boolean
    onError?: ((error) => void)

    Type declaration

      • (error): void
      • Parameters

        • error: Error

        Returns void

    on_game_screen: boolean
    one_click_submit: boolean
    original_square_size: number | ((goban) => number) | "auto"

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    parent: HTMLElement
    pause_control?: AdHocPauseControl
    paused_since?: number
    pen_layer?: SVGGraphicsElement
    pen_marks: any[]
    player_id: number
    preloaded_data?: GobanConfig
    previous_mode: string
    puzzle_autoplace_delay: number
    ready_to_draw: boolean = false
    restrict_moves_to_movetree: boolean
    review_had_gamedata: boolean
    review_id: number
    scoring_mode: boolean | "stalling-scoring-mode"
    sendLatencyTimer?: Timeout
    sent_timed_out_message: boolean = false
    shadow_grid: (undefined | SVGElement)[][] = []
    shadow_layer?: SVGGraphicsElement
    shift_key_is_down: boolean
    show_move_numbers: boolean
    show_variation_move_numbers: boolean
    showing_scores: boolean = false
    socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
    square_size: number = 10
    stalling_score_estimate?: StallingScoreEstimate
    stone_placement_enabled: boolean
    stone_removal_auto_scoring_done?: boolean = false
    svg: SVGElement
    svg_defs: SVGDefsElement
    theme_black: GobanTheme
    theme_black_stones: any[] = []
    theme_black_text_color: string = HOT_PINK
    theme_blank_text_color: string = HOT_PINK
    theme_board: GobanTheme
    theme_faded_line_color: string = HOT_PINK
    theme_faded_star_color: string = HOT_PINK
    theme_line_color: string = ""
    theme_star_color: string = ""
    theme_stone_radius: number = 10
    theme_white: GobanTheme
    theme_white_stones: any[] = []
    theme_white_text_color: string = HOT_PINK
    themes: GobanSelectedThemes = ...
    title_div?: HTMLElement
    variation_stone_opacity: number
    visual_undo_request_indicator: boolean
    width: number
    THEMES: ThemesInterface = THEMES
    THEMES_SORTED: {
        black: GobanTheme[];
        board: GobanTheme[];
        white: GobanTheme[];
        [key: string]: GobanTheme[];
    } = THEMES_SORTED

    Type declaration

    setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

    Type declaration

      • (newCallbacks): void
      • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

        -

        Parameters

        Returns void

    setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

    Type declaration

      • (_catalog, _debug_mode?): void
      • Parameters

        Returns void

    Accessors

    Methods

    setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

    Type declaration

      • (_catalog, _debug_mode?): void
      • Parameters

        Returns void

    Accessors

    Methods

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/docs/classes/ScoreEstimator.html b/docs/classes/ScoreEstimator.html index 4724f184..8bca499a 100644 --- a/docs/classes/ScoreEstimator.html +++ b/docs/classes/ScoreEstimator.html @@ -1,4 +1,4 @@ -ScoreEstimator | goban

    Class ScoreEstimator

    Hierarchy (view full)

    Constructors

    constructor +ScoreEstimator | goban

    Class ScoreEstimator

    Hierarchy (view full)

    Constructors

    Properties

    amount: number = NaN
    autoscore: boolean = false
    autoscored_needs_sealing?: JGOFSealingIntersection[]
    autoscored_removed?: JGOFMove[]
    autoscored_state?: JGOFNumericPlayerColor[][]
    black: PlayerScore = ...
    black_prisoners: number
    board_is_repeating: boolean
    color_to_move: "black" | "white"
    engine: GobanEngine
    estimated_hard_score: number
    goban_callback?: GobanBase
    height: number = 19
    ownership: number[][]
    prefer_remote: boolean
    removal: boolean[][]
    territory: number[][]
    tolerance: number
    trials: number
    when_ready: Promise<void>
    white: PlayerScore = ...
    white_prisoners: number
    width: number = 19
    winner: string = ""

    Methods

    • Computes scoring locations for the board. If area_scoring is true, we +

    Constructors

    Properties

    amount: number = NaN
    autoscore: boolean = false
    autoscored_needs_sealing?: JGOFSealingIntersection[]
    autoscored_removed?: JGOFMove[]
    autoscored_state?: JGOFNumericPlayerColor[][]
    black: PlayerScore = ...
    black_prisoners: number
    board_is_repeating: boolean
    color_to_move: "black" | "white"
    engine: GobanEngine
    estimated_hard_score: number
    goban_callback?: GobanBase
    height: number = 19
    ownership: number[][]
    prefer_remote: boolean
    removal: boolean[][]
    territory: number[][]
    tolerance: number
    trials: number
    when_ready: Promise<void>
    white: PlayerScore = ...
    white_prisoners: number
    width: number = 19
    winner: string = ""

    Methods

    • Parameters

      • trials: number
      • tolerance: number
      • autoscore: boolean

      Returns Promise<void>

    • Parameters

      • trials: number
      • tolerance: number

      Returns Promise<void>

    • Parameters

      • trials: number
      • tolerance: number
      • autoscore: boolean

      Returns Promise<void>

    • Parameters

      • trials: number
      • tolerance: number

      Returns Promise<void>

    • Parameters

      • i: number
      • j: number
      • mod_key: boolean
      • press_duration_ms: number

      Returns void

    • Parameters

      • i: number
      • j: number
      • mod_key: boolean
      • press_duration_ms: number

      Returns void

    • Sets a position as being removed or not removed. If emit_stone_removal_updated is set to false, the "stone-removal.updated" event will not be emitted, and it is up to the caller to emit this event appropriately.

      -

      Parameters

      • x: number
      • y: number
      • removed: boolean

      Returns void

    • Toggles a group of stones for removal or restoration.

      By default, if we are marking a group for removal but the group is almost certainly alive (two eyes, etc), this will result in a no-op, unless force_removal is set to true.

      -

      Parameters

      • x: number
      • y: number
      • force_removal: boolean = false

      Returns {
          group: RawStoneString;
          removed: boolean;
      }

    • Parameters

      • estimated_score: number
      • ownership: number[][]
      • Optional score: number

      Returns void

    \ No newline at end of file +

    Parameters

    Returns {
        group: RawStoneString;
        removed: boolean;
    }

    \ No newline at end of file diff --git a/docs/classes/StoneString.html b/docs/classes/StoneString.html index 49af318f..aa7914f0 100644 --- a/docs/classes/StoneString.html +++ b/docs/classes/StoneString.html @@ -1,6 +1,6 @@ StoneString | goban

    Class StoneString

    A StoneString instance represents a group of intersections that are connected to each other and are all the same color.

    -

    Constructors

    Constructors

    Properties

    Constructors

    Properties

    __added_neighbors: {
        [group_id: number]: boolean;
    }

    Type declaration

    • [group_id: number]: boolean
    id: number
    intersections: JGOFIntersection[]
    is_territory: boolean = false
    neighboring_space: StoneString[]
    neighboring_stone_strings: StoneString[]
    neighbors: StoneString[]
    territory_color: JGOFNumericPlayerColor = 0

    Methods

    • Adds a stone string to our neighbor list. This should probably only be called by StoneStringBuilder.

      -

      Parameters

      Returns void

    • Add a stone to the group. This should probably only be called by StoneStringBuilder.

      -

      Parameters

      • x: number
      • y: number

      Returns void

    • Compute if this string is considered potential territory (if all of it's +

    Constructors

    Properties

    __added_neighbors: {
        [group_id: number]: boolean;
    }

    Type declaration

    • [group_id: number]: boolean
    id: number
    intersections: JGOFIntersection[]
    is_territory: boolean = false
    neighboring_space: StoneString[]
    neighboring_stone_strings: StoneString[]
    neighbors: StoneString[]
    territory_color: JGOFNumericPlayerColor = 0

    Methods

    • Adds a stone string to our neighbor list. This should probably only be called by StoneStringBuilder.

      +

      Parameters

      Returns void

    • Add a stone to the group. This should probably only be called by StoneStringBuilder.

      +

      Parameters

      • x: number
      • y: number

      Returns void

    • Compute if this string is considered potential territory (if all of it's neighbors are the same color). NOTE: This does not perform any advanced logic to determine seki status or anything like that, this only looks to see if the string contains EMPTY locations and that all of the surrounding neighboring are the same color. This should probably only be called by StoneStringBuilder.

      -

      Returns void

    • Parameters

      • fn: ((stone_string) => void)
          • (stone_string): void
          • Parameters

            Returns void

      Returns void

    • Parameters

      • fn: ((stone_string) => void)
          • (stone_string): void
          • Parameters

            Returns void

      Returns void

    • Parameters

      • fn: ((stone_string) => void)
          • (stone_string): void
          • Parameters

            Returns void

      Returns void

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/docs/classes/StoneStringBuilder.html b/docs/classes/StoneStringBuilder.html index e206f180..9c0f695c 100644 --- a/docs/classes/StoneStringBuilder.html +++ b/docs/classes/StoneStringBuilder.html @@ -1,7 +1,7 @@ -StoneStringBuilder | goban

    Class StoneStringBuilder

    Constructors

    constructor +StoneStringBuilder | goban

    Class StoneStringBuilder

    Constructors

    Properties

    state: BoardState
    stone_string_id_map: number[][]
    stone_strings: StoneString[]

    Methods

    \ No newline at end of file +

    Constructors

    Properties

    state: BoardState
    stone_string_id_map: number[][]
    stone_strings: StoneString[]

    Methods

    \ No newline at end of file diff --git a/docs/classes/TestGoban.html b/docs/classes/TestGoban.html index 97ef3ae3..930f5e8f 100644 --- a/docs/classes/TestGoban.html +++ b/docs/classes/TestGoban.html @@ -1,5 +1,5 @@ TestGoban | goban

    Class TestGoban

    This is a minimal implementation of Goban, primarily used for unit tests.

    -

    Hierarchy (view full)

    Constructors

    Hierarchy (view full)

    Constructors

    Properties

    __board_redraw_pen_layer_timer: any = null
    __clock_timer?: Timeout
    __draw_state: string[][]
    __last_pt: {
        i: number;
        j: number;
        valid: boolean;
    } = ...

    Type declaration

    • i: number
    • j: number
    • valid: boolean
    __update_move_tree: any = null
    analysis_move_counter: number
    analysis_removal_last_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    analysis_removal_state?: boolean
    bounded_height: number
    bounded_width: number
    bounds: GobanBounds
    chat_log: GobanChatLog = []
    circle_radius: number
    clock_should_be_paused_for_move_submission: boolean = false
    colored_circles?: (undefined | ColoredCircle)[][]
    conditional_path: string = ""
    conditional_starting_color: "black" | "white" | "invalid" = "invalid"
    conditional_tree: ConditionalMoveTree = ...
    config: GobanConfig
    connectToReviewSent?: boolean
    current_cmove?: ConditionalMoveTree
    currently_my_cmove: boolean = false
    dirty_redraw: any = null
    disconnectedFromGame: boolean = true
    display_width?: number
    done_loading_review: boolean = false
    dont_draw_last_move: boolean
    double_click_submit: boolean
    draw_bottom_labels: boolean
    draw_left_labels: boolean
    draw_right_labels: boolean
    draw_top_labels: boolean
    edit_color?: "black" | "white"
    engine: GobanEngine
    errorHandler: ((e) => void)

    Type declaration

      • (e): void
      • Parameters

        • e: Error

        Returns void

    game_id: number
    game_type: string
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    goban_id: number = ++last_goban_id

    Base fields *

    -
    heatmap?: NumberMatrix
    height: number
    highlight_movetree_moves: boolean
    interactive: boolean
    isInPushedAnalysis: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    label_character: string
    label_mark: string = "[UNSET]"
    last_clock?: AdHocClock
    last_emitted_clock?: JGOFClockWithTransmitting
    last_hover_square?: JGOFIntersection
    last_move?: MoveTree
    last_move_radius: number
    last_paused_by_player_state: null | boolean = null
    last_paused_state: null | boolean = null
    last_phase?: GobanEnginePhase
    last_review_message: ReviewMessage
    last_sound_played_for_a_stone_placement?: string
    last_stone_sound: number
    leavePushedAnalysis: (() => void)

    Type declaration

      • (): void
      • Returns void

    marked_analysis_score?: boolean[][]
    move_selected?: JGOFIntersection
    no_display: boolean
    onError?: ((error) => void)

    Type declaration

      • (error): void
      • Parameters

        • error: Error

        Returns void

    on_game_screen: boolean
    one_click_submit: boolean
    original_square_size: number | ((goban) => number) | "auto"

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    parent: HTMLElement
    pause_control?: AdHocPauseControl
    paused_since?: number
    pen_marks: any[]
    player_id: number
    preloaded_data?: GobanConfig
    previous_mode: string
    puzzle_autoplace_delay: number
    restrict_moves_to_movetree: boolean
    review_had_gamedata: boolean
    review_id: number
    scoring_mode: boolean | "stalling-scoring-mode"
    sendLatencyTimer?: Timeout
    sent_timed_out_message: boolean = false
    shift_key_is_down: boolean
    show_move_numbers: boolean
    show_variation_move_numbers: boolean
    showing_scores: boolean = false
    socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
    square_size: number = 10
    stalling_score_estimate?: StallingScoreEstimate
    stone_placement_enabled: boolean
    stone_removal_auto_scoring_done?: boolean = false
    variation_stone_opacity: number
    visual_undo_request_indicator: boolean
    width: number
    THEMES: ThemesInterface = THEMES
    THEMES_SORTED: {
        black: GobanTheme[];
        board: GobanTheme[];
        white: GobanTheme[];
        [key: string]: GobanTheme[];
    } = THEMES_SORTED

    Type declaration

    setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

    Type declaration

      • (newCallbacks): void
      • Set's callback functions to be called in various situations. You can set any +

    Constructors

    Properties

    __board_redraw_pen_layer_timer: any = null
    __clock_timer?: Timeout
    __draw_state: string[][]
    __last_pt: {
        i: number;
        j: number;
        valid: boolean;
    } = ...

    Type declaration

    • i: number
    • j: number
    • valid: boolean
    __update_move_tree: any = null
    analysis_move_counter: number
    analysis_removal_last_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    analysis_removal_state?: boolean
    bounded_height: number
    bounded_width: number
    bounds: GobanBounds
    chat_log: GobanChatLog = []
    circle_radius: number
    clock_should_be_paused_for_move_submission: boolean = false
    colored_circles?: (undefined | ColoredCircle)[][]
    conditional_path: string = ""
    conditional_starting_color: "black" | "white" | "invalid" = "invalid"
    conditional_tree: ConditionalMoveTree = ...
    config: GobanConfig
    connectToReviewSent?: boolean
    current_cmove?: ConditionalMoveTree
    currently_my_cmove: boolean = false
    dirty_redraw: any = null
    disconnectedFromGame: boolean = true
    display_width?: number
    done_loading_review: boolean = false
    dont_draw_last_move: boolean
    double_click_submit: boolean
    draw_bottom_labels: boolean
    draw_left_labels: boolean
    draw_right_labels: boolean
    draw_top_labels: boolean
    edit_color?: "black" | "white"
    engine: GobanEngine
    errorHandler: ((e) => void)

    Type declaration

      • (e): void
      • Parameters

        • e: Error

        Returns void

    game_id: number
    game_type: string
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    goban_id: number = ++last_goban_id

    Base fields *

    +
    heatmap?: NumberMatrix
    height: number
    highlight_movetree_moves: boolean
    interactive: boolean
    isInPushedAnalysis: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    label_character: string
    label_mark: string = "[UNSET]"
    last_clock?: AdHocClock
    last_emitted_clock?: JGOFClockWithTransmitting
    last_hover_square?: JGOFIntersection
    last_move?: MoveTree
    last_move_radius: number
    last_paused_by_player_state: null | boolean = null
    last_paused_state: null | boolean = null
    last_phase?: GobanEnginePhase
    last_review_message: ReviewMessage
    last_sound_played_for_a_stone_placement?: string
    last_stone_sound: number
    leavePushedAnalysis: (() => void)

    Type declaration

      • (): void
      • Returns void

    marked_analysis_score?: boolean[][]
    move_selected?: JGOFIntersection
    no_display: boolean
    onError?: ((error) => void)

    Type declaration

      • (error): void
      • Parameters

        • error: Error

        Returns void

    on_game_screen: boolean
    one_click_submit: boolean
    original_square_size: number | ((goban) => number) | "auto"

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    parent: HTMLElement
    pause_control?: AdHocPauseControl
    paused_since?: number
    pen_marks: any[]
    player_id: number
    preloaded_data?: GobanConfig
    previous_mode: string
    puzzle_autoplace_delay: number
    restrict_moves_to_movetree: boolean
    review_had_gamedata: boolean
    review_id: number
    scoring_mode: boolean | "stalling-scoring-mode"
    sendLatencyTimer?: Timeout
    sent_timed_out_message: boolean = false
    shift_key_is_down: boolean
    show_move_numbers: boolean
    show_variation_move_numbers: boolean
    showing_scores: boolean = false
    socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
    square_size: number = 10
    stalling_score_estimate?: StallingScoreEstimate
    stone_placement_enabled: boolean
    stone_removal_auto_scoring_done?: boolean = false
    variation_stone_opacity: number
    visual_undo_request_indicator: boolean
    width: number
    THEMES: ThemesInterface = THEMES
    THEMES_SORTED: {
        black: GobanTheme[];
        board: GobanTheme[];
        white: GobanTheme[];
        [key: string]: GobanTheme[];
    } = THEMES_SORTED

    Type declaration

    setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

    Type declaration

      • (newCallbacks): void
      • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

        -

        Parameters

        Returns void

    setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

    Type declaration

      • (_catalog, _debug_mode?): void
      • Parameters

        Returns void

    Accessors

    • get analyze_subtool(): string
    • Returns string

    • set analyze_subtool(analyze_subtool): void
    • Parameters

      • analyze_subtool: string

      Returns void

    • get destroyed(): boolean
    • Returns boolean

    • get review_controller_id(): undefined | number
    • Returns undefined | number

    • set review_controller_id(review_controller_id): void
    • Parameters

      • review_controller_id: undefined | number

      Returns void

    • get review_owner_id(): undefined | number
    • Returns undefined | number

    • set review_owner_id(review_owner_id): void
    • Parameters

      • review_owner_id: undefined | number

      Returns void

    • get submit_move(): undefined | (() => void)
    • Returns undefined | (() => void)

    • set submit_move(submit_move): void
    • Parameters

      • submit_move: undefined | (() => void)

      Returns void

    Methods

    • Decodes any of the various ways we express moves that we've accumulated over the years into +

      Parameters

      Returns void

    setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

    Type declaration

      • (_catalog, _debug_mode?): void
      • Parameters

        Returns void

    Accessors

    • get analyze_subtool(): string
    • Returns string

    • set analyze_subtool(analyze_subtool): void
    • Parameters

      • analyze_subtool: string

      Returns void

    • get destroyed(): boolean
    • Returns boolean

    • get review_controller_id(): undefined | number
    • Returns undefined | number

    • set review_controller_id(review_controller_id): void
    • Parameters

      • review_controller_id: undefined | number

      Returns void

    • get review_owner_id(): undefined | number
    • Returns undefined | number

    • set review_owner_id(review_owner_id): void
    • Parameters

      • review_owner_id: undefined | number

      Returns void

    • get submit_move(): undefined | (() => void)
    • Returns undefined | (() => void)

    • set submit_move(submit_move): void
    • Parameters

      • submit_move: undefined | (() => void)

      Returns void

    Methods

    • Decodes a move string like "A11" into a move object like {x: 0, y: 10}. Also handles the special cases like ".." and "pass" which map to {x: -1, y: -1}.

      -

      Parameters

      • coordinates: string

      Returns JGOFMove

    • Marks scores on the board when in analysis mode. Note: this will not clear existing scores, this is intentional as I think it's the expected behavior of reviewers

      -

      Returns void

    • Goban calls some abstract methods as part of the construction process. Because our subclasses might (and do) need to do some of their own config before these are called, we set this function to be called by our subclass after it's done it's own internal config stuff.

      -

      Returns GobanEngine

    • When we think our clock has runout, send a message to the server letting it know. Otherwise we have to wait for the server grace period to expire for it to time us out.

      -

      Returns void

    • Parameters

      • colored_marks: {
            [key: string]: {
                color: string;
                move: string;
            };
        }
        • [key: string]: {
              color: string;
              move: string;
          }
          • color: string
          • move: string

      Returns void

    • Called when a location is marked or unmarked for removal

      -

      Parameters

      • x: number
      • y: number
      • removed: boolean
      • emit_stone_removal_updated: boolean = true

      Returns void

    • Parameters

      • colored_marks: {
            [key: string]: {
                color: string;
                move: string;
            };
        }
        • [key: string]: {
              color: string;
              move: string;
          }
          • color: string
          • move: string

      Returns void

    • Called when a location is marked or unmarked for removal

      +

      Parameters

      • x: number
      • y: number
      • removed: boolean
      • emit_stone_removal_updated: boolean = true

      Returns void

    • This is a callback that gets called by GobanEngine.getState to save and board state as it pushes and pops state. Our renderers can override this to save state they need.

      -

      Parameters

      • marks: {
            [mark: string]: string;
        }
        • [mark: string]: string
      • Optional dont_draw: boolean

      Returns void

    • This is a callback that gets called by GobanEngine.setState to load +

      Parameters

      • marks: {
            [mark: string]: string;
        }
        • [mark: string]: string
      • Optional dont_draw: boolean

      Returns void

    • Parameters

      • msg_id: MessageID
      • Optional parameters: {
            [key: string]: any;
        }
        • [key: string]: any
      • Optional timeout: number

      Returns void

    • Parameters

      • x: number
      • y: number
      • mark: string | number
      • Optional force_label: boolean
      • Optional force_put: boolean

      Returns boolean

    • Parameters

      • x: number
      • y: number
      • anti_slip: boolean = true

      Returns {
          i: number;
          j: number;
          valid: boolean;
      }

      • i: number
      • j: number
      • valid: boolean
    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/docs/classes/_internal_.OGSConnectivity.html b/docs/classes/_internal_.OGSConnectivity.html index 69a33fb5..1e678c1a 100644 --- a/docs/classes/_internal_.OGSConnectivity.html +++ b/docs/classes/_internal_.OGSConnectivity.html @@ -2,7 +2,7 @@ that manages connections to the online-go.com servers.

    We have it as a separate base class simply to help with code organization and to keep our Goban class size down.

    -

    Hierarchy (view full)

    Constructors

    Hierarchy (view full)

    Constructors

    Properties

    __board_redraw_pen_layer_timer: any = null
    __clock_timer?: Timeout
    __draw_state: string[][]
    __last_pt: {
        i: number;
        j: number;
        valid: boolean;
    } = ...

    Type declaration

    • i: number
    • j: number
    • valid: boolean
    __update_move_tree: any = null
    analysis_move_counter: number
    analysis_removal_last_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    analysis_removal_state?: boolean
    bounded_height: number
    bounded_width: number
    bounds: GobanBounds
    chat_log: GobanChatLog = []
    circle_radius: number
    clock_should_be_paused_for_move_submission: boolean = false
    colored_circles?: (undefined | ColoredCircle)[][]
    conditional_path: string = ""
    conditional_starting_color: "black" | "white" | "invalid" = "invalid"
    conditional_tree: ConditionalMoveTree = ...
    config: GobanConfig
    connectToReviewSent?: boolean
    current_cmove?: ConditionalMoveTree
    currently_my_cmove: boolean = false
    dirty_redraw: any = null
    disconnectedFromGame: boolean = true
    display_width?: number
    done_loading_review: boolean = false
    dont_draw_last_move: boolean
    double_click_submit: boolean
    draw_bottom_labels: boolean
    draw_left_labels: boolean
    draw_right_labels: boolean
    draw_top_labels: boolean
    edit_color?: "black" | "white"
    engine: GobanEngine
    errorHandler: ((e) => void)

    Type declaration

      • (e): void
      • Parameters

        • e: Error

        Returns void

    game_id: number
    game_type: string
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    goban_id: number = ++last_goban_id

    Base fields *

    -
    heatmap?: NumberMatrix
    height: number
    highlight_movetree_moves: boolean
    interactive: boolean
    isInPushedAnalysis: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    label_character: string
    label_mark: string = "[UNSET]"
    last_clock?: AdHocClock
    last_emitted_clock?: JGOFClockWithTransmitting
    last_hover_square?: JGOFIntersection
    last_move?: MoveTree
    last_move_radius: number
    last_paused_by_player_state: null | boolean = null
    last_paused_state: null | boolean = null
    last_phase?: GobanEnginePhase
    last_review_message: ReviewMessage
    last_sound_played_for_a_stone_placement?: string
    last_stone_sound: number
    leavePushedAnalysis: (() => void)

    Type declaration

      • (): void
      • Returns void

    marked_analysis_score?: boolean[][]
    move_selected?: JGOFIntersection
    no_display: boolean
    onError?: ((error) => void)

    Type declaration

      • (error): void
      • Parameters

        • error: Error

        Returns void

    on_game_screen: boolean
    one_click_submit: boolean
    original_square_size: number | ((goban) => number) | "auto"

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    pause_control?: AdHocPauseControl
    paused_since?: number
    pen_marks: any[]
    player_id: number
    preloaded_data?: GobanConfig
    previous_mode: string
    puzzle_autoplace_delay: number
    restrict_moves_to_movetree: boolean
    review_had_gamedata: boolean
    review_id: number
    scoring_mode: boolean | "stalling-scoring-mode"
    sendLatencyTimer?: Timeout
    sent_timed_out_message: boolean = false
    shift_key_is_down: boolean
    show_move_numbers: boolean
    show_variation_move_numbers: boolean
    showing_scores: boolean = false
    socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
    square_size: number = 10
    stalling_score_estimate?: StallingScoreEstimate
    stone_placement_enabled: boolean
    stone_removal_auto_scoring_done?: boolean = false
    variation_stone_opacity: number
    visual_undo_request_indicator: boolean
    width: number
    setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

    Type declaration

      • (newCallbacks): void
      • Set's callback functions to be called in various situations. You can set any +

    Constructors

    Properties

    __board_redraw_pen_layer_timer: any = null
    __clock_timer?: Timeout
    __draw_state: string[][]
    __last_pt: {
        i: number;
        j: number;
        valid: boolean;
    } = ...

    Type declaration

    • i: number
    • j: number
    • valid: boolean
    __update_move_tree: any = null
    analysis_move_counter: number
    analysis_removal_last_position: {
        i: number;
        j: number;
    } = ...

    Type declaration

    • i: number
    • j: number
    analysis_removal_state?: boolean
    bounded_height: number
    bounded_width: number
    bounds: GobanBounds
    chat_log: GobanChatLog = []
    circle_radius: number
    clock_should_be_paused_for_move_submission: boolean = false
    colored_circles?: (undefined | ColoredCircle)[][]
    conditional_path: string = ""
    conditional_starting_color: "black" | "white" | "invalid" = "invalid"
    conditional_tree: ConditionalMoveTree = ...
    config: GobanConfig
    connectToReviewSent?: boolean
    current_cmove?: ConditionalMoveTree
    currently_my_cmove: boolean = false
    dirty_redraw: any = null
    disconnectedFromGame: boolean = true
    display_width?: number
    done_loading_review: boolean = false
    dont_draw_last_move: boolean
    double_click_submit: boolean
    draw_bottom_labels: boolean
    draw_left_labels: boolean
    draw_right_labels: boolean
    draw_top_labels: boolean
    edit_color?: "black" | "white"
    engine: GobanEngine
    errorHandler: ((e) => void)

    Type declaration

      • (e): void
      • Parameters

        • e: Error

        Returns void

    game_id: number
    game_type: string
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    goban_id: number = ++last_goban_id

    Base fields *

    +
    heatmap?: NumberMatrix
    height: number
    highlight_movetree_moves: boolean
    interactive: boolean
    isInPushedAnalysis: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    label_character: string
    label_mark: string = "[UNSET]"
    last_clock?: AdHocClock
    last_emitted_clock?: JGOFClockWithTransmitting
    last_hover_square?: JGOFIntersection
    last_move?: MoveTree
    last_move_radius: number
    last_paused_by_player_state: null | boolean = null
    last_paused_state: null | boolean = null
    last_phase?: GobanEnginePhase
    last_review_message: ReviewMessage
    last_sound_played_for_a_stone_placement?: string
    last_stone_sound: number
    leavePushedAnalysis: (() => void)

    Type declaration

      • (): void
      • Returns void

    marked_analysis_score?: boolean[][]
    move_selected?: JGOFIntersection
    no_display: boolean
    onError?: ((error) => void)

    Type declaration

      • (error): void
      • Parameters

        • error: Error

        Returns void

    on_game_screen: boolean
    one_click_submit: boolean
    original_square_size: number | ((goban) => number) | "auto"

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    pause_control?: AdHocPauseControl
    paused_since?: number
    pen_marks: any[]
    player_id: number
    preloaded_data?: GobanConfig
    previous_mode: string
    puzzle_autoplace_delay: number
    restrict_moves_to_movetree: boolean
    review_had_gamedata: boolean
    review_id: number
    scoring_mode: boolean | "stalling-scoring-mode"
    sendLatencyTimer?: Timeout
    sent_timed_out_message: boolean = false
    shift_key_is_down: boolean
    show_move_numbers: boolean
    show_variation_move_numbers: boolean
    showing_scores: boolean = false
    socket_event_bindings: [keyof GobanSocketEvents, (() => void)][] = []
    square_size: number = 10
    stalling_score_estimate?: StallingScoreEstimate
    stone_placement_enabled: boolean
    stone_removal_auto_scoring_done?: boolean = false
    variation_stone_opacity: number
    visual_undo_request_indicator: boolean
    width: number
    setCallbacks: ((newCallbacks) => void) = setGobanCallbacks

    Type declaration

      • (newCallbacks): void
      • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

        -

        Parameters

        Returns void

    setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

    Type declaration

      • (_catalog, _debug_mode?): void
      • Parameters

        Returns void

    Accessors

    Methods

    setTranslations: ((_catalog, _debug_mode?) => void) = setGobanTranslations

    Type declaration

      • (_catalog, _debug_mode?): void
      • Parameters

        Returns void

    Accessors

    Methods

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/docs/enums/JGOFNumericPlayerColor.html b/docs/enums/JGOFNumericPlayerColor.html index 906bcde8..c73e961a 100644 --- a/docs/enums/JGOFNumericPlayerColor.html +++ b/docs/enums/JGOFNumericPlayerColor.html @@ -1,4 +1,4 @@ -JGOFNumericPlayerColor | goban

    Enumeration JGOFNumericPlayerColor

    Enumeration Members

    BLACK +JGOFNumericPlayerColor | goban

    Enumeration JGOFNumericPlayerColor

    Enumeration Members

    Enumeration Members

    BLACK: 1
    EMPTY: 0
    WHITE: 2
    \ No newline at end of file +

    Enumeration Members

    BLACK: 1
    EMPTY: 0
    WHITE: 2
    \ No newline at end of file diff --git a/docs/enums/protocol.RemoteStorageReplication.html b/docs/enums/protocol.RemoteStorageReplication.html index 295c47c9..992854e1 100644 --- a/docs/enums/protocol.RemoteStorageReplication.html +++ b/docs/enums/protocol.RemoteStorageReplication.html @@ -1,13 +1,13 @@ RemoteStorageReplication | goban

    Enumeration RemoteStorageReplication

    This enum defines the various replication strategies for the remote storage system. For more details on the remote storage replication system see: https://github.com/online-go/online-go.com/blob/devel/src/lib/data.ts

    -

    Enumeration Members

    Enumeration Members

    LOCAL_OVERWRITES_REMOTE: 1

    Locally set data will overwrite remotely set data, but if not set will default to remotely set data

    -
    NONE: 0

    No replication of this change

    -
    REMOTE_ONLY: 4

    Remotely set data, but do not update our local value

    -
    REMOTE_OVERWRITES_LOCAL: 2

    Remotely set data will overwrite locally set data

    -
    \ No newline at end of file +
    NONE: 0

    No replication of this change

    +
    REMOTE_ONLY: 4

    Remotely set data, but do not update our local value

    +
    REMOTE_OVERWRITES_LOCAL: 2

    Remotely set data will overwrite locally set data

    +
    \ No newline at end of file diff --git a/docs/functions/adjust_estimate.html b/docs/functions/adjust_estimate.html index aaed400f..d9aecf60 100644 --- a/docs/functions/adjust_estimate.html +++ b/docs/functions/adjust_estimate.html @@ -4,4 +4,4 @@
  • area_map: number[][]

    Representation of the ownership, 1=Black, -1=White, 0=Undecided using Area rules

  • score: number

    estimated score (not accounting for captures)

    -
  • Returns {
        ownership: Matrix<number>;
        score: number;
    }

    \ No newline at end of file +

    Returns {
        ownership: Matrix<number>;
        score: number;
    }

    \ No newline at end of file diff --git a/docs/functions/allocateCanvasOrError.html b/docs/functions/allocateCanvasOrError.html index 05378d2e..8f5b082d 100644 --- a/docs/functions/allocateCanvasOrError.html +++ b/docs/functions/allocateCanvasOrError.html @@ -5,4 +5,4 @@

    If string dimensions are used we'll use setAttribute, if numbers are used we'll set the canvas .width and .height parameter. This is for device scaling considerations when the given dimensions are scaled on HDPI devices.

    -

    Parameters

    Returns HTMLCanvasElement

    \ No newline at end of file +

    Parameters

    Returns HTMLCanvasElement

    \ No newline at end of file diff --git a/docs/functions/autoscore.html b/docs/functions/autoscore.html index caab6afb..d53692e6 100644 --- a/docs/functions/autoscore.html +++ b/docs/functions/autoscore.html @@ -1 +1 @@ -autoscore | goban

    Function autoscore

    \ No newline at end of file +autoscore | goban

    Function autoscore

    \ No newline at end of file diff --git a/docs/functions/char2num.html b/docs/functions/char2num.html index 22025c13..e7412aea 100644 --- a/docs/functions/char2num.html +++ b/docs/functions/char2num.html @@ -1 +1 @@ -char2num | goban

    Function char2num

    \ No newline at end of file +char2num | goban

    Function char2num

    \ No newline at end of file diff --git a/docs/functions/cloneMatrix.html b/docs/functions/cloneMatrix.html index a88d373f..3faa2016 100644 --- a/docs/functions/cloneMatrix.html +++ b/docs/functions/cloneMatrix.html @@ -1,2 +1,2 @@ cloneMatrix | goban

    Function cloneMatrix

    • Returns a cloned copy of the provided matrix

      -

      Type Parameters

      • T

      Parameters

      • matrix: T[][]

      Returns T[][]

    \ No newline at end of file +

    Type Parameters

    Parameters

    Returns T[][]

    \ No newline at end of file diff --git a/docs/functions/closeErrorCodeToString.html b/docs/functions/closeErrorCodeToString.html index 95cb2bbc..7a3af9d3 100644 --- a/docs/functions/closeErrorCodeToString.html +++ b/docs/functions/closeErrorCodeToString.html @@ -1 +1 @@ -closeErrorCodeToString | goban

    Function closeErrorCodeToString

    \ No newline at end of file +closeErrorCodeToString | goban

    Function closeErrorCodeToString

    \ No newline at end of file diff --git a/docs/functions/color_blend.html b/docs/functions/color_blend.html index c2433ab0..a7912bfe 100644 --- a/docs/functions/color_blend.html +++ b/docs/functions/color_blend.html @@ -1,2 +1,2 @@ color_blend | goban

    Function color_blend

    • Simple 50% blend of two colors in hex format

      -

      Parameters

      • c1: string
      • c2: string

      Returns string

    \ No newline at end of file +

    Parameters

    Returns string

    \ No newline at end of file diff --git a/docs/functions/computeAverageMoveTime.html b/docs/functions/computeAverageMoveTime.html index 7b8493c0..6fb5fcb1 100644 --- a/docs/functions/computeAverageMoveTime.html +++ b/docs/functions/computeAverageMoveTime.html @@ -1,2 +1,2 @@ computeAverageMoveTime | goban

    Function computeAverageMoveTime

    \ No newline at end of file +

    Parameters

    Returns number

    \ No newline at end of file diff --git a/docs/functions/createDeviceScaledCanvas.html b/docs/functions/createDeviceScaledCanvas.html index 16a718e9..648cb59a 100644 --- a/docs/functions/createDeviceScaledCanvas.html +++ b/docs/functions/createDeviceScaledCanvas.html @@ -1 +1 @@ -createDeviceScaledCanvas | goban

    Function createDeviceScaledCanvas

    • Parameters

      • width: number
      • height: number

      Returns HTMLCanvasElement

    \ No newline at end of file +createDeviceScaledCanvas | goban

    Function createDeviceScaledCanvas

    • Parameters

      • width: number
      • height: number

      Returns HTMLCanvasElement

    \ No newline at end of file diff --git a/docs/functions/createGoban.html b/docs/functions/createGoban.html index 78e02da3..cc4f0b8d 100644 --- a/docs/functions/createGoban.html +++ b/docs/functions/createGoban.html @@ -1 +1 @@ -createGoban | goban

    Function createGoban

    \ No newline at end of file +createGoban | goban

    Function createGoban

    \ No newline at end of file diff --git a/docs/functions/decodeCoordinate.html b/docs/functions/decodeCoordinate.html index de666f1b..76555627 100644 --- a/docs/functions/decodeCoordinate.html +++ b/docs/functions/decodeCoordinate.html @@ -1,2 +1,2 @@ decodeCoordinate | goban

    Function decodeCoordinate

    \ No newline at end of file +

    Parameters

    Returns number

    \ No newline at end of file diff --git a/docs/functions/decodeGTPCoordinates.html b/docs/functions/decodeGTPCoordinates.html index 7c655f34..74a1924b 100644 --- a/docs/functions/decodeGTPCoordinates.html +++ b/docs/functions/decodeGTPCoordinates.html @@ -1,2 +1,2 @@ decodeGTPCoordinates | goban

    Function decodeGTPCoordinates

    \ No newline at end of file +

    Parameters

    Returns JGOFMove

    \ No newline at end of file diff --git a/docs/functions/decodeMoves.html b/docs/functions/decodeMoves.html index 35fa945d..bbb1bafb 100644 --- a/docs/functions/decodeMoves.html +++ b/docs/functions/decodeMoves.html @@ -1,3 +1,3 @@ decodeMoves | goban

    Function decodeMoves

    \ No newline at end of file +

    Parameters

    Returns JGOFMove[]

    \ No newline at end of file diff --git a/docs/functions/decodePrettyCoordinates.html b/docs/functions/decodePrettyCoordinates.html index 8cd9ed57..dba0d0a0 100644 --- a/docs/functions/decodePrettyCoordinates.html +++ b/docs/functions/decodePrettyCoordinates.html @@ -1,2 +1,2 @@ decodePrettyCoordinates | goban

    Function decodePrettyCoordinates

    \ No newline at end of file +

    Parameters

    Returns JGOFMove

    \ No newline at end of file diff --git a/docs/functions/decodePrettyXCoordinate.html b/docs/functions/decodePrettyXCoordinate.html index 062025dc..b8cbab29 100644 --- a/docs/functions/decodePrettyXCoordinate.html +++ b/docs/functions/decodePrettyXCoordinate.html @@ -1,2 +1,2 @@ decodePrettyXCoordinate | goban

    Function decodePrettyXCoordinate

    • Decodes the pretty X coordinate to a number

      -

      Parameters

      • ch: string

      Returns number

    \ No newline at end of file +

    Parameters

    Returns number

    \ No newline at end of file diff --git a/docs/functions/deepClone.html b/docs/functions/deepClone.html index ba14b66d..20152582 100644 --- a/docs/functions/deepClone.html +++ b/docs/functions/deepClone.html @@ -1,2 +1,2 @@ deepClone | goban

    Function deepClone

    \ No newline at end of file +

    Parameters

    Returns any

    \ No newline at end of file diff --git a/docs/functions/deepEqual.html b/docs/functions/deepEqual.html index 8d8a4c29..b6ee199d 100644 --- a/docs/functions/deepEqual.html +++ b/docs/functions/deepEqual.html @@ -1,2 +1,2 @@ deepEqual | goban

    Function deepEqual

    \ No newline at end of file +

    Parameters

    Returns boolean

    \ No newline at end of file diff --git a/docs/functions/deviceCanvasScalingRatio.html b/docs/functions/deviceCanvasScalingRatio.html index 2e2cd508..c297b794 100644 --- a/docs/functions/deviceCanvasScalingRatio.html +++ b/docs/functions/deviceCanvasScalingRatio.html @@ -1 +1 @@ -deviceCanvasScalingRatio | goban

    Function deviceCanvasScalingRatio

    \ No newline at end of file +deviceCanvasScalingRatio | goban

    Function deviceCanvasScalingRatio

    \ No newline at end of file diff --git a/docs/functions/elementOffset.html b/docs/functions/elementOffset.html index a330c660..28f6c247 100644 --- a/docs/functions/elementOffset.html +++ b/docs/functions/elementOffset.html @@ -1 +1 @@ -elementOffset | goban

    Function elementOffset

    • Parameters

      • element: HTMLElement

      Returns {
          left: number;
          top: number;
      }

      • left: number
      • top: number
    \ No newline at end of file +elementOffset | goban

    Function elementOffset

    • Parameters

      • element: HTMLElement

      Returns {
          left: number;
          top: number;
      }

      • left: number
      • top: number
    \ No newline at end of file diff --git a/docs/functions/encodeCoordinate.html b/docs/functions/encodeCoordinate.html index abe5b8d4..51ce8e9d 100644 --- a/docs/functions/encodeCoordinate.html +++ b/docs/functions/encodeCoordinate.html @@ -1,2 +1,2 @@ encodeCoordinate | goban

    Function encodeCoordinate

    • Encodes a single coordinate to a number

      -

      Parameters

      • coor: number

      Returns string

    \ No newline at end of file +

    Parameters

    Returns string

    \ No newline at end of file diff --git a/docs/functions/encodeMove.html b/docs/functions/encodeMove.html index 82f4e8fe..86ab730d 100644 --- a/docs/functions/encodeMove.html +++ b/docs/functions/encodeMove.html @@ -1 +1 @@ -encodeMove | goban

    Function encodeMove

    \ No newline at end of file +encodeMove | goban

    Function encodeMove

    \ No newline at end of file diff --git a/docs/functions/encodeMoveToArray.html b/docs/functions/encodeMoveToArray.html index a335dcbb..bf021267 100644 --- a/docs/functions/encodeMoveToArray.html +++ b/docs/functions/encodeMoveToArray.html @@ -1 +1 @@ -encodeMoveToArray | goban

    Function encodeMoveToArray

    \ No newline at end of file +encodeMoveToArray | goban

    Function encodeMoveToArray

    \ No newline at end of file diff --git a/docs/functions/encodeMoves.html b/docs/functions/encodeMoves.html index 8c46cca8..06264536 100644 --- a/docs/functions/encodeMoves.html +++ b/docs/functions/encodeMoves.html @@ -1 +1 @@ -encodeMoves | goban

    Function encodeMoves

    \ No newline at end of file +encodeMoves | goban

    Function encodeMoves

    \ No newline at end of file diff --git a/docs/functions/encodeMovesToArray.html b/docs/functions/encodeMovesToArray.html index f1e8ff79..26e13e6f 100644 --- a/docs/functions/encodeMovesToArray.html +++ b/docs/functions/encodeMovesToArray.html @@ -1 +1 @@ -encodeMovesToArray | goban

    Function encodeMovesToArray

    \ No newline at end of file +encodeMovesToArray | goban

    Function encodeMovesToArray

    \ No newline at end of file diff --git a/docs/functions/encodePrettyXCoordinate.html b/docs/functions/encodePrettyXCoordinate.html index 7bbcb0da..5f85906a 100644 --- a/docs/functions/encodePrettyXCoordinate.html +++ b/docs/functions/encodePrettyXCoordinate.html @@ -1,2 +1,2 @@ encodePrettyXCoordinate | goban

    Function encodePrettyXCoordinate

    • Encodes an X coordinate to a display encoding

      -

      Parameters

      • coor: number

      Returns string

    \ No newline at end of file +

    Parameters

    Returns string

    \ No newline at end of file diff --git a/docs/functions/escapeSGFText.html b/docs/functions/escapeSGFText.html index 47fb2d01..22e1c278 100644 --- a/docs/functions/escapeSGFText.html +++ b/docs/functions/escapeSGFText.html @@ -1 +1 @@ -escapeSGFText | goban

    Function escapeSGFText

    • Parameters

      • txt: string
      • escapeColon: boolean = false

      Returns string

    \ No newline at end of file +escapeSGFText | goban

    Function escapeSGFText

    • Parameters

      • txt: string
      • escapeColon: boolean = false

      Returns string

    \ No newline at end of file diff --git a/docs/functions/getRandomInt.html b/docs/functions/getRandomInt.html index b9cb5518..cadb39ad 100644 --- a/docs/functions/getRandomInt.html +++ b/docs/functions/getRandomInt.html @@ -1,2 +1,2 @@ getRandomInt | goban

    Function getRandomInt

    • Returns a random integer between min (inclusive) and max (exclusive)

      -

      Parameters

      • min: number
      • max: number

      Returns number

    \ No newline at end of file +

    Parameters

    Returns number

    \ No newline at end of file diff --git a/docs/functions/getRelativeEventPosition.html b/docs/functions/getRelativeEventPosition.html index 6e9e2565..3431b73f 100644 --- a/docs/functions/getRelativeEventPosition.html +++ b/docs/functions/getRelativeEventPosition.html @@ -1,2 +1,2 @@ getRelativeEventPosition | goban

    Function getRelativeEventPosition

    • Returns {x,y} of the event relative to the event target

      -

      Parameters

      • event: TouchEvent | MouseEvent
      • Optional target: HTMLElement

      Returns {
          x: number;
          y: number;
      }

      • x: number
      • y: number
    \ No newline at end of file +

    Parameters

    Returns {
        x: number;
        y: number;
    }

    \ No newline at end of file diff --git a/docs/functions/getWorstMoves.html b/docs/functions/getWorstMoves.html index 5b45a2cf..509c3d2a 100644 --- a/docs/functions/getWorstMoves.html +++ b/docs/functions/getWorstMoves.html @@ -1,4 +1,4 @@ getWorstMoves | goban

    Function getWorstMoves

    \ No newline at end of file +

    Parameters

    Returns AIReviewWorstMoveEntry[]

    \ No newline at end of file diff --git a/docs/functions/init_remote_ownership_estimator.html b/docs/functions/init_remote_ownership_estimator.html index 5a73b507..cf4cd91b 100644 --- a/docs/functions/init_remote_ownership_estimator.html +++ b/docs/functions/init_remote_ownership_estimator.html @@ -1 +1 @@ -init_remote_ownership_estimator | goban

    Function init_remote_ownership_estimator

    \ No newline at end of file +init_remote_ownership_estimator | goban

    Function init_remote_ownership_estimator

    \ No newline at end of file diff --git a/docs/functions/init_wasm_ownership_estimator.html b/docs/functions/init_wasm_ownership_estimator.html index 7330b86c..9f9f7ff8 100644 --- a/docs/functions/init_wasm_ownership_estimator.html +++ b/docs/functions/init_wasm_ownership_estimator.html @@ -1 +1 @@ -init_wasm_ownership_estimator | goban

    Function init_wasm_ownership_estimator

    \ No newline at end of file +init_wasm_ownership_estimator | goban

    Function init_wasm_ownership_estimator

    \ No newline at end of file diff --git a/docs/functions/makeEmptyMatrix.html b/docs/functions/makeEmptyMatrix.html index 76f9902e..abbd4580 100644 --- a/docs/functions/makeEmptyMatrix.html +++ b/docs/functions/makeEmptyMatrix.html @@ -1 +1 @@ -makeEmptyMatrix | goban

    Function makeEmptyMatrix

    • Type Parameters

      • T

      Parameters

      • width: number
      • height: number

      Returns (T | undefined)[][]

    \ No newline at end of file +makeEmptyMatrix | goban

    Function makeEmptyMatrix

    • Type Parameters

      • T

      Parameters

      • width: number
      • height: number

      Returns (T | undefined)[][]

    \ No newline at end of file diff --git a/docs/functions/makeMatrix.html b/docs/functions/makeMatrix.html index 647dfd84..71901500 100644 --- a/docs/functions/makeMatrix.html +++ b/docs/functions/makeMatrix.html @@ -1 +1 @@ -makeMatrix | goban

    Function makeMatrix

    \ No newline at end of file +makeMatrix | goban

    Function makeMatrix

    \ No newline at end of file diff --git a/docs/functions/makeObjectMatrix.html b/docs/functions/makeObjectMatrix.html index 804a5807..9a666a5a 100644 --- a/docs/functions/makeObjectMatrix.html +++ b/docs/functions/makeObjectMatrix.html @@ -1 +1 @@ -makeObjectMatrix | goban

    Function makeObjectMatrix

    • Type Parameters

      • T

      Parameters

      • width: number
      • height: number

      Returns T[][]

    \ No newline at end of file +makeObjectMatrix | goban

    Function makeObjectMatrix

    • Type Parameters

      • T

      Parameters

      • width: number
      • height: number

      Returns T[][]

    \ No newline at end of file diff --git a/docs/functions/matricesAreEqual.html b/docs/functions/matricesAreEqual.html index d99e27c2..53fcb7bd 100644 --- a/docs/functions/matricesAreEqual.html +++ b/docs/functions/matricesAreEqual.html @@ -1,3 +1,3 @@ matricesAreEqual | goban

    Function matricesAreEqual

    • Returns true if the contents of the two 2d matrices are equal when the cells are compared with ===

      -

      Type Parameters

      • T

      Parameters

      • m1: T[][]
      • m2: T[][]

      Returns boolean

    \ No newline at end of file +

    Type Parameters

    Parameters

    Returns boolean

    \ No newline at end of file diff --git a/docs/functions/newlines_to_spaces.html b/docs/functions/newlines_to_spaces.html index 2460a380..242d9bea 100644 --- a/docs/functions/newlines_to_spaces.html +++ b/docs/functions/newlines_to_spaces.html @@ -1,3 +1,3 @@ newlines_to_spaces | goban

    Function newlines_to_spaces

    • SGF "simple text", eg used in the LB property, we can't have newlines. This strips them and replaces them with spaces.

      -

      Parameters

      • txt: string

      Returns string

    \ No newline at end of file +

    Parameters

    Returns string

    \ No newline at end of file diff --git a/docs/functions/niceInterval.html b/docs/functions/niceInterval.html index 59d406f6..3bdcd067 100644 --- a/docs/functions/niceInterval.html +++ b/docs/functions/niceInterval.html @@ -1,4 +1,4 @@ niceInterval | goban

    Function niceInterval

    • Like setInterval, but debounces catchups (multiple invocation in rapid succession less than our desired interval) that happen in some browsers when tabs wake up from sleep. Cleared with the standard clearInterval.

      -

      Parameters

      • callback: (() => void)
          • (): void
          • Returns void

      • interval: number

      Returns ReturnType<typeof setInterval>

    \ No newline at end of file +

    Parameters

    Returns ReturnType<typeof setInterval>

    \ No newline at end of file diff --git a/docs/functions/num2char.html b/docs/functions/num2char.html index b783a2d9..7a7e2b65 100644 --- a/docs/functions/num2char.html +++ b/docs/functions/num2char.html @@ -1 +1 @@ -num2char | goban

    Function num2char

    \ No newline at end of file +num2char | goban

    Function num2char

    \ No newline at end of file diff --git a/docs/functions/ojeSequenceToMoves.html b/docs/functions/ojeSequenceToMoves.html index 46bc196a..7752e01e 100644 --- a/docs/functions/ojeSequenceToMoves.html +++ b/docs/functions/ojeSequenceToMoves.html @@ -1 +1 @@ -ojeSequenceToMoves | goban

    Function ojeSequenceToMoves

    \ No newline at end of file +ojeSequenceToMoves | goban

    Function ojeSequenceToMoves

    \ No newline at end of file diff --git a/docs/functions/placeRenderedImageStone.html b/docs/functions/placeRenderedImageStone.html index d87f7fd3..6163da9f 100644 --- a/docs/functions/placeRenderedImageStone.html +++ b/docs/functions/placeRenderedImageStone.html @@ -1 +1 @@ -placeRenderedImageStone | goban

    Function placeRenderedImageStone

    • Parameters

      • ctx: CanvasRenderingContext2D
      • shadow_ctx: null | CanvasRenderingContext2D
      • stone: StoneType
      • cx: number
      • cy: number
      • radius: number

      Returns void

    \ No newline at end of file +placeRenderedImageStone | goban

    Function placeRenderedImageStone

    • Parameters

      • ctx: CanvasRenderingContext2D
      • shadow_ctx: null | CanvasRenderingContext2D
      • stone: StoneType
      • cx: number
      • cy: number
      • radius: number

      Returns void

    \ No newline at end of file diff --git a/docs/functions/positionId.html b/docs/functions/positionId.html index 613e9d10..230ddf4e 100644 --- a/docs/functions/positionId.html +++ b/docs/functions/positionId.html @@ -1 +1 @@ -positionId | goban

    Function positionId

    \ No newline at end of file +positionId | goban

    Function positionId

    \ No newline at end of file diff --git a/docs/functions/preRenderImageStone.html b/docs/functions/preRenderImageStone.html index d9ee29e3..dfa55194 100644 --- a/docs/functions/preRenderImageStone.html +++ b/docs/functions/preRenderImageStone.html @@ -1 +1 @@ -preRenderImageStone | goban

    Function preRenderImageStone

    \ No newline at end of file +preRenderImageStone | goban

    Function preRenderImageStone

    \ No newline at end of file diff --git a/docs/functions/prettyCoordinates.html b/docs/functions/prettyCoordinates.html index 5be52fbe..481f2093 100644 --- a/docs/functions/prettyCoordinates.html +++ b/docs/functions/prettyCoordinates.html @@ -1,2 +1,2 @@ prettyCoordinates | goban

    Function prettyCoordinates

    • Encodes an x,y pair to "pretty" coordinates, like "A3", or "K10"

      -

      Parameters

      • x: number
      • y: number
      • board_height: number

      Returns string

    \ No newline at end of file +

    Parameters

    Returns string

    \ No newline at end of file diff --git a/docs/functions/resizeDeviceScaledCanvas.html b/docs/functions/resizeDeviceScaledCanvas.html index 539a6939..d5b1926e 100644 --- a/docs/functions/resizeDeviceScaledCanvas.html +++ b/docs/functions/resizeDeviceScaledCanvas.html @@ -1 +1 @@ -resizeDeviceScaledCanvas | goban

    Function resizeDeviceScaledCanvas

    • Parameters

      • canvas: HTMLCanvasElement
      • width: number
      • height: number

      Returns HTMLCanvasElement

    \ No newline at end of file +resizeDeviceScaledCanvas | goban

    Function resizeDeviceScaledCanvas

    • Parameters

      • canvas: HTMLCanvasElement
      • width: number
      • height: number

      Returns HTMLCanvasElement

    \ No newline at end of file diff --git a/docs/functions/setGobanCallbacks.html b/docs/functions/setGobanCallbacks.html index 2efbb37e..cbb60e02 100644 --- a/docs/functions/setGobanCallbacks.html +++ b/docs/functions/setGobanCallbacks.html @@ -1,3 +1,3 @@ setGobanCallbacks | goban

    Function setGobanCallbacks

    • Set's callback functions to be called in various situations. You can set any or all of the callbacks, only the provided callbacks will be updated.

      -

      Parameters

      Returns void

    \ No newline at end of file +

    Parameters

    Returns void

    \ No newline at end of file diff --git a/docs/functions/setGobanRenderer.html b/docs/functions/setGobanRenderer.html index 65a532af..7cb086f2 100644 --- a/docs/functions/setGobanRenderer.html +++ b/docs/functions/setGobanRenderer.html @@ -1 +1 @@ -setGobanRenderer | goban

    Function setGobanRenderer

    • Parameters

      • _renderer: "canvas" | "svg"

      Returns void

    \ No newline at end of file +setGobanRenderer | goban

    Function setGobanRenderer

    • Parameters

      • _renderer: "canvas" | "svg"

      Returns void

    \ No newline at end of file diff --git a/docs/functions/set_local_ownership_estimator.html b/docs/functions/set_local_ownership_estimator.html index d21fc67c..f467c383 100644 --- a/docs/functions/set_local_ownership_estimator.html +++ b/docs/functions/set_local_ownership_estimator.html @@ -1 +1 @@ -set_local_ownership_estimator | goban

    Function set_local_ownership_estimator

    \ No newline at end of file +set_local_ownership_estimator | goban

    Function set_local_ownership_estimator

    \ No newline at end of file diff --git a/docs/functions/shortDurationString.html b/docs/functions/shortDurationString.html index 278c839d..bb3662bc 100644 --- a/docs/functions/shortDurationString.html +++ b/docs/functions/shortDurationString.html @@ -1,2 +1,2 @@ shortDurationString | goban

    Function shortDurationString

    • Takes a number of seconds and returns a string like "1d 3h 2m 52s"

      -

      Parameters

      • seconds: number

      Returns string

    \ No newline at end of file +

    Parameters

    Returns string

    \ No newline at end of file diff --git a/docs/functions/sortMoves.html b/docs/functions/sortMoves.html index 0be4817a..559a371e 100644 --- a/docs/functions/sortMoves.html +++ b/docs/functions/sortMoves.html @@ -1,2 +1,2 @@ sortMoves | goban

    Function sortMoves

    \ No newline at end of file +

    Parameters

    Returns string

  • Parameters

    Returns JGOFMove[]

  • \ No newline at end of file diff --git a/docs/functions/translate._.html b/docs/functions/translate._.html index 710a6025..0593a525 100644 --- a/docs/functions/translate._.html +++ b/docs/functions/translate._.html @@ -1 +1 @@ -_ | goban

    Function _

    \ No newline at end of file +_ | goban

    Function _

    \ No newline at end of file diff --git a/docs/functions/translate.interpolate.html b/docs/functions/translate.interpolate.html index e2b0229a..dc7510cf 100644 --- a/docs/functions/translate.interpolate.html +++ b/docs/functions/translate.interpolate.html @@ -1 +1 @@ -interpolate | goban

    Function interpolate

    • Parameters

      • str: string
      • params: any

      Returns string

    \ No newline at end of file +interpolate | goban

    Function interpolate

    • Parameters

      • str: string
      • params: any

      Returns string

    \ No newline at end of file diff --git a/docs/functions/translate.setGobanTranslations.html b/docs/functions/translate.setGobanTranslations.html index 7e6dcafc..44d94318 100644 --- a/docs/functions/translate.setGobanTranslations.html +++ b/docs/functions/translate.setGobanTranslations.html @@ -1 +1 @@ -setGobanTranslations | goban

    Function setGobanTranslations

    \ No newline at end of file +setGobanTranslations | goban

    Function setGobanTranslations

    \ No newline at end of file diff --git a/docs/functions/validateCanvas.html b/docs/functions/validateCanvas.html index a8a687fb..d4c7a1c4 100644 --- a/docs/functions/validateCanvas.html +++ b/docs/functions/validateCanvas.html @@ -1,4 +1,4 @@ validateCanvas | goban

    Function validateCanvas

    • Validates that a canvas was created successfully and a 2d context can be allocated for it. If not, we call the GobanCore.canvasAllocationErrorHandler hook.

      -

      Parameters

      • canvas: null | HTMLCanvasElement
      • Optional err: Error
      • Optional width: string | number
      • Optional height: string | number

      Returns boolean

    \ No newline at end of file +

    Parameters

    Returns boolean

    \ No newline at end of file diff --git a/docs/functions/voronoi_estimate_ownership.html b/docs/functions/voronoi_estimate_ownership.html index 00e59a7d..10d5960f 100644 --- a/docs/functions/voronoi_estimate_ownership.html +++ b/docs/functions/voronoi_estimate_ownership.html @@ -1,4 +1,4 @@ voronoi_estimate_ownership | goban

    Function voronoi_estimate_ownership

    \ No newline at end of file +

    Parameters

    Returns number[][]

    \ No newline at end of file diff --git a/docs/functions/wasm_estimate_ownership.html b/docs/functions/wasm_estimate_ownership.html index 0481b777..56b6f5b2 100644 --- a/docs/functions/wasm_estimate_ownership.html +++ b/docs/functions/wasm_estimate_ownership.html @@ -1 +1 @@ -wasm_estimate_ownership | goban

    Function wasm_estimate_ownership

    \ No newline at end of file +wasm_estimate_ownership | goban

    Function wasm_estimate_ownership

    \ No newline at end of file diff --git a/docs/interfaces/AIReviewWorstMoveEntry.html b/docs/interfaces/AIReviewWorstMoveEntry.html index 3cb10ddd..a2c0e2ef 100644 --- a/docs/interfaces/AIReviewWorstMoveEntry.html +++ b/docs/interfaces/AIReviewWorstMoveEntry.html @@ -1,5 +1,5 @@ -AIReviewWorstMoveEntry | goban

    Interface AIReviewWorstMoveEntry

    interface AIReviewWorstMoveEntry {
        delta: number;
        move: JGOFIntersection;
        move_number: number;
        player: JGOFNumericPlayerColor;
    }

    Properties

    delta +AIReviewWorstMoveEntry | goban

    Interface AIReviewWorstMoveEntry

    interface AIReviewWorstMoveEntry {
        delta: number;
        move: JGOFIntersection;
        move_number: number;
        player: JGOFNumericPlayerColor;
    }

    Properties

    delta: number
    move_number: number
    \ No newline at end of file +

    Properties

    delta: number
    move_number: number
    \ No newline at end of file diff --git a/docs/interfaces/AdHocClock.html b/docs/interfaces/AdHocClock.html index 2134b264..01f9240f 100644 --- a/docs/interfaces/AdHocClock.html +++ b/docs/interfaces/AdHocClock.html @@ -1,4 +1,4 @@ -AdHocClock | goban

    Interface AdHocClock

    interface AdHocClock {
        black_player_id: number;
        black_time: number | AdHocPlayerClock;
        current_player: number;
        expiration: number;
        game_id: number;
        last_move: number;
        pause?: {
            pause_control: AdHocPauseControl;
            paused: boolean;
            paused_since: number;
        };
        paused_since?: number;
        start_mode?: boolean;
        title: string;
        white_player_id: number;
        white_time: number | AdHocPlayerClock;
    }

    Properties

    black_player_id +AdHocClock | goban

    Interface AdHocClock

    interface AdHocClock {
        black_player_id: number;
        black_time: number | AdHocPlayerClock;
        current_player: number;
        expiration: number;
        game_id: number;
        last_move: number;
        pause?: {
            pause_control: AdHocPauseControl;
            paused: boolean;
            paused_since: number;
        };
        paused_since?: number;
        start_mode?: boolean;
        title: string;
        white_player_id: number;
        white_time: number | AdHocPlayerClock;
    }

    Properties

    black_player_id: number

    OGS player id for black

    -
    black_time: number | AdHocPlayerClock

    Time left on black's clock. If this is a number (such as is the case +

    black_time: number | AdHocPlayerClock

    Time left on black's clock. If this is a number (such as is the case with simple time), it is expressed in milliseconds.

    -
    current_player: number

    Current player to move

    -
    expiration: number

    Time the game will end if no move is played, in milliseconds since +

    current_player: number

    Current player to move

    +
    expiration: number

    Time the game will end if no move is played, in milliseconds since 1970. This is computed by adding together any main and overtime left on the clock. If start_mode is set, this is the number of milliseconds left on the start clock.

    -
    game_id: number

    OGS Game id

    -
    last_move: number

    Time the last move was made, in milliseconds since 1970

    -
    pause?: {
        pause_control: AdHocPauseControl;
        paused: boolean;
        paused_since: number;
    }

    If set, this AdHocClock is updating the pause state

    -

    Type declaration

    paused_since?: number

    Time the game was paused. This field erroneously exists even after the +

    game_id: number

    OGS Game id

    +
    last_move: number

    Time the last move was made, in milliseconds since 1970

    +
    pause?: {
        pause_control: AdHocPauseControl;
        paused: boolean;
        paused_since: number;
    }

    If set, this AdHocClock is updating the pause state

    +

    Type declaration

    paused_since?: number

    Time the game was paused. This field erroneously exists even after the game has been resumed, this will be removed in these cases.

    -
    start_mode?: boolean

    If true, the game has not started and this is the count down until +

    start_mode?: boolean

    If true, the game has not started and this is the count down until the game is canceled if a move has not been played yet. If this is true, then the duration left on the start clock is stored in expiration (in ms)

    -
    title: string

    Title of the game. This field will be removed.

    -
    white_player_id: number

    OGS player id for white

    -
    white_time: number | AdHocPlayerClock

    Time left on white's clock. If this is a number (such as is the case +

    title: string

    Title of the game. This field will be removed.

    +
    white_player_id: number

    OGS player id for white

    +
    white_time: number | AdHocPlayerClock

    Time left on white's clock. If this is a number (such as is the case with simple time), it is expressed in milliseconds.k

    -
    \ No newline at end of file +
    \ No newline at end of file diff --git a/docs/interfaces/AdHocFormat.html b/docs/interfaces/AdHocFormat.html index c5dfb90f..a27c7de1 100644 --- a/docs/interfaces/AdHocFormat.html +++ b/docs/interfaces/AdHocFormat.html @@ -1,8 +1,8 @@ AdHocFormat | goban

    Interface AdHocFormat

    The to-be-deprecated format used by Online-Go.com, will be replaced by JGOF as we develop a migration plan

    -
    interface AdHocFormat {
        black: AdHocPlayer;
        clock: AdHocClock;
        pause_control: AdHocPauseControl;
        time_control: JGOFTimeControl;
        white: AdHocPlayer;
    }

    Properties

    interface AdHocFormat {
        black: AdHocPlayer;
        clock: AdHocClock;
        pause_control: AdHocPauseControl;
        time_control: JGOFTimeControl;
        white: AdHocPlayer;
    }

    Properties

    clock: AdHocClock
    pause_control: AdHocPauseControl
    time_control: JGOFTimeControl
    \ No newline at end of file +

    Properties

    clock: AdHocClock
    pause_control: AdHocPauseControl
    time_control: JGOFTimeControl
    \ No newline at end of file diff --git a/docs/interfaces/AdHocPauseControl.html b/docs/interfaces/AdHocPauseControl.html index 7dfa4b32..583ce5e1 100644 --- a/docs/interfaces/AdHocPauseControl.html +++ b/docs/interfaces/AdHocPauseControl.html @@ -1,6 +1,6 @@ -AdHocPauseControl | goban

    Interface AdHocPauseControl

    interface AdHocPauseControl {
        moderator_paused?: {
            moderator_id: number;
        };
        paused?: {
            pauses_left: number;
            pausing_player_id: number;
        };
        stone-removal?: true;
        system?: true;
        weekend?: true;
        [vacation: string]: any;
    }

    Indexable

    [vacation: string]: any

    Properties

    moderator_paused? +AdHocPauseControl | goban

    Interface AdHocPauseControl

    interface AdHocPauseControl {
        moderator_paused?: {
            moderator_id: number;
        };
        paused?: {
            pauses_left: number;
            pausing_player_id: number;
        };
        stone-removal?: true;
        system?: true;
        weekend?: true;
        [vacation: string]: any;
    }

    Indexable

    [vacation: string]: any

    Properties

    moderator_paused?: {
        moderator_id: number;
    }

    Type declaration

    • moderator_id: number
    paused?: {
        pauses_left: number;
        pausing_player_id: number;
    }

    Type declaration

    • pauses_left: number
    • pausing_player_id: number
    stone-removal?: true
    system?: true
    weekend?: true
    \ No newline at end of file +

    Properties

    moderator_paused?: {
        moderator_id: number;
    }

    Type declaration

    • moderator_id: number
    paused?: {
        pauses_left: number;
        pausing_player_id: number;
    }

    Type declaration

    • pauses_left: number
    • pausing_player_id: number
    stone-removal?: true
    system?: true
    weekend?: true
    \ No newline at end of file diff --git a/docs/interfaces/AdHocPlayer.html b/docs/interfaces/AdHocPlayer.html index 5297233c..2e2a4a81 100644 --- a/docs/interfaces/AdHocPlayer.html +++ b/docs/interfaces/AdHocPlayer.html @@ -1,3 +1,3 @@ -AdHocPlayer | goban

    Interface AdHocPlayer

    interface AdHocPlayer {
        id: number;
        name: string;
    }

    Properties

    id +AdHocPlayer | goban

    Interface AdHocPlayer

    interface AdHocPlayer {
        id: number;
        name: string;
    }

    Properties

    Properties

    id: number
    name: string
    \ No newline at end of file +

    Properties

    id: number
    name: string
    \ No newline at end of file diff --git a/docs/interfaces/AdHocPlayerClock.html b/docs/interfaces/AdHocPlayerClock.html index 98e08d2b..3574fb77 100644 --- a/docs/interfaces/AdHocPlayerClock.html +++ b/docs/interfaces/AdHocPlayerClock.html @@ -1,4 +1,4 @@ -AdHocPlayerClock | goban

    Interface AdHocPlayerClock

    interface AdHocPlayerClock {
        block_time?: number;
        moves_left?: number;
        period_time?: number;
        periods?: number;
        skip_bonus?: boolean;
        thinking_time: number;
    }

    Properties

    block_time? +AdHocPlayerClock | goban

    Interface AdHocPlayerClock

    interface AdHocPlayerClock {
        block_time?: number;
        moves_left?: number;
        period_time?: number;
        periods?: number;
        skip_bonus?: boolean;
        thinking_time: number;
    }

    Properties

    block_time?: number

    Used with canadian time control. Time left (in seconds) to make the remainder of your moves in yu

    -
    moves_left?: number

    Used with canadian time control. Number of moves left before a new +

    moves_left?: number

    Used with canadian time control. Number of moves left before a new block of time.

    -
    period_time?: number

    Used with byo-yomi time control. Length of each period, in seconds.

    -
    periods?: number

    Used with byo-yomi time control. Number of periods left.

    -
    skip_bonus?: boolean

    Used with fischer time control to denote that the next move should not +

    period_time?: number

    Used with byo-yomi time control. Length of each period, in seconds.

    +
    periods?: number

    Used with byo-yomi time control. Number of periods left.

    +
    skip_bonus?: boolean

    Used with fischer time control to denote that the next move should not increment the clock.

    -
    thinking_time: number

    Thinking time left, in seconds. Also used as main time for byo-yomi and +

    thinking_time: number

    Thinking time left, in seconds. Also used as main time for byo-yomi and canadian clocks.

    -
    \ No newline at end of file +
    \ No newline at end of file diff --git a/docs/interfaces/AudioClockEvent.html b/docs/interfaces/AudioClockEvent.html index 81b24230..e301b6a8 100644 --- a/docs/interfaces/AudioClockEvent.html +++ b/docs/interfaces/AudioClockEvent.html @@ -1,14 +1,14 @@ -AudioClockEvent | goban

    Interface AudioClockEvent

    interface AudioClockEvent {
        clock: JGOFPlayerClock;
        color: PlayerColor;
        countdown_seconds: number;
        in_overtime: boolean;
        player_id: string;
        time_control_system: JGOFTimeControlSystem;
    }

    Properties

    clock +AudioClockEvent | goban

    Interface AudioClockEvent

    interface AudioClockEvent {
        clock: JGOFPlayerClock;
        color: PlayerColor;
        countdown_seconds: number;
        in_overtime: boolean;
        player_id: string;
        time_control_system: JGOFTimeControlSystem;
    }

    Properties

    Full player clock information

    -

    The player whose turn it is

    -
    countdown_seconds: number

    Number of seconds left in the current period

    -
    in_overtime: boolean

    True if we are in overtime. This is only ever set for systems that have +

    The player whose turn it is

    +
    countdown_seconds: number

    Number of seconds left in the current period

    +
    in_overtime: boolean

    True if we are in overtime. This is only ever set for systems that have a concept of overtime.

    -
    player_id: string

    The player (id) whose turn it is

    -
    time_control_system: JGOFTimeControlSystem

    Time control system being used by the clock

    -
    \ No newline at end of file +
    player_id: string

    The player (id) whose turn it is

    +
    time_control_system: JGOFTimeControlSystem

    Time control system being used by the clock

    +
    \ No newline at end of file diff --git a/docs/interfaces/BoardConfig.html b/docs/interfaces/BoardConfig.html index 7706c64a..66087473 100644 --- a/docs/interfaces/BoardConfig.html +++ b/docs/interfaces/BoardConfig.html @@ -1,4 +1,4 @@ -BoardConfig | goban

    Interface BoardConfig

    interface BoardConfig {
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        height?: number;
        isobranch_hash?: string;
        player?: JGOFNumericPlayerColor;
        removal?: boolean[][];
        white_prisoners?: number;
        width?: number;
    }

    Hierarchy (view full)

    Implemented by

    Properties

    black_prisoners? +BoardConfig | goban

    Interface BoardConfig

    interface BoardConfig {
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        height?: number;
        isobranch_hash?: string;
        player?: JGOFNumericPlayerColor;
        removal?: boolean[][];
        white_prisoners?: number;
        width?: number;
    }

    Hierarchy (view full)

    Implemented by

    Properties

    black_prisoners?: number
    board_is_repeating?: boolean
    height?: number
    isobranch_hash?: string
    removal?: boolean[][]
    white_prisoners?: number
    width?: number
    \ No newline at end of file +

    Properties

    black_prisoners?: number
    board_is_repeating?: boolean
    height?: number
    isobranch_hash?: string
    removal?: boolean[][]
    white_prisoners?: number
    width?: number
    \ No newline at end of file diff --git a/docs/interfaces/CanvasRendererGobanConfig.html b/docs/interfaces/CanvasRendererGobanConfig.html index dca76e5d..9c64d9fa 100644 --- a/docs/interfaces/CanvasRendererGobanConfig.html +++ b/docs/interfaces/CanvasRendererGobanConfig.html @@ -1,4 +1,4 @@ -CanvasRendererGobanConfig | goban

    Interface CanvasRendererGobanConfig

    interface CanvasRendererGobanConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        auth?: string;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_div?: HTMLElement;
        board_is_repeating?: boolean;
        bounds?: GobanBounds;
        chat_log?: GobanChatLog;
        circle_radius?: number;
        clock?: GameClock;
        connect_to_chat?: number | boolean;
        disable_analysis?: boolean;
        display_width?: number;
        dont_draw_last_move?: boolean;
        dont_show_messages?: boolean;
        double_click_submit?: boolean;
        draw_bottom_labels?: boolean;
        draw_left_labels?: boolean;
        draw_right_labels?: boolean;
        draw_top_labels?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        game_type?: "temporary";
        getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting);
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        interactive?: boolean;
        isInPushedAnalysis?: (() => boolean);
        isPlayerController?: (() => boolean);
        isPlayerOwner?: (() => boolean);
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        last_move_opacity?: number;
        last_move_radius?: number;
        latencies?: {
            [player_id: string]: number;
        };
        leavePushedAnalysis?: (() => void);
        malkovich_log?: GobanChatLog;
        marks?: {
            [mark: string]: string;
        };
        mode?: GobanModes;
        move_tree?: MoveTreeJson;
        move_tree_container?: HTMLElement;
        moves?: GobanMovesArray;
        name?: string;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        onError?: ((err) => void);
        onScoreEstimationUpdated?: ((winning_color, points) => void);
        one_click_submit?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        pause_control?: AdHocPauseControl;
        paused_since?: number;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        server_socket?: GobanSocket<ClientToServer, ServerToClient>;
        spectator_log?: GobanChatLog;
        square_size?: number | "auto" | ((goban) => number);
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        title_div?: HTMLElement;
        tournament_id?: number;
        username?: string;
        variation_stone_opacity?: number;
        visual_undo_request_indicator?: boolean;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring? +CanvasRendererGobanConfig | goban

    Interface CanvasRendererGobanConfig

    interface CanvasRendererGobanConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        auth?: string;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_div?: HTMLElement;
        board_is_repeating?: boolean;
        bounds?: GobanBounds;
        chat_log?: GobanChatLog;
        circle_radius?: number;
        clock?: GameClock;
        connect_to_chat?: number | boolean;
        disable_analysis?: boolean;
        display_width?: number;
        dont_draw_last_move?: boolean;
        dont_show_messages?: boolean;
        double_click_submit?: boolean;
        draw_bottom_labels?: boolean;
        draw_left_labels?: boolean;
        draw_right_labels?: boolean;
        draw_top_labels?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        game_type?: "temporary";
        getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting);
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        interactive?: boolean;
        isInPushedAnalysis?: (() => boolean);
        isPlayerController?: (() => boolean);
        isPlayerOwner?: (() => boolean);
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        last_move_opacity?: number;
        last_move_radius?: number;
        latencies?: {
            [player_id: string]: number;
        };
        leavePushedAnalysis?: (() => void);
        malkovich_log?: GobanChatLog;
        marks?: {
            [mark: string]: string;
        };
        mode?: GobanModes;
        move_tree?: MoveTreeJson;
        move_tree_container?: HTMLElement;
        moves?: GobanMovesArray;
        name?: string;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        onError?: ((err) => void);
        onScoreEstimationUpdated?: ((winning_color, points) => void);
        one_click_submit?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        pause_control?: AdHocPauseControl;
        paused_since?: number;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        server_socket?: GobanSocket<ClientToServer, ServerToClient>;
        spectator_log?: GobanChatLog;
        square_size?: number | "auto" | ((goban) => number);
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        title_div?: HTMLElement;
        tournament_id?: number;
        username?: string;
        variation_stone_opacity?: number;
        visual_undo_request_indicator?: boolean;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    auth?: string
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_div?: HTMLElement
    board_is_repeating?: boolean
    bounds?: GobanBounds
    chat_log?: GobanChatLog
    circle_radius?: number
    clock?: GameClock
    connect_to_chat?: number | boolean
    disable_analysis?: boolean
    display_width?: number
    dont_draw_last_move?: boolean
    dont_show_messages?: boolean
    double_click_submit?: boolean
    draw_bottom_labels?: boolean
    draw_left_labels?: boolean
    draw_right_labels?: boolean
    draw_top_labels?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    game_type?: "temporary"
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    interactive?: boolean
    isInPushedAnalysis?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    last_move_opacity?: number
    last_move_radius?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    leavePushedAnalysis?: (() => void)

    Type declaration

      • (): void
      • Returns void

    malkovich_log?: GobanChatLog
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: GobanModes
    move_tree?: MoveTreeJson
    move_tree_container?: HTMLElement
    name?: string
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    -
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    -
    onError?: ((err) => void)

    Type declaration

      • (err): void
      • Parameters

        • err: Error

        Returns void

    onScoreEstimationUpdated?: ((winning_color, points) => void)

    Type declaration

      • (winning_color, points): void
      • Parameters

        • winning_color: "black" | "white"
        • points: number

        Returns void

    one_click_submit?: boolean
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    pause_control?: AdHocPauseControl
    paused_since?: number
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase +

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    auth?: string
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_div?: HTMLElement
    board_is_repeating?: boolean
    bounds?: GobanBounds
    chat_log?: GobanChatLog
    circle_radius?: number
    clock?: GameClock
    connect_to_chat?: number | boolean
    disable_analysis?: boolean
    display_width?: number
    dont_draw_last_move?: boolean
    dont_show_messages?: boolean
    double_click_submit?: boolean
    draw_bottom_labels?: boolean
    draw_left_labels?: boolean
    draw_right_labels?: boolean
    draw_top_labels?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    game_type?: "temporary"
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    interactive?: boolean
    isInPushedAnalysis?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    last_move_opacity?: number
    last_move_radius?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    leavePushedAnalysis?: (() => void)

    Type declaration

      • (): void
      • Returns void

    malkovich_log?: GobanChatLog
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: GobanModes
    move_tree?: MoveTreeJson
    move_tree_container?: HTMLElement
    name?: string
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    +
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    +
    onError?: ((err) => void)

    Type declaration

      • (err): void
      • Parameters

        • err: Error

        Returns void

    onScoreEstimationUpdated?: ((winning_color, points) => void)

    Type declaration

      • (winning_color, points): void
      • Parameters

        • winning_color: "black" | "white"
        • points: number

        Returns void

    one_click_submit?: boolean
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    pause_control?: AdHocPauseControl
    paused_since?: number
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase Passing an array of JGOFMove objects is preferred, the string format exists for historical backwards compatibility. It is an encoded move string, e.g. "aa" for A19

    -
    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    spectator_log?: GobanChatLog
    square_size?: number | "auto" | ((goban) => number)

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and +

    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    spectator_log?: GobanChatLog
    square_size?: number | "auto" | ((goban) => number)

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and handle bad data by just resorting to 'edit placing' moves. If this is true, then those errors are thrown instead.

    -
    time_control?: JGOFTimeControl
    time_per_move?: number
    title_div?: HTMLElement
    tournament_id?: number
    username?: string
    variation_stone_opacity?: number
    visual_undo_request_indicator?: boolean
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file +
    time_control?: JGOFTimeControl
    time_per_move?: number
    title_div?: HTMLElement
    tournament_id?: number
    username?: string
    variation_stone_opacity?: number
    visual_undo_request_indicator?: boolean
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file diff --git a/docs/interfaces/ColoredCircle.html b/docs/interfaces/ColoredCircle.html index 6a57fba8..16acaad6 100644 --- a/docs/interfaces/ColoredCircle.html +++ b/docs/interfaces/ColoredCircle.html @@ -1,5 +1,5 @@ -ColoredCircle | goban

    Interface ColoredCircle

    interface ColoredCircle {
        border_color?: string;
        border_width?: number;
        color: string;
        move: JGOFIntersection;
    }

    Properties

    border_color? +ColoredCircle | goban

    Interface ColoredCircle

    interface ColoredCircle {
        border_color?: string;
        border_width?: number;
        color: string;
        move: JGOFIntersection;
    }

    Properties

    border_color?: string
    border_width?: number
    color: string
    \ No newline at end of file +

    Properties

    border_color?: string
    border_width?: number
    color: string
    \ No newline at end of file diff --git a/docs/interfaces/ConditionalMoveResponseTree.html b/docs/interfaces/ConditionalMoveResponseTree.html index 01a98ec8..74537744 100644 --- a/docs/interfaces/ConditionalMoveResponseTree.html +++ b/docs/interfaces/ConditionalMoveResponseTree.html @@ -1 +1 @@ -ConditionalMoveResponseTree | goban

    Interface ConditionalMoveResponseTree

    interface ConditionalMoveResponseTree {
        [move: string]: ConditionalMoveResponse;
    }

    Indexable

    [move: string]: ConditionalMoveResponse
    \ No newline at end of file +ConditionalMoveResponseTree | goban

    Interface ConditionalMoveResponseTree

    interface ConditionalMoveResponseTree {
        [move: string]: ConditionalMoveResponse;
    }

    Indexable

    [move: string]: ConditionalMoveResponse
    \ No newline at end of file diff --git a/docs/interfaces/GobanBounds.html b/docs/interfaces/GobanBounds.html index 9097ddb3..7375652f 100644 --- a/docs/interfaces/GobanBounds.html +++ b/docs/interfaces/GobanBounds.html @@ -1,5 +1,5 @@ -GobanBounds | goban

    Interface GobanBounds

    interface GobanBounds {
        bottom: number;
        left: number;
        right: number;
        top: number;
    }

    Properties

    bottom +GobanBounds | goban

    Interface GobanBounds

    interface GobanBounds {
        bottom: number;
        left: number;
        right: number;
        top: number;
    }

    Properties

    Properties

    bottom: number
    left: number
    right: number
    top: number
    \ No newline at end of file +

    Properties

    bottom: number
    left: number
    right: number
    top: number
    \ No newline at end of file diff --git a/docs/interfaces/GobanCallbacks.html b/docs/interfaces/GobanCallbacks.html index 713a264d..ea2491f8 100644 --- a/docs/interfaces/GobanCallbacks.html +++ b/docs/interfaces/GobanCallbacks.html @@ -1,4 +1,4 @@ -GobanCallbacks | goban

    Interface GobanCallbacks

    interface GobanCallbacks {
        addCoordinatesToChatInput?: ((coordinates) => void);
        canvasAllocationErrorHandler?: ((note, error, extra) => void);
        customBlackStoneColor?: (() => string);
        customBlackStoneUrl?: (() => string);
        customBlackTextColor?: (() => string);
        customBoardColor?: (() => string);
        customBoardLineColor?: (() => string);
        customBoardUrl?: (() => string);
        customWhiteStoneColor?: (() => string);
        customWhiteStoneUrl?: (() => string);
        customWhiteTextColor?: (() => string);
        defaultConfig?: (() => any);
        getCDNReleaseBase?: (() => string);
        getClockDrift?: (() => number);
        getCoordinateDisplaySystem?: (() => "A1" | "1-1");
        getLocation?: (() => string);
        getMoveTreeNumbering?: (() => "none" | "move-coordinates" | "move-number");
        getNetworkLatency?: (() => number);
        getSelectedThemes?: (() => GobanSelectedThemes);
        getShowMoveNumbers?: (() => boolean);
        getShowVariationMoveNumbers?: (() => boolean);
        getSoundEnabled?: (() => boolean);
        getSoundVolume?: (() => number);
        isAnalysisDisabled?: ((goban, perGameSettingAppliesToNonPlayers) => boolean);
        toast?: ((message_id, duration) => void);
        updateScoreEstimation?: ((est_winning_color, number_of_points) => void);
        watchSelectedThemes?: ((cb) => {
            remove: (() => any);
        });
    }

    Properties

    addCoordinatesToChatInput? +GobanCallbacks | goban

    Interface GobanCallbacks

    interface GobanCallbacks {
        addCoordinatesToChatInput?: ((coordinates) => void);
        canvasAllocationErrorHandler?: ((note, error, extra) => void);
        customBlackStoneColor?: (() => string);
        customBlackStoneUrl?: (() => string);
        customBlackTextColor?: (() => string);
        customBoardColor?: (() => string);
        customBoardLineColor?: (() => string);
        customBoardUrl?: (() => string);
        customWhiteStoneColor?: (() => string);
        customWhiteStoneUrl?: (() => string);
        customWhiteTextColor?: (() => string);
        defaultConfig?: (() => any);
        getCDNReleaseBase?: (() => string);
        getClockDrift?: (() => number);
        getCoordinateDisplaySystem?: (() => "A1" | "1-1");
        getLocation?: (() => string);
        getMoveTreeNumbering?: (() => "none" | "move-coordinates" | "move-number");
        getNetworkLatency?: (() => number);
        getSelectedThemes?: (() => GobanSelectedThemes);
        getShowMoveNumbers?: (() => boolean);
        getShowVariationMoveNumbers?: (() => boolean);
        getSoundEnabled?: (() => boolean);
        getSoundVolume?: (() => number);
        isAnalysisDisabled?: ((goban, perGameSettingAppliesToNonPlayers) => boolean);
        toast?: ((message_id, duration) => void);
        updateScoreEstimation?: ((est_winning_color, number_of_points) => void);
        watchSelectedThemes?: ((cb) => {
            remove: (() => any);
        });
    }

    Properties

    addCoordinatesToChatInput?: ((coordinates) => void)

    Type declaration

      • (coordinates): void
      • Parameters

        • coordinates: string

        Returns void

    canvasAllocationErrorHandler?: ((note, error, extra) => void)

    Type declaration

      • (note, error, extra): void
      • Parameters

        • note: null | string
        • error: Error
        • extra: {
              height?: string | number;
              total_allocations_made: number;
              total_pixels_allocated: number;
              width?: string | number;
          }
          • Optional height?: string | number
          • total_allocations_made: number
          • total_pixels_allocated: number
          • Optional width?: string | number

        Returns void

    customBlackStoneColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBlackStoneUrl?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBlackTextColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBoardColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBoardLineColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBoardUrl?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customWhiteStoneColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customWhiteStoneUrl?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customWhiteTextColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    defaultConfig?: (() => any)

    Type declaration

      • (): any
      • Returns any

    getCDNReleaseBase?: (() => string)

    Type declaration

      • (): string
      • Returns string

    getClockDrift?: (() => number)

    Type declaration

      • (): number
      • Returns number

    getCoordinateDisplaySystem?: (() => "A1" | "1-1")

    Type declaration

      • (): "A1" | "1-1"
      • Returns "A1" | "1-1"

    getLocation?: (() => string)

    Type declaration

      • (): string
      • Returns string

    getMoveTreeNumbering?: (() => "none" | "move-coordinates" | "move-number")

    Type declaration

      • (): "none" | "move-coordinates" | "move-number"
      • Returns "none" | "move-coordinates" | "move-number"

    getNetworkLatency?: (() => number)

    Type declaration

      • (): number
      • Returns number

    getSelectedThemes?: (() => GobanSelectedThemes)

    Type declaration

    getShowMoveNumbers?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    getShowVariationMoveNumbers?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    getSoundEnabled?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    getSoundVolume?: (() => number)

    Type declaration

      • (): number
      • Returns number

    isAnalysisDisabled?: ((goban, perGameSettingAppliesToNonPlayers) => boolean)

    Type declaration

      • (goban, perGameSettingAppliesToNonPlayers): boolean
      • Parameters

        • goban: GobanBase
        • perGameSettingAppliesToNonPlayers: boolean

        Returns boolean

    toast?: ((message_id, duration) => void)

    Type declaration

      • (message_id, duration): void
      • Parameters

        • message_id: string
        • duration: number

        Returns void

    updateScoreEstimation?: ((est_winning_color, number_of_points) => void)

    Type declaration

      • (est_winning_color, number_of_points): void
      • Parameters

        • est_winning_color: "black" | "white"
        • number_of_points: number

        Returns void

    watchSelectedThemes?: ((cb) => {
        remove: (() => any);
    })

    Type declaration

      • (cb): {
            remove: (() => any);
        }
      • Parameters

        Returns {
            remove: (() => any);
        }

        • remove: (() => any)
            • (): any
            • Returns any

    \ No newline at end of file +

    Properties

    addCoordinatesToChatInput?: ((coordinates) => void)

    Type declaration

      • (coordinates): void
      • Parameters

        • coordinates: string

        Returns void

    canvasAllocationErrorHandler?: ((note, error, extra) => void)

    Type declaration

      • (note, error, extra): void
      • Parameters

        • note: null | string
        • error: Error
        • extra: {
              height?: string | number;
              total_allocations_made: number;
              total_pixels_allocated: number;
              width?: string | number;
          }
          • Optional height?: string | number
          • total_allocations_made: number
          • total_pixels_allocated: number
          • Optional width?: string | number

        Returns void

    customBlackStoneColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBlackStoneUrl?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBlackTextColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBoardColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBoardLineColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customBoardUrl?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customWhiteStoneColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customWhiteStoneUrl?: (() => string)

    Type declaration

      • (): string
      • Returns string

    customWhiteTextColor?: (() => string)

    Type declaration

      • (): string
      • Returns string

    defaultConfig?: (() => any)

    Type declaration

      • (): any
      • Returns any

    getCDNReleaseBase?: (() => string)

    Type declaration

      • (): string
      • Returns string

    getClockDrift?: (() => number)

    Type declaration

      • (): number
      • Returns number

    getCoordinateDisplaySystem?: (() => "A1" | "1-1")

    Type declaration

      • (): "A1" | "1-1"
      • Returns "A1" | "1-1"

    getLocation?: (() => string)

    Type declaration

      • (): string
      • Returns string

    getMoveTreeNumbering?: (() => "none" | "move-coordinates" | "move-number")

    Type declaration

      • (): "none" | "move-coordinates" | "move-number"
      • Returns "none" | "move-coordinates" | "move-number"

    getNetworkLatency?: (() => number)

    Type declaration

      • (): number
      • Returns number

    getSelectedThemes?: (() => GobanSelectedThemes)

    Type declaration

    getShowMoveNumbers?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    getShowVariationMoveNumbers?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    getSoundEnabled?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    getSoundVolume?: (() => number)

    Type declaration

      • (): number
      • Returns number

    isAnalysisDisabled?: ((goban, perGameSettingAppliesToNonPlayers) => boolean)

    Type declaration

      • (goban, perGameSettingAppliesToNonPlayers): boolean
      • Parameters

        • goban: GobanBase
        • perGameSettingAppliesToNonPlayers: boolean

        Returns boolean

    toast?: ((message_id, duration) => void)

    Type declaration

      • (message_id, duration): void
      • Parameters

        • message_id: string
        • duration: number

        Returns void

    updateScoreEstimation?: ((est_winning_color, number_of_points) => void)

    Type declaration

      • (est_winning_color, number_of_points): void
      • Parameters

        • est_winning_color: "black" | "white"
        • number_of_points: number

        Returns void

    watchSelectedThemes?: ((cb) => {
        remove: (() => any);
    })

    Type declaration

      • (cb): {
            remove: (() => any);
        }
      • Parameters

        Returns {
            remove: (() => any);
        }

        • remove: (() => any)
            • (): any
            • Returns any

    \ No newline at end of file diff --git a/docs/interfaces/GobanCanvasInterface.html b/docs/interfaces/GobanCanvasInterface.html index 66f26868..cae2487a 100644 --- a/docs/interfaces/GobanCanvasInterface.html +++ b/docs/interfaces/GobanCanvasInterface.html @@ -1,4 +1,4 @@ -GobanCanvasInterface | goban

    Interface GobanCanvasInterface

    interface GobanCanvasInterface {
        engine: GobanEngine;
        move_tree_container?: HTMLElement;
        clearAnalysisDrawing(): void;
        clearMessage(): void;
        destroy(): void;
        disablePen(): void;
        drawPenMarks(pen_marks): void;
        drawSquare(i, j): void;
        enablePen(): void;
        move_tree_bindCanvasEvents(canvas): void;
        move_tree_redraw(no_warp?): void;
        setByoYomiLabel(label): void;
        setLastMoveOpacity(opacity): void;
        setMoveTreeContainer(container): void;
        showMessage(message_id_or_error, parameters?, timeout?): void;
    }

    Implemented by

    Properties

    engine +GobanCanvasInterface | goban

    Interface GobanCanvasInterface

    interface GobanCanvasInterface {
        engine: GobanEngine;
        move_tree_container?: HTMLElement;
        clearAnalysisDrawing(): void;
        clearMessage(): void;
        destroy(): void;
        disablePen(): void;
        drawPenMarks(pen_marks): void;
        drawSquare(i, j): void;
        enablePen(): void;
        move_tree_bindCanvasEvents(canvas): void;
        move_tree_redraw(no_warp?): void;
        setByoYomiLabel(label): void;
        setLastMoveOpacity(opacity): void;
        setMoveTreeContainer(container): void;
        showMessage(message_id_or_error, parameters?, timeout?): void;
    }

    Implemented by

    Properties

    engine: GobanEngine
    move_tree_container?: HTMLElement

    Methods

    • Parameters

      • message_id_or_error: MessageID
      • Optional parameters: {
            [key: string]: any;
        }
        • [key: string]: any
      • Optional timeout: number

      Returns void

    \ No newline at end of file +

    Properties

    engine: GobanEngine
    move_tree_container?: HTMLElement

    Methods

    • Parameters

      • message_id_or_error: MessageID
      • Optional parameters: {
            [key: string]: any;
        }
        • [key: string]: any
      • Optional timeout: number

      Returns void

    \ No newline at end of file diff --git a/docs/interfaces/GobanConfig.html b/docs/interfaces/GobanConfig.html index ecf7e1e8..5934e535 100644 --- a/docs/interfaces/GobanConfig.html +++ b/docs/interfaces/GobanConfig.html @@ -1,4 +1,4 @@ -GobanConfig | goban

    Interface GobanConfig

    interface GobanConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        auth?: string;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        bounds?: GobanBounds;
        chat_log?: GobanChatLog;
        circle_radius?: number;
        clock?: GameClock;
        connect_to_chat?: number | boolean;
        disable_analysis?: boolean;
        display_width?: number;
        dont_draw_last_move?: boolean;
        dont_show_messages?: boolean;
        double_click_submit?: boolean;
        draw_bottom_labels?: boolean;
        draw_left_labels?: boolean;
        draw_right_labels?: boolean;
        draw_top_labels?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        game_type?: "temporary";
        getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting);
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        interactive?: boolean;
        isInPushedAnalysis?: (() => boolean);
        isPlayerController?: (() => boolean);
        isPlayerOwner?: (() => boolean);
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        last_move_radius?: number;
        latencies?: {
            [player_id: string]: number;
        };
        leavePushedAnalysis?: (() => void);
        malkovich_log?: GobanChatLog;
        marks?: {
            [mark: string]: string;
        };
        mode?: GobanModes;
        move_tree?: MoveTreeJson;
        moves?: GobanMovesArray;
        name?: string;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        onError?: ((err) => void);
        onScoreEstimationUpdated?: ((winning_color, points) => void);
        one_click_submit?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        pause_control?: AdHocPauseControl;
        paused_since?: number;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        server_socket?: GobanSocket<ClientToServer, ServerToClient>;
        spectator_log?: GobanChatLog;
        square_size?: number | "auto" | ((goban) => number);
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        tournament_id?: number;
        username?: string;
        variation_stone_opacity?: number;
        visual_undo_request_indicator?: boolean;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring? +GobanConfig | goban

    Interface GobanConfig

    interface GobanConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        auth?: string;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        bounds?: GobanBounds;
        chat_log?: GobanChatLog;
        circle_radius?: number;
        clock?: GameClock;
        connect_to_chat?: number | boolean;
        disable_analysis?: boolean;
        display_width?: number;
        dont_draw_last_move?: boolean;
        dont_show_messages?: boolean;
        double_click_submit?: boolean;
        draw_bottom_labels?: boolean;
        draw_left_labels?: boolean;
        draw_right_labels?: boolean;
        draw_top_labels?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        game_type?: "temporary";
        getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting);
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        interactive?: boolean;
        isInPushedAnalysis?: (() => boolean);
        isPlayerController?: (() => boolean);
        isPlayerOwner?: (() => boolean);
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        last_move_radius?: number;
        latencies?: {
            [player_id: string]: number;
        };
        leavePushedAnalysis?: (() => void);
        malkovich_log?: GobanChatLog;
        marks?: {
            [mark: string]: string;
        };
        mode?: GobanModes;
        move_tree?: MoveTreeJson;
        moves?: GobanMovesArray;
        name?: string;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        onError?: ((err) => void);
        onScoreEstimationUpdated?: ((winning_color, points) => void);
        one_click_submit?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        pause_control?: AdHocPauseControl;
        paused_since?: number;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        server_socket?: GobanSocket<ClientToServer, ServerToClient>;
        spectator_log?: GobanChatLog;
        square_size?: number | "auto" | ((goban) => number);
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        tournament_id?: number;
        username?: string;
        variation_stone_opacity?: number;
        visual_undo_request_indicator?: boolean;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    auth?: string
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_is_repeating?: boolean
    bounds?: GobanBounds
    chat_log?: GobanChatLog
    circle_radius?: number
    clock?: GameClock
    connect_to_chat?: number | boolean
    disable_analysis?: boolean
    display_width?: number
    dont_draw_last_move?: boolean
    dont_show_messages?: boolean
    double_click_submit?: boolean
    draw_bottom_labels?: boolean
    draw_left_labels?: boolean
    draw_right_labels?: boolean
    draw_top_labels?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    game_type?: "temporary"
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    interactive?: boolean
    isInPushedAnalysis?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    last_move_radius?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    leavePushedAnalysis?: (() => void)

    Type declaration

      • (): void
      • Returns void

    malkovich_log?: GobanChatLog
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: GobanModes
    move_tree?: MoveTreeJson
    name?: string
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    -
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    -
    onError?: ((err) => void)

    Type declaration

      • (err): void
      • Parameters

        • err: Error

        Returns void

    onScoreEstimationUpdated?: ((winning_color, points) => void)

    Type declaration

      • (winning_color, points): void
      • Parameters

        • winning_color: "black" | "white"
        • points: number

        Returns void

    one_click_submit?: boolean
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    pause_control?: AdHocPauseControl
    paused_since?: number
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase +

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    auth?: string
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_is_repeating?: boolean
    bounds?: GobanBounds
    chat_log?: GobanChatLog
    circle_radius?: number
    clock?: GameClock
    connect_to_chat?: number | boolean
    disable_analysis?: boolean
    display_width?: number
    dont_draw_last_move?: boolean
    dont_show_messages?: boolean
    double_click_submit?: boolean
    draw_bottom_labels?: boolean
    draw_left_labels?: boolean
    draw_right_labels?: boolean
    draw_top_labels?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    game_type?: "temporary"
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    interactive?: boolean
    isInPushedAnalysis?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    last_move_radius?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    leavePushedAnalysis?: (() => void)

    Type declaration

      • (): void
      • Returns void

    malkovich_log?: GobanChatLog
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: GobanModes
    move_tree?: MoveTreeJson
    name?: string
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    +
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    +
    onError?: ((err) => void)

    Type declaration

      • (err): void
      • Parameters

        • err: Error

        Returns void

    onScoreEstimationUpdated?: ((winning_color, points) => void)

    Type declaration

      • (winning_color, points): void
      • Parameters

        • winning_color: "black" | "white"
        • points: number

        Returns void

    one_click_submit?: boolean
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    pause_control?: AdHocPauseControl
    paused_since?: number
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase Passing an array of JGOFMove objects is preferred, the string format exists for historical backwards compatibility. It is an encoded move string, e.g. "aa" for A19

    -
    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    spectator_log?: GobanChatLog
    square_size?: number | "auto" | ((goban) => number)

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and +

    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    spectator_log?: GobanChatLog
    square_size?: number | "auto" | ((goban) => number)

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and handle bad data by just resorting to 'edit placing' moves. If this is true, then those errors are thrown instead.

    -
    time_control?: JGOFTimeControl
    time_per_move?: number
    tournament_id?: number
    username?: string
    variation_stone_opacity?: number
    visual_undo_request_indicator?: boolean
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file +
    time_control?: JGOFTimeControl
    time_per_move?: number
    tournament_id?: number
    username?: string
    variation_stone_opacity?: number
    visual_undo_request_indicator?: boolean
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file diff --git a/docs/interfaces/GobanEngineConfig.html b/docs/interfaces/GobanEngineConfig.html index a9742ca2..927916ce 100644 --- a/docs/interfaces/GobanEngineConfig.html +++ b/docs/interfaces/GobanEngineConfig.html @@ -1,4 +1,4 @@ -GobanEngineConfig | goban

    Interface GobanEngineConfig

    interface GobanEngineConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        clock?: GameClock;
        disable_analysis?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        latencies?: {
            [player_id: string]: number;
        };
        marks?: {
            [mark: string]: string;
        };
        move_tree?: MoveTreeJson;
        moves?: GobanMovesArray;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        tournament_id?: number;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring? +GobanEngineConfig | goban

    Interface GobanEngineConfig

    interface GobanEngineConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        clock?: GameClock;
        disable_analysis?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        latencies?: {
            [player_id: string]: number;
        };
        marks?: {
            [mark: string]: string;
        };
        move_tree?: MoveTreeJson;
        moves?: GobanMovesArray;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        tournament_id?: number;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_is_repeating?: boolean
    clock?: GameClock
    disable_analysis?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    move_tree?: MoveTreeJson
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    -
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    -
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase +

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_is_repeating?: boolean
    clock?: GameClock
    disable_analysis?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    move_tree?: MoveTreeJson
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    +
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    +
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase Passing an array of JGOFMove objects is preferred, the string format exists for historical backwards compatibility. It is an encoded move string, e.g. "aa" for A19

    -
    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and +

    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and handle bad data by just resorting to 'edit placing' moves. If this is true, then those errors are thrown instead.

    -
    time_control?: JGOFTimeControl
    time_per_move?: number
    tournament_id?: number
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file +
    time_control?: JGOFTimeControl
    time_per_move?: number
    tournament_id?: number
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file diff --git a/docs/interfaces/GobanEngineInitialState.html b/docs/interfaces/GobanEngineInitialState.html index 4a08e5e1..096294e2 100644 --- a/docs/interfaces/GobanEngineInitialState.html +++ b/docs/interfaces/GobanEngineInitialState.html @@ -1,3 +1,3 @@ -GobanEngineInitialState | goban

    Interface GobanEngineInitialState

    interface GobanEngineInitialState {
        black?: string;
        white?: string;
    }

    Properties

    black? +GobanEngineInitialState | goban

    Interface GobanEngineInitialState

    interface GobanEngineInitialState {
        black?: string;
        white?: string;
    }

    Properties

    Properties

    black?: string
    white?: string
    \ No newline at end of file +

    Properties

    black?: string
    white?: string
    \ No newline at end of file diff --git a/docs/interfaces/GobanEnginePlayerEntry.html b/docs/interfaces/GobanEnginePlayerEntry.html index 1dfdd5d9..c86b1418 100644 --- a/docs/interfaces/GobanEnginePlayerEntry.html +++ b/docs/interfaces/GobanEnginePlayerEntry.html @@ -1,4 +1,4 @@ -GobanEnginePlayerEntry | goban

    Interface GobanEnginePlayerEntry

    interface GobanEnginePlayerEntry {
        accepted_stones?: string;
        accepted_strict_seki_mode?: boolean;
        country?: string;
        id: number;
        name?: string;
        pro?: boolean;
        rank?: number;
        username: string;
    }

    Properties

    accepted_stones? +GobanEnginePlayerEntry | goban

    Interface GobanEnginePlayerEntry

    interface GobanEnginePlayerEntry {
        accepted_stones?: string;
        accepted_strict_seki_mode?: boolean;
        country?: string;
        id: number;
        name?: string;
        pro?: boolean;
        rank?: number;
        username: string;
    }

    Properties

    accepted_stones?: string

    The accepted stones for the stone removal phase that the player has accepted

    -
    accepted_strict_seki_mode?: boolean

    Whether or not the player has accepted scoring with strict seki mode on or not

    -
    country?: string
    id: number
    name?: string

    XXX: The server is using these, the client may or may not be, we need to normalize this

    -
    pro?: boolean
    rank?: number
    username: string
    \ No newline at end of file +
    accepted_strict_seki_mode?: boolean

    Whether or not the player has accepted scoring with strict seki mode on or not

    +
    country?: string
    id: number
    name?: string

    XXX: The server is using these, the client may or may not be, we need to normalize this

    +
    pro?: boolean
    rank?: number
    username: string
    \ No newline at end of file diff --git a/docs/interfaces/GobanEvents.html b/docs/interfaces/GobanEvents.html index 906cb9f3..9ed20056 100644 --- a/docs/interfaces/GobanEvents.html +++ b/docs/interfaces/GobanEvents.html @@ -1,4 +1,4 @@ -GobanEvents | goban

    Interface GobanEvents

    interface GobanEvents {
        advance-to-next-board: (() => void);
        analyze_subtool: ((d) => void);
        analyze_tool: ((d) => void);
        audio-capture-stones: ((obj) => void);
        audio-clock: ((event) => void);
        audio-disconnected: (() => void);
        audio-enter-stone-removal: (() => void);
        audio-game-ended: ((winner) => void);
        audio-game-paused: (() => void);
        audio-game-resumed: (() => void);
        audio-game-started: ((obj) => void);
        audio-other-player-disconnected: ((obj) => void);
        audio-other-player-reconnected: ((obj) => void);
        audio-pass: (() => void);
        audio-reconnected: (() => void);
        audio-resume-game-from-stone-removal: (() => void);
        audio-stone: ((obj) => void);
        audio-undo-granted: (() => void);
        audio-undo-requested: (() => void);
        auto-resign: ((obj) => void);
        captured-stones: ((obj) => void);
        chat: ((d) => void);
        chat-remove: ((ids) => void);
        chat-reset: (() => void);
        clear-auto-resign: ((obj) => void);
        clear-message: (() => void);
        clock: ((clock) => void);
        conditional-moves.updated: (() => void);
        cur_move: ((d) => void);
        cur_review_move: ((d) => void);
        destroy: (() => void);
        engine.updated: ((engine) => void);
        error: ((d) => void);
        gamedata: ((d) => void);
        last_official_move: ((d) => void);
        load: ((config) => void);
        mode: ((d) => void);
        move-made: (() => void);
        outcome: ((d) => void);
        paused: ((d) => void);
        phase: ((d) => void);
        played-by-click: ((player) => void);
        player-update: ((player) => void);
        puzzle-correct-answer: (() => void);
        puzzle-place: ((obj) => void);
        puzzle-wrong-answer: (() => void);
        review.load-end: (() => void);
        review.load-start: (() => void);
        review.sync-to-current-move: (() => void);
        review.updated: (() => void);
        review_controller_id: ((d) => void);
        review_owner_id: ((d) => void);
        rules: ((d) => void);
        score_estimate: ((d) => void);
        set-for-removal: {
            removed: boolean;
            x: number;
            y: number;
        };
        show-message: ((message) => void);
        stalling_score_estimate: ((data?) => void);
        state_text: ((state) => void);
        stone-removal.accepted: (() => void);
        stone-removal.needs-sealing: ((positions) => void);
        stone-removal.updated: (() => void);
        strict_seki_mode: ((d) => void);
        submit_move: ((d) => void);
        submitting-move: ((tf) => void);
        title: ((d) => void);
        undo_canceled: (() => void);
        undo_requested: ((d) => void);
        update: (() => void);
        winner: ((d) => void);
    }

    Hierarchy (view full)

    Properties

    advance-to-next-board +GobanEvents | goban

    Interface GobanEvents

    interface GobanEvents {
        advance-to-next-board: (() => void);
        analyze_subtool: ((d) => void);
        analyze_tool: ((d) => void);
        audio-capture-stones: ((obj) => void);
        audio-clock: ((event) => void);
        audio-disconnected: (() => void);
        audio-enter-stone-removal: (() => void);
        audio-game-ended: ((winner) => void);
        audio-game-paused: (() => void);
        audio-game-resumed: (() => void);
        audio-game-started: ((obj) => void);
        audio-other-player-disconnected: ((obj) => void);
        audio-other-player-reconnected: ((obj) => void);
        audio-pass: (() => void);
        audio-reconnected: (() => void);
        audio-resume-game-from-stone-removal: (() => void);
        audio-stone: ((obj) => void);
        audio-undo-granted: (() => void);
        audio-undo-requested: (() => void);
        auto-resign: ((obj) => void);
        captured-stones: ((obj) => void);
        chat: ((d) => void);
        chat-remove: ((ids) => void);
        chat-reset: (() => void);
        clear-auto-resign: ((obj) => void);
        clear-message: (() => void);
        clock: ((clock) => void);
        conditional-moves.updated: (() => void);
        cur_move: ((d) => void);
        cur_review_move: ((d) => void);
        destroy: (() => void);
        engine.updated: ((engine) => void);
        error: ((d) => void);
        gamedata: ((d) => void);
        last_official_move: ((d) => void);
        load: ((config) => void);
        mode: ((d) => void);
        move-made: (() => void);
        outcome: ((d) => void);
        paused: ((d) => void);
        phase: ((d) => void);
        played-by-click: ((player) => void);
        player-update: ((player) => void);
        puzzle-correct-answer: (() => void);
        puzzle-place: ((obj) => void);
        puzzle-wrong-answer: (() => void);
        review.load-end: (() => void);
        review.load-start: (() => void);
        review.sync-to-current-move: (() => void);
        review.updated: (() => void);
        review_controller_id: ((d) => void);
        review_owner_id: ((d) => void);
        rules: ((d) => void);
        score_estimate: ((d) => void);
        set-for-removal: {
            removed: boolean;
            x: number;
            y: number;
        };
        show-message: ((message) => void);
        stalling_score_estimate: ((data?) => void);
        state_text: ((state) => void);
        stone-removal.accepted: (() => void);
        stone-removal.needs-sealing: ((positions) => void);
        stone-removal.updated: (() => void);
        strict_seki_mode: ((d) => void);
        submit_move: ((d) => void);
        submitting-move: ((tf) => void);
        title: ((d) => void);
        undo_canceled: (() => void);
        undo_requested: ((d) => void);
        update: (() => void);
        winner: ((d) => void);
    }

    Hierarchy (view full)

    Properties

    advance-to-next-board: (() => void)

    Type declaration

      • (): void
      • Returns void

    analyze_subtool: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    analyze_tool: ((d) => void)

    Type declaration

    audio-capture-stones: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              already_captured: number;
              count: number;
          }
          • already_captured: number
          • count: number

        Returns void

    audio-clock: ((event) => void)

    Type declaration

    audio-disconnected: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-enter-stone-removal: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-game-ended: ((winner) => void)

    Type declaration

      • (winner): void
      • Parameters

        • winner: "black" | "white" | "tie"

        Returns void

    audio-game-paused: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-game-resumed: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-game-started: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              player_id: number;
          }
          • player_id: number

            Player to move

            -

        Returns void

    audio-other-player-disconnected: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              player_id: number;
          }
          • player_id: number

        Returns void

    audio-other-player-reconnected: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              player_id: number;
          }
          • player_id: number

        Returns void

    audio-pass: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-reconnected: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-resume-game-from-stone-removal: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-stone: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              color: "black" | "white";
              height: number;
              width: number;
              x: number;
              y: number;
          }
          • color: "black" | "white"
          • height: number
          • width: number
          • x: number
          • y: number

        Returns void

    audio-undo-granted: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-undo-requested: (() => void)

    Type declaration

      • (): void
      • Returns void

    auto-resign: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              expiration: number;
              game_id: number;
              player_id: number;
          }
          • expiration: number
          • game_id: number
          • player_id: number

        Returns void

    captured-stones: ((obj) => void)

    Type declaration

    chat: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: any

        Returns void

    chat-remove: ((ids) => void)

    Type declaration

      • (ids): void
      • Parameters

        • ids: {
              chat_ids: string[];
          }
          • chat_ids: string[]

        Returns void

    chat-reset: (() => void)

    Type declaration

      • (): void
      • Returns void

    clear-auto-resign: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              game_id: number;
              player_id: number;
          }
          • game_id: number
          • player_id: number

        Returns void

    clear-message: (() => void)

    Type declaration

      • (): void
      • Returns void

    clock: ((clock) => void)

    Type declaration

    conditional-moves.updated: (() => void)

    Type declaration

      • (): void
      • Returns void

    cur_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    cur_review_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    destroy: (() => void)

    Type declaration

      • (): void
      • Returns void

    engine.updated: ((engine) => void)

    Type declaration

      • (engine): void
      • Parameters

        Returns void

    error: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: any

        Returns void

    gamedata: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: any

        Returns void

    last_official_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    load: ((config) => void)

    Type declaration

      • (config): void
      • Parameters

        Returns void

    mode: ((d) => void)

    Type declaration

    move-made: (() => void)

    Type declaration

      • (): void
      • Returns void

    outcome: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    paused: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    phase: ((d) => void)

    Type declaration

    played-by-click: ((player) => void)

    Type declaration

      • (player): void
      • Parameters

        • player: {
              player_id: number;
              x: number;
              y: number;
          }
          • player_id: number
          • x: number
          • y: number

        Returns void

    player-update: ((player) => void)

    Type declaration

    puzzle-correct-answer: (() => void)

    Type declaration

      • (): void
      • Returns void

    puzzle-place: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              color: "black" | "white";
              height: number;
              width: number;
              x: number;
              y: number;
          }
          • color: "black" | "white"
          • height: number
          • width: number
          • x: number
          • y: number

        Returns void

    puzzle-wrong-answer: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.load-end: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.load-start: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.sync-to-current-move: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.updated: (() => void)

    Type declaration

      • (): void
      • Returns void

    review_controller_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    review_owner_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    rules: ((d) => void)

    Type declaration

    score_estimate: ((d) => void)

    Type declaration

    set-for-removal: {
        removed: boolean;
        x: number;
        y: number;
    }

    Type declaration

    • removed: boolean
    • x: number
    • y: number
    show-message: ((message) => void)

    Type declaration

      • (message): void
      • Parameters

        • message: {
              formatted: string;
              message_id: string;
              parameters?: {
                  [key: string]: any;
              };
          }
          • formatted: string
          • message_id: string
          • Optional parameters?: {
                [key: string]: any;
            }
            • [key: string]: any

        Returns void

    stalling_score_estimate: ((data?) => void)

    Type declaration

    state_text: ((state) => void)

    Type declaration

      • (state): void
      • Parameters

        • state: {
              show_moves_made_count?: boolean;
              title: string;
          }
          • Optional show_moves_made_count?: boolean
          • title: string

        Returns void

    stone-removal.accepted: (() => void)

    Type declaration

      • (): void
      • Returns void

    stone-removal.needs-sealing: ((positions) => void)

    Type declaration

    stone-removal.updated: (() => void)

    Type declaration

      • (): void
      • Returns void

    strict_seki_mode: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    submit_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | (() => void)

        Returns void

    submitting-move: ((tf) => void)

    Type declaration

      • (tf): void
      • Parameters

        • tf: boolean

        Returns void

    title: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    undo_canceled: (() => void)

    Type declaration

      • (): void
      • Returns void

    undo_requested: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    update: (() => void)

    Type declaration

      • (): void
      • Returns void

    winner: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    \ No newline at end of file +

    Properties

    advance-to-next-board: (() => void)

    Type declaration

      • (): void
      • Returns void

    analyze_subtool: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    analyze_tool: ((d) => void)

    Type declaration

    audio-capture-stones: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              already_captured: number;
              count: number;
          }
          • already_captured: number
          • count: number

        Returns void

    audio-clock: ((event) => void)

    Type declaration

    audio-disconnected: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-enter-stone-removal: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-game-ended: ((winner) => void)

    Type declaration

      • (winner): void
      • Parameters

        • winner: "black" | "white" | "tie"

        Returns void

    audio-game-paused: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-game-resumed: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-game-started: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              player_id: number;
          }
          • player_id: number

            Player to move

            +

        Returns void

    audio-other-player-disconnected: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              player_id: number;
          }
          • player_id: number

        Returns void

    audio-other-player-reconnected: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              player_id: number;
          }
          • player_id: number

        Returns void

    audio-pass: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-reconnected: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-resume-game-from-stone-removal: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-stone: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              color: "black" | "white";
              height: number;
              width: number;
              x: number;
              y: number;
          }
          • color: "black" | "white"
          • height: number
          • width: number
          • x: number
          • y: number

        Returns void

    audio-undo-granted: (() => void)

    Type declaration

      • (): void
      • Returns void

    audio-undo-requested: (() => void)

    Type declaration

      • (): void
      • Returns void

    auto-resign: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              expiration: number;
              game_id: number;
              player_id: number;
          }
          • expiration: number
          • game_id: number
          • player_id: number

        Returns void

    captured-stones: ((obj) => void)

    Type declaration

    chat: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: any

        Returns void

    chat-remove: ((ids) => void)

    Type declaration

      • (ids): void
      • Parameters

        • ids: {
              chat_ids: string[];
          }
          • chat_ids: string[]

        Returns void

    chat-reset: (() => void)

    Type declaration

      • (): void
      • Returns void

    clear-auto-resign: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              game_id: number;
              player_id: number;
          }
          • game_id: number
          • player_id: number

        Returns void

    clear-message: (() => void)

    Type declaration

      • (): void
      • Returns void

    clock: ((clock) => void)

    Type declaration

    conditional-moves.updated: (() => void)

    Type declaration

      • (): void
      • Returns void

    cur_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    cur_review_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    destroy: (() => void)

    Type declaration

      • (): void
      • Returns void

    engine.updated: ((engine) => void)

    Type declaration

      • (engine): void
      • Parameters

        Returns void

    error: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: any

        Returns void

    gamedata: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: any

        Returns void

    last_official_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    load: ((config) => void)

    Type declaration

      • (config): void
      • Parameters

        Returns void

    mode: ((d) => void)

    Type declaration

    move-made: (() => void)

    Type declaration

      • (): void
      • Returns void

    outcome: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    paused: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    phase: ((d) => void)

    Type declaration

    played-by-click: ((player) => void)

    Type declaration

      • (player): void
      • Parameters

        • player: {
              player_id: number;
              x: number;
              y: number;
          }
          • player_id: number
          • x: number
          • y: number

        Returns void

    player-update: ((player) => void)

    Type declaration

    puzzle-correct-answer: (() => void)

    Type declaration

      • (): void
      • Returns void

    puzzle-place: ((obj) => void)

    Type declaration

      • (obj): void
      • Parameters

        • obj: {
              color: "black" | "white";
              height: number;
              width: number;
              x: number;
              y: number;
          }
          • color: "black" | "white"
          • height: number
          • width: number
          • x: number
          • y: number

        Returns void

    puzzle-wrong-answer: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.load-end: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.load-start: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.sync-to-current-move: (() => void)

    Type declaration

      • (): void
      • Returns void

    review.updated: (() => void)

    Type declaration

      • (): void
      • Returns void

    review_controller_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    review_owner_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    rules: ((d) => void)

    Type declaration

    score_estimate: ((d) => void)

    Type declaration

    set-for-removal: {
        removed: boolean;
        x: number;
        y: number;
    }

    Type declaration

    • removed: boolean
    • x: number
    • y: number
    show-message: ((message) => void)

    Type declaration

      • (message): void
      • Parameters

        • message: {
              formatted: string;
              message_id: string;
              parameters?: {
                  [key: string]: any;
              };
          }
          • formatted: string
          • message_id: string
          • Optional parameters?: {
                [key: string]: any;
            }
            • [key: string]: any

        Returns void

    stalling_score_estimate: ((data?) => void)

    Type declaration

    state_text: ((state) => void)

    Type declaration

      • (state): void
      • Parameters

        • state: {
              show_moves_made_count?: boolean;
              title: string;
          }
          • Optional show_moves_made_count?: boolean
          • title: string

        Returns void

    stone-removal.accepted: (() => void)

    Type declaration

      • (): void
      • Returns void

    stone-removal.needs-sealing: ((positions) => void)

    Type declaration

    stone-removal.updated: (() => void)

    Type declaration

      • (): void
      • Returns void

    strict_seki_mode: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    submit_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | (() => void)

        Returns void

    submitting-move: ((tf) => void)

    Type declaration

      • (tf): void
      • Parameters

        • tf: boolean

        Returns void

    title: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    undo_canceled: (() => void)

    Type declaration

      • (): void
      • Returns void

    undo_requested: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    update: (() => void)

    Type declaration

      • (): void
      • Returns void

    winner: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    \ No newline at end of file diff --git a/docs/interfaces/GobanIOErrorMessageObject.html b/docs/interfaces/GobanIOErrorMessageObject.html index 2543be67..cbac67ea 100644 --- a/docs/interfaces/GobanIOErrorMessageObject.html +++ b/docs/interfaces/GobanIOErrorMessageObject.html @@ -1,3 +1,3 @@ -GobanIOErrorMessageObject | goban

    Interface GobanIOErrorMessageObject

    interface GobanIOErrorMessageObject {
        message_id: "failed_to_load_sgf";
        url: string;
    }

    Properties

    message_id +GobanIOErrorMessageObject | goban

    Interface GobanIOErrorMessageObject

    interface GobanIOErrorMessageObject {
        message_id: "failed_to_load_sgf";
        url: string;
    }

    Properties

    Properties

    message_id: "failed_to_load_sgf"
    url: string
    \ No newline at end of file +

    Properties

    message_id: "failed_to_load_sgf"
    url: string
    \ No newline at end of file diff --git a/docs/interfaces/GobanMetrics.html b/docs/interfaces/GobanMetrics.html index 88662dfe..a497e943 100644 --- a/docs/interfaces/GobanMetrics.html +++ b/docs/interfaces/GobanMetrics.html @@ -1,5 +1,5 @@ -GobanMetrics | goban

    Interface GobanMetrics

    interface GobanMetrics {
        height: number;
        mid: number;
        offset: number;
        width: number;
    }

    Properties

    height +GobanMetrics | goban

    Interface GobanMetrics

    interface GobanMetrics {
        height: number;
        mid: number;
        offset: number;
        width: number;
    }

    Properties

    Properties

    height: number
    mid: number
    offset: number
    width: number
    \ No newline at end of file +

    Properties

    height: number
    mid: number
    offset: number
    width: number
    \ No newline at end of file diff --git a/docs/interfaces/GobanMoveErrorMessageObject.html b/docs/interfaces/GobanMoveErrorMessageObject.html index 29e4a8b7..fe4cc4e5 100644 --- a/docs/interfaces/GobanMoveErrorMessageObject.html +++ b/docs/interfaces/GobanMoveErrorMessageObject.html @@ -1,4 +1,4 @@ -GobanMoveErrorMessageObject | goban

    Interface GobanMoveErrorMessageObject

    interface GobanMoveErrorMessageObject {
        coords: string;
        message_id: GobanMoveErrorMessageId;
        move_number: number;
    }

    Properties

    coords +GobanMoveErrorMessageObject | goban

    Interface GobanMoveErrorMessageObject

    interface GobanMoveErrorMessageObject {
        coords: string;
        message_id: GobanMoveErrorMessageId;
        move_number: number;
    }

    Properties

    coords: string
    move_number: number
    \ No newline at end of file +

    Properties

    coords: string
    move_number: number
    \ No newline at end of file diff --git a/docs/interfaces/GobanSelectedThemes.html b/docs/interfaces/GobanSelectedThemes.html index fec712ee..a84c68d1 100644 --- a/docs/interfaces/GobanSelectedThemes.html +++ b/docs/interfaces/GobanSelectedThemes.html @@ -1,4 +1,4 @@ -GobanSelectedThemes | goban

    Interface GobanSelectedThemes

    interface GobanSelectedThemes {
        black: string;
        board: string;
        white: string;
    }

    Properties

    black +GobanSelectedThemes | goban

    Interface GobanSelectedThemes

    interface GobanSelectedThemes {
        black: string;
        board: string;
        white: string;
    }

    Properties

    Properties

    black: string
    board: string
    white: string
    \ No newline at end of file +

    Properties

    black: string
    board: string
    white: string
    \ No newline at end of file diff --git a/docs/interfaces/GobanSocketEvents.html b/docs/interfaces/GobanSocketEvents.html index aa2446ee..d6577d1d 100644 --- a/docs/interfaces/GobanSocketEvents.html +++ b/docs/interfaces/GobanSocketEvents.html @@ -1,4 +1,4 @@ -GobanSocketEvents | goban

    Interface GobanSocketEvents

    interface GobanSocketEvents {
        ERROR: ((data) => void);
        HUP: (() => void);
        active-bots: ((data) => void);
        active_game: ((data) => void);
        automatch/cancel: ((data) => void);
        automatch/entry: ((data) => void);
        automatch/start: ((data) => void);
        chat-join: ((data) => void);
        chat-message: ((data) => void);
        chat-message-removed: ((data) => void);
        chat-part: ((data) => void);
        chat-topic: ((data) => void);
        chat-update-user: ((data) => void);
        connect: (() => void);
        disconnect: ((code) => void);
        game/:id/auto_resign: ((data) => void);
        game/:id/chat: ((data) => void);
        game/:id/chat/remove: ((data) => void);
        game/:id/clear_auto_resign: ((data) => void);
        game/:id/clock: ((data) => void);
        game/:id/conditional_moves: ((data) => void);
        game/:id/error: ((data) => void);
        game/:id/gamedata: ((data) => void);
        game/:id/latency: ((data) => void);
        game/:id/phase: ((data) => void);
        game/:id/removed_stones: ((data) => void);
        game/:id/removed_stones_accepted: ((data) => void);
        game/:id/reset-chats: (() => void);
        game/:id/stalling_score_estimate: ((data?) => void);
        game/:id/undo_accepted: ((data) => void);
        game/:id/undo_canceled: ((data) => void);
        game/:id/undo_requested: ((data) => void);
        gamelist-count: ((data) => void);
        gamelist-count-:channel: ((data) => void);
        hostinfo: ((data) => void);
        incident-report: ((data) => void);
        itc: ((data) => void);
        latency: ((latency, clock_drift) => void);
        net/pong: ((data) => void);
        notification: ((data) => void);
        private-message: ((data) => void);
        private-superchat: ((data) => void);
        reconnect: (() => void);
        remote_storage/sync_complete: (() => void);
        remote_storage/update: ((data) => void);
        review/:id/full_state: ((data) => void);
        review/:id/r: ((data) => void);
        score-estimator-enabled-state: ((data) => void);
        seekgraph/global: ((messages) => void);
        timeout: (() => void);
        ui-push: ((data) => void);
        unrecoverable_error: ((code, tag, message) => void);
        user/jwt: ((jwt) => void);
        user/state: ((data) => void);
        user/update: ((user) => void);
    }

    Hierarchy (view full)

    Properties

    ERROR +GobanSocketEvents | goban

    Interface GobanSocketEvents

    interface GobanSocketEvents {
        ERROR: ((data) => void);
        HUP: (() => void);
        active-bots: ((data) => void);
        active_game: ((data) => void);
        automatch/cancel: ((data) => void);
        automatch/entry: ((data) => void);
        automatch/start: ((data) => void);
        chat-join: ((data) => void);
        chat-message: ((data) => void);
        chat-message-removed: ((data) => void);
        chat-part: ((data) => void);
        chat-topic: ((data) => void);
        chat-update-user: ((data) => void);
        connect: (() => void);
        disconnect: ((code) => void);
        game/:id/auto_resign: ((data) => void);
        game/:id/chat: ((data) => void);
        game/:id/chat/remove: ((data) => void);
        game/:id/clear_auto_resign: ((data) => void);
        game/:id/clock: ((data) => void);
        game/:id/conditional_moves: ((data) => void);
        game/:id/error: ((data) => void);
        game/:id/gamedata: ((data) => void);
        game/:id/latency: ((data) => void);
        game/:id/phase: ((data) => void);
        game/:id/removed_stones: ((data) => void);
        game/:id/removed_stones_accepted: ((data) => void);
        game/:id/reset-chats: (() => void);
        game/:id/stalling_score_estimate: ((data?) => void);
        game/:id/undo_accepted: ((data) => void);
        game/:id/undo_canceled: ((data) => void);
        game/:id/undo_requested: ((data) => void);
        gamelist-count: ((data) => void);
        gamelist-count-:channel: ((data) => void);
        hostinfo: ((data) => void);
        incident-report: ((data) => void);
        itc: ((data) => void);
        latency: ((latency, clock_drift) => void);
        net/pong: ((data) => void);
        notification: ((data) => void);
        private-message: ((data) => void);
        private-superchat: ((data) => void);
        reconnect: (() => void);
        remote_storage/sync_complete: (() => void);
        remote_storage/update: ((data) => void);
        review/:id/full_state: ((data) => void);
        review/:id/r: ((data) => void);
        score-estimator-enabled-state: ((data) => void);
        seekgraph/global: ((messages) => void);
        timeout: (() => void);
        ui-push: ((data) => void);
        unrecoverable_error: ((code, tag, message) => void);
        user/jwt: ((jwt) => void);
        user/state: ((data) => void);
        user/update: ((user) => void);
    }

    Hierarchy (view full)

    Properties

    ERROR HUP active-bots active_game @@ -56,16 +56,16 @@

    Properties

    ERROR: ((data) => void)

    An error occurred, the message string should be displayed to the user. For a list of errcode's used, see https://github.com/online-go/online-go.com/blob/devel/src/components/Errcode/Errcode.tsx

    -

    Type declaration

      • (data): void
      • Parameters

        • data: string | {
              errcode: string;
          }

        Returns void

    HUP: (() => void)

    The client should reload

    -

    Type declaration

      • (): void
      • Returns void

    active-bots: ((data) => void)

    Updates the list of bots that are connected and ready to the server

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {
              [id: number]: User;
          }

        Returns void

    active_game: ((data) => void)

    Message to inform the client of an active game, or a change to an existing game

    -

    Type declaration

    automatch/cancel: ((data) => void)

    An automatch request was canceled

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {
              uuid: string;
          }
          • uuid: string

        Returns void

    automatch/entry: ((data) => void)

    An automatch request is active

    -

    Type declaration

    automatch/start: ((data) => void)

    An automatch request was started

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {
              game_id: number;
              uuid: string;
          }
          • game_id: number
          • uuid: string

        Returns void

    chat-join: ((data) => void)

    User(s) joined a chat channel

    +

    Type declaration

      • (data): void
      • Parameters

        • data: string | {
              errcode: string;
          }

        Returns void

    HUP: (() => void)

    The client should reload

    +

    Type declaration

      • (): void
      • Returns void

    active-bots: ((data) => void)

    Updates the list of bots that are connected and ready to the server

    +

    Type declaration

      • (data): void
      • Parameters

        • data: {
              [id: number]: User;
          }

        Returns void

    active_game: ((data) => void)

    Message to inform the client of an active game, or a change to an existing game

    +

    Type declaration

    automatch/cancel: ((data) => void)

    An automatch request was canceled

    +

    Type declaration

      • (data): void
      • Parameters

        • data: {
              uuid: string;
          }
          • uuid: string

        Returns void

    automatch/entry: ((data) => void)

    An automatch request is active

    +

    Type declaration

    automatch/start: ((data) => void)

    An automatch request was started

    +

    Type declaration

      • (data): void
      • Parameters

        • data: {
              game_id: number;
              uuid: string;
          }
          • game_id: number
          • uuid: string

        Returns void

    chat-join: ((data) => void)

    User(s) joined a chat channel

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel: string;
              users: User[];
          }
          • channel: string

            The channel

          • users: User[]

            List of users that joined

            -

        Returns void

    chat-message: ((data) => void)

    Chat message was received

    +

    Returns void

    chat-message: ((data) => void)

    Chat message was received

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel: string;
              country?: string;
              id: number;
              message: {
                  i?: string;
                  m: string;
                  t: number;
              };
              professional: boolean;
              ranking: number;
              system?: true;
              system_message_type?: "flood";
              ui_class: string;
              username: string;
          }
          • channel: string

            The channel

          • Optional country?: string

            Country the user is from

          • id: number

            User id of the sender

            @@ -78,14 +78,14 @@
          • Optional system?: true

            Whether it's a system message or not

          • Optional system_message_type?: "flood"
          • ui_class: string

            UI class of the sender

          • username: string

            Username of the sender

            -

        Returns void

    chat-message-removed: ((data) => void)

    A chat message should be removed from the display

    +

    Returns void

    chat-message-removed: ((data) => void)

    A chat message should be removed from the display

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel: string;
              uuid: string;
          }
          • channel: string

            The channel

          • uuid: string

            Message id. Note, despite the name, I don't think this is always a uuid in uuid format, just treat it as a string.

            -

        Returns void

    chat-part: ((data) => void)

    User left a chat channel

    +

    Returns void

    chat-part: ((data) => void)

    User left a chat channel

    Type declaration

    chat-topic: ((data) => void)

    Channel topic was updated

    +

    Returns void

    chat-topic: ((data) => void)

    Channel topic was updated

    Type declaration

    chat-update-user: ((data) => void)

    A user's profile was updated

    +

    Returns void

    chat-update-user: ((data) => void)

    A user's profile was updated

    Type declaration

    connect: (() => void)

    Type declaration

    disconnect: ((code) => void)

    Type declaration

    game/:id/auto_resign: ((data) => void)

    Informs the client the player is scheduled to resign if not cleared

    +

    Returns void

    connect: (() => void)

    Type declaration

    disconnect: ((code) => void)

    Type declaration

    game/:id/auto_resign: ((data) => void)

    Informs the client the player is scheduled to resign if not cleared

    Type declaration

    game/:id/chat: ((data) => void)

    A game chat message

    -

    Type declaration

    game/:id/chat/remove: ((data) => void)

    Game chat lines should be removed

    +

    Returns void

    game/:id/chat: ((data) => void)

    A game chat message

    +

    Type declaration

    game/:id/chat/remove: ((data) => void)

    Game chat lines should be removed

    Type declaration

    game/:id/clear_auto_resign: ((data) => void)

    The auto resign for the given player has been cleared

    +

    Returns void

    game/:id/clear_auto_resign: ((data) => void)

    The auto resign for the given player has been cleared

    Type declaration

    game/:id/clock: ((data) => void)

    Game clock update

    -

    Type declaration

    game/:id/conditional_moves: ((data) => void)

    Update the conditional moves currently active

    +

    Returns void

    game/:id/clock: ((data) => void)

    Game clock update

    +

    Type declaration

    game/:id/conditional_moves: ((data) => void)

    Update the conditional moves currently active

    Type declaration

    game/:id/error: ((data) => void)

    Error that should be displayed to the user

    -

    Type declaration

    game/:id/gamedata: ((data) => void)

    Update the entire game state

    -

    Type declaration

    game/:id/latency: ((data) => void)

    Update latency information for a player

    +

    Returns void

    game/:id/error: ((data) => void)

    Error that should be displayed to the user

    +

    Type declaration

    game/:id/gamedata: ((data) => void)

    Update the entire game state

    +

    Type declaration

    game/:id/latency: ((data) => void)

    Update latency information for a player

    Type declaration

    game/:id/phase: ((data) => void)

    The phase has changed for the game

    -

    Type declaration

    game/:id/removed_stones: ((data) => void)

    Update the state of the stone removal phase

    -

    Type declaration

    game/:id/removed_stones_accepted: ((data) => void)

    The stone removal phase has been completed, this is the final state and +

    Returns void

    game/:id/phase: ((data) => void)

    The phase has changed for the game

    +

    Type declaration

    game/:id/removed_stones: ((data) => void)

    Update the state of the stone removal phase

    +

    Type declaration

    game/:id/removed_stones_accepted: ((data) => void)

    The stone removal phase has been completed, this is the final state and indicates a phase change to the given phase (should always be "finished")

    Type declaration

    game/:id/reset-chats: (() => void)

    The chat log should be reset.

    -

    Type declaration

    game/:id/stalling_score_estimate: ((data?) => void)

    A score estimation result has been broadcast, this is used for avoiding game stalling

    -

    Type declaration

    game/:id/undo_accepted: ((data) => void)

    Undo move has been accepted, the parameter is the new move number

    -

    Type declaration

    game/:id/undo_canceled: ((data) => void)

    Undo request has been canceled, the parameter is the move number of the original request

    -

    Type declaration

    game/:id/undo_requested: ((data) => void)

    Undo request has been requested, the parameter is the move number that we want to go back to

    -

    Type declaration

    gamelist-count: ((data) => void)

    Update number of live and correspondence games are currently being +

    Returns void

    game/:id/reset-chats: (() => void)

    The chat log should be reset.

    +

    Type declaration

    game/:id/stalling_score_estimate: ((data?) => void)

    A score estimation result has been broadcast, this is used for avoiding game stalling

    +

    Type declaration

    game/:id/undo_accepted: ((data) => void)

    Undo move has been accepted, the parameter is the new move number

    +

    Type declaration

    game/:id/undo_canceled: ((data) => void)

    Undo request has been canceled, the parameter is the move number of the original request

    +

    Type declaration

    game/:id/undo_requested: ((data) => void)

    Undo request has been requested, the parameter is the move number that we want to go back to

    +

    Type declaration

    gamelist-count: ((data) => void)

    Update number of live and correspondence games are currently being played

    Type declaration

    gamelist-count-:channel: ((data) => void)

    Update number of live and correspondence games are currently being +

    Returns void

    gamelist-count-:channel: ((data) => void)

    Update number of live and correspondence games are currently being played in a particular channel

    Type declaration

    hostinfo: ((data) => void)

    General host information for the termination server you +

    Returns void

    hostinfo: ((data) => void)

    General host information for the termination server you are connected to. This is a response to the hostinfo client message.

    Type declaration

    incident-report: ((data) => void)

    Incident report update

    -

    Type declaration

    itc: ((data) => void)

    "Inter Tab Communication" message. This is a client utility to enable +

    Returns void

    incident-report: ((data) => void)

    Incident report update

    +

    Type declaration

    itc: ((data) => void)

    "Inter Tab Communication" message. This is a client utility to enable relaying of messages between devices - the event and data are application defined, the server blindly relays to all connected devices for the sending user. Note this is relayed to all devices regardless @@ -168,17 +168,17 @@ the web client sending this will arrive on an android and ios instance)

    Type declaration

    latency: ((latency, clock_drift) => void)

    Type declaration

    net/pong: ((data) => void)

    Pong response from a ping

    +

    Returns void

    latency: ((latency, clock_drift) => void)

    Type declaration

    net/pong: ((data) => void)

    Pong response from a ping

    Type declaration

    notification: ((data) => void)

    A notification that should be displayed to the user +

    Returns void

    notification: ((data) => void)

    A notification that should be displayed to the user These are not strongly modeled, see https://github.com/online-go/online-go.com/blob/devel/src/components/Notifications/Notifications.tsx as a reference for what types there are and what data they contain

    Type declaration

    private-message: ((data) => void)

    A private message was received

    +

    Returns void

    private-message: ((data) => void)

    A private message was received

    Type declaration

    private-superchat: ((data) => void)

    Notify the client that a private message "super chat" has started. A +

    Returns void

    private-superchat: ((data) => void)

    Notify the client that a private message "super chat" has started. A super chat is an undismissable chat sent by a moderator. It should take all focus and not let the client do anything until the conversation is resolved (the enable flag is set to false)

    @@ -199,30 +199,30 @@
  • moderator_username: string

    The moderator username contacting the player

  • player_id: number

    Your id

  • player_username: string

    Your username

    -
  • Returns void

    reconnect: (() => void)

    Type declaration

    remote_storage/sync_complete: (() => void)

    Notification that the server has completed sending all remote storage +

    Returns void

    reconnect: (() => void)

    Type declaration

    remote_storage/sync_complete: (() => void)

    Notification that the server has completed sending all remote storage data and the client should now be up to date.

    -

    Type declaration

    remote_storage/update: ((data) => void)

    Updates a key value pair

    +

    Type declaration

    remote_storage/update: ((data) => void)

    Updates a key value pair

    Type declaration

    review/:id/full_state: ((data) => void)

    Replay of the entire full state of the review

    -

    Type declaration

    review/:id/r: ((data) => void)

    An incremental modification to the review stream

    -

    Type declaration

    score-estimator-enabled-state: ((data) => void)

    Notifies the client whether the the client shares an IP with one of the +

    Returns void

    review/:id/full_state: ((data) => void)

    Replay of the entire full state of the review

    +

    Type declaration

    review/:id/r: ((data) => void)

    An incremental modification to the review stream

    +

    Type declaration

    score-estimator-enabled-state: ((data) => void)

    Notifies the client whether the the client shares an IP with one of the players of the game. This is used to disable the score estimator in anonymous browsing windows for players of a game when the score estimator is disabled for the game.

    Type declaration

    seekgraph/global: ((messages) => void)

    Type declaration

    timeout: (() => void)

    Type declaration

    ui-push: ((data) => void)

    A UI Push notification. The event and data are not well defined here, +

    Returns void

    seekgraph/global: ((messages) => void)

    Type declaration

    timeout: (() => void)

    Type declaration

    ui-push: ((data) => void)

    A UI Push notification. The event and data are not well defined here, they come as a result to subscribing to ui push channels with ui-pushes/subscribe.

    Type declaration

    unrecoverable_error: ((code, tag, message) => void)

    Type declaration

    user/jwt: ((jwt) => void)

    Update the user's JWT token

    -

    Type declaration

    user/state: ((data) => void)

    Updates whether a user is online or not. Subscribe to these updates for +

    Returns void

    unrecoverable_error: ((code, tag, message) => void)

    Type declaration

    user/jwt: ((jwt) => void)

    Update the user's JWT token

    +

    Type declaration

    user/state: ((data) => void)

    Updates whether a user is online or not. Subscribe to these updates for particular users using the user/monitor command.

    -

    Type declaration

    user/update: ((user) => void)

    Update user information. For other players, this has the standard User +

    Type declaration

    user/update: ((user) => void)

    Update user information. For other players, this has the standard User fields, when this is the current user, it can have additional fields that are found in the ui/config

    -

    Type declaration

    \ No newline at end of file +

    Type declaration

    \ No newline at end of file diff --git a/docs/interfaces/GobanThemeBackgroundCSS.html b/docs/interfaces/GobanThemeBackgroundCSS.html index 5ce313cc..1514e432 100644 --- a/docs/interfaces/GobanThemeBackgroundCSS.html +++ b/docs/interfaces/GobanThemeBackgroundCSS.html @@ -1,4 +1,4 @@ -GobanThemeBackgroundCSS | goban

    Interface GobanThemeBackgroundCSS

    interface GobanThemeBackgroundCSS {
        background-color?: string;
        background-image?: string;
        background-size?: string;
    }

    Properties

    background-color? +GobanThemeBackgroundCSS | goban

    Interface GobanThemeBackgroundCSS

    interface GobanThemeBackgroundCSS {
        background-color?: string;
        background-image?: string;
        background-size?: string;
    }

    Properties

    background-color?: string
    background-image?: string
    background-size?: string
    \ No newline at end of file +

    Properties

    background-color?: string
    background-image?: string
    background-size?: string
    \ No newline at end of file diff --git a/docs/interfaces/GobanThemeBackgroundReactStyles.html b/docs/interfaces/GobanThemeBackgroundReactStyles.html index 3ae567f3..bd22d539 100644 --- a/docs/interfaces/GobanThemeBackgroundReactStyles.html +++ b/docs/interfaces/GobanThemeBackgroundReactStyles.html @@ -1,4 +1,4 @@ -GobanThemeBackgroundReactStyles | goban

    Interface GobanThemeBackgroundReactStyles

    interface GobanThemeBackgroundReactStyles {
        backgroundColor?: string;
        backgroundImage?: string;
        backgroundSize?: string;
    }

    Properties

    backgroundColor? +GobanThemeBackgroundReactStyles | goban

    Interface GobanThemeBackgroundReactStyles

    interface GobanThemeBackgroundReactStyles {
        backgroundColor?: string;
        backgroundImage?: string;
        backgroundSize?: string;
    }

    Properties

    backgroundColor?: string
    backgroundImage?: string
    backgroundSize?: string
    \ No newline at end of file +

    Properties

    backgroundColor?: string
    backgroundImage?: string
    backgroundSize?: string
    \ No newline at end of file diff --git a/docs/interfaces/JGOF.html b/docs/interfaces/JGOF.html index 7526216d..0ec5007e 100644 --- a/docs/interfaces/JGOF.html +++ b/docs/interfaces/JGOF.html @@ -1,14 +1,14 @@ JGOF | goban

    Interface JGOF

    JGOF (JSON Go Format) is an attempt at normalizing the AdHocFormat.

    -
    interface JGOF {
        ai_reviews?: {
            [id: string]: JGOFAIReview;
        };
        black?: JGOFPlayer | JGOFPlayer[];
        clock?: JGOFClock;
        jgof: 1;
        time_control?: JGOFTimeControl;
        white?: JGOFPlayer | JGOFPlayer[];
    }

    Properties

    interface JGOF {
        ai_reviews?: {
            [id: string]: JGOFAIReview;
        };
        black?: JGOFPlayer | JGOFPlayer[];
        clock?: JGOFClock;
        jgof: 1;
        time_control?: JGOFTimeControl;
        white?: JGOFPlayer | JGOFPlayer[];
    }

    Properties

    ai_reviews?: {
        [id: string]: JGOFAIReview;
    }

    AI Review information computed for this game

    -

    Type declaration

    Player information for those playing Black

    -
    clock?: JGOFClock

    Current clock information, this is used for ongoing games

    -
    jgof: 1

    JGOF version number

    -
    time_control?: JGOFTimeControl

    Time control settings for the game

    -

    Player information for those playing White

    -
    \ No newline at end of file +

    Type declaration

    black?: JGOFPlayer | JGOFPlayer[]

    Player information for those playing Black

    +
    clock?: JGOFClock

    Current clock information, this is used for ongoing games

    +
    jgof: 1

    JGOF version number

    +
    time_control?: JGOFTimeControl

    Time control settings for the game

    +
    white?: JGOFPlayer | JGOFPlayer[]

    Player information for those playing White

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFAIReview.html b/docs/interfaces/JGOFAIReview.html index 633a6adc..0d732d63 100644 --- a/docs/interfaces/JGOFAIReview.html +++ b/docs/interfaces/JGOFAIReview.html @@ -1,5 +1,5 @@ JGOFAIReview | goban

    Interface JGOFAIReview


    -
    interface JGOFAIReview {
        analyzed_variations?: {
            [var_key: string]: JGOFAIReviewMove;
        };
        date: number;
        engine: string;
        engine_version: string;
        error?: {
            coords: string;
            message_id: GobanMoveErrorMessageId;
            move_number: number;
        };
        id: string;
        moves: {
            [move_number: string]: JGOFAIReviewMove;
        };
        network: string;
        network_size: string;
        scores?: number[];
        strength: number;
        type: "fast" | "full";
        uuid: string;
        win_rate: number;
        win_rates?: number[];
    }

    Properties

    interface JGOFAIReview {
        analyzed_variations?: {
            [var_key: string]: JGOFAIReviewMove;
        };
        date: number;
        engine: string;
        engine_version: string;
        error?: {
            coords: string;
            message_id: GobanMoveErrorMessageId;
            move_number: number;
        };
        id: string;
        moves: {
            [move_number: string]: JGOFAIReviewMove;
        };
        network: string;
        network_size: string;
        scores?: number[];
        strength: number;
        type: "fast" | "full";
        uuid: string;
        win_rate: number;
        win_rates?: number[];
    }

    Properties

    analyzed_variations?: {
        [var_key: string]: JGOFAIReviewMove;
    }

    Analysis of variations in the game.

    -

    Type declaration

    date: number

    millisecond epoch time (ms from 1970 UTC)

    -
    engine: string
    engine_version: string
    error?: {
        coords: string;
        message_id: GobanMoveErrorMessageId;
        move_number: number;
    }

    If there was an error processing the review, it can be stored here

    -

    Type declaration

    id: string
    moves: {
        [move_number: string]: JGOFAIReviewMove;
    }

    Analysis of moves in the game.

    -

    Type declaration

    network: string
    network_size: string
    scores?: number[]

    predicted scores that black will win or lose by (negative for loss) for all moves

    -
    strength: number
    type: "fast" | "full"

    A fast review typically only has a few moves reviewed, whereas a full +

    Type declaration

    date: number

    millisecond epoch time (ms from 1970 UTC)

    +
    engine: string
    engine_version: string
    error?: {
        coords: string;
        message_id: GobanMoveErrorMessageId;
        move_number: number;
    }

    If there was an error processing the review, it can be stored here

    +

    Type declaration

    id: string
    moves: {
        [move_number: string]: JGOFAIReviewMove;
    }

    Analysis of moves in the game.

    +

    Type declaration

    network: string
    network_size: string
    scores?: number[]

    predicted scores that black will win or lose by (negative for loss) for all moves

    +
    strength: number
    type: "fast" | "full"

    A fast review typically only has a few moves reviewed, whereas a full review is expected to have every move reviewed. Note that this sets an expectation but not a requirement on what values are stored in moves, and while games are being reviewed these objects will have zero or more entries in moves regardless of the type.

    -
    uuid: string
    win_rate: number

    predicted probability that black will win the last move

    -
    win_rates?: number[]

    predicted probability that black will win for all moves

    -
    \ No newline at end of file +
    uuid: string
    win_rate: number

    predicted probability that black will win the last move

    +
    win_rates?: number[]

    predicted probability that black will win for all moves

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFAIReviewMove.html b/docs/interfaces/JGOFAIReviewMove.html index 4ffb9ed3..9694765b 100644 --- a/docs/interfaces/JGOFAIReviewMove.html +++ b/docs/interfaces/JGOFAIReviewMove.html @@ -1,13 +1,13 @@ -JGOFAIReviewMove | goban

    Interface JGOFAIReviewMove

    interface JGOFAIReviewMove {
        branches: JGOFAIReviewMoveVariation[];
        move: JGOFIntersection;
        move_number: number;
        ownership?: number[][];
        score?: number;
        win_rate: number;
    }

    Properties

    branches +JGOFAIReviewMove | goban

    Interface JGOFAIReviewMove

    interface JGOFAIReviewMove {
        branches: JGOFAIReviewMoveVariation[];
        move: JGOFIntersection;
        move_number: number;
        ownership?: number[][];
        score?: number;
        win_rate: number;
    }

    Properties

    Followup move branches explored

    -

    The move that was played.

    -
    move_number: number

    The move number. This is 1 indexed.

    -
    ownership?: number[][]

    A width*height array of ownership values

    -
    score?: number

    How many points black is predicted to win by (if positive, lose by if negative)

    -
    win_rate: number

    Probability of black winning after this move was made

    -
    \ No newline at end of file +

    The move that was played.

    +
    move_number: number

    The move number. This is 1 indexed.

    +
    ownership?: number[][]

    A width*height array of ownership values

    +
    score?: number

    How many points black is predicted to win by (if positive, lose by if negative)

    +
    win_rate: number

    Probability of black winning after this move was made

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFAIReviewMoveVariation.html b/docs/interfaces/JGOFAIReviewMoveVariation.html index ff13cb14..412eca41 100644 --- a/docs/interfaces/JGOFAIReviewMoveVariation.html +++ b/docs/interfaces/JGOFAIReviewMoveVariation.html @@ -1,4 +1,4 @@ -JGOFAIReviewMoveVariation | goban

    Interface JGOFAIReviewMoveVariation

    interface JGOFAIReviewMoveVariation {
        lcb?: number;
        moves: JGOFIntersection[];
        policy?: number;
        score?: number;
        score_mean?: number;
        score_stdev?: number;
        utility?: number;
        utility_lcb?: number;
        visits: number;
        win_rate: number;
    }

    Properties

    lcb? +JGOFAIReviewMoveVariation | goban

    Interface JGOFAIReviewMoveVariation

    interface JGOFAIReviewMoveVariation {
        lcb?: number;
        moves: JGOFIntersection[];
        policy?: number;
        score?: number;
        score_mean?: number;
        score_stdev?: number;
        utility?: number;
        utility_lcb?: number;
        visits: number;
        win_rate: number;
    }

    Properties

    lcb? moves policy? score? @@ -9,13 +9,13 @@ visits win_rate

    Properties

    lcb?: number

    lower confidence bound, both KataGo and LeelaZero provide this

    -

    Followup predicted moves by the AI

    -
    policy?: number

    From Leela Zero

    -
    score?: number

    How many points black is predicted to win for this variation (or lose by if negative)

    -
    score_mean?: number

    From KataGo

    -
    score_stdev?: number

    From KataGo

    -
    utility?: number

    From KataGo

    -
    utility_lcb?: number

    From KataGo

    -
    visits: number

    Number of times the AI considered the first move of this variation

    -
    win_rate: number

    Probability of black wining to report for this variation

    -
    \ No newline at end of file +

    Followup predicted moves by the AI

    +
    policy?: number

    From Leela Zero

    +
    score?: number

    How many points black is predicted to win for this variation (or lose by if negative)

    +
    score_mean?: number

    From KataGo

    +
    score_stdev?: number

    From KataGo

    +
    utility?: number

    From KataGo

    +
    utility_lcb?: number

    From KataGo

    +
    visits: number

    Number of times the AI considered the first move of this variation

    +
    win_rate: number

    Probability of black wining to report for this variation

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFAbsoluteTimeControl.html b/docs/interfaces/JGOFAbsoluteTimeControl.html index 4f1b67c6..71eea62c 100644 --- a/docs/interfaces/JGOFAbsoluteTimeControl.html +++ b/docs/interfaces/JGOFAbsoluteTimeControl.html @@ -1,5 +1,5 @@ -JGOFAbsoluteTimeControl | goban

    Interface JGOFAbsoluteTimeControl

    interface JGOFAbsoluteTimeControl {
        pause_on_weekends: boolean;
        speed: JGOFTimeControlSpeed;
        system: "absolute";
        total_time: number;
    }

    Properties

    pause_on_weekends +JGOFAbsoluteTimeControl | goban

    Interface JGOFAbsoluteTimeControl

    interface JGOFAbsoluteTimeControl {
        pause_on_weekends: boolean;
        speed: JGOFTimeControlSpeed;
        system: "absolute";
        total_time: number;
    }

    Properties

    pause_on_weekends: boolean
    system: "absolute"
    total_time: number
    \ No newline at end of file +

    Properties

    pause_on_weekends: boolean
    system: "absolute"
    total_time: number
    \ No newline at end of file diff --git a/docs/interfaces/JGOFByoYomiTimeControl.html b/docs/interfaces/JGOFByoYomiTimeControl.html index 06bfc386..3b4b1e71 100644 --- a/docs/interfaces/JGOFByoYomiTimeControl.html +++ b/docs/interfaces/JGOFByoYomiTimeControl.html @@ -1,7 +1,7 @@ -JGOFByoYomiTimeControl | goban

    Interface JGOFByoYomiTimeControl

    interface JGOFByoYomiTimeControl {
        main_time: number;
        pause_on_weekends: boolean;
        period_time: number;
        periods: number;
        speed: JGOFTimeControlSpeed;
        system: "byoyomi";
    }

    Properties

    main_time +JGOFByoYomiTimeControl | goban

    Interface JGOFByoYomiTimeControl

    interface JGOFByoYomiTimeControl {
        main_time: number;
        pause_on_weekends: boolean;
        period_time: number;
        periods: number;
        speed: JGOFTimeControlSpeed;
        system: "byoyomi";
    }

    Properties

    main_time: number
    pause_on_weekends: boolean
    period_time: number
    periods: number
    system: "byoyomi"
    \ No newline at end of file +

    Properties

    main_time: number
    pause_on_weekends: boolean
    period_time: number
    periods: number
    system: "byoyomi"
    \ No newline at end of file diff --git a/docs/interfaces/JGOFCanadianTimeControl.html b/docs/interfaces/JGOFCanadianTimeControl.html index 94e12ccc..f80f57b3 100644 --- a/docs/interfaces/JGOFCanadianTimeControl.html +++ b/docs/interfaces/JGOFCanadianTimeControl.html @@ -1,7 +1,7 @@ -JGOFCanadianTimeControl | goban

    Interface JGOFCanadianTimeControl

    interface JGOFCanadianTimeControl {
        main_time: number;
        pause_on_weekends: boolean;
        period_time: number;
        speed: JGOFTimeControlSpeed;
        stones_per_period: number;
        system: "canadian";
    }

    Properties

    main_time +JGOFCanadianTimeControl | goban

    Interface JGOFCanadianTimeControl

    interface JGOFCanadianTimeControl {
        main_time: number;
        pause_on_weekends: boolean;
        period_time: number;
        speed: JGOFTimeControlSpeed;
        stones_per_period: number;
        system: "canadian";
    }

    Properties

    main_time: number
    pause_on_weekends: boolean
    period_time: number
    stones_per_period: number
    system: "canadian"
    \ No newline at end of file +

    Properties

    main_time: number
    pause_on_weekends: boolean
    period_time: number
    stones_per_period: number
    system: "canadian"
    \ No newline at end of file diff --git a/docs/interfaces/JGOFClock.html b/docs/interfaces/JGOFClock.html index 86d0ebf7..d4544b5f 100644 --- a/docs/interfaces/JGOFClock.html +++ b/docs/interfaces/JGOFClock.html @@ -1,5 +1,5 @@ JGOFClock | goban

    Interface JGOFClock


    -
    interface JGOFClock {
        black_clock: JGOFPlayerClock;
        current_player: "black" | "white";
        current_player_id: string;
        pause_state?: JGOFPauseState;
        paused_since?: number;
        start_mode?: boolean;
        start_time_left?: number;
        stone_removal_time_left?: number;
        time_of_last_move: number;
        white_clock: JGOFPlayerClock;
    }

    Hierarchy (view full)

    Properties

    interface JGOFClock {
        black_clock: JGOFPlayerClock;
        current_player: "black" | "white";
        current_player_id: string;
        pause_state?: JGOFPauseState;
        paused_since?: number;
        start_mode?: boolean;
        start_time_left?: number;
        stone_removal_time_left?: number;
        time_of_last_move: number;
        white_clock: JGOFPlayerClock;
    }

    Hierarchy (view full)

    Properties

    black_clock: JGOFPlayerClock

    Time left on blacks clock.

    -
    current_player: "black" | "white"

    Player to move, and thus player whose clock is running.

    -
    current_player_id: string

    Player ID of player to move

    -
    pause_state?: JGOFPauseState

    If this field is set, the game clocks are paused for one or more reasons.

    -
    paused_since?: number

    Time the game was paused, in milliseconds since 1970, as observed by the server

    -
    start_mode?: boolean

    True if the game has not begun yet and we are waiting for the first +

    current_player: "black" | "white"

    Player to move, and thus player whose clock is running.

    +
    current_player_id: string

    Player ID of player to move

    +
    pause_state?: JGOFPauseState

    If this field is set, the game clocks are paused for one or more reasons.

    +
    paused_since?: number

    Time the game was paused, in milliseconds since 1970, as observed by the server

    +
    start_mode?: boolean

    True if the game has not begun yet and we are waiting for the first move to be played. If this is true, start_time_left will be set.

    -
    start_time_left?: number

    If start_mode is true, this is the number of milliseconds left +

    start_time_left?: number

    If start_mode is true, this is the number of milliseconds left on the start clock, when the clock reaches zero the game will be canceled.

    -
    stone_removal_time_left?: number

    If pause_State.stone_removal is true, this is the number of +

    stone_removal_time_left?: number

    If pause_State.stone_removal is true, this is the number of milliseconds left before the result is automatically accepted.

    -
    time_of_last_move: number

    Time the last move was made, in milliseconds since 1970, as observed by the server.

    -
    white_clock: JGOFPlayerClock

    Time left on whites clock.

    -
    \ No newline at end of file +
    time_of_last_move: number

    Time the last move was made, in milliseconds since 1970, as observed by the server.

    +
    white_clock: JGOFPlayerClock

    Time left on whites clock.

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFClockWithTransmitting.html b/docs/interfaces/JGOFClockWithTransmitting.html index c61a4289..d60b41ba 100644 --- a/docs/interfaces/JGOFClockWithTransmitting.html +++ b/docs/interfaces/JGOFClockWithTransmitting.html @@ -1,5 +1,5 @@ JGOFClockWithTransmitting | goban

    Interface JGOFClockWithTransmitting


    -
    interface JGOFClockWithTransmitting {
        black_clock: JGOFPlayerClock;
        black_move_transmitting: number;
        current_player: "black" | "white";
        current_player_id: string;
        pause_state?: JGOFPauseState;
        paused_since?: number;
        start_mode?: boolean;
        start_time_left?: number;
        stone_removal_time_left?: number;
        time_of_last_move: number;
        white_clock: JGOFPlayerClock;
        white_move_transmitting: number;
    }

    Hierarchy (view full)

    Properties

    interface JGOFClockWithTransmitting {
        black_clock: JGOFPlayerClock;
        black_move_transmitting: number;
        current_player: "black" | "white";
        current_player_id: string;
        pause_state?: JGOFPauseState;
        paused_since?: number;
        start_mode?: boolean;
        start_time_left?: number;
        stone_removal_time_left?: number;
        time_of_last_move: number;
        white_clock: JGOFPlayerClock;
        white_move_transmitting: number;
    }

    Hierarchy (view full)

    Properties

    black_clock: JGOFPlayerClock

    Time left on blacks clock.

    -
    black_move_transmitting: number
    current_player: "black" | "white"

    Player to move, and thus player whose clock is running.

    -
    current_player_id: string

    Player ID of player to move

    -
    pause_state?: JGOFPauseState

    If this field is set, the game clocks are paused for one or more reasons.

    -
    paused_since?: number

    Time the game was paused, in milliseconds since 1970, as observed by the server

    -
    start_mode?: boolean

    True if the game has not begun yet and we are waiting for the first +

    black_move_transmitting: number
    current_player: "black" | "white"

    Player to move, and thus player whose clock is running.

    +
    current_player_id: string

    Player ID of player to move

    +
    pause_state?: JGOFPauseState

    If this field is set, the game clocks are paused for one or more reasons.

    +
    paused_since?: number

    Time the game was paused, in milliseconds since 1970, as observed by the server

    +
    start_mode?: boolean

    True if the game has not begun yet and we are waiting for the first move to be played. If this is true, start_time_left will be set.

    -
    start_time_left?: number

    If start_mode is true, this is the number of milliseconds left +

    start_time_left?: number

    If start_mode is true, this is the number of milliseconds left on the start clock, when the clock reaches zero the game will be canceled.

    -
    stone_removal_time_left?: number

    If pause_State.stone_removal is true, this is the number of +

    stone_removal_time_left?: number

    If pause_State.stone_removal is true, this is the number of milliseconds left before the result is automatically accepted.

    -
    time_of_last_move: number

    Time the last move was made, in milliseconds since 1970, as observed by the server.

    -
    white_clock: JGOFPlayerClock

    Time left on whites clock.

    -
    white_move_transmitting: number
    \ No newline at end of file +
    time_of_last_move: number

    Time the last move was made, in milliseconds since 1970, as observed by the server.

    +
    white_clock: JGOFPlayerClock

    Time left on whites clock.

    +
    white_move_transmitting: number
    \ No newline at end of file diff --git a/docs/interfaces/JGOFFischerTimeControl.html b/docs/interfaces/JGOFFischerTimeControl.html index c1c6e40d..1eb8ed54 100644 --- a/docs/interfaces/JGOFFischerTimeControl.html +++ b/docs/interfaces/JGOFFischerTimeControl.html @@ -1,7 +1,7 @@ -JGOFFischerTimeControl | goban

    Interface JGOFFischerTimeControl

    interface JGOFFischerTimeControl {
        initial_time: number;
        max_time: number;
        pause_on_weekends: boolean;
        speed: JGOFTimeControlSpeed;
        system: "fischer";
        time_increment: number;
    }

    Properties

    initial_time +JGOFFischerTimeControl | goban

    Interface JGOFFischerTimeControl

    interface JGOFFischerTimeControl {
        initial_time: number;
        max_time: number;
        pause_on_weekends: boolean;
        speed: JGOFTimeControlSpeed;
        system: "fischer";
        time_increment: number;
    }

    Properties

    initial_time: number
    max_time: number
    pause_on_weekends: boolean
    system: "fischer"
    time_increment: number
    \ No newline at end of file +

    Properties

    initial_time: number
    max_time: number
    pause_on_weekends: boolean
    system: "fischer"
    time_increment: number
    \ No newline at end of file diff --git a/docs/interfaces/JGOFIntersection.html b/docs/interfaces/JGOFIntersection.html index b47623c0..88b0f27c 100644 --- a/docs/interfaces/JGOFIntersection.html +++ b/docs/interfaces/JGOFIntersection.html @@ -1,5 +1,5 @@ -JGOFIntersection | goban

    Interface JGOFIntersection

    interface JGOFIntersection {
        x: number;
        y: number;
    }

    Hierarchy (view full)

    Properties

    x +JGOFIntersection | goban

    Interface JGOFIntersection

    interface JGOFIntersection {
        x: number;
        y: number;
    }

    Hierarchy (view full)

    Properties

    x y

    Properties

    x: number

    Horizontal coordinate, counting left to right, starting with zero

    -
    y: number

    Vertical coordinate, counting top to bottom, starting with zero

    -
    \ No newline at end of file +
    y: number

    Vertical coordinate, counting top to bottom, starting with zero

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFMove.html b/docs/interfaces/JGOFMove.html index adea9fb2..748ab818 100644 --- a/docs/interfaces/JGOFMove.html +++ b/docs/interfaces/JGOFMove.html @@ -1,4 +1,4 @@ -JGOFMove | goban

    Interface JGOFMove

    interface JGOFMove {
        blur?: number;
        color?: JGOFNumericPlayerColor;
        edited?: boolean;
        played_by?: number;
        player_update?: JGOFPlayerSummary;
        removal_reason?: string;
        sgf_downloaded_by?: number[];
        timedelta?: number;
        x: number;
        y: number;
    }

    Hierarchy (view full)

    Properties

    blur? +JGOFMove | goban

    Interface JGOFMove

    interface JGOFMove {
        blur?: number;
        color?: JGOFNumericPlayerColor;
        edited?: boolean;
        played_by?: number;
        player_update?: JGOFPlayerSummary;
        removal_reason?: string;
        sgf_downloaded_by?: number[];
        timedelta?: number;
        x: number;
        y: number;
    }

    Hierarchy (view full)

    Properties

    Properties

    blur?: number
    edited?: boolean
    played_by?: number
    player_update?: JGOFPlayerSummary
    removal_reason?: string

    Stone removal reasoning, primarily for debugging

    -
    sgf_downloaded_by?: number[]
    timedelta?: number
    x: number

    Horizontal coordinate, counting left to right, starting with zero

    -
    y: number

    Vertical coordinate, counting top to bottom, starting with zero

    -
    \ No newline at end of file +

    Properties

    blur?: number
    edited?: boolean
    played_by?: number
    player_update?: JGOFPlayerSummary
    removal_reason?: string

    Stone removal reasoning, primarily for debugging

    +
    sgf_downloaded_by?: number[]
    timedelta?: number
    x: number

    Horizontal coordinate, counting left to right, starting with zero

    +
    y: number

    Vertical coordinate, counting top to bottom, starting with zero

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFNoneTimeControl.html b/docs/interfaces/JGOFNoneTimeControl.html index 3eee0ab1..75c44bf6 100644 --- a/docs/interfaces/JGOFNoneTimeControl.html +++ b/docs/interfaces/JGOFNoneTimeControl.html @@ -1,4 +1,4 @@ -JGOFNoneTimeControl | goban

    Interface JGOFNoneTimeControl

    interface JGOFNoneTimeControl {
        pause_on_weekends: boolean;
        speed: "correspondence";
        system: "none";
    }

    Properties

    pause_on_weekends +JGOFNoneTimeControl | goban

    Interface JGOFNoneTimeControl

    interface JGOFNoneTimeControl {
        pause_on_weekends: boolean;
        speed: "correspondence";
        system: "none";
    }

    Properties

    pause_on_weekends: boolean
    speed: "correspondence"
    system: "none"
    \ No newline at end of file +

    Properties

    pause_on_weekends: boolean
    speed: "correspondence"
    system: "none"
    \ No newline at end of file diff --git a/docs/interfaces/JGOFPauseState.html b/docs/interfaces/JGOFPauseState.html index 998893c5..6f9a1552 100644 --- a/docs/interfaces/JGOFPauseState.html +++ b/docs/interfaces/JGOFPauseState.html @@ -1,16 +1,16 @@ -JGOFPauseState | goban

    Interface JGOFPauseState

    interface JGOFPauseState {
        moderator?: string;
        player?: {
            pauses_left: number;
            player_id: string;
        };
        server?: true;
        stone_removal?: true;
        vacation?: {
            [player_id: string]: true;
        };
        weekend?: true;
    }

    Properties

    moderator? +JGOFPauseState | goban

    Interface JGOFPauseState

    interface JGOFPauseState {
        moderator?: string;
        player?: {
            pauses_left: number;
            player_id: string;
        };
        server?: true;
        stone_removal?: true;
        vacation?: {
            [player_id: string]: true;
        };
        weekend?: true;
    }

    Properties

    moderator?: string

    Paused by a moderator, value of this field is the moderator's id

    -
    player?: {
        pauses_left: number;
        player_id: string;
    }

    Paused by a player. The game can only be paused by one player at a time.

    +
    player?: {
        pauses_left: number;
        player_id: string;
    }

    Paused by a player. The game can only be paused by one player at a time.

    Type declaration

    • pauses_left: number

      Number of pauses left for the pausing player.

    • player_id: string

      Player id of the player who paused the game.

      -
    server?: true

    Paused by the server

    -
    stone_removal?: true

    Paused because the game is in the stone removal phase

    -
    vacation?: {
        [player_id: string]: true;
    }

    Paused because one or more players is on vacation

    +
    server?: true

    Paused by the server

    +
    stone_removal?: true

    Paused because the game is in the stone removal phase

    +
    vacation?: {
        [player_id: string]: true;
    }

    Paused because one or more players is on vacation

    Type declaration

    • [player_id: string]: true

      Player id that is on vacation

      -
    weekend?: true

    Paused because it is the weekend

    -
    \ No newline at end of file +
    weekend?: true

    Paused because it is the weekend

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFPlayer.html b/docs/interfaces/JGOFPlayer.html index 75e9ecd5..362a7ebd 100644 --- a/docs/interfaces/JGOFPlayer.html +++ b/docs/interfaces/JGOFPlayer.html @@ -1,5 +1,5 @@ -JGOFPlayer | goban

    Interface JGOFPlayer

    interface JGOFPlayer {
        id?: string;
        name: string;
    }

    Properties

    id? +JGOFPlayer | goban

    Interface JGOFPlayer

    interface JGOFPlayer {
        id?: string;
        name: string;
    }

    Properties

    Properties

    id?: string

    Identifier for the player

    -
    name: string

    Name or username of the player

    -
    \ No newline at end of file +
    name: string

    Name or username of the player

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFPlayerClock.html b/docs/interfaces/JGOFPlayerClock.html index 0fcb6a2c..346802eb 100644 --- a/docs/interfaces/JGOFPlayerClock.html +++ b/docs/interfaces/JGOFPlayerClock.html @@ -1,13 +1,13 @@ -JGOFPlayerClock | goban

    Interface JGOFPlayerClock

    interface JGOFPlayerClock {
        block_time_left?: number;
        main_time: number;
        moves_left?: number;
        period_time_left?: number;
        periods_left?: number;
    }

    Hierarchy (view full)

    Properties

    block_time_left? +JGOFPlayerClock | goban

    Interface JGOFPlayerClock

    interface JGOFPlayerClock {
        block_time_left?: number;
        main_time: number;
        moves_left?: number;
        period_time_left?: number;
        periods_left?: number;
    }

    Hierarchy (view full)

    Properties

    block_time_left?: number

    Used with canadian time control. Time left in milliseconds to make the remainder of your moves in the current block

    -
    main_time: number

    Main time left on the clock, in milliseconds.

    -
    moves_left?: number

    Used with canadian time control. Number of moves left before a new +

    main_time: number

    Main time left on the clock, in milliseconds.

    +
    moves_left?: number

    Used with canadian time control. Number of moves left before a new block of time.

    -
    period_time_left?: number

    Used with byo-yomi time control. Time left on the period time, in milliseconds.

    -
    periods_left?: number

    Used with byo-yomi time control. Number of periods left.

    -
    \ No newline at end of file +
    period_time_left?: number

    Used with byo-yomi time control. Time left on the period time, in milliseconds.

    +
    periods_left?: number

    Used with byo-yomi time control. Number of periods left.

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFPlayerSummary.html b/docs/interfaces/JGOFPlayerSummary.html index 08c7df7c..7a7a1a96 100644 --- a/docs/interfaces/JGOFPlayerSummary.html +++ b/docs/interfaces/JGOFPlayerSummary.html @@ -1,4 +1,4 @@ -JGOFPlayerSummary | goban

    Interface JGOFPlayerSummary

    interface JGOFPlayerSummary {
        dropped_players?: {
            black?: number[];
            white?: number[];
        };
        players: {
            black: number;
            white: number;
        };
        rengo_teams: {
            black: number[];
            white: number[];
        };
    }

    Properties

    dropped_players? +JGOFPlayerSummary | goban

    Interface JGOFPlayerSummary

    interface JGOFPlayerSummary {
        dropped_players?: {
            black?: number[];
            white?: number[];
        };
        players: {
            black: number;
            white: number;
        };
        rengo_teams: {
            black: number[];
            white: number[];
        };
    }

    Properties

    dropped_players?: {
        black?: number[];
        white?: number[];
    }

    Type declaration

    • Optional black?: number[]
    • Optional white?: number[]
    players: {
        black: number;
        white: number;
    }

    Type declaration

    • black: number
    • white: number
    rengo_teams: {
        black: number[];
        white: number[];
    }

    Type declaration

    • black: number[]
    • white: number[]
    \ No newline at end of file +

    Properties

    dropped_players?: {
        black?: number[];
        white?: number[];
    }

    Type declaration

    • Optional black?: number[]
    • Optional white?: number[]
    players: {
        black: number;
        white: number;
    }

    Type declaration

    • black: number
    • white: number
    rengo_teams: {
        black: number[];
        white: number[];
    }

    Type declaration

    • black: number[]
    • white: number[]
    \ No newline at end of file diff --git a/docs/interfaces/JGOFSealingIntersection.html b/docs/interfaces/JGOFSealingIntersection.html index 6d7bf336..f77159db 100644 --- a/docs/interfaces/JGOFSealingIntersection.html +++ b/docs/interfaces/JGOFSealingIntersection.html @@ -1,8 +1,8 @@ -JGOFSealingIntersection | goban

    Interface JGOFSealingIntersection

    interface JGOFSealingIntersection {
        color: JGOFNumericPlayerColor;
        x: number;
        y: number;
    }

    Hierarchy (view full)

    Properties

    color +JGOFSealingIntersection | goban

    Interface JGOFSealingIntersection

    interface JGOFSealingIntersection {
        color: JGOFNumericPlayerColor;
        x: number;
        y: number;
    }

    Hierarchy (view full)

    Properties

    Properties

    Color the intersection is probably presumed to be by the players, but is in fact empty.

    -
    x: number

    Horizontal coordinate, counting left to right, starting with zero

    -
    y: number

    Vertical coordinate, counting top to bottom, starting with zero

    -
    \ No newline at end of file +
    x: number

    Horizontal coordinate, counting left to right, starting with zero

    +
    y: number

    Vertical coordinate, counting top to bottom, starting with zero

    +
    \ No newline at end of file diff --git a/docs/interfaces/JGOFSimpleTimeControl.html b/docs/interfaces/JGOFSimpleTimeControl.html index caf71b4e..27a69b88 100644 --- a/docs/interfaces/JGOFSimpleTimeControl.html +++ b/docs/interfaces/JGOFSimpleTimeControl.html @@ -1,5 +1,5 @@ -JGOFSimpleTimeControl | goban

    Interface JGOFSimpleTimeControl

    interface JGOFSimpleTimeControl {
        pause_on_weekends: boolean;
        per_move: number;
        speed: JGOFTimeControlSpeed;
        system: "simple";
    }

    Properties

    pause_on_weekends +JGOFSimpleTimeControl | goban

    Interface JGOFSimpleTimeControl

    interface JGOFSimpleTimeControl {
        pause_on_weekends: boolean;
        per_move: number;
        speed: JGOFTimeControlSpeed;
        system: "simple";
    }

    Properties

    pause_on_weekends: boolean
    per_move: number
    system: "simple"
    \ No newline at end of file +

    Properties

    pause_on_weekends: boolean
    per_move: number
    system: "simple"
    \ No newline at end of file diff --git a/docs/interfaces/MarkInterface.html b/docs/interfaces/MarkInterface.html index 31fe407a..6e488e46 100644 --- a/docs/interfaces/MarkInterface.html +++ b/docs/interfaces/MarkInterface.html @@ -1,4 +1,4 @@ -MarkInterface | goban

    Interface MarkInterface

    interface MarkInterface {
        black?: boolean;
        blue_move?: boolean;
        chat_triangle?: boolean;
        circle?: boolean;
        color?: string;
        cross?: boolean;
        hint?: boolean;
        letter?: string;
        mark_x?: boolean;
        needs_sealing?: boolean;
        remove?: boolean;
        score?: string;
        square?: boolean;
        stone_removed?: boolean;
        sub_triangle?: boolean;
        subscript?: string;
        transient_letter?: string;
        triangle?: boolean;
        white?: boolean;
        [label: string]: string | boolean | undefined;
    }

    Indexable

    [label: string]: string | boolean | undefined

    Properties

    black? +MarkInterface | goban

    Interface MarkInterface

    interface MarkInterface {
        black?: boolean;
        blue_move?: boolean;
        chat_triangle?: boolean;
        circle?: boolean;
        color?: string;
        cross?: boolean;
        hint?: boolean;
        letter?: string;
        mark_x?: boolean;
        needs_sealing?: boolean;
        remove?: boolean;
        score?: string;
        square?: boolean;
        stone_removed?: boolean;
        sub_triangle?: boolean;
        subscript?: string;
        transient_letter?: string;
        triangle?: boolean;
        white?: boolean;
        [label: string]: string | boolean | undefined;
    }

    Indexable

    [label: string]: string | boolean | undefined

    Properties

    black?: boolean
    blue_move?: boolean
    chat_triangle?: boolean
    circle?: boolean
    color?: string
    cross?: boolean
    hint?: boolean
    letter?: string
    mark_x?: boolean
    needs_sealing?: boolean
    remove?: boolean
    score?: string
    square?: boolean
    stone_removed?: boolean
    sub_triangle?: boolean
    subscript?: string
    transient_letter?: string
    triangle?: boolean
    white?: boolean
    \ No newline at end of file +

    Properties

    black?: boolean
    blue_move?: boolean
    chat_triangle?: boolean
    circle?: boolean
    color?: string
    cross?: boolean
    hint?: boolean
    letter?: string
    mark_x?: boolean
    needs_sealing?: boolean
    remove?: boolean
    score?: string
    square?: boolean
    stone_removed?: boolean
    sub_triangle?: boolean
    subscript?: string
    transient_letter?: string
    triangle?: boolean
    white?: boolean
    \ No newline at end of file diff --git a/docs/interfaces/MoveCommand.html b/docs/interfaces/MoveCommand.html index ae0c064a..70b91b0d 100644 --- a/docs/interfaces/MoveCommand.html +++ b/docs/interfaces/MoveCommand.html @@ -1,5 +1,5 @@ -MoveCommand | goban

    Interface MoveCommand

    interface MoveCommand {
        blur?: number;
        clock?: JGOFPlayerClock;
        game_id: number;
        move: string;
    }

    Properties

    blur? +MoveCommand | goban

    Interface MoveCommand

    interface MoveCommand {
        blur?: number;
        clock?: JGOFPlayerClock;
        game_id: number;
        move: string;
    }

    Properties

    Properties

    blur?: number
    game_id: number
    move: string
    \ No newline at end of file +

    Properties

    blur?: number
    game_id: number
    move: string
    \ No newline at end of file diff --git a/docs/interfaces/MoveTreeChatLine.html b/docs/interfaces/MoveTreeChatLine.html index 7143b1d0..a910e448 100644 --- a/docs/interfaces/MoveTreeChatLine.html +++ b/docs/interfaces/MoveTreeChatLine.html @@ -1,3 +1,3 @@ -MoveTreeChatLine | goban

    Interface MoveTreeChatLine

    interface MoveTreeChatLine {
        body: MoveTreeChatLineBody;
        username: string;
    }

    Properties

    body +MoveTreeChatLine | goban

    Interface MoveTreeChatLine

    interface MoveTreeChatLine {
        body: MoveTreeChatLineBody;
        username: string;
    }

    Properties

    Properties

    username: string
    \ No newline at end of file +

    Properties

    username: string
    \ No newline at end of file diff --git a/docs/interfaces/MoveTreeChatLineBody.html b/docs/interfaces/MoveTreeChatLineBody.html index a6727551..2586ba1e 100644 --- a/docs/interfaces/MoveTreeChatLineBody.html +++ b/docs/interfaces/MoveTreeChatLineBody.html @@ -1,5 +1,5 @@ -MoveTreeChatLineBody | goban

    Interface MoveTreeChatLineBody

    interface MoveTreeChatLineBody {
        from: number;
        moves: string | AdHocPackedMove;
        name: string;
        type: "analysis";
    }

    Properties

    from +MoveTreeChatLineBody | goban

    Interface MoveTreeChatLineBody

    interface MoveTreeChatLineBody {
        from: number;
        moves: string | AdHocPackedMove;
        name: string;
        type: "analysis";
    }

    Properties

    Properties

    from: number
    moves: string | AdHocPackedMove
    name: string
    type: "analysis"
    \ No newline at end of file +

    Properties

    from: number
    moves: string | AdHocPackedMove
    name: string
    type: "analysis"
    \ No newline at end of file diff --git a/docs/interfaces/MoveTreeJson.html b/docs/interfaces/MoveTreeJson.html index b7cf21ee..4e570286 100644 --- a/docs/interfaces/MoveTreeJson.html +++ b/docs/interfaces/MoveTreeJson.html @@ -1,4 +1,4 @@ -MoveTreeJson | goban

    Interface MoveTreeJson

    interface MoveTreeJson {
        branches?: MoveTreeJson[];
        correct_answer?: boolean;
        marks?: {
            marks: MarkInterface;
            x: number;
            y: number;
        }[];
        pen_marks?: MoveTreePenMarks;
        text?: string;
        trunk_next?: MoveTreeJson;
        wrong_answer?: boolean;
        x: number;
        y: number;
    }

    Properties

    branches? +MoveTreeJson | goban

    Interface MoveTreeJson

    interface MoveTreeJson {
        branches?: MoveTreeJson[];
        correct_answer?: boolean;
        marks?: {
            marks: MarkInterface;
            x: number;
            y: number;
        }[];
        pen_marks?: MoveTreePenMarks;
        text?: string;
        trunk_next?: MoveTreeJson;
        wrong_answer?: boolean;
        x: number;
        y: number;
    }

    Properties

    branches?: MoveTreeJson[]
    correct_answer?: boolean
    marks?: {
        marks: MarkInterface;
        x: number;
        y: number;
    }[]

    Type declaration

    pen_marks?: MoveTreePenMarks
    text?: string
    trunk_next?: MoveTreeJson
    wrong_answer?: boolean
    x: number
    y: number
    \ No newline at end of file +

    Properties

    branches?: MoveTreeJson[]
    correct_answer?: boolean
    marks?: {
        marks: MarkInterface;
        x: number;
        y: number;
    }[]

    Type declaration

    pen_marks?: MoveTreePenMarks
    text?: string
    trunk_next?: MoveTreeJson
    wrong_answer?: boolean
    x: number
    y: number
    \ No newline at end of file diff --git a/docs/interfaces/PlayerScore.html b/docs/interfaces/PlayerScore.html index 03dce615..de9aaa87 100644 --- a/docs/interfaces/PlayerScore.html +++ b/docs/interfaces/PlayerScore.html @@ -1,8 +1,8 @@ -PlayerScore | goban

    Interface PlayerScore

    interface PlayerScore {
        handicap: number;
        komi: number;
        prisoners: number;
        scoring_positions: string;
        stones: number;
        territory: number;
        total: number;
    }

    Properties

    handicap +PlayerScore | goban

    Interface PlayerScore

    interface PlayerScore {
        handicap: number;
        komi: number;
        prisoners: number;
        scoring_positions: string;
        stones: number;
        territory: number;
        total: number;
    }

    Properties

    handicap: number
    komi: number
    prisoners: number
    scoring_positions: string
    stones: number
    territory: number
    total: number
    \ No newline at end of file +

    Properties

    handicap: number
    komi: number
    prisoners: number
    scoring_positions: string
    stones: number
    territory: number
    total: number
    \ No newline at end of file diff --git a/docs/interfaces/PuzzleConfig.html b/docs/interfaces/PuzzleConfig.html index f45c03b7..7314c8cf 100644 --- a/docs/interfaces/PuzzleConfig.html +++ b/docs/interfaces/PuzzleConfig.html @@ -1,4 +1,4 @@ -PuzzleConfig | goban

    Interface PuzzleConfig

    interface PuzzleConfig {
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        isobranch_hash?: string;
        marks?: {
            [mark: string]: string;
        };
        mode?: string;
        move_tree?: MoveTreeJson;
        name?: string;
        player?: JGOFNumericPlayerColor;
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        removal?: boolean[][];
        white_prisoners?: number;
        width?: number;
    }

    Hierarchy (view full)

    Properties

    black_prisoners? +PuzzleConfig | goban

    Interface PuzzleConfig

    interface PuzzleConfig {
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_is_repeating?: boolean;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        isobranch_hash?: string;
        marks?: {
            [mark: string]: string;
        };
        mode?: string;
        move_tree?: MoveTreeJson;
        name?: string;
        player?: JGOFNumericPlayerColor;
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        removal?: boolean[][];
        white_prisoners?: number;
        width?: number;
    }

    Hierarchy (view full)

    Properties

    black_prisoners?: number
    board_is_repeating?: boolean
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    isobranch_hash?: string
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: string
    move_tree?: MoveTreeJson
    name?: string
    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    removal?: boolean[][]
    white_prisoners?: number
    width?: number
    \ No newline at end of file +

    Properties

    black_prisoners?: number
    board_is_repeating?: boolean
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    isobranch_hash?: string
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: string
    move_tree?: MoveTreeJson
    name?: string
    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    removal?: boolean[][]
    white_prisoners?: number
    width?: number
    \ No newline at end of file diff --git a/docs/interfaces/ReviewMessage.html b/docs/interfaces/ReviewMessage.html index b6006b30..48c16b69 100644 --- a/docs/interfaces/ReviewMessage.html +++ b/docs/interfaces/ReviewMessage.html @@ -1,7 +1,7 @@ ReviewMessage | goban

    Interface ReviewMessage

    Reviews are constructed by a stream of modifications messages, this interface describes the format of those modification messages. A message can contain any number of the fields listed.

    -
    interface ReviewMessage {
        chat?: {
            channel: string;
            chat_id: string;
            date: number;
            from: number;
            moves: string | AdHocPackedMove;
            player_id: number;
        };
        clearpen?: boolean;
        controller?: number | {
            id: number;
            username: string;
        };
        delete?: number;
        f?: number;
        gamedata?: GobanEngineConfig;
        k?: {
            [mark: string]: string;
        };
        m?: string;
        om?: [number, number, number];
        owner?: number | {
            id: number;
            username: string;
        };
        pen?: string;
        player_update?: JGOFPlayerSummary;
        pp?: [number, number];
        remove-chat?: string;
        review_id?: number;
        t?: string;
        t+?: string;
        ts?: number;
        undo?: boolean;
    }

    Properties

    interface ReviewMessage {
        chat?: {
            channel: string;
            chat_id: string;
            date: number;
            from: number;
            moves: string | AdHocPackedMove;
            player_id: number;
        };
        clearpen?: boolean;
        controller?: number | {
            id: number;
            username: string;
        };
        delete?: number;
        f?: number;
        gamedata?: GobanEngineConfig;
        k?: {
            [mark: string]: string;
        };
        m?: string;
        om?: [number, number, number];
        owner?: number | {
            id: number;
            username: string;
        };
        pen?: string;
        player_update?: JGOFPlayerSummary;
        pp?: [number, number];
        remove-chat?: string;
        review_id?: number;
        t?: string;
        t+?: string;
        ts?: number;
        undo?: boolean;
    }

    Properties

    chat? clearpen? controller? delete? @@ -23,24 +23,24 @@

    Properties

    chat?: {
        channel: string;
        chat_id: string;
        date: number;
        from: number;
        moves: string | AdHocPackedMove;
        player_id: number;
    }

    Chat message

    Type declaration

    • channel: string
    • chat_id: string
    • date: number
    • from: number

      Turn number

    • moves: string | AdHocPackedMove

      this might just be "string", i'm not entirely sure

      -
    • player_id: number
    clearpen?: boolean

    Clears the pen drawings on the node

    -
    controller?: number | {
        id: number;
        username: string;
    }

    Sets the controller of the review

    -

    Type declaration

    • id: number
    • username: string
    delete?: number

    Delete

    -
    f?: number

    from (move number)

    -

    Initial gamedata to review

    -
    k?: {
        [mark: string]: string;
    }

    Marks made

    -

    Type declaration

    • [mark: string]: string
    m?: string

    Moves made

    -
    om?: [number, number, number]

    official move [reviewing live game]

    -
    owner?: number | {
        id: number;
        username: string;
    }

    Sets the owner of the review

    -

    Type declaration

    • id: number
    • username: string
    pen?: string

    pen color / pen start

    -
    player_update?: JGOFPlayerSummary

    Updated information about the players, such as name etc.

    -
    pp?: [number, number]

    pen point

    -
    remove-chat?: string

    Remove's the given chat by id

    -
    review_id?: number

    The review ID. This is used when sending from the client to the server, +

  • player_id: number
  • clearpen?: boolean

    Clears the pen drawings on the node

    +
    controller?: number | {
        id: number;
        username: string;
    }

    Sets the controller of the review

    +

    Type declaration

    • id: number
    • username: string
    delete?: number

    Delete

    +
    f?: number

    from (move number)

    +

    Initial gamedata to review

    +
    k?: {
        [mark: string]: string;
    }

    Marks made

    +

    Type declaration

    • [mark: string]: string
    m?: string

    Moves made

    +
    om?: [number, number, number]

    official move [reviewing live game]

    +
    owner?: number | {
        id: number;
        username: string;
    }

    Sets the owner of the review

    +

    Type declaration

    • id: number
    • username: string
    pen?: string

    pen color / pen start

    +
    player_update?: JGOFPlayerSummary

    Updated information about the players, such as name etc.

    +
    pp?: [number, number]

    pen point

    +
    remove-chat?: string

    Remove's the given chat by id

    +
    review_id?: number

    The review ID. This is used when sending from the client to the server, but is not sent by the server back to the client (as the id is encoded in the message event name)

    -
    t?: string

    text note for the current node

    -
    t+?: string

    text append to the current node

    -
    ts?: number

    timestamp (ms)

    -
    undo?: boolean

    official undo [reviewing live game]

    -
    \ No newline at end of file +
    t?: string

    text note for the current node

    +
    t+?: string

    text append to the current node

    +
    ts?: number

    timestamp (ms)

    +
    undo?: boolean

    official undo [reviewing live game]

    +
    \ No newline at end of file diff --git a/docs/interfaces/SVGRendererGobanConfig.html b/docs/interfaces/SVGRendererGobanConfig.html index b9d7fc7c..ea2568fb 100644 --- a/docs/interfaces/SVGRendererGobanConfig.html +++ b/docs/interfaces/SVGRendererGobanConfig.html @@ -1,4 +1,4 @@ -SVGRendererGobanConfig | goban

    Interface SVGRendererGobanConfig

    interface SVGRendererGobanConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        auth?: string;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_div?: HTMLElement;
        board_is_repeating?: boolean;
        bounds?: GobanBounds;
        chat_log?: GobanChatLog;
        circle_radius?: number;
        clock?: GameClock;
        connect_to_chat?: number | boolean;
        disable_analysis?: boolean;
        display_width?: number;
        dont_draw_last_move?: boolean;
        dont_show_messages?: boolean;
        double_click_submit?: boolean;
        draw_bottom_labels?: boolean;
        draw_left_labels?: boolean;
        draw_right_labels?: boolean;
        draw_top_labels?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        game_type?: "temporary";
        getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting);
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        interactive?: boolean;
        isInPushedAnalysis?: (() => boolean);
        isPlayerController?: (() => boolean);
        isPlayerOwner?: (() => boolean);
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        last_move_opacity?: number;
        last_move_radius?: number;
        latencies?: {
            [player_id: string]: number;
        };
        leavePushedAnalysis?: (() => void);
        malkovich_log?: GobanChatLog;
        marks?: {
            [mark: string]: string;
        };
        mode?: GobanModes;
        move_tree?: MoveTreeJson;
        move_tree_container?: HTMLElement;
        moves?: GobanMovesArray;
        name?: string;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        onError?: ((err) => void);
        onScoreEstimationUpdated?: ((winning_color, points) => void);
        one_click_submit?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        pause_control?: AdHocPauseControl;
        paused_since?: number;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        server_socket?: GobanSocket<ClientToServer, ServerToClient>;
        spectator_log?: GobanChatLog;
        square_size?: number | "auto" | ((goban) => number);
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        title_div?: HTMLElement;
        tournament_id?: number;
        username?: string;
        variation_stone_opacity?: number;
        visual_undo_request_indicator?: boolean;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring? +SVGRendererGobanConfig | goban

    Interface SVGRendererGobanConfig

    interface SVGRendererGobanConfig {
        aga_handicap_scoring?: boolean;
        allow_ko?: boolean;
        allow_self_capture?: boolean;
        allow_superko?: boolean;
        auth?: string;
        automatic_stone_removal?: boolean;
        black_player_id?: number;
        black_prisoners?: number;
        board?: JGOFNumericPlayerColor[][];
        board_div?: HTMLElement;
        board_is_repeating?: boolean;
        bounds?: GobanBounds;
        chat_log?: GobanChatLog;
        circle_radius?: number;
        clock?: GameClock;
        connect_to_chat?: number | boolean;
        disable_analysis?: boolean;
        display_width?: number;
        dont_draw_last_move?: boolean;
        dont_show_messages?: boolean;
        double_click_submit?: boolean;
        draw_bottom_labels?: boolean;
        draw_left_labels?: boolean;
        draw_right_labels?: boolean;
        draw_top_labels?: boolean;
        end_time?: number;
        errors?: {
            error: string;
            stack: any;
        }[];
        free_handicap_placement?: boolean;
        game_date?: string;
        game_id?: string | number;
        game_name?: string;
        game_type?: "temporary";
        getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting);
        group_ids?: number[];
        handicap?: number;
        handicap_rank_difference?: number;
        height?: number;
        initial_player?: PlayerColor;
        initial_state?: GobanEngineInitialState;
        interactive?: boolean;
        isInPushedAnalysis?: (() => boolean);
        isPlayerController?: (() => boolean);
        isPlayerOwner?: (() => boolean);
        isobranch_hash?: string;
        komi?: number;
        ladder?: number;
        ladder_id?: number;
        last_move_opacity?: number;
        last_move_radius?: number;
        latencies?: {
            [player_id: string]: number;
        };
        leavePushedAnalysis?: (() => void);
        malkovich_log?: GobanChatLog;
        marks?: {
            [mark: string]: string;
        };
        mode?: GobanModes;
        move_tree?: MoveTreeJson;
        move_tree_container?: HTMLElement;
        moves?: GobanMovesArray;
        name?: string;
        needs_sealing?: JGOFSealingIntersection[];
        ogs?: {
            black_dead_stones: string;
            black_seki_eyes: string;
            black_stones: string;
            black_territory: string;
            white_dead_stones: string;
            white_seki_eyes: string;
            white_stones: string;
            white_territory: string;
        };
        ogs_import?: boolean;
        onError?: ((err) => void);
        onScoreEstimationUpdated?: ((winning_color, points) => void);
        one_click_submit?: boolean;
        opponent_plays_first_after_resume?: boolean;
        original_disable_analysis?: boolean;
        original_sgf?: string;
        outcome?: string;
        pause_control?: AdHocPauseControl;
        paused_since?: number;
        phase?: GobanEnginePhase;
        player?: JGOFNumericPlayerColor;
        player_id?: number;
        player_pool?: {
            [id: number]: GobanEnginePlayerEntry;
        };
        players?: {
            black: GobanEnginePlayerEntry;
            white: GobanEnginePlayerEntry;
        };
        puzzle_autoplace_delay?: number;
        puzzle_collection?: number;
        puzzle_description?: string;
        puzzle_opponent_move_mode?: PuzzleOpponentMoveMode;
        puzzle_player_move_mode?: PuzzlePlayerMoveMode;
        puzzle_rank?: number;
        puzzle_type?: string;
        ranked?: boolean;
        removal?: boolean[][];
        removed?: string | JGOFMove[];
        rengo?: boolean;
        rengo_casual_mode?: boolean;
        rengo_teams?: {
            black: GobanEnginePlayerEntry[];
            white: GobanEnginePlayerEntry[];
        };
        review_id?: number;
        reviews?: {
            [review_id: number]: GobanEnginePlayerEntry;
        };
        rules?: GobanEngineRules;
        score?: Score;
        score_handicap?: boolean;
        score_passes?: boolean;
        score_prisoners?: boolean;
        score_stones?: boolean;
        score_territory?: boolean;
        score_territory_in_seki?: boolean;
        server_socket?: GobanSocket<ClientToServer, ServerToClient>;
        spectator_log?: GobanChatLog;
        square_size?: number | "auto" | ((goban) => number);
        stalling_score_estimate?: StallingScoreEstimate;
        start_time?: number;
        strict_seki_mode?: boolean;
        superko_algorithm?: GobanEngineSuperKoAlgorithm;
        throw_all_errors?: boolean;
        time_control?: JGOFTimeControl;
        time_per_move?: number;
        title_div?: HTMLElement;
        tournament_id?: number;
        username?: string;
        variation_stone_opacity?: number;
        visual_undo_request_indicator?: boolean;
        white_must_pass_last?: boolean;
        white_player_id?: number;
        white_prisoners?: number;
        width?: number;
        winner?: number | "black" | "white";
    }

    Hierarchy (view full)

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    auth?: string
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_div?: HTMLElement
    board_is_repeating?: boolean
    bounds?: GobanBounds
    chat_log?: GobanChatLog
    circle_radius?: number
    clock?: GameClock
    connect_to_chat?: number | boolean
    disable_analysis?: boolean
    display_width?: number
    dont_draw_last_move?: boolean
    dont_show_messages?: boolean
    double_click_submit?: boolean
    draw_bottom_labels?: boolean
    draw_left_labels?: boolean
    draw_right_labels?: boolean
    draw_top_labels?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    game_type?: "temporary"
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    interactive?: boolean
    isInPushedAnalysis?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    last_move_opacity?: number
    last_move_radius?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    leavePushedAnalysis?: (() => void)

    Type declaration

      • (): void
      • Returns void

    malkovich_log?: GobanChatLog
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: GobanModes
    move_tree?: MoveTreeJson
    move_tree_container?: HTMLElement
    name?: string
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    -
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    -
    onError?: ((err) => void)

    Type declaration

      • (err): void
      • Parameters

        • err: Error

        Returns void

    onScoreEstimationUpdated?: ((winning_color, points) => void)

    Type declaration

      • (winning_color, points): void
      • Parameters

        • winning_color: "black" | "white"
        • points: number

        Returns void

    one_click_submit?: boolean
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    pause_control?: AdHocPauseControl
    paused_since?: number
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase +

    Properties

    aga_handicap_scoring?: boolean
    allow_ko?: boolean
    allow_self_capture?: boolean
    allow_superko?: boolean
    auth?: string
    automatic_stone_removal?: boolean
    black_player_id?: number
    black_prisoners?: number
    board_div?: HTMLElement
    board_is_repeating?: boolean
    bounds?: GobanBounds
    chat_log?: GobanChatLog
    circle_radius?: number
    clock?: GameClock
    connect_to_chat?: number | boolean
    disable_analysis?: boolean
    display_width?: number
    dont_draw_last_move?: boolean
    dont_show_messages?: boolean
    double_click_submit?: boolean
    draw_bottom_labels?: boolean
    draw_left_labels?: boolean
    draw_right_labels?: boolean
    draw_top_labels?: boolean
    end_time?: number
    errors?: {
        error: string;
        stack: any;
    }[]

    Type declaration

    • error: string
    • stack: any
    free_handicap_placement?: boolean
    game_date?: string
    game_id?: string | number
    game_name?: string
    game_type?: "temporary"
    getPuzzlePlacementSetting?: (() => PuzzlePlacementSetting)
    group_ids?: number[]
    handicap?: number
    handicap_rank_difference?: number
    height?: number
    initial_player?: PlayerColor
    initial_state?: GobanEngineInitialState
    interactive?: boolean
    isInPushedAnalysis?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerController?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isPlayerOwner?: (() => boolean)

    Type declaration

      • (): boolean
      • Returns boolean

    isobranch_hash?: string
    komi?: number
    ladder?: number
    ladder_id?: number
    last_move_opacity?: number
    last_move_radius?: number
    latencies?: {
        [player_id: string]: number;
    }

    Type declaration

    • [player_id: string]: number
    leavePushedAnalysis?: (() => void)

    Type declaration

      • (): void
      • Returns void

    malkovich_log?: GobanChatLog
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    mode?: GobanModes
    move_tree?: MoveTreeJson
    move_tree_container?: HTMLElement
    name?: string
    needs_sealing?: JGOFSealingIntersection[]

    Intersections that need to be sealed before scoring should happen

    +
    ogs?: {
        black_dead_stones: string;
        black_seki_eyes: string;
        black_stones: string;
        black_territory: string;
        white_dead_stones: string;
        white_seki_eyes: string;
        white_stones: string;
        white_territory: string;
    }

    Type declaration

    • black_dead_stones: string
    • black_seki_eyes: string
    • black_stones: string
    • black_territory: string
    • white_dead_stones: string
    • white_seki_eyes: string
    • white_stones: string
    • white_territory: string
    ogs_import?: boolean

    Deprecated, I don't think we need this anymore, but need to be sure

    +
    onError?: ((err) => void)

    Type declaration

      • (err): void
      • Parameters

        • err: Error

        Returns void

    onScoreEstimationUpdated?: ((winning_color, points) => void)

    Type declaration

      • (winning_color, points): void
      • Parameters

        • winning_color: "black" | "white"
        • points: number

        Returns void

    one_click_submit?: boolean
    opponent_plays_first_after_resume?: boolean
    original_disable_analysis?: boolean
    original_sgf?: string
    outcome?: string
    pause_control?: AdHocPauseControl
    paused_since?: number
    player_id?: number
    player_pool?: {
        [id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    players?: {
        black: GobanEnginePlayerEntry;
        white: GobanEnginePlayerEntry;
    }

    Type declaration

    puzzle_autoplace_delay?: number
    puzzle_collection?: number
    puzzle_description?: string
    puzzle_opponent_move_mode?: PuzzleOpponentMoveMode
    puzzle_player_move_mode?: PuzzlePlayerMoveMode
    puzzle_rank?: number
    puzzle_type?: string
    ranked?: boolean
    removal?: boolean[][]
    removed?: string | JGOFMove[]

    Removed stones in stone removal phase Passing an array of JGOFMove objects is preferred, the string format exists for historical backwards compatibility. It is an encoded move string, e.g. "aa" for A19

    -
    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    spectator_log?: GobanChatLog
    square_size?: number | "auto" | ((goban) => number)

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and +

    rengo?: boolean
    rengo_casual_mode?: boolean
    rengo_teams?: {
        black: GobanEnginePlayerEntry[];
        white: GobanEnginePlayerEntry[];
    }

    Type declaration

    review_id?: number
    reviews?: {
        [review_id: number]: GobanEnginePlayerEntry;
    }

    Type declaration

    score?: Score
    score_handicap?: boolean
    score_passes?: boolean
    score_prisoners?: boolean
    score_stones?: boolean
    score_territory?: boolean
    score_territory_in_seki?: boolean
    spectator_log?: GobanChatLog
    square_size?: number | "auto" | ((goban) => number)

    Type declaration

      • (goban): number
      • Parameters

        Returns number

    stalling_score_estimate?: StallingScoreEstimate
    start_time?: number
    strict_seki_mode?: boolean
    superko_algorithm?: GobanEngineSuperKoAlgorithm
    throw_all_errors?: boolean

    When loading initial state or moves, by default GobanEngine will try and handle bad data by just resorting to 'edit placing' moves. If this is true, then those errors are thrown instead.

    -
    time_control?: JGOFTimeControl
    time_per_move?: number
    title_div?: HTMLElement
    tournament_id?: number
    username?: string
    variation_stone_opacity?: number
    visual_undo_request_indicator?: boolean
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file +
    time_control?: JGOFTimeControl
    time_per_move?: number
    title_div?: HTMLElement
    tournament_id?: number
    username?: string
    variation_stone_opacity?: number
    visual_undo_request_indicator?: boolean
    white_must_pass_last?: boolean
    white_player_id?: number
    white_prisoners?: number
    width?: number
    winner?: number | "black" | "white"
    \ No newline at end of file diff --git a/docs/interfaces/SVGStoneParameters.html b/docs/interfaces/SVGStoneParameters.html index dc4266be..18792ee7 100644 --- a/docs/interfaces/SVGStoneParameters.html +++ b/docs/interfaces/SVGStoneParameters.html @@ -1,7 +1,7 @@ -SVGStoneParameters | goban

    Interface SVGStoneParameters

    interface SVGStoneParameters {
        fill?: string;
        gradient?: {
            cx?: number;
            cy?: number;
            fx?: number;
            fy?: number;
            r?: number;
            stops: SVGStop[];
            type?: "radial" | "linear";
            x1?: number;
            x2?: number;
            y1?: number;
            y2?: number;
        };
        id: string;
        stroke?: string;
        stroke_scale?: number;
        url?: string;
    }

    Properties

    fill? +SVGStoneParameters | goban

    Interface SVGStoneParameters

    interface SVGStoneParameters {
        fill?: string;
        gradient?: {
            cx?: number;
            cy?: number;
            fx?: number;
            fy?: number;
            r?: number;
            stops: SVGStop[];
            type?: "radial" | "linear";
            x1?: number;
            x2?: number;
            y1?: number;
            y2?: number;
        };
        id: string;
        stroke?: string;
        stroke_scale?: number;
        url?: string;
    }

    Properties

    fill?: string
    gradient?: {
        cx?: number;
        cy?: number;
        fx?: number;
        fy?: number;
        r?: number;
        stops: SVGStop[];
        type?: "radial" | "linear";
        x1?: number;
        x2?: number;
        y1?: number;
        y2?: number;
    }

    Type declaration

    • Optional cx?: number
    • Optional cy?: number
    • Optional fx?: number
    • Optional fy?: number
    • Optional r?: number
    • stops: SVGStop[]
    • Optional type?: "radial" | "linear"
    • Optional x1?: number
    • Optional x2?: number
    • Optional y1?: number
    • Optional y2?: number
    id: string
    stroke?: string
    stroke_scale?: number
    url?: string
    \ No newline at end of file +

    Properties

    fill?: string
    gradient?: {
        cx?: number;
        cy?: number;
        fx?: number;
        fy?: number;
        r?: number;
        stops: SVGStop[];
        type?: "radial" | "linear";
        x1?: number;
        x2?: number;
        y1?: number;
        y2?: number;
    }

    Type declaration

    • Optional cx?: number
    • Optional cy?: number
    • Optional fx?: number
    • Optional fy?: number
    • Optional r?: number
    • stops: SVGStop[]
    • Optional type?: "radial" | "linear"
    • Optional x1?: number
    • Optional x2?: number
    • Optional y1?: number
    • Optional y2?: number
    id: string
    stroke?: string
    stroke_scale?: number
    url?: string
    \ No newline at end of file diff --git a/docs/interfaces/SVGStop.html b/docs/interfaces/SVGStop.html index 506df702..d6a13cd4 100644 --- a/docs/interfaces/SVGStop.html +++ b/docs/interfaces/SVGStop.html @@ -1,3 +1,3 @@ -SVGStop | goban

    Interface SVGStop

    interface SVGStop {
        color: string;
        offset: number;
    }

    Properties

    color +SVGStop | goban

    Interface SVGStop

    interface SVGStop {
        color: string;
        offset: number;
    }

    Properties

    Properties

    color: string
    offset: number
    \ No newline at end of file +

    Properties

    color: string
    offset: number
    \ No newline at end of file diff --git a/docs/interfaces/Score.html b/docs/interfaces/Score.html index 297fb44b..7a9507fa 100644 --- a/docs/interfaces/Score.html +++ b/docs/interfaces/Score.html @@ -1,3 +1,3 @@ -Score | goban

    Interface Score

    interface Score {
        black: PlayerScore;
        white: PlayerScore;
    }

    Properties

    black +Score | goban

    Interface Score

    interface Score {
        black: PlayerScore;
        white: PlayerScore;
    }

    Properties

    Properties

    \ No newline at end of file +

    Properties

    \ No newline at end of file diff --git a/docs/interfaces/ScoreEstimateRequest.html b/docs/interfaces/ScoreEstimateRequest.html index 86e4861e..bcee0b79 100644 --- a/docs/interfaces/ScoreEstimateRequest.html +++ b/docs/interfaces/ScoreEstimateRequest.html @@ -1,4 +1,4 @@ -ScoreEstimateRequest | goban

    Interface ScoreEstimateRequest

    interface ScoreEstimateRequest {
        autoscore?: boolean;
        black_prisoners?: number;
        board_state: JGOFNumericPlayerColor[][];
        height: number;
        jwt: string;
        komi?: number;
        player_to_move: "black" | "white";
        rules: GobanEngineRules;
        white_prisoners?: number;
        width: number;
    }

    Properties

    autoscore? +ScoreEstimateRequest | goban

    Interface ScoreEstimateRequest

    interface ScoreEstimateRequest {
        autoscore?: boolean;
        black_prisoners?: number;
        board_state: JGOFNumericPlayerColor[][];
        height: number;
        jwt: string;
        komi?: number;
        player_to_move: "black" | "white";
        rules: GobanEngineRules;
        white_prisoners?: number;
        width: number;
    }

    Properties

    Properties

    autoscore?: boolean

    Whether to run autoscoring logic. If true, player_to_move is essentially ignored as we compute estimates with each player moving first in turn.

    -
    black_prisoners?: number
    board_state: JGOFNumericPlayerColor[][]
    height: number
    jwt: string
    komi?: number
    player_to_move: "black" | "white"
    white_prisoners?: number
    width: number
    \ No newline at end of file +
    black_prisoners?: number
    board_state: JGOFNumericPlayerColor[][]
    height: number
    jwt: string
    komi?: number
    player_to_move: "black" | "white"
    white_prisoners?: number
    width: number
    \ No newline at end of file diff --git a/docs/interfaces/ScoreEstimateResponse.html b/docs/interfaces/ScoreEstimateResponse.html index 752a7e97..044cd077 100644 --- a/docs/interfaces/ScoreEstimateResponse.html +++ b/docs/interfaces/ScoreEstimateResponse.html @@ -1,13 +1,13 @@ -ScoreEstimateResponse | goban

    Interface ScoreEstimateResponse

    interface ScoreEstimateResponse {
        autoscored_board_state?: JGOFNumericPlayerColor[][];
        autoscored_needs_sealing?: JGOFSealingIntersection[];
        autoscored_removed?: JGOFMove[];
        ownership: number[][];
        score?: number;
        win_rate?: number;
    }

    Properties

    autoscored_board_state? +ScoreEstimateResponse | goban

    Interface ScoreEstimateResponse

    interface ScoreEstimateResponse {
        autoscored_board_state?: JGOFNumericPlayerColor[][];
        autoscored_needs_sealing?: JGOFSealingIntersection[];
        autoscored_removed?: JGOFMove[];
        ownership: number[][];
        score?: number;
        win_rate?: number;
    }

    Properties

    autoscored_board_state?: JGOFNumericPlayerColor[][]

    Board state after autoscoring logic has been run. Only defined if autoscore was true in the request.

    -
    autoscored_needs_sealing?: JGOFSealingIntersection[]

    Coordinates that still need sealing

    -
    autoscored_removed?: JGOFMove[]

    Intersections that are dead or dame. Only defined if autoscore was true in the request.

    -
    ownership: number[][]

    Matrix of ownership estimates ranged from -1 (white) to 1 (black)

    -
    score?: number

    Estimated score

    -
    win_rate?: number

    Estimated win rate

    -
    \ No newline at end of file +
    autoscored_needs_sealing?: JGOFSealingIntersection[]

    Coordinates that still need sealing

    +
    autoscored_removed?: JGOFMove[]

    Intersections that are dead or dame. Only defined if autoscore was true in the request.

    +
    ownership: number[][]

    Matrix of ownership estimates ranged from -1 (white) to 1 (black)

    +
    score?: number

    Estimated score

    +
    win_rate?: number

    Estimated win rate

    +
    \ No newline at end of file diff --git a/docs/interfaces/ScoringLocations.html b/docs/interfaces/ScoringLocations.html index 3a6a1798..956001ac 100644 --- a/docs/interfaces/ScoringLocations.html +++ b/docs/interfaces/ScoringLocations.html @@ -1,3 +1,3 @@ -ScoringLocations | goban

    Interface ScoringLocations

    interface ScoringLocations {
        black: {
            locations: JGOFIntersection[];
            stones: number;
            territory: number;
        };
        white: {
            locations: JGOFIntersection[];
            stones: number;
            territory: number;
        };
    }

    Properties

    black +ScoringLocations | goban

    Interface ScoringLocations

    interface ScoringLocations {
        black: {
            locations: JGOFIntersection[];
            stones: number;
            territory: number;
        };
        white: {
            locations: JGOFIntersection[];
            stones: number;
            territory: number;
        };
    }

    Properties

    Properties

    black: {
        locations: JGOFIntersection[];
        stones: number;
        territory: number;
    }

    Type declaration

    white: {
        locations: JGOFIntersection[];
        stones: number;
        territory: number;
    }

    Type declaration

    \ No newline at end of file +

    Properties

    black: {
        locations: JGOFIntersection[];
        stones: number;
        territory: number;
    }

    Type declaration

    white: {
        locations: JGOFIntersection[];
        stones: number;
        territory: number;
    }

    Type declaration

    \ No newline at end of file diff --git a/docs/interfaces/StateUpdateEvents.html b/docs/interfaces/StateUpdateEvents.html index 8d18458c..5865818c 100644 --- a/docs/interfaces/StateUpdateEvents.html +++ b/docs/interfaces/StateUpdateEvents.html @@ -1,4 +1,4 @@ -StateUpdateEvents | goban

    Interface StateUpdateEvents

    interface StateUpdateEvents {
        analyze_subtool: ((d) => void);
        analyze_tool: ((d) => void);
        cur_move: ((d) => void);
        cur_review_move: ((d) => void);
        last_official_move: ((d) => void);
        mode: ((d) => void);
        outcome: ((d) => void);
        paused: ((d) => void);
        phase: ((d) => void);
        review_controller_id: ((d) => void);
        review_owner_id: ((d) => void);
        rules: ((d) => void);
        score_estimate: ((d) => void);
        stalling_score_estimate: ((data?) => void);
        strict_seki_mode: ((d) => void);
        submit_move: ((d) => void);
        title: ((d) => void);
        undo_canceled: (() => void);
        undo_requested: ((d) => void);
        winner: ((d) => void);
    }

    Hierarchy (view full)

    Properties

    analyze_subtool +StateUpdateEvents | goban

    Interface StateUpdateEvents

    interface StateUpdateEvents {
        analyze_subtool: ((d) => void);
        analyze_tool: ((d) => void);
        cur_move: ((d) => void);
        cur_review_move: ((d) => void);
        last_official_move: ((d) => void);
        mode: ((d) => void);
        outcome: ((d) => void);
        paused: ((d) => void);
        phase: ((d) => void);
        review_controller_id: ((d) => void);
        review_owner_id: ((d) => void);
        rules: ((d) => void);
        score_estimate: ((d) => void);
        stalling_score_estimate: ((data?) => void);
        strict_seki_mode: ((d) => void);
        submit_move: ((d) => void);
        title: ((d) => void);
        undo_canceled: (() => void);
        undo_requested: ((d) => void);
        winner: ((d) => void);
    }

    Hierarchy (view full)

    Properties

    analyze_subtool: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    analyze_tool: ((d) => void)

    Type declaration

    cur_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    cur_review_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    last_official_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    mode: ((d) => void)

    Type declaration

    outcome: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    paused: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    phase: ((d) => void)

    Type declaration

    review_controller_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    review_owner_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    rules: ((d) => void)

    Type declaration

    score_estimate: ((d) => void)

    Type declaration

    stalling_score_estimate: ((data?) => void)

    Type declaration

    strict_seki_mode: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    submit_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | (() => void)

        Returns void

    title: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    undo_canceled: (() => void)

    Type declaration

      • (): void
      • Returns void

    undo_requested: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    winner: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    \ No newline at end of file +

    Properties

    analyze_subtool: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    analyze_tool: ((d) => void)

    Type declaration

    cur_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    cur_review_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    last_official_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        Returns void

    mode: ((d) => void)

    Type declaration

    outcome: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    paused: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    phase: ((d) => void)

    Type declaration

    review_controller_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    review_owner_id: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    rules: ((d) => void)

    Type declaration

    score_estimate: ((d) => void)

    Type declaration

    stalling_score_estimate: ((data?) => void)

    Type declaration

    strict_seki_mode: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: boolean

        Returns void

    submit_move: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | (() => void)

        Returns void

    title: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: string

        Returns void

    undo_canceled: (() => void)

    Type declaration

      • (): void
      • Returns void

    undo_requested: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    winner: ((d) => void)

    Type declaration

      • (d): void
      • Parameters

        • d: undefined | number

        Returns void

    \ No newline at end of file diff --git a/docs/interfaces/ThemesInterface.html b/docs/interfaces/ThemesInterface.html index f60ea8fd..28f98e0d 100644 --- a/docs/interfaces/ThemesInterface.html +++ b/docs/interfaces/ThemesInterface.html @@ -1,4 +1,4 @@ -ThemesInterface | goban

    Interface ThemesInterface

    interface ThemesInterface {
        black: {
            [name: string]: typeof GobanTheme;
        };
        board: {
            [name: string]: typeof GobanTheme;
        };
        white: {
            [name: string]: typeof GobanTheme;
        };
        [key: string]: {
            [name: string]: typeof GobanTheme;
        };
    }

    Indexable

    [key: string]: {
        [name: string]: typeof GobanTheme;
    }

    Properties

    black +ThemesInterface | goban

    Interface ThemesInterface

    interface ThemesInterface {
        black: {
            [name: string]: typeof GobanTheme;
        };
        board: {
            [name: string]: typeof GobanTheme;
        };
        white: {
            [name: string]: typeof GobanTheme;
        };
        [key: string]: {
            [name: string]: typeof GobanTheme;
        };
    }

    Indexable

    [key: string]: {
        [name: string]: typeof GobanTheme;
    }

    Properties

    Properties

    black: {
        [name: string]: typeof GobanTheme;
    }

    Type declaration

    board: {
        [name: string]: typeof GobanTheme;
    }

    Type declaration

    white: {
        [name: string]: typeof GobanTheme;
    }

    Type declaration

    \ No newline at end of file +

    Properties

    black: {
        [name: string]: typeof GobanTheme;
    }

    Type declaration

    board: {
        [name: string]: typeof GobanTheme;
    }

    Type declaration

    white: {
        [name: string]: typeof GobanTheme;
    }

    Type declaration

    \ No newline at end of file diff --git a/docs/interfaces/_internal_.AbsoluteClock.html b/docs/interfaces/_internal_.AbsoluteClock.html index e1b1230f..a3dda766 100644 --- a/docs/interfaces/_internal_.AbsoluteClock.html +++ b/docs/interfaces/_internal_.AbsoluteClock.html @@ -1,2 +1,2 @@ -AbsoluteClock | goban

    Interface AbsoluteClock

    interface AbsoluteClock {
        thinking_time: number;
    }

    Properties

    Properties

    thinking_time: number
    \ No newline at end of file +AbsoluteClock | goban

    Interface AbsoluteClock

    interface AbsoluteClock {
        thinking_time: number;
    }

    Properties

    Properties

    thinking_time: number
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.AnalysisComment.html b/docs/interfaces/_internal_.AnalysisComment.html index d5114f09..ca797fa1 100644 --- a/docs/interfaces/_internal_.AnalysisComment.html +++ b/docs/interfaces/_internal_.AnalysisComment.html @@ -1,8 +1,8 @@ -AnalysisComment | goban

    Interface AnalysisComment

    interface AnalysisComment {
        branch_move?: number;
        from?: number;
        marks?: {
            [mark: string]: string;
        };
        moves?: string;
        name?: string;
        pen_marks?: unknown[];
        type: "analysis";
    }

    Properties

    branch_move? +AnalysisComment | goban

    Interface AnalysisComment

    interface AnalysisComment {
        branch_move?: number;
        from?: number;
        marks?: {
            [mark: string]: string;
        };
        moves?: string;
        name?: string;
        pen_marks?: unknown[];
        type: "analysis";
    }

    Properties

    branch_move?: number
    from?: number
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    moves?: string
    name?: string
    pen_marks?: unknown[]
    type: "analysis"
    \ No newline at end of file +

    Properties

    branch_move?: number
    from?: number
    marks?: {
        [mark: string]: string;
    }

    Type declaration

    • [mark: string]: string
    moves?: string
    name?: string
    pen_marks?: unknown[]
    type: "analysis"
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.AutoscoreResults.html b/docs/interfaces/_internal_.AutoscoreResults.html index 8276f975..a2653a08 100644 --- a/docs/interfaces/_internal_.AutoscoreResults.html +++ b/docs/interfaces/_internal_.AutoscoreResults.html @@ -1,5 +1,5 @@ -AutoscoreResults | goban

    Interface AutoscoreResults

    interface AutoscoreResults {
        needs_sealing: JGOFSealingIntersection[];
        removed: JGOFMove[];
        result: JGOFNumericPlayerColor[][];
        sealed_result: JGOFNumericPlayerColor[][];
    }

    Properties

    needs_sealing +AutoscoreResults | goban

    Interface AutoscoreResults

    interface AutoscoreResults {
        needs_sealing: JGOFSealingIntersection[];
        removed: JGOFMove[];
        result: JGOFNumericPlayerColor[][];
        sealed_result: JGOFNumericPlayerColor[][];
    }

    Properties

    needs_sealing: JGOFSealingIntersection[]
    removed: JGOFMove[]
    sealed_result: JGOFNumericPlayerColor[][]
    \ No newline at end of file +

    Properties

    needs_sealing: JGOFSealingIntersection[]
    removed: JGOFMove[]
    sealed_result: JGOFNumericPlayerColor[][]
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.BoardStateWithIsobranchHash.html b/docs/interfaces/_internal_.BoardStateWithIsobranchHash.html index 7c376720..f793b62b 100644 --- a/docs/interfaces/_internal_.BoardStateWithIsobranchHash.html +++ b/docs/interfaces/_internal_.BoardStateWithIsobranchHash.html @@ -1,4 +1,4 @@ -BoardStateWithIsobranchHash | goban

    Interface BoardStateWithIsobranchHash

    interface BoardStateWithIsobranchHash {
        black_prisoners: number;
        board: JGOFNumericPlayerColor[][];
        board_is_repeating: boolean;
        goban_callback?: GobanBase;
        height: number;
        isobranch_hash?: string;
        player: JGOFNumericPlayerColor;
        removal: boolean[][];
        white_prisoners: number;
        width: number;
        boardEquals(other): boolean;
        clearRemoved(): void;
        cloneBoard(): JGOFNumericPlayerColor[][];
        cloneBoardState(): BoardState;
        computeScoringLocations(area_scoring): ScoringLocations;
        countLiberties(raw_stone_string): number;
        foreachNeighbor(pt_or_raw_stone_string, callback): void;
        getNeighboringRawStoneStrings(raw_stone_string): RawStoneString[];
        getRawStoneString(x, y, clearMarks): RawStoneString;
        setRemoved(x, y, removed, emit_stone_removal_updated?): void;
        toggleSingleGroupRemoval(x, y, force_removal?): {
            group: RawStoneString;
            removed: boolean;
        };
    }

    Hierarchy (view full)

    Properties

    black_prisoners +BoardStateWithIsobranchHash | goban

    Interface BoardStateWithIsobranchHash

    interface BoardStateWithIsobranchHash {
        black_prisoners: number;
        board: JGOFNumericPlayerColor[][];
        board_is_repeating: boolean;
        goban_callback?: GobanBase;
        height: number;
        isobranch_hash?: string;
        player: JGOFNumericPlayerColor;
        removal: boolean[][];
        white_prisoners: number;
        width: number;
        boardEquals(other): boolean;
        clearRemoved(): void;
        cloneBoard(): JGOFNumericPlayerColor[][];
        cloneBoardState(): BoardState;
        computeScoringLocations(area_scoring): ScoringLocations;
        countLiberties(raw_stone_string): number;
        foreachNeighbor(pt_or_raw_stone_string, callback): void;
        getNeighboringRawStoneStrings(raw_stone_string): RawStoneString[];
        getRawStoneString(x, y, clearMarks): RawStoneString;
        setRemoved(x, y, removed, emit_stone_removal_updated?): void;
        toggleSingleGroupRemoval(x, y, force_removal?): {
            group: RawStoneString;
            removed: boolean;
        };
    }

    Hierarchy (view full)

    Properties

    black_prisoners: number
    board_is_repeating: boolean
    goban_callback?: GobanBase
    height: number = 19
    isobranch_hash?: string

    The isobranch hash is a hash of the board state. This field is used by +

    Properties

    black_prisoners: number
    board_is_repeating: boolean
    goban_callback?: GobanBase
    height: number = 19
    isobranch_hash?: string

    The isobranch hash is a hash of the board state. This field is used by the move tree to detect isomorphic branches. This field is populated when recomputeIsoBranches is called.

    -
    removal: boolean[][]
    white_prisoners: number
    width: number = 19

    Methods

    removal: boolean[][]
    white_prisoners: number
    width: number = 19

    Methods

    • Sets a position as being removed or not removed. If emit_stone_removal_updated is set to false, the "stone-removal.updated" event will not be emitted, and it is up to the caller to emit this event appropriately.

      -

      Parameters

      • x: number
      • y: number
      • removed: boolean
      • emit_stone_removal_updated: boolean = true

      Returns void

    • Toggles a group of stones for removal or restoration.

      +

      Parameters

      • x: number
      • y: number
      • removed: boolean
      • emit_stone_removal_updated: boolean = true

      Returns void

    • Toggles a group of stones for removal or restoration.

      By default, if we are marking a group for removal but the group is almost certainly alive (two eyes, etc), this will result in a no-op, unless force_removal is set to true.

      -

      Parameters

      • x: number
      • y: number
      • force_removal: boolean = false

      Returns {
          group: RawStoneString;
          removed: boolean;
      }

    \ No newline at end of file +

    Parameters

    Returns {
        group: RawStoneString;
        removed: boolean;
    }

    \ No newline at end of file diff --git a/docs/interfaces/_internal_.ByoYomiClock.html b/docs/interfaces/_internal_.ByoYomiClock.html index 120f9eaa..51b3e84d 100644 --- a/docs/interfaces/_internal_.ByoYomiClock.html +++ b/docs/interfaces/_internal_.ByoYomiClock.html @@ -1,5 +1,5 @@ -ByoYomiClock | goban

    Interface ByoYomiClock

    interface ByoYomiClock {
        period_time: number;
        period_time_left?: number;
        periods: number;
        thinking_time: number;
    }

    Properties

    period_time +ByoYomiClock | goban

    Interface ByoYomiClock

    interface ByoYomiClock {
        period_time: number;
        period_time_left?: number;
        periods: number;
        thinking_time: number;
    }

    Properties

    period_time: number
    period_time_left?: number
    periods: number
    thinking_time: number
    \ No newline at end of file +

    Properties

    period_time: number
    period_time_left?: number
    periods: number
    thinking_time: number
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.CanadianClock.html b/docs/interfaces/_internal_.CanadianClock.html index 2be20be5..9c90c6b8 100644 --- a/docs/interfaces/_internal_.CanadianClock.html +++ b/docs/interfaces/_internal_.CanadianClock.html @@ -1,4 +1,4 @@ -CanadianClock | goban

    Interface CanadianClock

    interface CanadianClock {
        block_time: number;
        moves_left: number;
        thinking_time: number;
    }

    Properties

    block_time +CanadianClock | goban

    Interface CanadianClock

    interface CanadianClock {
        block_time: number;
        moves_left: number;
        thinking_time: number;
    }

    Properties

    block_time: number
    moves_left: number
    thinking_time: number
    \ No newline at end of file +

    Properties

    block_time: number
    moves_left: number
    thinking_time: number
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.ErrorResponse.html b/docs/interfaces/_internal_.ErrorResponse.html index 2dd96ba7..46ec3f83 100644 --- a/docs/interfaces/_internal_.ErrorResponse.html +++ b/docs/interfaces/_internal_.ErrorResponse.html @@ -1,3 +1,3 @@ -ErrorResponse | goban

    Interface ErrorResponse

    interface ErrorResponse {
        code: string;
        message: string;
    }

    Properties

    code +ErrorResponse | goban

    Interface ErrorResponse

    interface ErrorResponse {
        code: string;
        message: string;
    }

    Properties

    Properties

    code: string
    message: string
    \ No newline at end of file +

    Properties

    code: string
    message: string
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.FischerClock.html b/docs/interfaces/_internal_.FischerClock.html index 16774a6f..d10d2c37 100644 --- a/docs/interfaces/_internal_.FischerClock.html +++ b/docs/interfaces/_internal_.FischerClock.html @@ -1,3 +1,3 @@ -FischerClock | goban

    Interface FischerClock

    interface FischerClock {
        skip_bonus: boolean;
        thinking_time: number;
    }

    Properties

    skip_bonus +FischerClock | goban

    Interface FischerClock

    interface FischerClock {
        skip_bonus: boolean;
        thinking_time: number;
    }

    Properties

    skip_bonus: boolean
    thinking_time: number
    \ No newline at end of file +

    Properties

    skip_bonus: boolean
    thinking_time: number
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.GameListPlayer.html b/docs/interfaces/_internal_.GameListPlayer.html index 86280821..8a5190d5 100644 --- a/docs/interfaces/_internal_.GameListPlayer.html +++ b/docs/interfaces/_internal_.GameListPlayer.html @@ -1,7 +1,7 @@ -GameListPlayer | goban

    Interface GameListPlayer

    interface GameListPlayer {
        accepted: boolean;
        id: number;
        professional: boolean;
        rank: number;
        ratings: {
            overall: {
                deviation: number;
                rating: number;
                volatility: number;
            };
            version: number;
        };
        username: string;
    }

    Properties

    accepted +GameListPlayer | goban

    Interface GameListPlayer

    interface GameListPlayer {
        accepted: boolean;
        id: number;
        professional: boolean;
        rank: number;
        ratings: {
            overall: {
                deviation: number;
                rating: number;
                volatility: number;
            };
            version: number;
        };
        username: string;
    }

    Properties

    accepted: boolean
    id: number
    professional: boolean
    rank: number
    ratings: {
        overall: {
            deviation: number;
            rating: number;
            volatility: number;
        };
        version: number;
    }

    Type declaration

    • overall: {
          deviation: number;
          rating: number;
          volatility: number;
      }
      • deviation: number
      • rating: number
      • volatility: number
    • version: number
    username: string
    \ No newline at end of file +

    Properties

    accepted: boolean
    id: number
    professional: boolean
    rank: number
    ratings: {
        overall: {
            deviation: number;
            rating: number;
            volatility: number;
        };
        version: number;
    }

    Type declaration

    • overall: {
          deviation: number;
          rating: number;
          volatility: number;
      }
      • deviation: number
      • rating: number
      • volatility: number
    • version: number
    username: string
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.GobanSVGInterface.html b/docs/interfaces/_internal_.GobanSVGInterface.html index 8eb75efa..fc065d88 100644 --- a/docs/interfaces/_internal_.GobanSVGInterface.html +++ b/docs/interfaces/_internal_.GobanSVGInterface.html @@ -1,4 +1,4 @@ -GobanSVGInterface | goban

    Interface GobanSVGInterface

    interface GobanSVGInterface {
        engine: GobanEngine;
        move_tree_container?: HTMLElement;
        clearAnalysisDrawing(): void;
        clearMessage(): void;
        destroy(): void;
        disablePen(): void;
        drawPenMarks(pen_marks): void;
        drawSquare(i, j): void;
        enablePen(): void;
        move_tree_bindEvents(svg): void;
        move_tree_redraw(no_warp?): void;
        setByoYomiLabel(label): void;
        setLastMoveOpacity(opacity): void;
        setMoveTreeContainer(container): void;
        showMessage(message_id_or_error, parameters?, timeout?): void;
    }

    Implemented by

    Properties

    engine +GobanSVGInterface | goban

    Interface GobanSVGInterface

    interface GobanSVGInterface {
        engine: GobanEngine;
        move_tree_container?: HTMLElement;
        clearAnalysisDrawing(): void;
        clearMessage(): void;
        destroy(): void;
        disablePen(): void;
        drawPenMarks(pen_marks): void;
        drawSquare(i, j): void;
        enablePen(): void;
        move_tree_bindEvents(svg): void;
        move_tree_redraw(no_warp?): void;
        setByoYomiLabel(label): void;
        setLastMoveOpacity(opacity): void;
        setMoveTreeContainer(container): void;
        showMessage(message_id_or_error, parameters?, timeout?): void;
    }

    Implemented by

    Properties

    engine: GobanEngine
    move_tree_container?: HTMLElement

    Methods

    • Parameters

      • container: HTMLElement

      Returns void

    • Parameters

      • message_id_or_error: MessageID
      • Optional parameters: {
            [key: string]: any;
        }
        • [key: string]: any
      • Optional timeout: number

      Returns void

    \ No newline at end of file +

    Properties

    engine: GobanEngine
    move_tree_container?: HTMLElement

    Methods

    • Parameters

      • container: HTMLElement

      Returns void

    • Parameters

      • message_id_or_error: MessageID
      • Optional parameters: {
            [key: string]: any;
        }
        • [key: string]: any
      • Optional timeout: number

      Returns void

    \ No newline at end of file diff --git a/docs/interfaces/_internal_.GobanSocketOptions.html b/docs/interfaces/_internal_.GobanSocketOptions.html index 061c8fc2..a9f0b657 100644 --- a/docs/interfaces/_internal_.GobanSocketOptions.html +++ b/docs/interfaces/_internal_.GobanSocketOptions.html @@ -1,7 +1,7 @@ -GobanSocketOptions | goban

    Interface GobanSocketOptions

    interface GobanSocketOptions {
        dont_ping?: boolean;
        ping_interval?: number;
        quiet?: boolean;
        timeout_delay?: number;
    }

    Properties

    dont_ping? +GobanSocketOptions | goban

    Interface GobanSocketOptions

    interface GobanSocketOptions {
        dont_ping?: boolean;
        ping_interval?: number;
        quiet?: boolean;
        timeout_delay?: number;
    }

    Properties

    dont_ping?: boolean

    Don't automatically send pings

    -
    ping_interval?: number
    quiet?: boolean

    Don't log connection/disconnect things

    -
    timeout_delay?: number
    \ No newline at end of file +
    ping_interval?: number
    quiet?: boolean

    Don't log connection/disconnect things

    +
    timeout_delay?: number
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.JGOFPlayerClockWithTimedOut.html b/docs/interfaces/_internal_.JGOFPlayerClockWithTimedOut.html index 030ba91e..3e9bef7c 100644 --- a/docs/interfaces/_internal_.JGOFPlayerClockWithTimedOut.html +++ b/docs/interfaces/_internal_.JGOFPlayerClockWithTimedOut.html @@ -1,4 +1,4 @@ -JGOFPlayerClockWithTimedOut | goban

    Interface JGOFPlayerClockWithTimedOut

    interface JGOFPlayerClockWithTimedOut {
        block_time_left?: number;
        main_time: number;
        moves_left?: number;
        period_time_left?: number;
        periods_left?: number;
        timed_out: boolean;
    }

    Hierarchy (view full)

    Properties

    block_time_left? +JGOFPlayerClockWithTimedOut | goban

    Interface JGOFPlayerClockWithTimedOut

    interface JGOFPlayerClockWithTimedOut {
        block_time_left?: number;
        main_time: number;
        moves_left?: number;
        period_time_left?: number;
        periods_left?: number;
        timed_out: boolean;
    }

    Hierarchy (view full)

    Properties

    block_time_left?: number

    Used with canadian time control. Time left in milliseconds to make the remainder of your moves in the current block

    -
    main_time: number

    Main time left on the clock, in milliseconds.

    -
    moves_left?: number

    Used with canadian time control. Number of moves left before a new +

    main_time: number

    Main time left on the clock, in milliseconds.

    +
    moves_left?: number

    Used with canadian time control. Number of moves left before a new block of time.

    -
    period_time_left?: number

    Used with byo-yomi time control. Time left on the period time, in milliseconds.

    -
    periods_left?: number

    Used with byo-yomi time control. Number of periods left.

    -
    timed_out: boolean
    \ No newline at end of file +
    period_time_left?: number

    Used with byo-yomi time control. Time left on the period time, in milliseconds.

    +
    periods_left?: number

    Used with byo-yomi time control. Number of periods left.

    +
    timed_out: boolean
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.MoveTreeViewPortInterface.html b/docs/interfaces/_internal_.MoveTreeViewPortInterface.html index 39b416ab..79ad3fca 100644 --- a/docs/interfaces/_internal_.MoveTreeViewPortInterface.html +++ b/docs/interfaces/_internal_.MoveTreeViewPortInterface.html @@ -1,7 +1,7 @@ -MoveTreeViewPortInterface | goban

    Interface MoveTreeViewPortInterface

    interface MoveTreeViewPortInterface {
        maxx: number;
        maxy: number;
        minx: number;
        miny: number;
        offset_x: number;
        offset_y: number;
    }

    Properties

    maxx +MoveTreeViewPortInterface | goban

    Interface MoveTreeViewPortInterface

    interface MoveTreeViewPortInterface {
        maxx: number;
        maxy: number;
        minx: number;
        miny: number;
        offset_x: number;
        offset_y: number;
    }

    Properties

    maxx: number
    maxy: number
    minx: number
    miny: number
    offset_x: number
    offset_y: number
    \ No newline at end of file +

    Properties

    maxx: number
    maxy: number
    minx: number
    miny: number
    offset_x: number
    offset_y: number
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.ReviewComment.html b/docs/interfaces/_internal_.ReviewComment.html index 432986d7..e6bc8633 100644 --- a/docs/interfaces/_internal_.ReviewComment.html +++ b/docs/interfaces/_internal_.ReviewComment.html @@ -1,3 +1,3 @@ -ReviewComment | goban

    Interface ReviewComment

    interface ReviewComment {
        review_id: number;
        type: "review";
    }

    Properties

    review_id +ReviewComment | goban

    Interface ReviewComment

    interface ReviewComment {
        review_id: number;
        type: "review";
    }

    Properties

    Properties

    review_id: number
    type: "review"
    \ No newline at end of file +

    Properties

    review_id: number
    type: "review"
    \ No newline at end of file diff --git a/docs/interfaces/_internal_.ViewPortInterface.html b/docs/interfaces/_internal_.ViewPortInterface.html index 61761356..8b584c59 100644 --- a/docs/interfaces/_internal_.ViewPortInterface.html +++ b/docs/interfaces/_internal_.ViewPortInterface.html @@ -1,7 +1,7 @@ -ViewPortInterface | goban

    Interface ViewPortInterface

    interface ViewPortInterface {
        maxx: number;
        maxy: number;
        minx: number;
        miny: number;
        offset_x: number;
        offset_y: number;
    }

    Properties

    maxx +ViewPortInterface | goban

    Interface ViewPortInterface

    interface ViewPortInterface {
        maxx: number;
        maxy: number;
        minx: number;
        miny: number;
        offset_x: number;
        offset_y: number;
    }

    Properties

    maxx: number
    maxy: number
    minx: number
    miny: number
    offset_x: number
    offset_y: number
    \ No newline at end of file +

    Properties

    maxx: number
    maxy: number
    minx: number
    miny: number
    offset_x: number
    offset_y: number
    \ No newline at end of file diff --git a/docs/interfaces/protocol.AIServerToClient.html b/docs/interfaces/protocol.AIServerToClient.html index 42841018..9a4e5a47 100644 --- a/docs/interfaces/protocol.AIServerToClient.html +++ b/docs/interfaces/protocol.AIServerToClient.html @@ -1,6 +1,6 @@ AIServerToClient | goban

    Interface AIServerToClient

    interface AIServerToClient {
        net/pong: ((data) => void);
        [uuid: string]: ((data) => void);
    }

    Indexable

    [uuid: string]: ((data) => void)

    AI review messages are streamed back to the AI review UUID.

    -
      • (data): void
      • Parameters

        • data: any

        Returns void

    Properties

      • (data): void
      • Parameters

        • data: any

        Returns void

    Properties

    Properties

    net/pong: ((data) => void)

    Pong response from a ping

    Type declaration

      • (data): void
      • Parameters

        • data: {
              client: number;
              server: number;
          }
          • client: number

            Client timestamp that was sent

          • server: number

            Server timestamp when it was received

            -

        Returns void

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/docs/interfaces/protocol.AutomatchPreferences.html b/docs/interfaces/protocol.AutomatchPreferences.html index 12db438e..5618a148 100644 --- a/docs/interfaces/protocol.AutomatchPreferences.html +++ b/docs/interfaces/protocol.AutomatchPreferences.html @@ -1,4 +1,4 @@ -AutomatchPreferences | goban

    Interface AutomatchPreferences

    interface AutomatchPreferences {
        handicap: {
            condition: AutomatchCondition;
            value: "enabled" | "disabled";
        };
        lower_rank_diff: number;
        rules: {
            condition: AutomatchCondition;
            value: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz";
        };
        size_speed_options: {
            size: Size;
            speed: Speed;
        }[];
        time_control: {
            condition: AutomatchCondition;
            value: {
                initial_time?: number;
                main_time?: number;
                max_time?: number;
                pause_on_weekends?: boolean;
                per_move?: number;
                period_time?: number;
                periods?: number;
                stones_per_period?: number;
                system: "fischer" | "byoyomi" | "canadian" | "simple";
                time_increment?: number;
            };
        };
        timestamp?: number;
        upper_rank_diff: number;
        uuid: string;
    }

    Properties

    handicap +AutomatchPreferences | goban

    Interface AutomatchPreferences

    interface AutomatchPreferences {
        handicap: {
            condition: AutomatchCondition;
            value: "enabled" | "disabled";
        };
        lower_rank_diff: number;
        rules: {
            condition: AutomatchCondition;
            value: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz";
        };
        size_speed_options: {
            size: Size;
            speed: Speed;
        }[];
        time_control: {
            condition: AutomatchCondition;
            value: {
                initial_time?: number;
                main_time?: number;
                max_time?: number;
                pause_on_weekends?: boolean;
                per_move?: number;
                period_time?: number;
                periods?: number;
                stones_per_period?: number;
                system: "fischer" | "byoyomi" | "canadian" | "simple";
                time_increment?: number;
            };
        };
        timestamp?: number;
        upper_rank_diff: number;
        uuid: string;
    }

    Properties

    handicap: {
        condition: AutomatchCondition;
        value: "enabled" | "disabled";
    }

    Type declaration

    lower_rank_diff: number
    rules: {
        condition: AutomatchCondition;
        value: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz";
    }

    Type declaration

    • condition: AutomatchCondition
    • value: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz"
    size_speed_options: {
        size: Size;
        speed: Speed;
    }[]

    Type declaration

    time_control: {
        condition: AutomatchCondition;
        value: {
            initial_time?: number;
            main_time?: number;
            max_time?: number;
            pause_on_weekends?: boolean;
            per_move?: number;
            period_time?: number;
            periods?: number;
            stones_per_period?: number;
            system: "fischer" | "byoyomi" | "canadian" | "simple";
            time_increment?: number;
        };
    }

    Type declaration

    • condition: AutomatchCondition
    • value: {
          initial_time?: number;
          main_time?: number;
          max_time?: number;
          pause_on_weekends?: boolean;
          per_move?: number;
          period_time?: number;
          periods?: number;
          stones_per_period?: number;
          system: "fischer" | "byoyomi" | "canadian" | "simple";
          time_increment?: number;
      }
      • Optional initial_time?: number
      • Optional main_time?: number
      • Optional max_time?: number
      • Optional pause_on_weekends?: boolean
      • Optional per_move?: number
      • Optional period_time?: number
      • Optional periods?: number
      • Optional stones_per_period?: number
      • system: "fischer" | "byoyomi" | "canadian" | "simple"
      • Optional time_increment?: number
    timestamp?: number
    upper_rank_diff: number
    uuid: string
    \ No newline at end of file +

    Properties

    handicap: {
        condition: AutomatchCondition;
        value: "enabled" | "disabled";
    }

    Type declaration

    lower_rank_diff: number
    rules: {
        condition: AutomatchCondition;
        value: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz";
    }

    Type declaration

    • condition: AutomatchCondition
    • value: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz"
    size_speed_options: {
        size: Size;
        speed: Speed;
    }[]

    Type declaration

    time_control: {
        condition: AutomatchCondition;
        value: {
            initial_time?: number;
            main_time?: number;
            max_time?: number;
            pause_on_weekends?: boolean;
            per_move?: number;
            period_time?: number;
            periods?: number;
            stones_per_period?: number;
            system: "fischer" | "byoyomi" | "canadian" | "simple";
            time_increment?: number;
        };
    }

    Type declaration

    • condition: AutomatchCondition
    • value: {
          initial_time?: number;
          main_time?: number;
          max_time?: number;
          pause_on_weekends?: boolean;
          per_move?: number;
          period_time?: number;
          periods?: number;
          stones_per_period?: number;
          system: "fischer" | "byoyomi" | "canadian" | "simple";
          time_increment?: number;
      }
      • Optional initial_time?: number
      • Optional main_time?: number
      • Optional max_time?: number
      • Optional pause_on_weekends?: boolean
      • Optional per_move?: number
      • Optional period_time?: number
      • Optional periods?: number
      • Optional stones_per_period?: number
      • system: "fischer" | "byoyomi" | "canadian" | "simple"
      • Optional time_increment?: number
    timestamp?: number
    upper_rank_diff: number
    uuid: string
    \ No newline at end of file diff --git a/docs/interfaces/protocol.ClientToAIServer.html b/docs/interfaces/protocol.ClientToAIServer.html index 22ba567b..5f9172bd 100644 --- a/docs/interfaces/protocol.ClientToAIServer.html +++ b/docs/interfaces/protocol.ClientToAIServer.html @@ -1,6 +1,6 @@ ClientToAIServer | goban

    Interface ClientToAIServer

    This is an exhaustive list of the messages that the client can send to the AI servers.

    -
    interface ClientToAIServer {
        ai-analyze-position: ((data) => any);
        ai-analyze-subscribe: ((data) => void);
        ai-analyze-unsubscribe: ((data) => void);
        ai-analyze-variation: ((data) => void);
        ai-relay-analyzed-position: ((data) => any);
        ai-review-connect: ((data) => void);
        ai-review-disconnect: ((data) => void);
        authenticate: ((data) => undefined | {
            id: number;
            username: string;
        });
        net/ping: ((data) => void);
    }

    Hierarchy (view full)

    Properties

    interface ClientToAIServer {
        ai-analyze-position: ((data) => any);
        ai-analyze-subscribe: ((data) => void);
        ai-analyze-unsubscribe: ((data) => void);
        ai-analyze-variation: ((data) => void);
        ai-relay-analyzed-position: ((data) => any);
        ai-review-connect: ((data) => void);
        ai-review-disconnect: ((data) => void);
        authenticate: ((data) => undefined | {
            id: number;
            username: string;
        });
        net/ping: ((data) => void);
    }

    Hierarchy (view full)

    Properties

  • rules: RuleSet

    Ruleset to use

  • uuid: string

    UUID identifying the request

  • white_prisoners: number

    Number of captures white has

    -
  • Returns any

    ai-analyze-subscribe: ((data) => void)

    Subscribers to analyze position calls

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel_id: string;
          }
          • channel_id: string

        Returns void

    ai-analyze-unsubscribe: ((data) => void)

    Un-subscribers to analyze position calls

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel_id: string;
          }
          • channel_id: string

        Returns void

    ai-analyze-variation: ((data) => void)

    Type declaration

      • (data): void
      • Parameters

        • data: {
              ai_review_id: string | number;
              from: number;
              game_id: string | number;
              uuid: string;
              variation: string;
          }
          • ai_review_id: string | number

            The AI review id we're basing our analysis off of

            +

        Returns any

    ai-analyze-subscribe: ((data) => void)

    Subscribers to analyze position calls

    +

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel_id: string;
          }
          • channel_id: string

        Returns void

    ai-analyze-unsubscribe: ((data) => void)

    Un-subscribers to analyze position calls

    +

    Type declaration

      • (data): void
      • Parameters

        • data: {
              channel_id: string;
          }
          • channel_id: string

        Returns void

    ai-analyze-variation: ((data) => void)

    Type declaration

      • (data): void
      • Parameters

        • data: {
              ai_review_id: string | number;
              from: number;
              game_id: string | number;
              uuid: string;
              variation: string;
          }
          • ai_review_id: string | number

            The AI review id we're basing our analysis off of

          • from: number

            The move number we're branching from

          • game_id: string | number

            The game id we're analyzing

          • uuid: string

            AI UUID

          • variation: string

            Move string

            -

        Returns void

    ai-relay-analyzed-position: ((data) => any)

    Relay an already analyzed position out to any other viewers

    +

    Returns void

    ai-relay-analyzed-position: ((data) => any)

    Relay an already analyzed position out to any other viewers

    Type declaration

    ai-review-connect: ((data) => void)

    Type declaration

    ai-review-connect: ((data) => void)

    Type declaration

    ai-review-disconnect: ((data) => void)

    Type declaration

    authenticate: ((data) => undefined | {
        id: number;
        username: string;
    })

    Authenticate with the server.

    +

    Returns void

    ai-review-disconnect: ((data) => void)

    Type declaration

    authenticate: ((data) => undefined | {
        id: number;
        username: string;
    })

    Authenticate with the server.

    Prior to authentication, you should perform a GET request to /api/v1/ui/config to get the current configuration. Within the returned JSON @@ -47,7 +47,7 @@

  • Optional language?: string

    ISO 639-1 language code used on this device.

  • Optional language_version?: string

    The version of the translation dictionary.

  • Optional user_agent?: string

    Browser user agent (or websocket library)

    -
  • Returns undefined | {
        id: number;
        username: string;
    }

    net/ping: ((data) => void)

    Sends a ping to the server. This message should be +

    Returns undefined | {
        id: number;
        username: string;
    }

    net/ping: ((data) => void)

    Sends a ping to the server. This message should be sent regularly. The default interval is 10 seconds. This keeps the connection alive and allows a client to measure clock drift and latency, both of which @@ -55,4 +55,4 @@

    Type declaration

    \ No newline at end of file +

    Returns void

    \ No newline at end of file diff --git a/docs/interfaces/protocol.ClientToServer.html b/docs/interfaces/protocol.ClientToServer.html index 1e277ccc..324a39e7 100644 --- a/docs/interfaces/protocol.ClientToServer.html +++ b/docs/interfaces/protocol.ClientToServer.html @@ -11,7 +11,7 @@
     {
    bot_apikey?: string;
    bot_username?: string;
    client?: string;
    client_version?: string;
    device_id?: string;
    jwt: string;
    language?: string;
    language_version?: string;
    user_agent?: string;
    }

    and you can expect to receive back either undefined or {id: number, username: string}

    -
    interface ClientToServer {
        authenticate: ((data) => undefined | {
            id: number;
            username: string;
        });
        automatch/cancel: ((data) => void);
        automatch/find_match: ((data) => void);
        automatch/list: ((data) => void);
        bot/config: ((config) => void);
        bot/status: ((data) => void);
        challenge/keepalive: ((data) => void);
        chat/join: ((data) => void);
        chat/part: ((data) => void);
        chat/pm: ((data) => undefined | {
            from: User;
            message: {
                i: string;
                m: string;
                t: number;
            };
            to: {
                id: number;
                username: string;
            };
        });
        chat/pm/close: ((data) => void);
        chat/pm/load: ((data) => void);
        chat/pm/superchat: ((data) => void);
        chat/remove: ((data) => void);
        chat/remove_all: ((data) => void);
        chat/send: ((data) => void);
        chat/topic: ((data) => void);
        game/annul: ((data) => void);
        game/cancel: ((data) => void);
        game/chat: ((data) => void);
        game/chat/remove: ((data) => void);
        game/clear_delayed_resign: ((data) => void);
        game/conditional_moves/set: ((data) => void);
        game/connect: ((data) => void);
        game/delayed_resign: ((data) => void);
        game/disconnect: ((data) => void);
        game/latency: ((data) => void);
        game/log: ((data) => {
            data: any;
            event: string;
            timestamp: string;
        }[]);
        game/move: ((data) => void);
        game/pause: ((data) => void);
        game/prevent_escaping: ((data) => void);
        game/prevent_stalling: ((data) => void);
        game/removed_stones/accept: ((data) => void);
        game/removed_stones/reject: ((data) => void);
        game/removed_stones/set: ((data) => void);
        game/resign: ((data) => void);
        game/resume: ((data) => void);
        game/timed_out: ((data) => void);
        game/undo/accept: ((data) => void);
        game/undo/cancel: ((data) => void);
        game/undo/request: ((data) => void);
        gamelist/count/subscribe: ((data) => void);
        gamelist/count/unsubscribe: ((data) => void);
        gamelist/query: ((data) => undefined | {
            by: string;
            from: number;
            limit: number;
            list: string;
            results: GameListEntry[];
            size: number;
            where: GameListWhere;
        });
        hostinfo: ((data) => {
            clients: number;
            ggs-version: string;
            hostname: string;
            uptime: number;
        });
        itc: ((data) => void);
        net/ping: ((data) => void);
        notification/delete: ((data) => void);
        remote_storage/remove: ((data) => {
            error?: string;
            retry?: boolean;
        } | {
            success: true;
        });
        remote_storage/set: ((data) => {
            error?: string;
            retry?: boolean;
        } | {
            success: true;
        });
        remote_storage/sync: ((data) => {
            error?: string;
            retry?: boolean;
        } | {
            success: true;
        });
        review/append: ((data) => void);
        review/chat: ((data) => void);
        review/chat/remove: ((data) => void);
        review/connect: ((data) => void);
        review/disconnect: ((data) => void);
        seek_graph/connect: ((data) => void);
        seek_graph/disconnect: ((data) => void);
        stats/online: ((data) => number);
        ui-pushes/subscribe: ((data) => void);
        ui-pushes/unsubscribe: ((data) => void);
        user/monitor: ((data) => void);
    }

    Hierarchy (view full)

    Properties

    interface ClientToServer {
        authenticate: ((data) => undefined | {
            id: number;
            username: string;
        });
        automatch/cancel: ((data) => void);
        automatch/find_match: ((data) => void);
        automatch/list: ((data) => void);
        bot/config: ((config) => void);
        bot/status: ((data) => void);
        challenge/keepalive: ((data) => void);
        chat/join: ((data) => void);
        chat/part: ((data) => void);
        chat/pm: ((data) => undefined | {
            from: User;
            message: {
                i: string;
                m: string;
                t: number;
            };
            to: {
                id: number;
                username: string;
            };
        });
        chat/pm/close: ((data) => void);
        chat/pm/load: ((data) => void);
        chat/pm/superchat: ((data) => void);
        chat/remove: ((data) => void);
        chat/remove_all: ((data) => void);
        chat/send: ((data) => void);
        chat/topic: ((data) => void);
        game/annul: ((data) => void);
        game/cancel: ((data) => void);
        game/chat: ((data) => void);
        game/chat/remove: ((data) => void);
        game/clear_delayed_resign: ((data) => void);
        game/conditional_moves/set: ((data) => void);
        game/connect: ((data) => void);
        game/delayed_resign: ((data) => void);
        game/disconnect: ((data) => void);
        game/latency: ((data) => void);
        game/log: ((data) => {
            data: any;
            event: string;
            timestamp: string;
        }[]);
        game/move: ((data) => void);
        game/pause: ((data) => void);
        game/prevent_escaping: ((data) => void);
        game/prevent_stalling: ((data) => void);
        game/removed_stones/accept: ((data) => void);
        game/removed_stones/reject: ((data) => void);
        game/removed_stones/set: ((data) => void);
        game/resign: ((data) => void);
        game/resume: ((data) => void);
        game/timed_out: ((data) => void);
        game/undo/accept: ((data) => void);
        game/undo/cancel: ((data) => void);
        game/undo/request: ((data) => void);
        gamelist/count/subscribe: ((data) => void);
        gamelist/count/unsubscribe: ((data) => void);
        gamelist/query: ((data) => undefined | {
            by: string;
            from: number;
            limit: number;
            list: string;
            results: GameListEntry[];
            size: number;
            where: GameListWhere;
        });
        hostinfo: ((data) => {
            clients: number;
            ggs-version: string;
            hostname: string;
            uptime: number;
        });
        itc: ((data) => void);
        net/ping: ((data) => void);
        notification/delete: ((data) => void);
        remote_storage/remove: ((data) => {
            error?: string;
            retry?: boolean;
        } | {
            success: true;
        });
        remote_storage/set: ((data) => {
            error?: string;
            retry?: boolean;
        } | {
            success: true;
        });
        remote_storage/sync: ((data) => {
            error?: string;
            retry?: boolean;
        } | {
            success: true;
        });
        review/append: ((data) => void);
        review/chat: ((data) => void);
        review/chat/remove: ((data) => void);
        review/connect: ((data) => void);
        review/disconnect: ((data) => void);
        seek_graph/connect: ((data) => void);
        seek_graph/disconnect: ((data) => void);
        stats/online: ((data) => number);
        ui-pushes/subscribe: ((data) => void);
        ui-pushes/unsubscribe: ((data) => void);
        user/monitor: ((data) => void);
    }

    Hierarchy (view full)

    Properties

  • Optional language?: string

    ISO 639-1 language code used on this device.

  • Optional language_version?: string

    The version of the translation dictionary.

  • Optional user_agent?: string

    Browser user agent (or websocket library)

    -
  • Returns undefined | {
        id: number;
        username: string;
    }

    automatch/cancel: ((data) => void)

    Cancel a match request

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {
              uuid: string;
          }
          • uuid: string

        Returns void

    automatch/find_match: ((data) => void)

    Request a match via the automatch system

    -

    Type declaration

    automatch/list: ((data) => void)

    Get active automatch entries for the current user

    -

    Type declaration

      • (data): void
      • Parameters

        • data: {}

          Returns void

      bot/config: ((config) => void)

      Updates the config for the bot

      -

      Type declaration

        • (config): void
        • Parameters

          • config: any

          Returns void

      bot/status: ((data) => void)

      Update the number of games that the bot is currently playing

      -

      Type declaration

        • (data): void
        • Parameters

          • data: {
                ongoing_blitz_count: number;
                ongoing_correspondence_count: number;
                ongoing_live_count: number;
            }
            • ongoing_blitz_count: number
            • ongoing_correspondence_count: number
            • ongoing_live_count: number

          Returns void

      challenge/keepalive: ((data) => void)

      Message to let the server know the client is still interested +

      Returns undefined | {
          id: number;
          username: string;
      }

      automatch/cancel: ((data) => void)

      Cancel a match request

      +

      Type declaration

        • (data): void
        • Parameters

          • data: {
                uuid: string;
            }
            • uuid: string

          Returns void

      automatch/find_match: ((data) => void)

      Request a match via the automatch system

      +

      Type declaration

      automatch/list: ((data) => void)

      Get active automatch entries for the current user

      +

      Type declaration

        • (data): void
        • Parameters

          • data: {}

            Returns void

        bot/config: ((config) => void)

        Updates the config for the bot

        +

        Type declaration

          • (config): void
          • Parameters

            • config: any

            Returns void

        bot/status: ((data) => void)

        Update the number of games that the bot is currently playing

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  ongoing_blitz_count: number;
                  ongoing_correspondence_count: number;
                  ongoing_live_count: number;
              }
              • ongoing_blitz_count: number
              • ongoing_correspondence_count: number
              • ongoing_live_count: number

            Returns void

        challenge/keepalive: ((data) => void)

        Message to let the server know the client is still interested in the specified blitz or live challenge. These should be sent about once a second to prevent the server from canceling the challenge.

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  challenge_id: number;
                  game_id: number;
              }
              • challenge_id: number
              • game_id: number

            Returns void

        chat/join: ((data) => void)

        Join a chat channel

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  challenge_id: number;
                  game_id: number;
              }
              • challenge_id: number
              • game_id: number

            Returns void

        chat/join: ((data) => void)

        Join a chat channel

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
              }
              • channel: string

                Channel to join

                -

            Returns void

        chat/part: ((data) => void)

        Leave a channel

        +

        Returns void

        chat/part: ((data) => void)

        Leave a channel

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
              }
              • channel: string

                Channel to leave

                -

            Returns void

        chat/pm: ((data) => undefined | {
            from: User;
            message: {
                i: string;
                m: string;
                t: number;
            };
            to: {
                id: number;
                username: string;
            };
        })

        Send a private message to another user

        +

        Returns void

        chat/pm: ((data) => undefined | {
            from: User;
            message: {
                i: string;
                m: string;
                t: number;
            };
            to: {
                id: number;
                username: string;
            };
        })

        Send a private message to another user

        Type declaration

          • (data): undefined | {
                from: User;
                message: {
                    i: string;
                    m: string;
                    t: number;
                };
                to: {
                    id: number;
                    username: string;
                };
            }
          • Parameters

            • data: {
                  as_system?: true;
                  message: string;
                  player_id: number;
                  uid: string;
                  username: string;
              }
              • Optional as_system?: true

                Moderator option to send the chat from the system not from their personal PM

              • message: string

                Message text

              • player_id: number

                Player ID of the recipient

              • uid: string

                UUID for the message

              • username: string

                Username of the recipient

                -

            Returns undefined | {
                from: User;
                message: {
                    i: string;
                    m: string;
                    t: number;
                };
                to: {
                    id: number;
                    username: string;
                };
            }

        chat/pm/close: ((data) => void)

        Closes the current user's private message session with the given player id

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  player_id: number;
              }
              • player_id: number

            Returns void

        chat/pm/load: ((data) => void)

        Loads the current user's private message session history with the given player id

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  player_id: number;
              }
              • player_id: number

            Returns void

        chat/pm/superchat: ((data) => void)

        Begins a "super chat" session with the given player id, which creates an +

        Returns undefined | {
            from: User;
            message: {
                i: string;
                m: string;
                t: number;
            };
            to: {
                id: number;
                username: string;
            };
        }

        chat/pm/close: ((data) => void)

        Closes the current user's private message session with the given player id

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  player_id: number;
              }
              • player_id: number

            Returns void

        chat/pm/load: ((data) => void)

        Loads the current user's private message session history with the given player id

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  player_id: number;
              }
              • player_id: number

            Returns void

        chat/pm/superchat: ((data) => void)

        Begins a "super chat" session with the given player id, which creates an unclosable dialog if enable is true, and makes the dialog closable again if enable is false. This is only available to moderators.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  enable: boolean;
                  player_id: number;
                  username: string;
              }
              • enable: boolean

                Set to true if you want the modal to be unclosable, false if you want the modal to be closable again

              • player_id: number
              • username: string

                Username of the recipient

                -

            Returns void

        chat/remove: ((data) => void)

        Moderator only command to remove a single chat message

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  uuid: string;
              }
              • uuid: string

            Returns void

        chat/remove_all: ((data) => void)

        Moderator only command to remove all chat messages for a given player

        +

        Returns void

        chat/remove: ((data) => void)

        Moderator only command to remove a single chat message

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  uuid: string;
              }
              • uuid: string

            Returns void

        chat/remove_all: ((data) => void)

        Moderator only command to remove all chat messages for a given player

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  player_id: number;
              }
              • player_id: number

                Player id to remove all messages for

                -

            Returns void

        chat/send: ((data) => void)

        Sends a chat message to the given channel

        +

        Returns void

        chat/send: ((data) => void)

        Sends a chat message to the given channel

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
                  message: string;
                  uuid: string;
              }
              • channel: string

                Channel to send the message to

              • message: string

                Message text

              • uuid: string

                ID for the message

                -

            Returns void

        chat/topic: ((data) => void)

        Sets a channel topic

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
                  topic: string;
              }
              • channel: string
              • topic: string

            Returns void

        game/annul: ((data) => void)

        In Japanese rules, if the game is found to be repeating, the players +

        Returns void

        chat/topic: ((data) => void)

        Sets a channel topic

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
                  topic: string;
              }
              • channel: string
              • topic: string

            Returns void

        game/annul: ((data) => void)

        In Japanese rules, if the game is found to be repeating, the players may opt to annul the entire game and start over.

        This is largely undesired in an online setting and support for this will probably be removed in the future, dont' bother implementing this.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/cancel: ((data) => void)

        Cancels a game. This is effectively the same as resign, except the +

        Returns void

        game/cancel: ((data) => void)

        Cancels a game. This is effectively the same as resign, except the game will not be ranked. This is only allowed within the first few moves of the game. (See GobanEngine.gameCanBeCancelled for cancellation )

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/chat: ((data) => void)

        Sends a chat message to a game

        +

        Returns void

        game/chat: ((data) => void)

        Sends a chat message to a game

        Type declaration

        game/chat/remove: ((data) => void)

        Moderator only command to remove a single chat message from a game

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
                  chat_id: string;
                  game_id: number;
              }
              • channel: string
              • chat_id: string
              • game_id: number

            Returns void

        game/clear_delayed_resign: ((data) => void)

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/conditional_moves/set: ((data) => void)

        Sets conditional moves to be made on behalf of the player in response +

        Returns void

        game/chat/remove: ((data) => void)

        Moderator only command to remove a single chat message from a game

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel: string;
                  chat_id: string;
                  game_id: number;
              }
              • channel: string
              • chat_id: string
              • game_id: number

            Returns void

        game/clear_delayed_resign: ((data) => void)

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                +

            Returns void

        game/conditional_moves/set: ((data) => void)

        Sets conditional moves to be made on behalf of the player in response to a move by the opponent.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  conditional_moves: ConditionalMoveResponse;
                  game_id: number;
                  move_number: number;
              }
              • conditional_moves: ConditionalMoveResponse

                The conditional moves. The top level should be an array that looks like [null, { ... }] where the second element contains the responses to the opponent's move.

              • game_id: number

                The game id

              • move_number: number

                The move number from which the conditional moves are rooted in

                -

            Returns void

        game/connect: ((data) => void)

        Connect to a game. Once connected, the client will receive game +

        Returns void

        game/connect: ((data) => void)

        Connect to a game. Once connected, the client will receive game updates relevant to the game.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  chat?: boolean;
                  game_id: number;
              }
              • Optional chat?: boolean

                If true, the client will receive the game chat log and new chat events

              • game_id: number

                The game id to connect to

                -

            Returns void

        game/delayed_resign: ((data) => void)

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/disconnect: ((data) => void)

        Disconnect from a game. This will stop game updates for a particular game.

        -

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

            Returns void

        game/latency: ((data) => void)

        Update your latency information for a particular game. This is used +

        Returns void

        game/delayed_resign: ((data) => void)

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                +

            Returns void

        game/disconnect: ((data) => void)

        Disconnect from a game. This will stop game updates for a particular game.

        +

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

            Returns void

        game/latency: ((data) => void)

        Update your latency information for a particular game. This is used for clock synchronization. It is not strictly required, however strongly suggested for live games.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  latency: number;
              }
              • game_id: number

                The game id

              • latency: number

                Network latency, measured in milliseconds. See net/ping to measure this.

                -

            Returns void

        game/log: ((data) => {
            data: any;
            event: string;
            timestamp: string;
        }[])

        Returns an event log for the given game. This is primarily +

        Returns void

        game/log: ((data) => {
            data: any;
            event: string;
            timestamp: string;
        }[])

        Returns an event log for the given game. This is primarily for moderation purposes, although the endpoint is generally available to all users.

        -

        Type declaration

          • (data): {
                data: any;
                event: string;
                timestamp: string;
            }[]
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

            Returns {
                data: any;
                event: string;
                timestamp: string;
            }[]

        game/move: ((data) => void)

        Submit a move for a game

        +

        Type declaration

          • (data): {
                data: any;
                event: string;
                timestamp: string;
            }[]
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

            Returns {
                data: any;
                event: string;
                timestamp: string;
            }[]

        game/move: ((data) => void)

        Submit a move for a game

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  blur?: number;
                  clock?: JGOFPlayerClock;
                  game_id: number;
                  move: string;
              }
              • Optional blur?: number

                Maximum number of milliseconds the client was out of focus between the last move and this move

              • Optional clock?: JGOFPlayerClock

                Clock according to the client. If this is within the margin of @@ -168,18 +168,18 @@ clock value. If not provided, the server clock will be used.

              • game_id: number

                The game id

              • move: string

                The move number to play at

                -

            Returns void

        game/pause: ((data) => void)

        Pauses the game clocks

        +

        Returns void

        game/pause: ((data) => void)

        Pauses the game clocks

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/prevent_escaping: ((data) => void)

        Request the server end a game that someone has left without resigning +

        Returns void

        game/prevent_escaping: ((data) => void)

        Request the server end a game that someone has left without resigning from

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  annul: boolean;
                  game_id: number;
                  winner: "black" | "white";
              }
              • annul: boolean

                Request that the game be annulled or not

              • game_id: number

                The game id

              • winner: "black" | "white"

                The proposed winner

                -

            Returns void

        game/prevent_stalling: ((data) => void)

        Request the server end a game that is being stalled by one of the +

        Returns void

        game/prevent_stalling: ((data) => void)

        Request the server end a game that is being stalled by one of the players. This will only work if the server agrees in the outcome.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  winner: "black" | "white";
              }
              • game_id: number

                The game id

              • winner: "black" | "white"

                The proposed winner

                -

            Returns void

        game/removed_stones/accept: ((data) => void)

        Accepts the stones as removed. Once both players have accepted the same +

        Returns void

        game/removed_stones/accept: ((data) => void)

        Accepts the stones as removed. Once both players have accepted the same stones, the stone removal phase will conclude and the game will finish.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  stones: string;
                  strict_seki_mode: boolean;
              }
              • game_id: number

                The game id

              • stones: string

                All of the stones that are accepted as removed, and all @@ -190,9 +190,9 @@ era of the game, the official client no longer displays this as an option to the user as it was very largely unused and was a large source of confusion.

                -

            Returns void

        game/removed_stones/reject: ((data) => void)

        Rejects the removed stones and resumes the game from the stone removal phase

        +

        Returns void

        game/removed_stones/reject: ((data) => void)

        Rejects the removed stones and resumes the game from the stone removal phase

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/removed_stones/set: ((data) => void)

        Sets removed stones in the stone removal phase.

        +

        Returns void

        game/removed_stones/set: ((data) => void)

        Sets removed stones in the stone removal phase.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  needs_sealing?: JGOFSealingIntersection[];
                  removed: boolean;
                  stones: string | JGOFMove[];
                  strict_seki_mode?: boolean;
              }
              • game_id: number

                The game id

              • Optional needs_sealing?: JGOFSealingIntersection[]

                List of intersections that need to be sealed before the game can be correctly scored. Note, if this is undefined, the value will not @@ -208,47 +208,47 @@ option to the user as it was very largely unused and was a large source of confusion. This field is deprecated and will likely be removed in the future.

                -

            Returns void

        game/resign: ((data) => void)

        Resigns from the game

        +

        Returns void

        game/resign: ((data) => void)

        Resigns from the game

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/resume: ((data) => void)

        Resumes the game clocks

        +

        Returns void

        game/resume: ((data) => void)

        Resumes the game clocks

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/timed_out: ((data) => void)

        Inform the server that the client believes it's clock has timed out +

        Returns void

        game/timed_out: ((data) => void)

        Inform the server that the client believes it's clock has timed out and the game should be ended in a timeout. This is not strictly necessary to implement as the server will also timeout games, however there is a grace period to account for network latency, so well behaved clients can (and should) send this message to be very exact with timeouts.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
              }
              • game_id: number

                The game id

                -

            Returns void

        game/undo/accept: ((data) => void)

        Accepts an undo

        +

        Returns void

        game/undo/accept: ((data) => void)

        Accepts an undo

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  move_number: number;
              }
              • game_id: number

                The game id

              • move_number: number

                The current move number

                -

            Returns void

        game/undo/cancel: ((data) => void)

        Cancels an undo request

        +

        Returns void

        game/undo/cancel: ((data) => void)

        Cancels an undo request

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  move_number: number;
              }
              • game_id: number

                The game id

              • move_number: number

                The current move number

                -

            Returns void

        game/undo/request: ((data) => void)

        Requests an undo

        +

        Returns void

        game/undo/request: ((data) => void)

        Requests an undo

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  game_id: number;
                  move_number: number;
              }
              • game_id: number

                The game id

              • move_number: number

                The current move number

                -

            Returns void

        gamelist/count/subscribe: ((data) => void)

        Connects to the game list count. +

        Returns void

        gamelist/count/subscribe: ((data) => void)

        Connects to the game list count. Once connected you'll start receiving gamelist-count or gamelist-count-${channel} messages.

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel?: string;
              }
              • Optional channel?: string

                The group or tournament channel to subscribe to. If no channel is provided, the global server counts will be sent

                -

            Returns void

        gamelist/count/unsubscribe: ((data) => void)

        Disconnects from the game list count

        +

        Returns void

        gamelist/count/unsubscribe: ((data) => void)

        Disconnects from the game list count

        Type declaration

          • (data): void
          • Parameters

            • data: {
                  channel?: string;
              }
              • Optional channel?: string

                The group or tournament channel to unsubscribe from. If no channel is provided, the global server counts will be unsubscribed from

                -

            Returns void

        gamelist/query: ((data) => undefined | {
            by: string;
            from: number;
            limit: number;
            list: string;
            results: GameListEntry[];
            size: number;
            where: GameListWhere;
        })

        Queries the server for a list of games

        +

        Returns void

        gamelist/query: ((data) => undefined | {
            by: string;
            from: number;
            limit: number;
            list: string;
            results: GameListEntry[];
            size: number;
            where: GameListWhere;
        })

        Queries the server for a list of games

        Type declaration

          • (data): undefined | {
                by: string;
                from: number;
                limit: number;
                list: string;
                results: GameListEntry[];
                size: number;
                where: GameListWhere;
            }
          • Parameters

            • data: {
                  channel?: string;
                  from: number;
                  limit: number;
                  list: "live" | "corr" | "kidsgo";
                  sort_by: "rank";
                  where: GameListWhere;
              }
              • Optional channel?: string

                The group or tournament channel to query

              • from: number

                The number of games to skip before returning results

              • limit: number

                Number of games to return, between 1 and 300

              • list: "live" | "corr" | "kidsgo"
              • sort_by: "rank"
              • where: GameListWhere

                Filtering options

                -

            Returns undefined | {
                by: string;
                from: number;
                limit: number;
                list: string;
                results: GameListEntry[];
                size: number;
                where: GameListWhere;
            }

        hostinfo: ((data) => {
            clients: number;
            ggs-version: string;
            hostname: string;
            uptime: number;
        })

        Retrieve host information for the termination server you are connected to

        -

        Type declaration

          • (data): {
                clients: number;
                ggs-version: string;
                hostname: string;
                uptime: number;
            }
          • Parameters

            • data: {}

              Returns {
                  clients: number;
                  ggs-version: string;
                  hostname: string;
                  uptime: number;
              }

              • clients: number
              • ggs-version: string
              • hostname: string
              • uptime: number
          itc: ((data) => void)

          Sends an "Inter Tab Communication" message to all other connected +

          Returns undefined | {
              by: string;
              from: number;
              limit: number;
              list: string;
              results: GameListEntry[];
              size: number;
              where: GameListWhere;
          }

          hostinfo: ((data) => {
              clients: number;
              ggs-version: string;
              hostname: string;
              uptime: number;
          })

          Retrieve host information for the termination server you are connected to

          +

          Type declaration

            • (data): {
                  clients: number;
                  ggs-version: string;
                  hostname: string;
                  uptime: number;
              }
            • Parameters

              • data: {}

                Returns {
                    clients: number;
                    ggs-version: string;
                    hostname: string;
                    uptime: number;
                }

                • clients: number
                • ggs-version: string
                • hostname: string
                • uptime: number
            itc: ((data) => void)

            Sends an "Inter Tab Communication" message to all other connected clients for the current user. This includes other devices, so the "Tab" part is a bit of a misnomer.

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      data: any;
                      event: string;
                  }
                  • data: any

                    User defined data

                  • event: string

                    User defined event string

                    -

                Returns void

            net/ping: ((data) => void)

            Sends a ping to the server. This message should be +

            Returns void

            net/ping: ((data) => void)

            Sends a ping to the server. This message should be sent regularly. The default interval is 10 seconds. This keeps the connection alive and allows a client to measure clock drift and latency, both of which @@ -256,37 +256,37 @@

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      client: number;
                      drift: number;
                      latency: number;
                  }
                  • client: number

                    Client timestamp - milliseconds since epoch

                  • drift: number

                    Last clock drift measurement, or 0

                  • latency: number

                    Last latency measurement, or 0

                    -

                Returns void

            notification/delete: ((data) => void)

            Deletes a notification

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      notification_id: string;
                  }
                  • notification_id: string

                Returns void

            remote_storage/remove: ((data) => {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            })

            Remove the given key from remote storage system for this user

            +

            Returns void

            notification/delete: ((data) => void)

            Deletes a notification

            +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      notification_id: string;
                  }
                  • notification_id: string

                Returns void

            remote_storage/remove: ((data) => {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            })

            Remove the given key from remote storage system for this user

            For more details on the remote storage replication system see: https://github.com/online-go/online-go.com/blob/devel/src/lib/data.ts

            -

            Type declaration

              • (data): {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }
              • Parameters

                Returns {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }

            remote_storage/set: ((data) => {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            })

            Set the given key in the remote storage system for this user

            +

            Type declaration

              • (data): {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }
              • Parameters

                Returns {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }

            remote_storage/set: ((data) => {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            })

            Set the given key in the remote storage system for this user

            For more details on the remote storage replication system see: https://github.com/online-go/online-go.com/blob/devel/src/lib/data.ts

            -

            Type declaration

              • (data): {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }
              • Parameters

                Returns {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }

            remote_storage/sync: ((data) => {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            })

            Requests all updated key/value pairs for this user since the +

            Type declaration

              • (data): {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }
              • Parameters

                Returns {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }

            remote_storage/sync: ((data) => {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            })

            Requests all updated key/value pairs for this user since the provided timestamp (as as ISO 8601 string).

            For more details on the remote storage replication system see: https://github.com/online-go/online-go.com/blob/devel/src/lib/data.ts

            Type declaration

              • (data): {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }
              • Parameters

                • data: {
                      since: string;
                  }
                  • since: string

                    ISO 8601 timestamp. Updates made after this timestamp will be sent to the client.

                    -

                Returns {
                    error?: string;
                    retry?: boolean;
                } | {
                    success: true;
                }

            review/append: ((data) => void)

            Append a review action to the review log.

            -

            Type declaration

            review/chat: ((data) => void)

            Sends a chat message to a review

            +

            Returns {
                error?: string;
                retry?: boolean;
            } | {
                success: true;
            }

            review/append: ((data) => void)

            Append a review action to the review log.

            +

            Type declaration

            review/chat: ((data) => void)

            Sends a chat message to a review

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      body: string;
                      from: number;
                      moves: string;
                      review_id: number;
                  }
                  • body: string

                    The chat message

                  • from: number

                    The root of the branch the user is viewing

                  • moves: string

                    The analysis branch the user is viewing

                  • review_id: number

                    The review id

                    -

                Returns void

            review/chat/remove: ((data) => void)

            Moderator only command to remove a single chat message from a game

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: string;
                      chat_id: string;
                      review_id: number;
                  }
                  • channel: string
                  • chat_id: string
                  • review_id: number

                Returns void

            review/connect: ((data) => void)

            Connects to a review

            +

            Returns void

            review/chat/remove: ((data) => void)

            Moderator only command to remove a single chat message from a game

            +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: string;
                      chat_id: string;
                      review_id: number;
                  }
                  • channel: string
                  • chat_id: string
                  • review_id: number

                Returns void

            review/connect: ((data) => void)

            Connects to a review

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      review_id: number;
                  }
                  • review_id: number

                    The review id

                    -

                Returns void

            review/disconnect: ((data) => void)

            Disconnects from a review

            +

            Returns void

            review/disconnect: ((data) => void)

            Disconnects from a review

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      review_id: number;
                  }
                  • review_id: number

                    The review id

                    -

                Returns void

            seek_graph/connect: ((data) => void)

            Subscribes to the seek graph events. The channel is required to be "global" +

            Returns void

            seek_graph/connect: ((data) => void)

            Subscribes to the seek graph events. The channel is required to be "global" for now and the foreseeable future.

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: "global";
                  }
                  • channel: "global"

                Returns void

            seek_graph/disconnect: ((data) => void)

            Un-Subscribes to the seek graph events. The channel is required to be "global" +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: "global";
                  }
                  • channel: "global"

                Returns void

            seek_graph/disconnect: ((data) => void)

            Un-Subscribes to the seek graph events. The channel is required to be "global" for now and the foreseeable future.

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: "global";
                  }
                  • channel: "global"

                Returns void

            stats/online: ((data) => number)

            Request the number of unique authenticated players +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: "global";
                  }
                  • channel: "global"

                Returns void

            stats/online: ((data) => number)

            Request the number of unique authenticated players online within the given interval

            Type declaration

              • (data): number
              • Parameters

                • data: {
                      interval: number;
                  }
                  • interval: number

                    Interval in seconds

                    -

                Returns number

            ui-pushes/subscribe: ((data) => void)

            Subscribes to UI related push event messages sent to a particular channel

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: string;
                  }
                  • channel: string

                Returns void

            ui-pushes/unsubscribe: ((data) => void)

            Un-Subscribes to UI related push event messages sent to a particular channel

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: string;
                  }
                  • channel: string

                Returns void

            user/monitor: ((data) => void)

            Subscribes to online status updates for the given player ids

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      user_ids: number[];
                  }
                  • user_ids: number[]

                Returns void

            \ No newline at end of file +

            Returns number

            ui-pushes/subscribe: ((data) => void)

            Subscribes to UI related push event messages sent to a particular channel

            +

            Type declaration

            ui-pushes/unsubscribe: ((data) => void)

            Un-Subscribes to UI related push event messages sent to a particular channel

            +

            Type declaration

            user/monitor: ((data) => void)

            Subscribes to online status updates for the given player ids

            +

            Type declaration

            \ No newline at end of file diff --git a/docs/interfaces/protocol.ClientToServerBase.html b/docs/interfaces/protocol.ClientToServerBase.html index 72183195..23165208 100644 --- a/docs/interfaces/protocol.ClientToServerBase.html +++ b/docs/interfaces/protocol.ClientToServerBase.html @@ -1,5 +1,5 @@ ClientToServerBase | goban

            Interface ClientToServerBase

            Messages that clients send, regardless of target server

            -
            interface ClientToServerBase {
                authenticate: ((data) => undefined | {
                    id: number;
                    username: string;
                });
                net/ping: ((data) => void);
            }

            Hierarchy (view full)

            Properties

            interface ClientToServerBase {
                authenticate: ((data) => undefined | {
                    id: number;
                    username: string;
                });
                net/ping: ((data) => void);
            }

            Hierarchy (view full)

            Properties

            authenticate: ((data) => undefined | {
                id: number;
                username: string;
            })

            Authenticate with the server.

            Prior to authentication, you should perform a GET request to @@ -16,7 +16,7 @@

          • Optional language?: string

            ISO 639-1 language code used on this device.

          • Optional language_version?: string

            The version of the translation dictionary.

          • Optional user_agent?: string

            Browser user agent (or websocket library)

            -
          • Returns undefined | {
                id: number;
                username: string;
            }

            net/ping: ((data) => void)

            Sends a ping to the server. This message should be +

            Returns undefined | {
                id: number;
                username: string;
            }

            net/ping: ((data) => void)

            Sends a ping to the server. This message should be sent regularly. The default interval is 10 seconds. This keeps the connection alive and allows a client to measure clock drift and latency, both of which @@ -24,4 +24,4 @@

            Type declaration

            \ No newline at end of file +

            Returns void

            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameChatAnalysisMessage.html b/docs/interfaces/protocol.GameChatAnalysisMessage.html index 2a9b9fbe..d24f623b 100644 --- a/docs/interfaces/protocol.GameChatAnalysisMessage.html +++ b/docs/interfaces/protocol.GameChatAnalysisMessage.html @@ -1,4 +1,4 @@ -GameChatAnalysisMessage | goban

            Interface GameChatAnalysisMessage

            interface GameChatAnalysisMessage {
                branch_move?: number;
                engine_analysis?: {
                    score?: number;
                    visits?: number;
                    win_rate: number;
                    [key: string]: number | undefined;
                };
                from?: number;
                marks?: {
                    [mark: string]: string;
                };
                moves?: string;
                name?: string;
                pen_marks?: unknown[];
                type: "analysis";
            }

            Properties

            branch_move? +GameChatAnalysisMessage | goban

            Interface GameChatAnalysisMessage

            interface GameChatAnalysisMessage {
                branch_move?: number;
                engine_analysis?: {
                    score?: number;
                    visits?: number;
                    win_rate: number;
                    [key: string]: number | undefined;
                };
                from?: number;
                marks?: {
                    [mark: string]: string;
                };
                moves?: string;
                name?: string;
                pen_marks?: unknown[];
                type: "analysis";
            }

            Properties

            branch_move?: number
            engine_analysis?: {
                score?: number;
                visits?: number;
                win_rate: number;
                [key: string]: number | undefined;
            }

            Type declaration

            • [key: string]: number | undefined
            • Optional score?: number
            • Optional visits?: number
            • win_rate: number
            from?: number
            marks?: {
                [mark: string]: string;
            }

            Type declaration

            • [mark: string]: string
            moves?: string
            name?: string
            pen_marks?: unknown[]
            type: "analysis"
            \ No newline at end of file +

            Properties

            branch_move?: number
            engine_analysis?: {
                score?: number;
                visits?: number;
                win_rate: number;
                [key: string]: number | undefined;
            }

            Type declaration

            • [key: string]: number | undefined
            • Optional score?: number
            • Optional visits?: number
            • win_rate: number
            from?: number
            marks?: {
                [mark: string]: string;
            }

            Type declaration

            • [mark: string]: string
            moves?: string
            name?: string
            pen_marks?: unknown[]
            type: "analysis"
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameChatLine.html b/docs/interfaces/protocol.GameChatLine.html index b3d9063c..efb1c15f 100644 --- a/docs/interfaces/protocol.GameChatLine.html +++ b/docs/interfaces/protocol.GameChatLine.html @@ -1,4 +1,4 @@ -GameChatLine | goban

            Interface GameChatLine

            interface GameChatLine {
                body: string | AnalysisComment | ReviewComment;
                channel: string;
                chat_id: string;
                date: number;
                from?: number;
                move_number: number;
                moves?: string;
                player_id: number;
                username?: string;
            }

            Properties

            body +GameChatLine | goban

            Interface GameChatLine

            interface GameChatLine {
                body: string | AnalysisComment | ReviewComment;
                channel: string;
                chat_id: string;
                date: number;
                from?: number;
                move_number: number;
                moves?: string;
                player_id: number;
                username?: string;
            }

            Properties

            Properties

            channel: string
            chat_id: string
            date: number
            from?: number
            move_number: number
            moves?: string
            player_id: number
            username?: string
            \ No newline at end of file +

            Properties

            channel: string
            chat_id: string
            date: number
            from?: number
            move_number: number
            moves?: string
            player_id: number
            username?: string
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameChatMessage.html b/docs/interfaces/protocol.GameChatMessage.html index 666a9305..fb033c48 100644 --- a/docs/interfaces/protocol.GameChatMessage.html +++ b/docs/interfaces/protocol.GameChatMessage.html @@ -1,3 +1,3 @@ -GameChatMessage | goban

            Interface GameChatMessage

            interface GameChatMessage {
                channel: "main" | "malkovich" | "hidden" | "personal" | "spectator" | "shadowban";
                line: GameChatLine;
            }

            Properties

            channel +GameChatMessage | goban

            Interface GameChatMessage

            interface GameChatMessage {
                channel: "main" | "malkovich" | "hidden" | "personal" | "spectator" | "shadowban";
                line: GameChatLine;
            }

            Properties

            Properties

            channel: "main" | "malkovich" | "hidden" | "personal" | "spectator" | "shadowban"
            \ No newline at end of file +

            Properties

            channel: "main" | "malkovich" | "hidden" | "personal" | "spectator" | "shadowban"
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameChatReviewMessage.html b/docs/interfaces/protocol.GameChatReviewMessage.html index 35dfb294..55793688 100644 --- a/docs/interfaces/protocol.GameChatReviewMessage.html +++ b/docs/interfaces/protocol.GameChatReviewMessage.html @@ -1,3 +1,3 @@ -GameChatReviewMessage | goban

            Interface GameChatReviewMessage

            interface GameChatReviewMessage {
                review_id: number;
                type: "review";
            }

            Properties

            review_id +GameChatReviewMessage | goban

            Interface GameChatReviewMessage

            interface GameChatReviewMessage {
                review_id: number;
                type: "review";
            }

            Properties

            Properties

            review_id: number
            type: "review"
            \ No newline at end of file +

            Properties

            review_id: number
            type: "review"
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameChatTranslatedMessage.html b/docs/interfaces/protocol.GameChatTranslatedMessage.html index 828dc1d1..dec02927 100644 --- a/docs/interfaces/protocol.GameChatTranslatedMessage.html +++ b/docs/interfaces/protocol.GameChatTranslatedMessage.html @@ -1,3 +1,3 @@ -GameChatTranslatedMessage | goban

            Interface GameChatTranslatedMessage

            interface GameChatTranslatedMessage {
                en: string;
                type: "translated";
                [lang: string]: string;
            }

            Indexable

            [lang: string]: string

            Properties

            en +GameChatTranslatedMessage | goban

            Interface GameChatTranslatedMessage

            interface GameChatTranslatedMessage {
                en: string;
                type: "translated";
                [lang: string]: string;
            }

            Indexable

            [lang: string]: string

            Properties

            Properties

            en: string
            type: "translated"
            \ No newline at end of file +

            Properties

            en: string
            type: "translated"
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameClock.html b/docs/interfaces/protocol.GameClock.html index 838226c2..2b6292ea 100644 --- a/docs/interfaces/protocol.GameClock.html +++ b/docs/interfaces/protocol.GameClock.html @@ -1,4 +1,4 @@ -GameClock | goban

            Interface GameClock

            interface GameClock {
                black_player_id: number;
                black_time?: ClockTime;
                current_player: number;
                expiration: number;
                expiration_delta?: number;
                game_id: number;
                last_move: number;
                now?: number;
                pause?: {
                    pause_control?: {
                        [key: string]: boolean;
                    };
                    paused?: boolean;
                    paused_since?: number;
                };
                pause_delta?: number;
                paused_since?: number;
                start_mode?: boolean;
                stone_removal_expiration?: number;
                stone_removal_mode?: boolean;
                title: string;
                white_player_id: number;
                white_time?: ClockTime;
            }

            Properties

            black_player_id +GameClock | goban

            Interface GameClock

            interface GameClock {
                black_player_id: number;
                black_time?: ClockTime;
                current_player: number;
                expiration: number;
                expiration_delta?: number;
                game_id: number;
                last_move: number;
                now?: number;
                pause?: {
                    pause_control?: {
                        [key: string]: boolean;
                    };
                    paused?: boolean;
                    paused_since?: number;
                };
                pause_delta?: number;
                paused_since?: number;
                start_mode?: boolean;
                stone_removal_expiration?: number;
                stone_removal_mode?: boolean;
                title: string;
                white_player_id: number;
                white_time?: ClockTime;
            }

            Properties

            black_player_id: number
            black_time?: ClockTime
            current_player: number
            expiration: number
            expiration_delta?: number
            game_id: number
            last_move: number
            now?: number
            pause?: {
                pause_control?: {
                    [key: string]: boolean;
                };
                paused?: boolean;
                paused_since?: number;
            }

            Type declaration

            • Optional pause_control?: {
                  [key: string]: boolean;
              }
              • [key: string]: boolean
            • Optional paused?: boolean
            • Optional paused_since?: number
            pause_delta?: number
            paused_since?: number
            start_mode?: boolean
            stone_removal_expiration?: number
            stone_removal_mode?: boolean
            title: string
            white_player_id: number
            white_time?: ClockTime
            \ No newline at end of file +

            Properties

            black_player_id: number
            black_time?: ClockTime
            current_player: number
            expiration: number
            expiration_delta?: number
            game_id: number
            last_move: number
            now?: number
            pause?: {
                pause_control?: {
                    [key: string]: boolean;
                };
                paused?: boolean;
                paused_since?: number;
            }

            Type declaration

            • Optional pause_control?: {
                  [key: string]: boolean;
              }
              • [key: string]: boolean
            • Optional paused?: boolean
            • Optional paused_since?: number
            pause_delta?: number
            paused_since?: number
            start_mode?: boolean
            stone_removal_expiration?: number
            stone_removal_mode?: boolean
            title: string
            white_player_id: number
            white_time?: ClockTime
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameListEntry.html b/docs/interfaces/protocol.GameListEntry.html index b605272c..487ac0e5 100644 --- a/docs/interfaces/protocol.GameListEntry.html +++ b/docs/interfaces/protocol.GameListEntry.html @@ -1,4 +1,4 @@ -GameListEntry | goban

            Interface GameListEntry

            interface GameListEntry {
                _participants?: number[];
                black: GameListPlayer;
                bot_game?: boolean;
                clock_expiration: number;
                dropped_player: number;
                group_ids?: number[];
                group_ids_map?: {
                    [id: string]: boolean;
                };
                handicap?: number;
                height: number;
                id: number;
                in_beginning?: boolean;
                in_end?: boolean;
                in_middle?: boolean;
                kidsgo_game?: boolean;
                komi?: number;
                ladder_id?: number;
                malkovich_present?: boolean;
                move_number: number;
                name: string;
                paused: boolean;
                phase: string;
                player_to_move: number;
                private: boolean;
                ranked?: boolean;
                rengo: boolean;
                rengo_casual_mode: boolean;
                rengo_teams: {
                    black: User[];
                    white: User[];
                };
                socket_id?: any;
                time_per_move: number;
                tournament_id?: number;
                white: GameListPlayer;
                width: number;
            }

            Properties

            _participants? +GameListEntry | goban

            Interface GameListEntry

            interface GameListEntry {
                _participants?: number[];
                black: GameListPlayer;
                bot_game?: boolean;
                clock_expiration: number;
                dropped_player: number;
                group_ids?: number[];
                group_ids_map?: {
                    [id: string]: boolean;
                };
                handicap?: number;
                height: number;
                id: number;
                in_beginning?: boolean;
                in_end?: boolean;
                in_middle?: boolean;
                kidsgo_game?: boolean;
                komi?: number;
                ladder_id?: number;
                malkovich_present?: boolean;
                move_number: number;
                name: string;
                paused: boolean;
                phase: string;
                player_to_move: number;
                private: boolean;
                ranked?: boolean;
                rengo: boolean;
                rengo_casual_mode: boolean;
                rengo_teams: {
                    black: User[];
                    white: User[];
                };
                socket_id?: any;
                time_per_move: number;
                tournament_id?: number;
                white: GameListPlayer;
                width: number;
            }

            Properties

            _participants?: number[]
            bot_game?: boolean
            clock_expiration: number
            dropped_player: number
            group_ids?: number[]
            group_ids_map?: {
                [id: string]: boolean;
            }

            Type declaration

            • [id: string]: boolean
            handicap?: number
            height: number
            id: number
            in_beginning?: boolean
            in_end?: boolean
            in_middle?: boolean
            kidsgo_game?: boolean
            komi?: number
            ladder_id?: number
            malkovich_present?: boolean
            move_number: number
            name: string
            paused: boolean
            phase: string
            player_to_move: number
            private: boolean
            ranked?: boolean
            rengo: boolean
            rengo_casual_mode: boolean
            rengo_teams: {
                black: User[];
                white: User[];
            }

            Type declaration

            socket_id?: any
            time_per_move: number
            tournament_id?: number
            width: number
            \ No newline at end of file +

            Properties

            _participants?: number[]
            bot_game?: boolean
            clock_expiration: number
            dropped_player: number
            group_ids?: number[]
            group_ids_map?: {
                [id: string]: boolean;
            }

            Type declaration

            • [id: string]: boolean
            handicap?: number
            height: number
            id: number
            in_beginning?: boolean
            in_end?: boolean
            in_middle?: boolean
            kidsgo_game?: boolean
            komi?: number
            ladder_id?: number
            malkovich_present?: boolean
            move_number: number
            name: string
            paused: boolean
            phase: string
            player_to_move: number
            private: boolean
            ranked?: boolean
            rengo: boolean
            rengo_casual_mode: boolean
            rengo_teams: {
                black: User[];
                white: User[];
            }

            Type declaration

            socket_id?: any
            time_per_move: number
            tournament_id?: number
            width: number
            \ No newline at end of file diff --git a/docs/interfaces/protocol.GameListWhere.html b/docs/interfaces/protocol.GameListWhere.html index c1a67c87..d5e8ebb3 100644 --- a/docs/interfaces/protocol.GameListWhere.html +++ b/docs/interfaces/protocol.GameListWhere.html @@ -1,5 +1,5 @@ GameListWhere | goban

            Interface GameListWhere

            Parameters for the gamelist/query message

            -
            interface GameListWhere {
                hide_13x13?: boolean;
                hide_19x19?: boolean;
                hide_9x9?: boolean;
                hide_beginning?: boolean;
                hide_bot_games?: boolean;
                hide_end?: boolean;
                hide_even?: boolean;
                hide_handicap?: boolean;
                hide_ladder?: boolean;
                hide_middle?: boolean;
                hide_open?: boolean;
                hide_other?: boolean;
                hide_ranked?: boolean;
                hide_tournament?: boolean;
                hide_unranked?: boolean;
                ladder_id?: number;
                malk_only?: boolean;
                players?: number[];
                rengo_only?: boolean;
                tournament_id?: number;
            }

            Properties

            interface GameListWhere {
                hide_13x13?: boolean;
                hide_19x19?: boolean;
                hide_9x9?: boolean;
                hide_beginning?: boolean;
                hide_bot_games?: boolean;
                hide_end?: boolean;
                hide_even?: boolean;
                hide_handicap?: boolean;
                hide_ladder?: boolean;
                hide_middle?: boolean;
                hide_open?: boolean;
                hide_other?: boolean;
                hide_ranked?: boolean;
                hide_tournament?: boolean;
                hide_unranked?: boolean;
                ladder_id?: number;
                malk_only?: boolean;
                players?: number[];
                rengo_only?: boolean;
                tournament_id?: number;
            }

            Properties

            hide_13x13?: boolean
            hide_19x19?: boolean
            hide_9x9?: boolean
            hide_beginning?: boolean
            hide_bot_games?: boolean
            hide_end?: boolean
            hide_even?: boolean
            hide_handicap?: boolean
            hide_ladder?: boolean
            hide_middle?: boolean
            hide_open?: boolean
            hide_other?: boolean
            hide_ranked?: boolean
            hide_tournament?: boolean
            hide_unranked?: boolean
            ladder_id?: number
            malk_only?: boolean
            players?: number[]
            rengo_only?: boolean
            tournament_id?: number
            \ No newline at end of file +

            Properties

            hide_13x13?: boolean
            hide_19x19?: boolean
            hide_9x9?: boolean
            hide_beginning?: boolean
            hide_bot_games?: boolean
            hide_end?: boolean
            hide_even?: boolean
            hide_handicap?: boolean
            hide_ladder?: boolean
            hide_middle?: boolean
            hide_open?: boolean
            hide_other?: boolean
            hide_ranked?: boolean
            hide_tournament?: boolean
            hide_unranked?: boolean
            ladder_id?: number
            malk_only?: boolean
            players?: number[]
            rengo_only?: boolean
            tournament_id?: number
            \ No newline at end of file diff --git a/docs/interfaces/protocol.Glicko2.html b/docs/interfaces/protocol.Glicko2.html index bb84ef0e..06b5dd68 100644 --- a/docs/interfaces/protocol.Glicko2.html +++ b/docs/interfaces/protocol.Glicko2.html @@ -1,5 +1,5 @@ -Glicko2 | goban

            Interface Glicko2

            interface Glicko2 {
                deviation: number;
                games_played?: number;
                rating: number;
                volatility: number;
            }

            Properties

            deviation +Glicko2 | goban

            Interface Glicko2

            interface Glicko2 {
                deviation: number;
                games_played?: number;
                rating: number;
                volatility: number;
            }

            Properties

            deviation: number
            games_played?: number
            rating: number
            volatility: number
            \ No newline at end of file +

            Properties

            deviation: number
            games_played?: number
            rating: number
            volatility: number
            \ No newline at end of file diff --git a/docs/interfaces/protocol.SeekgraphChallengeMessage.html b/docs/interfaces/protocol.SeekgraphChallengeMessage.html index 55885a76..4c4112ac 100644 --- a/docs/interfaces/protocol.SeekgraphChallengeMessage.html +++ b/docs/interfaces/protocol.SeekgraphChallengeMessage.html @@ -1,4 +1,4 @@ -SeekgraphChallengeMessage | goban

            Interface SeekgraphChallengeMessage

            interface SeekgraphChallengeMessage {
                challenge_id: number;
                challenger_color: "black" | "white" | "automatic";
                disable_analysis: boolean;
                game_id: number;
                handicap: null | number;
                height: number;
                invite_only: boolean;
                komi: null | number;
                max_rank: number;
                min_rank: number;
                name: string;
                professional: boolean;
                ranked: boolean;
                ranking: number;
                rengo: boolean;
                rengo_auto_start: boolean;
                rengo_black_team: number[];
                rengo_casual_mode: boolean;
                rengo_nominees: number[];
                rengo_participants: number[];
                rengo_white_team: number[];
                rules: string;
                time_control: string;
                time_control_parameters: JGOFTimeControl;
                time_per_move: number;
                user_id: number;
                username: string;
                uuid: string;
                width: number;
            }

            Properties

            challenge_id +SeekgraphChallengeMessage | goban

            Interface SeekgraphChallengeMessage

            interface SeekgraphChallengeMessage {
                challenge_id: number;
                challenger_color: "black" | "white" | "automatic";
                disable_analysis: boolean;
                game_id: number;
                handicap: null | number;
                height: number;
                invite_only: boolean;
                komi: null | number;
                max_rank: number;
                min_rank: number;
                name: string;
                professional: boolean;
                ranked: boolean;
                ranking: number;
                rengo: boolean;
                rengo_auto_start: boolean;
                rengo_black_team: number[];
                rengo_casual_mode: boolean;
                rengo_nominees: number[];
                rengo_participants: number[];
                rengo_white_team: number[];
                rules: string;
                time_control: string;
                time_control_parameters: JGOFTimeControl;
                time_per_move: number;
                user_id: number;
                username: string;
                uuid: string;
                width: number;
            }

            Properties

            challenge_id: number

            The ID of the challenge

            -
            challenger_color: "black" | "white" | "automatic"

            Color the accepting player will be

            -
            disable_analysis: boolean

            If analysis is disabled

            -
            game_id: number

            The game ID

            -
            handicap: null | number

            The game handicap

            -
            height: number

            Board height

            -
            invite_only: boolean

            If the game is only joinable by invitation

            -
            komi: null | number

            Komi

            -
            max_rank: number

            Maximum rank allowed to accept the game

            -
            min_rank: number

            Minimum rank allowed to accept the game

            -
            name: string

            Game name

            -
            professional: boolean

            If they are a professional player

            -
            ranked: boolean

            If the game is ranked

            -
            ranking: number

            Their ranking *

            -
            rengo: boolean

            If it's a rengo game

            -
            rengo_auto_start: boolean

            If the rengo game will automatically start

            -
            rengo_black_team: number[]

            Player ids of the players on the Black team

            -
            rengo_casual_mode: boolean

            If the game is a casual rengo game

            -
            rengo_nominees: number[]

            Player ids of people that have been nominated to play

            -
            rengo_participants: number[]

            All player ids involved in the game

            -
            rengo_white_team: number[]

            Player ids of the players on the White team

            -
            rules: string

            Rules being used

            -
            time_control: string

            Time control system type

            -
            time_control_parameters: JGOFTimeControl

            Time control parameters

            -
            time_per_move: number

            Average time per move

            -
            user_id: number

            User id of the player who is looking for a game

            -
            username: string

            Username of the player looking for the game

            -
            uuid: string

            A UUID for the invitation

            -
            width: number

            Board width

            -
            \ No newline at end of file +
            challenger_color: "black" | "white" | "automatic"

            Color the accepting player will be

            +
            disable_analysis: boolean

            If analysis is disabled

            +
            game_id: number

            The game ID

            +
            handicap: null | number

            The game handicap

            +
            height: number

            Board height

            +
            invite_only: boolean

            If the game is only joinable by invitation

            +
            komi: null | number

            Komi

            +
            max_rank: number

            Maximum rank allowed to accept the game

            +
            min_rank: number

            Minimum rank allowed to accept the game

            +
            name: string

            Game name

            +
            professional: boolean

            If they are a professional player

            +
            ranked: boolean

            If the game is ranked

            +
            ranking: number

            Their ranking *

            +
            rengo: boolean

            If it's a rengo game

            +
            rengo_auto_start: boolean

            If the rengo game will automatically start

            +
            rengo_black_team: number[]

            Player ids of the players on the Black team

            +
            rengo_casual_mode: boolean

            If the game is a casual rengo game

            +
            rengo_nominees: number[]

            Player ids of people that have been nominated to play

            +
            rengo_participants: number[]

            All player ids involved in the game

            +
            rengo_white_team: number[]

            Player ids of the players on the White team

            +
            rules: string

            Rules being used

            +
            time_control: string

            Time control system type

            +
            time_control_parameters: JGOFTimeControl

            Time control parameters

            +
            time_per_move: number

            Average time per move

            +
            user_id: number

            User id of the player who is looking for a game

            +
            username: string

            Username of the player looking for the game

            +
            uuid: string

            A UUID for the invitation

            +
            width: number

            Board width

            +
            \ No newline at end of file diff --git a/docs/interfaces/protocol.SeekgraphDeleteMessage.html b/docs/interfaces/protocol.SeekgraphDeleteMessage.html index f69b8a5c..4ff60237 100644 --- a/docs/interfaces/protocol.SeekgraphDeleteMessage.html +++ b/docs/interfaces/protocol.SeekgraphDeleteMessage.html @@ -1,5 +1,5 @@ -SeekgraphDeleteMessage | goban

            Interface SeekgraphDeleteMessage

            interface SeekgraphDeleteMessage {
                challenge_id: number;
                delete: true;
            }

            Properties

            challenge_id +SeekgraphDeleteMessage | goban

            Interface SeekgraphDeleteMessage

            interface SeekgraphDeleteMessage {
                challenge_id: number;
                delete: true;
            }

            Properties

            Properties

            challenge_id: number

            The ID of the challenge

            -
            delete: true

            The entry should be deleted if this field exists and is true

            -
            \ No newline at end of file +
            delete: true

            The entry should be deleted if this field exists and is true

            +
            \ No newline at end of file diff --git a/docs/interfaces/protocol.SeekgraphStartedMessage.html b/docs/interfaces/protocol.SeekgraphStartedMessage.html index 6e54d048..29e18b11 100644 --- a/docs/interfaces/protocol.SeekgraphStartedMessage.html +++ b/docs/interfaces/protocol.SeekgraphStartedMessage.html @@ -1,4 +1,4 @@ -SeekgraphStartedMessage | goban

            Interface SeekgraphStartedMessage

            interface SeekgraphStartedMessage {
                black: User;
                challenge_id: number;
                creator: number;
                game_id: number;
                game_started?: true;
                rengo?: true;
                rengo_auto_start?: boolean;
                rengo_black_team?: number[];
                rengo_casual_mode?: boolean;
                rengo_white_team?: number[];
                time_control: string;
                time_control_parameters: JGOFTimeControl;
                white: User;
            }

            Properties

            black +SeekgraphStartedMessage | goban

            Interface SeekgraphStartedMessage

            interface SeekgraphStartedMessage {
                black: User;
                challenge_id: number;
                creator: number;
                game_id: number;
                game_started?: true;
                rengo?: true;
                rengo_auto_start?: boolean;
                rengo_black_team?: number[];
                rengo_casual_mode?: boolean;
                rengo_white_team?: number[];
                time_control: string;
                time_control_parameters: JGOFTimeControl;
                white: User;
            }

            Properties

            black: User

            Black player

            -
            challenge_id: number

            The ID of the challenge

            -
            creator: number

            Player ID of the creator

            -
            game_id: number

            The game id

            -
            game_started?: true

            If exists and is true, the game has been started and the entry should be removed from the seek graph

            -
            rengo?: true

            Rengo game if true

            -
            rengo_auto_start?: boolean

            Whether the rengo game with automatically start

            -
            rengo_black_team?: number[]

            Player ids of the players on the Black team

            -
            rengo_casual_mode?: boolean

            Wether it's a Casual mode rengo game

            -
            rengo_white_team?: number[]

            Player ids of the players on the White team

            -
            time_control: string

            Time control system

            -
            time_control_parameters: JGOFTimeControl

            Time control parameters

            -
            white: User

            White player

            -
            \ No newline at end of file +
            challenge_id: number

            The ID of the challenge

            +
            creator: number

            Player ID of the creator

            +
            game_id: number

            The game id

            +
            game_started?: true

            If exists and is true, the game has been started and the entry should be removed from the seek graph

            +
            rengo?: true

            Rengo game if true

            +
            rengo_auto_start?: boolean

            Whether the rengo game with automatically start

            +
            rengo_black_team?: number[]

            Player ids of the players on the Black team

            +
            rengo_casual_mode?: boolean

            Wether it's a Casual mode rengo game

            +
            rengo_white_team?: number[]

            Player ids of the players on the White team

            +
            time_control: string

            Time control system

            +
            time_control_parameters: JGOFTimeControl

            Time control parameters

            +
            white: User

            White player

            +
            \ No newline at end of file diff --git a/docs/interfaces/protocol.ServerToClient.html b/docs/interfaces/protocol.ServerToClient.html index 04585b53..8caa0c90 100644 --- a/docs/interfaces/protocol.ServerToClient.html +++ b/docs/interfaces/protocol.ServerToClient.html @@ -1,5 +1,5 @@ ServerToClient | goban

            Interface ServerToClient

            interface ServerToClient {
                ERROR: ((data) => void);
                HUP: (() => void);
                active-bots: ((data) => void);
                active_game: ((data) => void);
                automatch/cancel: ((data) => void);
                automatch/entry: ((data) => void);
                automatch/start: ((data) => void);
                chat-join: ((data) => void);
                chat-message: ((data) => void);
                chat-message-removed: ((data) => void);
                chat-part: ((data) => void);
                chat-topic: ((data) => void);
                chat-update-user: ((data) => void);
                game/:id/auto_resign: ((data) => void);
                game/:id/chat: ((data) => void);
                game/:id/chat/remove: ((data) => void);
                game/:id/clear_auto_resign: ((data) => void);
                game/:id/clock: ((data) => void);
                game/:id/conditional_moves: ((data) => void);
                game/:id/error: ((data) => void);
                game/:id/gamedata: ((data) => void);
                game/:id/latency: ((data) => void);
                game/:id/phase: ((data) => void);
                game/:id/removed_stones: ((data) => void);
                game/:id/removed_stones_accepted: ((data) => void);
                game/:id/reset-chats: (() => void);
                game/:id/stalling_score_estimate: ((data?) => void);
                game/:id/undo_accepted: ((data) => void);
                game/:id/undo_canceled: ((data) => void);
                game/:id/undo_requested: ((data) => void);
                gamelist-count: ((data) => void);
                gamelist-count-:channel: ((data) => void);
                hostinfo: ((data) => void);
                incident-report: ((data) => void);
                itc: ((data) => void);
                net/pong: ((data) => void);
                notification: ((data) => void);
                private-message: ((data) => void);
                private-superchat: ((data) => void);
                remote_storage/sync_complete: (() => void);
                remote_storage/update: ((data) => void);
                review/:id/full_state: ((data) => void);
                review/:id/r: ((data) => void);
                score-estimator-enabled-state: ((data) => void);
                seekgraph/global: ((messages) => void);
                ui-push: ((data) => void);
                user/jwt: ((jwt) => void);
                user/state: ((data) => void);
                user/update: ((user) => void);
                [k: `gamelist-count-${string}`]: ServerToClient["gamelist-count-:channel"];
            }

            Hierarchy (view full)

            Indexable

            [k: `gamelist-count-${string}`]: ServerToClient["gamelist-count-:channel"]

            A move was made on a game

            -

            Properties

            Properties

            ERROR HUP active-bots active_game @@ -51,16 +51,16 @@

            Properties

            ERROR: ((data) => void)

            An error occurred, the message string should be displayed to the user. For a list of errcode's used, see https://github.com/online-go/online-go.com/blob/devel/src/components/Errcode/Errcode.tsx

            -

            Type declaration

              • (data): void
              • Parameters

                • data: string | {
                      errcode: string;
                  }

                Returns void

            HUP: (() => void)

            The client should reload

            -

            Type declaration

              • (): void
              • Returns void

            active-bots: ((data) => void)

            Updates the list of bots that are connected and ready to the server

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      [id: number]: User;
                  }

                Returns void

            active_game: ((data) => void)

            Message to inform the client of an active game, or a change to an existing game

            -

            Type declaration

            automatch/cancel: ((data) => void)

            An automatch request was canceled

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      uuid: string;
                  }
                  • uuid: string

                Returns void

            automatch/entry: ((data) => void)

            An automatch request is active

            -

            Type declaration

            automatch/start: ((data) => void)

            An automatch request was started

            -

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      game_id: number;
                      uuid: string;
                  }
                  • game_id: number
                  • uuid: string

                Returns void

            chat-join: ((data) => void)

            User(s) joined a chat channel

            +

            Type declaration

              • (data): void
              • Parameters

                • data: string | {
                      errcode: string;
                  }

                Returns void

            HUP: (() => void)

            The client should reload

            +

            Type declaration

              • (): void
              • Returns void

            active-bots: ((data) => void)

            Updates the list of bots that are connected and ready to the server

            +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      [id: number]: User;
                  }

                Returns void

            active_game: ((data) => void)

            Message to inform the client of an active game, or a change to an existing game

            +

            Type declaration

            automatch/cancel: ((data) => void)

            An automatch request was canceled

            +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      uuid: string;
                  }
                  • uuid: string

                Returns void

            automatch/entry: ((data) => void)

            An automatch request is active

            +

            Type declaration

            automatch/start: ((data) => void)

            An automatch request was started

            +

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      game_id: number;
                      uuid: string;
                  }
                  • game_id: number
                  • uuid: string

                Returns void

            chat-join: ((data) => void)

            User(s) joined a chat channel

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: string;
                      users: User[];
                  }
                  • channel: string

                    The channel

                  • users: User[]

                    List of users that joined

                    -

                Returns void

            chat-message: ((data) => void)

            Chat message was received

            +

            Returns void

            chat-message: ((data) => void)

            Chat message was received

            Type declaration

              • (data): void
              • Parameters

                • data: {
                      channel: string;
                      country?: string;
                      id: number;
                      message: {
                          i?: string;
                          m: string;
                          t: number;
                      };
                      professional: boolean;
                      ranking: number;
                      system?: true;
                      system_message_type?: "flood";
                      ui_class: string;
                      username: string;
                  }
                  • channel: string

                    The channel

                  • Optional country?: string

                    Country the user is from

                  • id: number

                    User id of the sender

                    @@ -73,14 +73,14 @@
                  • Optional system?: true

                    Whether it's a system message or not

                  • Optional system_message_type?: "flood"
                  • ui_class: string

                    UI class of the sender

                  • username: string

                    Username of the sender

                    -

                Returns void

            chat-message-removed: ((data) => void)

            A chat message should be removed from the display

            +

            Returns void

            chat-message-removed: ((data) => void)

            A chat message should be removed from the display

            Type declaration

            chat-part: ((data) => void)

            User left a chat channel

            +

            Returns void

            chat-part: ((data) => void)

            User left a chat channel

            Type declaration

            chat-topic: ((data) => void)

            Channel topic was updated

            +

            Returns void

            chat-topic: ((data) => void)

            Channel topic was updated

            Type declaration

            chat-update-user: ((data) => void)

            A user's profile was updated

            +

            Returns void

            chat-update-user: ((data) => void)

            A user's profile was updated

            Type declaration

            game/:id/auto_resign: ((data) => void)

            Informs the client the player is scheduled to resign if not cleared

            +

            Returns void

            game/:id/auto_resign: ((data) => void)

            Informs the client the player is scheduled to resign if not cleared

            Type declaration

            game/:id/chat: ((data) => void)

            A game chat message

            -

            Type declaration

            game/:id/chat/remove: ((data) => void)

            Game chat lines should be removed

            +

            Returns void

            game/:id/chat: ((data) => void)

            A game chat message

            +

            Type declaration

            game/:id/chat/remove: ((data) => void)

            Game chat lines should be removed

            Type declaration

            game/:id/clear_auto_resign: ((data) => void)

            The auto resign for the given player has been cleared

            +

            Returns void

            game/:id/clear_auto_resign: ((data) => void)

            The auto resign for the given player has been cleared

            Type declaration

            game/:id/clock: ((data) => void)

            Game clock update

            -

            Type declaration

            game/:id/conditional_moves: ((data) => void)

            Update the conditional moves currently active

            +

            Returns void

            game/:id/clock: ((data) => void)

            Game clock update

            +

            Type declaration

            game/:id/conditional_moves: ((data) => void)

            Update the conditional moves currently active

            Type declaration

            game/:id/error: ((data) => void)

            Error that should be displayed to the user

            -

            Type declaration

            game/:id/gamedata: ((data) => void)

            Update the entire game state

            -

            Type declaration

            game/:id/latency: ((data) => void)

            Update latency information for a player

            +

            Returns void

            game/:id/error: ((data) => void)

            Error that should be displayed to the user

            +

            Type declaration

            game/:id/gamedata: ((data) => void)

            Update the entire game state

            +

            Type declaration

            game/:id/latency: ((data) => void)

            Update latency information for a player

            Type declaration

            game/:id/phase: ((data) => void)

            The phase has changed for the game

            -

            Type declaration

            game/:id/removed_stones: ((data) => void)

            Update the state of the stone removal phase

            -

            Type declaration

            game/:id/removed_stones_accepted: ((data) => void)

            The stone removal phase has been completed, this is the final state and +

            Returns void

            game/:id/phase: ((data) => void)

            The phase has changed for the game

            +

            Type declaration

            game/:id/removed_stones: ((data) => void)

            Update the state of the stone removal phase

            +

            Type declaration

            game/:id/removed_stones_accepted: ((data) => void)

            The stone removal phase has been completed, this is the final state and indicates a phase change to the given phase (should always be "finished")

            Type declaration

            game/:id/reset-chats: (() => void)

            The chat log should be reset.

            -

            Type declaration

            game/:id/stalling_score_estimate: ((data?) => void)

            A score estimation result has been broadcast, this is used for avoiding game stalling

            -

            Type declaration

            game/:id/undo_accepted: ((data) => void)

            Undo move has been accepted, the parameter is the new move number

            -

            Type declaration

            game/:id/undo_canceled: ((data) => void)

            Undo request has been canceled, the parameter is the move number of the original request

            -

            Type declaration

            game/:id/undo_requested: ((data) => void)

            Undo request has been requested, the parameter is the move number that we want to go back to

            -

            Type declaration

            gamelist-count: ((data) => void)

            Update number of live and correspondence games are currently being +

            Returns void

            game/:id/reset-chats: (() => void)

            The chat log should be reset.

            +

            Type declaration

            game/:id/stalling_score_estimate: ((data?) => void)

            A score estimation result has been broadcast, this is used for avoiding game stalling

            +

            Type declaration

            game/:id/undo_accepted: ((data) => void)

            Undo move has been accepted, the parameter is the new move number

            +

            Type declaration

            game/:id/undo_canceled: ((data) => void)

            Undo request has been canceled, the parameter is the move number of the original request

            +

            Type declaration

            game/:id/undo_requested: ((data) => void)

            Undo request has been requested, the parameter is the move number that we want to go back to

            +

            Type declaration

            gamelist-count: ((data) => void)

            Update number of live and correspondence games are currently being played

            Type declaration

            gamelist-count-:channel: ((data) => void)

            Update number of live and correspondence games are currently being +

            Returns void

            gamelist-count-:channel: ((data) => void)

            Update number of live and correspondence games are currently being played in a particular channel

            Type declaration

            hostinfo: ((data) => void)

            General host information for the termination server you +

            Returns void

            hostinfo: ((data) => void)

            General host information for the termination server you are connected to. This is a response to the hostinfo client message.

            Type declaration

            incident-report: ((data) => void)

            Incident report update

            -

            Type declaration

            itc: ((data) => void)

            "Inter Tab Communication" message. This is a client utility to enable +

            Returns void

            incident-report: ((data) => void)

            Incident report update

            +

            Type declaration

            itc: ((data) => void)

            "Inter Tab Communication" message. This is a client utility to enable relaying of messages between devices - the event and data are application defined, the server blindly relays to all connected devices for the sending user. Note this is relayed to all devices regardless @@ -163,17 +163,17 @@ the web client sending this will arrive on an android and ios instance)

            Type declaration

            net/pong: ((data) => void)

            Pong response from a ping

            +

            Returns void

            net/pong: ((data) => void)

            Pong response from a ping

            Type declaration

            notification: ((data) => void)

            A notification that should be displayed to the user +

            Returns void

            notification: ((data) => void)

            A notification that should be displayed to the user These are not strongly modeled, see https://github.com/online-go/online-go.com/blob/devel/src/components/Notifications/Notifications.tsx as a reference for what types there are and what data they contain

            Type declaration

            private-message: ((data) => void)

            A private message was received

            +

            Returns void

            private-message: ((data) => void)

            A private message was received

            Type declaration

            private-superchat: ((data) => void)

            Notify the client that a private message "super chat" has started. A +

            Returns void

            private-superchat: ((data) => void)

            Notify the client that a private message "super chat" has started. A super chat is an undismissable chat sent by a moderator. It should take all focus and not let the client do anything until the conversation is resolved (the enable flag is set to false)

            @@ -194,30 +194,30 @@
          • moderator_username: string

            The moderator username contacting the player

          • player_id: number

            Your id

          • player_username: string

            Your username

            -
          • Returns void

            remote_storage/sync_complete: (() => void)

            Notification that the server has completed sending all remote storage +

            Returns void

            remote_storage/sync_complete: (() => void)

            Notification that the server has completed sending all remote storage data and the client should now be up to date.

            -

            Type declaration

            remote_storage/update: ((data) => void)

            Updates a key value pair

            +

            Type declaration

            remote_storage/update: ((data) => void)

            Updates a key value pair

            Type declaration

            review/:id/full_state: ((data) => void)

            Replay of the entire full state of the review

            -

            Type declaration

            review/:id/r: ((data) => void)

            An incremental modification to the review stream

            -

            Type declaration

            score-estimator-enabled-state: ((data) => void)

            Notifies the client whether the the client shares an IP with one of the +

            Returns void

            review/:id/full_state: ((data) => void)

            Replay of the entire full state of the review

            +

            Type declaration

            review/:id/r: ((data) => void)

            An incremental modification to the review stream

            +

            Type declaration

            score-estimator-enabled-state: ((data) => void)

            Notifies the client whether the the client shares an IP with one of the players of the game. This is used to disable the score estimator in anonymous browsing windows for players of a game when the score estimator is disabled for the game.

            Type declaration

            seekgraph/global: ((messages) => void)

            Type declaration

            ui-push: ((data) => void)

            A UI Push notification. The event and data are not well defined here, +

            Returns void

            seekgraph/global: ((messages) => void)

            Type declaration

            ui-push: ((data) => void)

            A UI Push notification. The event and data are not well defined here, they come as a result to subscribing to ui push channels with ui-pushes/subscribe.

            Type declaration

            user/jwt: ((jwt) => void)

            Update the user's JWT token

            -

            Type declaration

            user/state: ((data) => void)

            Updates whether a user is online or not. Subscribe to these updates for +

            Returns void

            user/jwt: ((jwt) => void)

            Update the user's JWT token

            +

            Type declaration

            user/state: ((data) => void)

            Updates whether a user is online or not. Subscribe to these updates for particular users using the user/monitor command.

            -

            Type declaration

            user/update: ((user) => void)

            Update user information. For other players, this has the standard User +

            Type declaration

            user/update: ((user) => void)

            Update user information. For other players, this has the standard User fields, when this is the current user, it can have additional fields that are found in the ui/config

            -

            Type declaration

            \ No newline at end of file +

            Type declaration

            \ No newline at end of file diff --git a/docs/interfaces/protocol.StallingScoreEstimate.html b/docs/interfaces/protocol.StallingScoreEstimate.html index 55116fe3..4f384fbb 100644 --- a/docs/interfaces/protocol.StallingScoreEstimate.html +++ b/docs/interfaces/protocol.StallingScoreEstimate.html @@ -1,8 +1,8 @@ -StallingScoreEstimate | goban

            Interface StallingScoreEstimate

            interface StallingScoreEstimate {
                game_id: number;
                move_number: number;
                ownership: any[];
                predicted_winner: "black" | "white";
                removed: string;
                score: number;
                win_rate: number;
            }

            Properties

            game_id +StallingScoreEstimate | goban

            Interface StallingScoreEstimate

            interface StallingScoreEstimate {
                game_id: number;
                move_number: number;
                ownership: any[];
                predicted_winner: "black" | "white";
                removed: string;
                score: number;
                win_rate: number;
            }

            Properties

            game_id: number
            move_number: number
            ownership: any[]
            predicted_winner: "black" | "white"
            removed: string
            score: number
            win_rate: number
            \ No newline at end of file +

            Properties

            game_id: number
            move_number: number
            ownership: any[]
            predicted_winner: "black" | "white"
            removed: string
            score: number
            win_rate: number
            \ No newline at end of file diff --git a/docs/interfaces/protocol.User.html b/docs/interfaces/protocol.User.html index 11964386..5bc2e64c 100644 --- a/docs/interfaces/protocol.User.html +++ b/docs/interfaces/protocol.User.html @@ -1,8 +1,8 @@ -User | goban

            Interface User

            interface User {
                country?: string;
                id: number;
                professional?: boolean;
                ranking?: number;
                ratings?: {
                    [speed_size: string]: Glicko2;
                };
                ui_class?: string;
                username: string;
            }

            Properties

            country? +User | goban

            Interface User

            interface User {
                country?: string;
                id: number;
                professional?: boolean;
                ranking?: number;
                ratings?: {
                    [speed_size: string]: Glicko2;
                };
                ui_class?: string;
                username: string;
            }

            Properties

            country?: string
            id: number
            professional?: boolean
            ranking?: number
            ratings?: {
                [speed_size: string]: Glicko2;
            }

            Type declaration

            ui_class?: string
            username: string
            \ No newline at end of file +

            Properties

            country?: string
            id: number
            professional?: boolean
            ranking?: number
            ratings?: {
                [speed_size: string]: Glicko2;
            }

            Type declaration

            ui_class?: string
            username: string
            \ No newline at end of file diff --git a/docs/interfaces/translate.GobanStrings.html b/docs/interfaces/translate.GobanStrings.html index 6197990d..8ff3a8b1 100644 --- a/docs/interfaces/translate.GobanStrings.html +++ b/docs/interfaces/translate.GobanStrings.html @@ -1,4 +1,4 @@ -GobanStrings | goban

            Interface GobanStrings

            interface GobanStrings {
                %sd: string;
                %sh: string;
                %sm: string;
                %ss: string;
                %swk: string;
                A stone has already been placed here: string;
                Anime: string;
                Black: string;
                Black Walnut: string;
                Black to move: string;
                Book: string;
                Bright Kaya: string;
                Control passed to %s: string;
                Custom: string;
                Enter the label you want to add to the board: string;
                Error: string;
                Error submitting move: string;
                Game Finished: string;
                Glass: string;
                Granite: string;
                HNG: string;
                HNG Night: string;
                Illegal Ko Move: string;
                Illegal board repetition: string;
                Kaya: string;
                Loading...: string;
                Move is suicidal: string;
                Night: string;
                Night Play: string;
                Persimmon: string;
                Plain: string;
                Processing...: string;
                Red Oak: string;
                Review: string;
                Self-capture is not allowed: string;
                Shell: string;
                Slate: string;
                Stone Removal: string;
                Stone Removal Phase: string;
                Submitting...: string;
                Synchronization error, reloading: string;
                The game would be repeating with that move, please play somewhere else first: string;
                White: string;
                White to move: string;
                Worn Glass: string;
                Your move: string;
                Your move - opponent passed: string;
            }

            Properties

            %sd +GobanStrings | goban

            Interface GobanStrings

            interface GobanStrings {
                %sd: string;
                %sh: string;
                %sm: string;
                %ss: string;
                %swk: string;
                A stone has already been placed here: string;
                Anime: string;
                Black: string;
                Black Walnut: string;
                Black to move: string;
                Book: string;
                Bright Kaya: string;
                Control passed to %s: string;
                Custom: string;
                Enter the label you want to add to the board: string;
                Error: string;
                Error submitting move: string;
                Game Finished: string;
                Glass: string;
                Granite: string;
                HNG: string;
                HNG Night: string;
                Illegal Ko Move: string;
                Illegal board repetition: string;
                Kaya: string;
                Loading...: string;
                Move is suicidal: string;
                Night: string;
                Night Play: string;
                Persimmon: string;
                Plain: string;
                Processing...: string;
                Red Oak: string;
                Review: string;
                Self-capture is not allowed: string;
                Shell: string;
                Slate: string;
                Stone Removal: string;
                Stone Removal Phase: string;
                Submitting...: string;
                Synchronization error, reloading: string;
                The game would be repeating with that move, please play somewhere else first: string;
                White: string;
                White to move: string;
                Worn Glass: string;
                Your move: string;
                Your move - opponent passed: string;
            }

            Properties

            %sd: string
            %sh: string
            %sm: string
            %ss: string
            %swk: string
            A stone has already been placed here: string
            Anime: string
            Black: string
            Black Walnut: string
            Black to move: string
            Book: string
            Bright Kaya: string
            Control passed to %s: string
            Custom: string
            Enter the label you want to add to the board: string
            Error: string
            Error submitting move: string
            Game Finished: string
            Glass: string
            Granite: string
            HNG: string
            HNG Night: string
            Illegal Ko Move: string
            Illegal board repetition: string
            Kaya: string
            Loading...: string
            Move is suicidal: string
            Night: string
            Night Play: string
            Persimmon: string
            Plain: string
            Processing...: string
            Red Oak: string
            Review: string
            Self-capture is not allowed: string
            Shell: string
            Slate: string
            Stone Removal: string
            Stone Removal Phase: string
            Submitting...: string
            Synchronization error, reloading: string
            The game would be repeating with that move, please play somewhere else first: string
            White: string
            White to move: string
            Worn Glass: string
            Your move: string
            Your move - opponent passed: string
            \ No newline at end of file +

            Properties

            %sd: string
            %sh: string
            %sm: string
            %ss: string
            %swk: string
            A stone has already been placed here: string
            Anime: string
            Black: string
            Black Walnut: string
            Black to move: string
            Book: string
            Bright Kaya: string
            Control passed to %s: string
            Custom: string
            Enter the label you want to add to the board: string
            Error: string
            Error submitting move: string
            Game Finished: string
            Glass: string
            Granite: string
            HNG: string
            HNG Night: string
            Illegal Ko Move: string
            Illegal board repetition: string
            Kaya: string
            Loading...: string
            Move is suicidal: string
            Night: string
            Night Play: string
            Persimmon: string
            Plain: string
            Processing...: string
            Red Oak: string
            Review: string
            Self-capture is not allowed: string
            Shell: string
            Slate: string
            Stone Removal: string
            Stone Removal Phase: string
            Submitting...: string
            Synchronization error, reloading: string
            The game would be repeating with that move, please play somewhere else first: string
            White: string
            White to move: string
            Worn Glass: string
            Your move: string
            Your move - opponent passed: string
            \ No newline at end of file diff --git a/docs/modules/protocol.html b/docs/modules/protocol.html index b05426f9..a0723bd8 100644 --- a/docs/modules/protocol.html +++ b/docs/modules/protocol.html @@ -59,7 +59,7 @@ for backwards compatibility.

            -

            Index

            Enumerations

            Index

            Enumerations

            Interfaces

            AIServerToClient AutomatchPreferences ClientToAIServer diff --git a/docs/modules/translate.html b/docs/modules/translate.html index 4d57e642..04d1a45c 100644 --- a/docs/modules/translate.html +++ b/docs/modules/translate.html @@ -1,4 +1,4 @@ -translate | goban

            Namespace translate

            Index

            Interfaces

            GobanStrings +translate | goban

            Namespace translate

            Index

            Interfaces

            Functions

            _ interpolate setGobanTranslations diff --git a/docs/types/AdHocPackedMove.html b/docs/types/AdHocPackedMove.html index 6205aae3..ef4160fa 100644 --- a/docs/types/AdHocPackedMove.html +++ b/docs/types/AdHocPackedMove.html @@ -1 +1 @@ -AdHocPackedMove | goban

            Type alias AdHocPackedMove

            AdHocPackedMove: [number, number, number?, JGOFNumericPlayerColor?, {
                [index: string]: any;
            }?]
            \ No newline at end of file +AdHocPackedMove | goban

            Type alias AdHocPackedMove

            AdHocPackedMove: [number, number, number?, JGOFNumericPlayerColor?, {
                [index: string]: any;
            }?]
            \ No newline at end of file diff --git a/docs/types/AnalysisSubTool.html b/docs/types/AnalysisSubTool.html index 833c08f3..837002b4 100644 --- a/docs/types/AnalysisSubTool.html +++ b/docs/types/AnalysisSubTool.html @@ -1 +1 @@ -AnalysisSubTool | goban

            Type alias AnalysisSubTool

            AnalysisSubTool: "black" | "white" | "alternate" | "letters" | "numbers" | string
            \ No newline at end of file +AnalysisSubTool | goban

            Type alias AnalysisSubTool

            AnalysisSubTool: "black" | "white" | "alternate" | "letters" | "numbers" | string
            \ No newline at end of file diff --git a/docs/types/AnalysisTool.html b/docs/types/AnalysisTool.html index 16e94941..ed99992a 100644 --- a/docs/types/AnalysisTool.html +++ b/docs/types/AnalysisTool.html @@ -1 +1 @@ -AnalysisTool | goban

            Type alias AnalysisTool

            AnalysisTool: "stone" | "draw" | "label" | "score" | "removal"
            \ No newline at end of file +AnalysisTool | goban

            Type alias AnalysisTool

            AnalysisTool: "stone" | "draw" | "label" | "score" | "removal"
            \ No newline at end of file diff --git a/docs/types/BoardTransform.html b/docs/types/BoardTransform.html index c3c36b44..c0f0bf04 100644 --- a/docs/types/BoardTransform.html +++ b/docs/types/BoardTransform.html @@ -9,4 +9,4 @@

            The "easy to understand" part is that the id can be compared visually to the board position

            The downside is that the id string can be moderately long for boards with lots of stones

            -

            Type declaration

              • (x, y): {
                    x: number;
                    y: number;
                }
              • Parameters

                • x: number
                • y: number

                Returns {
                    x: number;
                    y: number;
                }

                • x: number
                • y: number
            \ No newline at end of file +

            Type declaration

              • (x, y): {
                    x: number;
                    y: number;
                }
              • Parameters

                • x: number
                • y: number

                Returns {
                    x: number;
                    y: number;
                }

                • x: number
                • y: number
            \ No newline at end of file diff --git a/docs/types/ConditionalMoveResponse.html b/docs/types/ConditionalMoveResponse.html index 7ea0fb9a..0a674374 100644 --- a/docs/types/ConditionalMoveResponse.html +++ b/docs/types/ConditionalMoveResponse.html @@ -1,3 +1,3 @@ ConditionalMoveResponse | goban

            Type alias ConditionalMoveResponse

            ConditionalMoveResponse: [string | null, ConditionalMoveResponseTree]

            A branch in the conditional move tree, consists of the response move and the sub-tree of the next possible moves

            -
            \ No newline at end of file +
            \ No newline at end of file diff --git a/docs/types/DataArgument.html b/docs/types/DataArgument.html index 5cea9a9b..79f5867b 100644 --- a/docs/types/DataArgument.html +++ b/docs/types/DataArgument.html @@ -1 +1 @@ -DataArgument | goban

            Type alias DataArgument<Entry>

            DataArgument<Entry>: Entry extends ((...args) => void)
                ? A[0]
                : never

            Type Parameters

            • Entry
            \ No newline at end of file +DataArgument | goban

            Type alias DataArgument<Entry>

            DataArgument<Entry>: Entry extends ((...args) => void)
                ? A[0]
                : never

            Type Parameters

            • Entry
            \ No newline at end of file diff --git a/docs/types/GobanChatLog.html b/docs/types/GobanChatLog.html index a5aa70d8..b4586b9d 100644 --- a/docs/types/GobanChatLog.html +++ b/docs/types/GobanChatLog.html @@ -1 +1 @@ -GobanChatLog | goban

            Type alias GobanChatLog

            GobanChatLog: GameChatLine[]
            \ No newline at end of file +GobanChatLog | goban

            Type alias GobanChatLog

            GobanChatLog: GameChatLine[]
            \ No newline at end of file diff --git a/docs/types/GobanEnginePhase.html b/docs/types/GobanEnginePhase.html index 5afbb89e..5f20b6fb 100644 --- a/docs/types/GobanEnginePhase.html +++ b/docs/types/GobanEnginePhase.html @@ -1 +1 @@ -GobanEnginePhase | goban

            Type alias GobanEnginePhase

            GobanEnginePhase: "play" | "stone removal" | "finished"
            \ No newline at end of file +GobanEnginePhase | goban

            Type alias GobanEnginePhase

            GobanEnginePhase: "play" | "stone removal" | "finished"
            \ No newline at end of file diff --git a/docs/types/GobanEngineRules.html b/docs/types/GobanEngineRules.html index ca40a394..5c8b09a5 100644 --- a/docs/types/GobanEngineRules.html +++ b/docs/types/GobanEngineRules.html @@ -1 +1 @@ -GobanEngineRules | goban

            Type alias GobanEngineRules

            GobanEngineRules: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz"
            \ No newline at end of file +GobanEngineRules | goban

            Type alias GobanEngineRules

            GobanEngineRules: "chinese" | "aga" | "japanese" | "korean" | "ing" | "nz"
            \ No newline at end of file diff --git a/docs/types/GobanEngineSuperKoAlgorithm.html b/docs/types/GobanEngineSuperKoAlgorithm.html index 3599d8ff..3e8c5141 100644 --- a/docs/types/GobanEngineSuperKoAlgorithm.html +++ b/docs/types/GobanEngineSuperKoAlgorithm.html @@ -1 +1 @@ -GobanEngineSuperKoAlgorithm | goban

            Type alias GobanEngineSuperKoAlgorithm

            GobanEngineSuperKoAlgorithm: "psk" | "csk" | "ssk" | "noresult" | "ing"
            \ No newline at end of file +GobanEngineSuperKoAlgorithm | goban

            Type alias GobanEngineSuperKoAlgorithm

            GobanEngineSuperKoAlgorithm: "psk" | "csk" | "ssk" | "noresult" | "ing"
            \ No newline at end of file diff --git a/docs/types/GobanErrorMessageId.html b/docs/types/GobanErrorMessageId.html index b2a35c63..1409b8c8 100644 --- a/docs/types/GobanErrorMessageId.html +++ b/docs/types/GobanErrorMessageId.html @@ -1 +1 @@ -GobanErrorMessageId | goban

            Type alias GobanErrorMessageId

            \ No newline at end of file +GobanErrorMessageId | goban

            Type alias GobanErrorMessageId

            \ No newline at end of file diff --git a/docs/types/GobanErrorMessageObject.html b/docs/types/GobanErrorMessageObject.html index 5ba941a4..5baf30e8 100644 --- a/docs/types/GobanErrorMessageObject.html +++ b/docs/types/GobanErrorMessageObject.html @@ -1 +1 @@ -GobanErrorMessageObject | goban

            Type alias GobanErrorMessageObject

            \ No newline at end of file +GobanErrorMessageObject | goban

            Type alias GobanErrorMessageObject

            \ No newline at end of file diff --git a/docs/types/GobanIOErrorMessageId.html b/docs/types/GobanIOErrorMessageId.html index 886964ee..208d0abb 100644 --- a/docs/types/GobanIOErrorMessageId.html +++ b/docs/types/GobanIOErrorMessageId.html @@ -1 +1 @@ -GobanIOErrorMessageId | goban

            Type alias GobanIOErrorMessageId

            GobanIOErrorMessageId: "failed_to_load_sgf"
            \ No newline at end of file +GobanIOErrorMessageId | goban

            Type alias GobanIOErrorMessageId

            GobanIOErrorMessageId: "failed_to_load_sgf"
            \ No newline at end of file diff --git a/docs/types/GobanModes.html b/docs/types/GobanModes.html index bb6efeca..4b88a9fd 100644 --- a/docs/types/GobanModes.html +++ b/docs/types/GobanModes.html @@ -1 +1 @@ -GobanModes | goban

            Type alias GobanModes

            GobanModes: "play" | "puzzle" | "score estimation" | "analyze" | "conditional"
            \ No newline at end of file +GobanModes | goban

            Type alias GobanModes

            GobanModes: "play" | "puzzle" | "score estimation" | "analyze" | "conditional"
            \ No newline at end of file diff --git a/docs/types/GobanMoveErrorMessageId.html b/docs/types/GobanMoveErrorMessageId.html index 623aa240..d5a59f3c 100644 --- a/docs/types/GobanMoveErrorMessageId.html +++ b/docs/types/GobanMoveErrorMessageId.html @@ -1 +1 @@ -GobanMoveErrorMessageId | goban

            Type alias GobanMoveErrorMessageId

            GobanMoveErrorMessageId: "stone_already_placed_here" | "illegal_self_capture" | "illegal_ko_move" | "illegal_board_repetition" | "move_error"
            \ No newline at end of file +GobanMoveErrorMessageId | goban

            Type alias GobanMoveErrorMessageId

            GobanMoveErrorMessageId: "stone_already_placed_here" | "illegal_self_capture" | "illegal_ko_move" | "illegal_board_repetition" | "move_error"
            \ No newline at end of file diff --git a/docs/types/GobanMovesArray.html b/docs/types/GobanMovesArray.html index 802d91ef..24629c14 100644 --- a/docs/types/GobanMovesArray.html +++ b/docs/types/GobanMovesArray.html @@ -1 +1 @@ -GobanMovesArray | goban

            Type alias GobanMovesArray

            GobanMovesArray: AdHocPackedMove[] | JGOFMove[]
            \ No newline at end of file +GobanMovesArray | goban

            Type alias GobanMovesArray

            GobanMovesArray: AdHocPackedMove[] | JGOFMove[]
            \ No newline at end of file diff --git a/docs/types/GobanRenderer.html b/docs/types/GobanRenderer.html index e2378862..30eb9930 100644 --- a/docs/types/GobanRenderer.html +++ b/docs/types/GobanRenderer.html @@ -1 +1 @@ -GobanRenderer | goban

            Type alias GobanRenderer

            GobanRenderer: GobanCanvas | SVGRenderer
            \ No newline at end of file +GobanRenderer | goban

            Type alias GobanRenderer

            GobanRenderer: GobanCanvas | SVGRenderer
            \ No newline at end of file diff --git a/docs/types/GobanRendererConfig.html b/docs/types/GobanRendererConfig.html index 3a194da8..a81495fb 100644 --- a/docs/types/GobanRendererConfig.html +++ b/docs/types/GobanRendererConfig.html @@ -1 +1 @@ -GobanRendererConfig | goban

            Type alias GobanRendererConfig

            \ No newline at end of file +GobanRendererConfig | goban

            Type alias GobanRendererConfig

            \ No newline at end of file diff --git a/docs/types/JGOFTimeControl.html b/docs/types/JGOFTimeControl.html index 64c6b6a1..4e8467ab 100644 --- a/docs/types/JGOFTimeControl.html +++ b/docs/types/JGOFTimeControl.html @@ -1 +1 @@ -JGOFTimeControl | goban
            \ No newline at end of file +JGOFTimeControl | goban
            \ No newline at end of file diff --git a/docs/types/JGOFTimeControlSpeed.html b/docs/types/JGOFTimeControlSpeed.html index 3cae8bfa..0925c4a9 100644 --- a/docs/types/JGOFTimeControlSpeed.html +++ b/docs/types/JGOFTimeControlSpeed.html @@ -1 +1 @@ -JGOFTimeControlSpeed | goban

            Type alias JGOFTimeControlSpeed

            JGOFTimeControlSpeed: "blitz" | "live" | "correspondence"
            \ No newline at end of file +JGOFTimeControlSpeed | goban

            Type alias JGOFTimeControlSpeed

            JGOFTimeControlSpeed: "blitz" | "live" | "correspondence"
            \ No newline at end of file diff --git a/docs/types/JGOFTimeControlSystem.html b/docs/types/JGOFTimeControlSystem.html index 30545c41..28795f33 100644 --- a/docs/types/JGOFTimeControlSystem.html +++ b/docs/types/JGOFTimeControlSystem.html @@ -1 +1 @@ -JGOFTimeControlSystem | goban

            Type alias JGOFTimeControlSystem

            JGOFTimeControlSystem: "fischer" | "byoyomi" | "canadian" | "simple" | "absolute" | "none"
            \ No newline at end of file +JGOFTimeControlSystem | goban

            Type alias JGOFTimeControlSystem

            JGOFTimeControlSystem: "fischer" | "byoyomi" | "canadian" | "simple" | "absolute" | "none"
            \ No newline at end of file diff --git a/docs/types/LabelPosition.html b/docs/types/LabelPosition.html index c595d315..50dd2502 100644 --- a/docs/types/LabelPosition.html +++ b/docs/types/LabelPosition.html @@ -1 +1 @@ -LabelPosition | goban

            Type alias LabelPosition

            LabelPosition: "all" | "none" | "top-left" | "top-right" | "bottom-right" | "bottom-left"
            \ No newline at end of file +LabelPosition | goban

            Type alias LabelPosition

            LabelPosition: "all" | "none" | "top-left" | "top-right" | "bottom-right" | "bottom-left"
            \ No newline at end of file diff --git a/docs/types/Matrix.html b/docs/types/Matrix.html index 153e6cc6..fef3b60e 100644 --- a/docs/types/Matrix.html +++ b/docs/types/Matrix.html @@ -1 +1 @@ -Matrix | goban

            Type alias Matrix<T>

            Matrix<T>: T[][]

            Type Parameters

            • T
            \ No newline at end of file +Matrix | goban

            Type alias Matrix<T>

            Matrix<T>: T[][]

            Type Parameters

            • T
            \ No newline at end of file diff --git a/docs/types/MoveTreePenMarks.html b/docs/types/MoveTreePenMarks.html index 2bb6f06d..3da1c9ce 100644 --- a/docs/types/MoveTreePenMarks.html +++ b/docs/types/MoveTreePenMarks.html @@ -1 +1 @@ -MoveTreePenMarks | goban

            Type alias MoveTreePenMarks

            MoveTreePenMarks: {
                color: string;
                points: number[];
            }[]

            Type declaration

            • color: string
            • points: number[]
            \ No newline at end of file +MoveTreePenMarks | goban

            Type alias MoveTreePenMarks

            MoveTreePenMarks: {
                color: string;
                points: number[];
            }[]

            Type declaration

            • color: string
            • points: number[]
            \ No newline at end of file diff --git a/docs/types/NumberMatrix.html b/docs/types/NumberMatrix.html index 022c0463..b47f05ee 100644 --- a/docs/types/NumberMatrix.html +++ b/docs/types/NumberMatrix.html @@ -1 +1 @@ -NumberMatrix | goban

            Type alias NumberMatrix

            NumberMatrix: Matrix<number>
            \ No newline at end of file +NumberMatrix | goban

            Type alias NumberMatrix

            NumberMatrix: Matrix<number>
            \ No newline at end of file diff --git a/docs/types/PlayerColor.html b/docs/types/PlayerColor.html index 4a915f00..9b5fc13e 100644 --- a/docs/types/PlayerColor.html +++ b/docs/types/PlayerColor.html @@ -1 +1 @@ -PlayerColor | goban

            Type alias PlayerColor

            PlayerColor: "black" | "white"
            \ No newline at end of file +PlayerColor | goban

            Type alias PlayerColor

            PlayerColor: "black" | "white"
            \ No newline at end of file diff --git a/docs/types/ProtocolResponseType.html b/docs/types/ProtocolResponseType.html index de18f813..31684985 100644 --- a/docs/types/ProtocolResponseType.html +++ b/docs/types/ProtocolResponseType.html @@ -1 +1 @@ -ProtocolResponseType | goban

            Type alias ProtocolResponseType<Entry>

            ProtocolResponseType<Entry>: Entry extends ((...args) => infer R)
                ? R
                : never

            Type Parameters

            • Entry
            \ No newline at end of file +ProtocolResponseType | goban

            Type alias ProtocolResponseType<Entry>

            ProtocolResponseType<Entry>: Entry extends ((...args) => infer R)
                ? R
                : never

            Type Parameters

            • Entry
            \ No newline at end of file diff --git a/docs/types/PuzzleOpponentMoveMode.html b/docs/types/PuzzleOpponentMoveMode.html index ea802c5d..4a7877a6 100644 --- a/docs/types/PuzzleOpponentMoveMode.html +++ b/docs/types/PuzzleOpponentMoveMode.html @@ -1 +1 @@ -PuzzleOpponentMoveMode | goban

            Type alias PuzzleOpponentMoveMode

            PuzzleOpponentMoveMode: "manual" | "automatic"
            \ No newline at end of file +PuzzleOpponentMoveMode | goban

            Type alias PuzzleOpponentMoveMode

            PuzzleOpponentMoveMode: "manual" | "automatic"
            \ No newline at end of file diff --git a/docs/types/PuzzlePlacementSetting.html b/docs/types/PuzzlePlacementSetting.html index 1764a757..5a1d18be 100644 --- a/docs/types/PuzzlePlacementSetting.html +++ b/docs/types/PuzzlePlacementSetting.html @@ -1 +1 @@ -PuzzlePlacementSetting | goban

            Type alias PuzzlePlacementSetting

            PuzzlePlacementSetting: {
                mode: "play";
            } | {
                color: JGOFNumericPlayerColor;
                mode: "setup";
            } | {
                color: 0;
                mode: "place";
            }

            Type declaration

            • mode: "play"

            Type declaration

            Type declaration

            • color: 0
            • mode: "place"
            \ No newline at end of file +PuzzlePlacementSetting | goban

            Type alias PuzzlePlacementSetting

            PuzzlePlacementSetting: {
                mode: "play";
            } | {
                color: JGOFNumericPlayerColor;
                mode: "setup";
            } | {
                color: 0;
                mode: "place";
            }

            Type declaration

            • mode: "play"

            Type declaration

            Type declaration

            • color: 0
            • mode: "place"
            \ No newline at end of file diff --git a/docs/types/PuzzlePlayerMoveMode.html b/docs/types/PuzzlePlayerMoveMode.html index 7e6dbde9..426fad5f 100644 --- a/docs/types/PuzzlePlayerMoveMode.html +++ b/docs/types/PuzzlePlayerMoveMode.html @@ -1 +1 @@ -PuzzlePlayerMoveMode | goban

            Type alias PuzzlePlayerMoveMode

            PuzzlePlayerMoveMode: "free" | "fixed"
            \ No newline at end of file +PuzzlePlayerMoveMode | goban

            Type alias PuzzlePlayerMoveMode

            PuzzlePlayerMoveMode: "free" | "fixed"
            \ No newline at end of file diff --git a/docs/types/RawStoneString.html b/docs/types/RawStoneString.html index 284d7d3b..dc197afb 100644 --- a/docs/types/RawStoneString.html +++ b/docs/types/RawStoneString.html @@ -1,2 +1,2 @@ RawStoneString | goban

            Type alias RawStoneString

            RawStoneString: JGOFIntersection[]

            A raw stone string is simply an array of intersections

            -
            \ No newline at end of file +
            \ No newline at end of file diff --git a/docs/types/StringMatrix.html b/docs/types/StringMatrix.html index a108aebf..4359cd49 100644 --- a/docs/types/StringMatrix.html +++ b/docs/types/StringMatrix.html @@ -1 +1 @@ -StringMatrix | goban

            Type alias StringMatrix

            StringMatrix: Matrix<string>
            \ No newline at end of file +StringMatrix | goban

            Type alias StringMatrix

            StringMatrix: Matrix<string>
            \ No newline at end of file diff --git a/docs/types/_internal_.ClockTime.html b/docs/types/_internal_.ClockTime.html index d14198d3..65f92302 100644 --- a/docs/types/_internal_.ClockTime.html +++ b/docs/types/_internal_.ClockTime.html @@ -1 +1 @@ -ClockTime | goban
            \ No newline at end of file +ClockTime | goban
            \ No newline at end of file diff --git a/docs/types/_internal_.DebugOutput.html b/docs/types/_internal_.DebugOutput.html index 385d5b14..fe419a7f 100644 --- a/docs/types/_internal_.DebugOutput.html +++ b/docs/types/_internal_.DebugOutput.html @@ -1,2 +1,2 @@ DebugOutput | goban

            Type alias DebugOutput

            DebugOutput: string

            -
            \ No newline at end of file +
            \ No newline at end of file diff --git a/docs/types/_internal_.LocalEstimator.html b/docs/types/_internal_.LocalEstimator.html index 5ea38329..3d747cee 100644 --- a/docs/types/_internal_.LocalEstimator.html +++ b/docs/types/_internal_.LocalEstimator.html @@ -5,4 +5,4 @@
          • trials: number

            number of playouts. Not applicable to all estimators, but higher generally means higher accuracy and higher compute cost

          • tolerance: number

            (0.0-1.0) confidence required to mark an intersection not neutral.

            -
          • Returns NumberMatrix

            \ No newline at end of file +

            Returns NumberMatrix

            \ No newline at end of file diff --git a/docs/types/_internal_.MessageID.html b/docs/types/_internal_.MessageID.html index 4aab6d03..a1b339e7 100644 --- a/docs/types/_internal_.MessageID.html +++ b/docs/types/_internal_.MessageID.html @@ -1 +1 @@ -MessageID | goban

            Type alias MessageID

            MessageID: GobanMoveErrorMessageId | "error" | "error_submitting_move" | "loading" | "processing" | "self_capture_not_allowed" | "server_message" | "illegal_ko_move" | "synchronization_error"
            \ No newline at end of file +MessageID | goban

            Type alias MessageID

            MessageID: GobanMoveErrorMessageId | "error" | "error_submitting_move" | "loading" | "processing" | "self_capture_not_allowed" | "server_message" | "illegal_ko_move" | "synchronization_error"
            \ No newline at end of file diff --git a/docs/types/_internal_.NoneClock.html b/docs/types/_internal_.NoneClock.html index cc9e1f88..a5c18036 100644 --- a/docs/types/_internal_.NoneClock.html +++ b/docs/types/_internal_.NoneClock.html @@ -1 +1 @@ -NoneClock | goban

            Type alias NoneClock

            NoneClock: undefined
            \ No newline at end of file +NoneClock | goban

            Type alias NoneClock

            NoneClock: undefined
            \ No newline at end of file diff --git a/docs/types/_internal_.SimpleClock.html b/docs/types/_internal_.SimpleClock.html index 9345d4a6..d19544dd 100644 --- a/docs/types/_internal_.SimpleClock.html +++ b/docs/types/_internal_.SimpleClock.html @@ -1 +1 @@ -SimpleClock | goban

            Type alias SimpleClock

            SimpleClock: number
            \ No newline at end of file +SimpleClock | goban

            Type alias SimpleClock

            SimpleClock: number
            \ No newline at end of file diff --git a/docs/types/_internal_.StoneType.html b/docs/types/_internal_.StoneType.html index 4415b4b4..451f47c8 100644 --- a/docs/types/_internal_.StoneType.html +++ b/docs/types/_internal_.StoneType.html @@ -1 +1 @@ -StoneType | goban

            Type alias StoneType

            StoneType: {
                shadow: HTMLCanvasElement;
                stone: HTMLCanvasElement;
            }

            Type declaration

            • shadow: HTMLCanvasElement
            • stone: HTMLCanvasElement
            \ No newline at end of file +StoneType | goban

            Type alias StoneType

            StoneType: {
                shadow: HTMLCanvasElement;
                stone: HTMLCanvasElement;
            }

            Type declaration

            • shadow: HTMLCanvasElement
            • stone: HTMLCanvasElement
            \ No newline at end of file diff --git a/docs/types/_internal_.StoneTypeArray.html b/docs/types/_internal_.StoneTypeArray.html index 7a17f459..360bb368 100644 --- a/docs/types/_internal_.StoneTypeArray.html +++ b/docs/types/_internal_.StoneTypeArray.html @@ -1 +1 @@ -StoneTypeArray | goban

            Type alias StoneTypeArray

            StoneTypeArray: StoneType[]
            \ No newline at end of file +StoneTypeArray | goban

            Type alias StoneTypeArray

            StoneTypeArray: StoneType[]
            \ No newline at end of file diff --git a/docs/types/protocol.AutomatchCondition.html b/docs/types/protocol.AutomatchCondition.html index a1fac42f..871a478c 100644 --- a/docs/types/protocol.AutomatchCondition.html +++ b/docs/types/protocol.AutomatchCondition.html @@ -1 +1 @@ -AutomatchCondition | goban

            Type alias AutomatchCondition

            AutomatchCondition: "required" | "preferred" | "no-preference"
            \ No newline at end of file +AutomatchCondition | goban

            Type alias AutomatchCondition

            AutomatchCondition: "required" | "preferred" | "no-preference"
            \ No newline at end of file diff --git a/docs/types/protocol.RuleSet.html b/docs/types/protocol.RuleSet.html index 16912cc9..5713d3d2 100644 --- a/docs/types/protocol.RuleSet.html +++ b/docs/types/protocol.RuleSet.html @@ -1 +1 @@ -RuleSet | goban

            Type alias RuleSet

            RuleSet: "japanese" | "chinese" | "aga" | "korean" | "nz" | "ing"
            \ No newline at end of file +RuleSet | goban

            Type alias RuleSet

            RuleSet: "japanese" | "chinese" | "aga" | "korean" | "nz" | "ing"
            \ No newline at end of file diff --git a/docs/types/protocol.Size.html b/docs/types/protocol.Size.html index 6984d4b5..df443ba9 100644 --- a/docs/types/protocol.Size.html +++ b/docs/types/protocol.Size.html @@ -1 +1 @@ -Size | goban

            Type alias Size

            Size: "9x9" | "13x13" | "19x19"
            \ No newline at end of file +Size | goban

            Type alias Size

            Size: "9x9" | "13x13" | "19x19"
            \ No newline at end of file diff --git a/docs/types/protocol.Speed.html b/docs/types/protocol.Speed.html index 6cb9656d..95253a46 100644 --- a/docs/types/protocol.Speed.html +++ b/docs/types/protocol.Speed.html @@ -1 +1 @@ -Speed | goban

            Type alias Speed

            Speed: "blitz" | "live" | "correspondence"
            \ No newline at end of file +Speed | goban

            Type alias Speed

            Speed: "blitz" | "live" | "correspondence"
            \ No newline at end of file diff --git a/docs/variables/AUTOSCORE_TOLERANCE.html b/docs/variables/AUTOSCORE_TOLERANCE.html index 5528ecf3..ed738170 100644 --- a/docs/variables/AUTOSCORE_TOLERANCE.html +++ b/docs/variables/AUTOSCORE_TOLERANCE.html @@ -1 +1 @@ -AUTOSCORE_TOLERANCE | goban

            Variable AUTOSCORE_TOLERANCEConst

            AUTOSCORE_TOLERANCE: 0.1 = 0.1
            \ No newline at end of file +AUTOSCORE_TOLERANCE | goban

            Variable AUTOSCORE_TOLERANCEConst

            AUTOSCORE_TOLERANCE: 0.1 = 0.1
            \ No newline at end of file diff --git a/docs/variables/AUTOSCORE_TRIALS.html b/docs/variables/AUTOSCORE_TRIALS.html index 02f917b7..ada3776c 100644 --- a/docs/variables/AUTOSCORE_TRIALS.html +++ b/docs/variables/AUTOSCORE_TRIALS.html @@ -1 +1 @@ -AUTOSCORE_TRIALS | goban

            Variable AUTOSCORE_TRIALSConst

            AUTOSCORE_TRIALS: 1000 = 1000
            \ No newline at end of file +AUTOSCORE_TRIALS | goban

            Variable AUTOSCORE_TRIALSConst

            AUTOSCORE_TRIALS: 1000 = 1000
            \ No newline at end of file diff --git a/docs/variables/GOBAN_FONT.html b/docs/variables/GOBAN_FONT.html index 13eebfe6..0d3fdec3 100644 --- a/docs/variables/GOBAN_FONT.html +++ b/docs/variables/GOBAN_FONT.html @@ -1 +1 @@ -GOBAN_FONT | goban

            Variable GOBAN_FONTConst

            GOBAN_FONT: "Verdana,Arial,sans-serif" = "Verdana,Arial,sans-serif"
            \ No newline at end of file +GOBAN_FONT | goban

            Variable GOBAN_FONTConst

            GOBAN_FONT: "Verdana,Arial,sans-serif" = "Verdana,Arial,sans-serif"
            \ No newline at end of file diff --git a/docs/variables/MARK_TYPES.html b/docs/variables/MARK_TYPES.html index 2558eccd..8cf4b314 100644 --- a/docs/variables/MARK_TYPES.html +++ b/docs/variables/MARK_TYPES.html @@ -1 +1 @@ -MARK_TYPES | goban

            Variable MARK_TYPESConst

            MARK_TYPES: (keyof MarkInterface)[] = ...
            \ No newline at end of file +MARK_TYPES | goban

            Variable MARK_TYPESConst

            MARK_TYPES: (keyof MarkInterface)[] = ...
            \ No newline at end of file diff --git a/docs/variables/SCORE_ESTIMATION_TOLERANCE.html b/docs/variables/SCORE_ESTIMATION_TOLERANCE.html index 74456a55..4d2cbb26 100644 --- a/docs/variables/SCORE_ESTIMATION_TOLERANCE.html +++ b/docs/variables/SCORE_ESTIMATION_TOLERANCE.html @@ -1 +1 @@ -SCORE_ESTIMATION_TOLERANCE | goban

            Variable SCORE_ESTIMATION_TOLERANCEConst

            SCORE_ESTIMATION_TOLERANCE: 0.3 = 0.3
            \ No newline at end of file +SCORE_ESTIMATION_TOLERANCE | goban

            Variable SCORE_ESTIMATION_TOLERANCEConst

            SCORE_ESTIMATION_TOLERANCE: 0.3 = 0.3
            \ No newline at end of file diff --git a/docs/variables/SCORE_ESTIMATION_TRIALS.html b/docs/variables/SCORE_ESTIMATION_TRIALS.html index 856e013e..1b5af957 100644 --- a/docs/variables/SCORE_ESTIMATION_TRIALS.html +++ b/docs/variables/SCORE_ESTIMATION_TRIALS.html @@ -1 +1 @@ -SCORE_ESTIMATION_TRIALS | goban

            Variable SCORE_ESTIMATION_TRIALSConst

            SCORE_ESTIMATION_TRIALS: 1000 = 1000
            \ No newline at end of file +SCORE_ESTIMATION_TRIALS | goban

            Variable SCORE_ESTIMATION_TRIALSConst

            SCORE_ESTIMATION_TRIALS: 1000 = 1000
            \ No newline at end of file diff --git a/docs/variables/THEMES.html b/docs/variables/THEMES.html index 181bbd6b..81436b8c 100644 --- a/docs/variables/THEMES.html +++ b/docs/variables/THEMES.html @@ -1 +1 @@ -THEMES | goban

            Variable THEMESConst

            THEMES: ThemesInterface = ...
            \ No newline at end of file +THEMES | goban

            Variable THEMESConst

            THEMES: ThemesInterface = ...
            \ No newline at end of file diff --git a/docs/variables/THEMES_SORTED.html b/docs/variables/THEMES_SORTED.html index 8bd05e53..144a93cf 100644 --- a/docs/variables/THEMES_SORTED.html +++ b/docs/variables/THEMES_SORTED.html @@ -1 +1 @@ -THEMES_SORTED | goban

            Variable THEMES_SORTEDConst

            THEMES_SORTED: {
                black: GobanTheme[];
                board: GobanTheme[];
                white: GobanTheme[];
                [key: string]: GobanTheme[];
            } = ...

            Type declaration

            \ No newline at end of file +THEMES_SORTED | goban

            Variable THEMES_SORTEDConst

            THEMES_SORTED: {
                black: GobanTheme[];
                board: GobanTheme[];
                white: GobanTheme[];
                [key: string]: GobanTheme[];
            } = ...

            Type declaration

            \ No newline at end of file diff --git a/docs/variables/callbacks.html b/docs/variables/callbacks.html index df411b87..3f940b45 100644 --- a/docs/variables/callbacks.html +++ b/docs/variables/callbacks.html @@ -1 +1 @@ -callbacks | goban

            Variable callbacksConst

            callbacks: GobanCallbacks = ...
            \ No newline at end of file +callbacks | goban

            Variable callbacksConst

            callbacks: GobanCallbacks = ...
            \ No newline at end of file diff --git a/docs/variables/remote_estimate_ownership.html b/docs/variables/remote_estimate_ownership.html index 375f0461..7acc9172 100644 --- a/docs/variables/remote_estimate_ownership.html +++ b/docs/variables/remote_estimate_ownership.html @@ -1 +1 @@ -remote_estimate_ownership | goban

            Variable remote_estimate_ownership

            remote_estimate_ownership: ((req) => Promise<ScoreEstimateResponse>) | undefined

            Type declaration

            \ No newline at end of file +remote_estimate_ownership | goban

            Variable remote_estimate_ownership

            remote_estimate_ownership: ((req) => Promise<ScoreEstimateResponse>) | undefined

            Type declaration

            \ No newline at end of file