import { queryParams, type RouteQueryOptions, type RouteDefinition, type RouteFormDefinition, applyUrlDefaults, validateParameters } from './../../../../../wayfinder'
/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
const index73a8e8c582c88c585c07959a90a79a61 = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: index73a8e8c582c88c585c07959a90a79a61.url(options),
    method: 'get',
})

index73a8e8c582c88c585c07959a90a79a61.definition = {
    methods: ["get","head"],
    url: '/admin/roles',
} satisfies RouteDefinition<["get","head"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
index73a8e8c582c88c585c07959a90a79a61.url = (options?: RouteQueryOptions) => {
    return index73a8e8c582c88c585c07959a90a79a61.definition.url + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
index73a8e8c582c88c585c07959a90a79a61.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: index73a8e8c582c88c585c07959a90a79a61.url(options),
    method: 'get',
})
/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
index73a8e8c582c88c585c07959a90a79a61.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
    url: index73a8e8c582c88c585c07959a90a79a61.url(options),
    method: 'head',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
    const index73a8e8c582c88c585c07959a90a79a61Form = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
        action: index73a8e8c582c88c585c07959a90a79a61.url(options),
        method: 'get',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
        index73a8e8c582c88c585c07959a90a79a61Form.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: index73a8e8c582c88c585c07959a90a79a61.url(options),
            method: 'get',
        })
            /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/roles'
 */
        index73a8e8c582c88c585c07959a90a79a61Form.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: index73a8e8c582c88c585c07959a90a79a61.url({
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'HEAD',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'get',
        })
    
    index73a8e8c582c88c585c07959a90a79a61.form = index73a8e8c582c88c585c07959a90a79a61Form
    /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
const index8821b87d4e16e4da08dca6b82a54a681 = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: index8821b87d4e16e4da08dca6b82a54a681.url(options),
    method: 'get',
})

index8821b87d4e16e4da08dca6b82a54a681.definition = {
    methods: ["get","head"],
    url: '/admin/role',
} satisfies RouteDefinition<["get","head"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
index8821b87d4e16e4da08dca6b82a54a681.url = (options?: RouteQueryOptions) => {
    return index8821b87d4e16e4da08dca6b82a54a681.definition.url + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
index8821b87d4e16e4da08dca6b82a54a681.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: index8821b87d4e16e4da08dca6b82a54a681.url(options),
    method: 'get',
})
/**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
index8821b87d4e16e4da08dca6b82a54a681.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
    url: index8821b87d4e16e4da08dca6b82a54a681.url(options),
    method: 'head',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
    const index8821b87d4e16e4da08dca6b82a54a681Form = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
        action: index8821b87d4e16e4da08dca6b82a54a681.url(options),
        method: 'get',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
        index8821b87d4e16e4da08dca6b82a54a681Form.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: index8821b87d4e16e4da08dca6b82a54a681.url(options),
            method: 'get',
        })
            /**
* @see \App\Http\Controllers\Admin\RoleController::index
 * @see app/Http/Controllers/Admin/RoleController.php:28
 * @route '/admin/role'
 */
        index8821b87d4e16e4da08dca6b82a54a681Form.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: index8821b87d4e16e4da08dca6b82a54a681.url({
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'HEAD',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'get',
        })
    
    index8821b87d4e16e4da08dca6b82a54a681.form = index8821b87d4e16e4da08dca6b82a54a681Form

export const index = {
    '/admin/roles': index73a8e8c582c88c585c07959a90a79a61,
    '/admin/role': index8821b87d4e16e4da08dca6b82a54a681,
}

/**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
export const create = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: create.url(options),
    method: 'get',
})

create.definition = {
    methods: ["get","head"],
    url: '/admin/roles/create',
} satisfies RouteDefinition<["get","head"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
create.url = (options?: RouteQueryOptions) => {
    return create.definition.url + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
create.get = (options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: create.url(options),
    method: 'get',
})
/**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
create.head = (options?: RouteQueryOptions): RouteDefinition<'head'> => ({
    url: create.url(options),
    method: 'head',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
    const createForm = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
        action: create.url(options),
        method: 'get',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
        createForm.get = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: create.url(options),
            method: 'get',
        })
            /**
* @see \App\Http\Controllers\Admin\RoleController::create
 * @see app/Http/Controllers/Admin/RoleController.php:45
 * @route '/admin/roles/create'
 */
        createForm.head = (options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: create.url({
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'HEAD',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'get',
        })
    
    create.form = createForm
/**
* @see \App\Http\Controllers\Admin\RoleController::store
 * @see app/Http/Controllers/Admin/RoleController.php:58
 * @route '/admin/roles'
 */
export const store = (options?: RouteQueryOptions): RouteDefinition<'post'> => ({
    url: store.url(options),
    method: 'post',
})

store.definition = {
    methods: ["post"],
    url: '/admin/roles',
} satisfies RouteDefinition<["post"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::store
 * @see app/Http/Controllers/Admin/RoleController.php:58
 * @route '/admin/roles'
 */
store.url = (options?: RouteQueryOptions) => {
    return store.definition.url + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::store
 * @see app/Http/Controllers/Admin/RoleController.php:58
 * @route '/admin/roles'
 */
store.post = (options?: RouteQueryOptions): RouteDefinition<'post'> => ({
    url: store.url(options),
    method: 'post',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::store
 * @see app/Http/Controllers/Admin/RoleController.php:58
 * @route '/admin/roles'
 */
    const storeForm = (options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
        action: store.url(options),
        method: 'post',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::store
 * @see app/Http/Controllers/Admin/RoleController.php:58
 * @route '/admin/roles'
 */
        storeForm.post = (options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
            action: store.url(options),
            method: 'post',
        })
    
    store.form = storeForm
/**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
export const show = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: show.url(args, options),
    method: 'get',
})

show.definition = {
    methods: ["get","head"],
    url: '/admin/roles/{role}',
} satisfies RouteDefinition<["get","head"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
show.url = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions) => {
    if (typeof args === 'string' || typeof args === 'number') {
        args = { role: args }
    }

    
    if (Array.isArray(args)) {
        args = {
                    role: args[0],
                }
    }

    args = applyUrlDefaults(args)

    const parsedArgs = {
                        role: args.role,
                }

    return show.definition.url
            .replace('{role}', parsedArgs.role.toString())
            .replace(/\/+$/, '') + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
show.get = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: show.url(args, options),
    method: 'get',
})
/**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
show.head = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'head'> => ({
    url: show.url(args, options),
    method: 'head',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
    const showForm = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
        action: show.url(args, options),
        method: 'get',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
        showForm.get = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: show.url(args, options),
            method: 'get',
        })
            /**
* @see \App\Http\Controllers\Admin\RoleController::show
 * @see app/Http/Controllers/Admin/RoleController.php:84
 * @route '/admin/roles/{role}'
 */
        showForm.head = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: show.url(args, {
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'HEAD',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'get',
        })
    
    show.form = showForm
/**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
export const edit = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: edit.url(args, options),
    method: 'get',
})

edit.definition = {
    methods: ["get","head"],
    url: '/admin/roles/{role}/edit',
} satisfies RouteDefinition<["get","head"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
edit.url = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions) => {
    if (typeof args === 'string' || typeof args === 'number') {
        args = { role: args }
    }

    
    if (Array.isArray(args)) {
        args = {
                    role: args[0],
                }
    }

    args = applyUrlDefaults(args)

    const parsedArgs = {
                        role: args.role,
                }

    return edit.definition.url
            .replace('{role}', parsedArgs.role.toString())
            .replace(/\/+$/, '') + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
edit.get = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'get'> => ({
    url: edit.url(args, options),
    method: 'get',
})
/**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
edit.head = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'head'> => ({
    url: edit.url(args, options),
    method: 'head',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
    const editForm = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
        action: edit.url(args, options),
        method: 'get',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
        editForm.get = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: edit.url(args, options),
            method: 'get',
        })
            /**
* @see \App\Http\Controllers\Admin\RoleController::edit
 * @see app/Http/Controllers/Admin/RoleController.php:101
 * @route '/admin/roles/{role}/edit'
 */
        editForm.head = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'get'> => ({
            action: edit.url(args, {
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'HEAD',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'get',
        })
    
    edit.form = editForm
/**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
export const update = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'put'> => ({
    url: update.url(args, options),
    method: 'put',
})

update.definition = {
    methods: ["put","patch"],
    url: '/admin/roles/{role}',
} satisfies RouteDefinition<["put","patch"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
update.url = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions) => {
    if (typeof args === 'string' || typeof args === 'number') {
        args = { role: args }
    }

    
    if (Array.isArray(args)) {
        args = {
                    role: args[0],
                }
    }

    args = applyUrlDefaults(args)

    const parsedArgs = {
                        role: args.role,
                }

    return update.definition.url
            .replace('{role}', parsedArgs.role.toString())
            .replace(/\/+$/, '') + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
update.put = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'put'> => ({
    url: update.url(args, options),
    method: 'put',
})
/**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
update.patch = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'patch'> => ({
    url: update.url(args, options),
    method: 'patch',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
    const updateForm = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
        action: update.url(args, {
                    [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                        _method: 'PUT',
                        ...(options?.query ?? options?.mergeQuery ?? {}),
                    }
                }),
        method: 'post',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
        updateForm.put = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
            action: update.url(args, {
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'PUT',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'post',
        })
            /**
* @see \App\Http\Controllers\Admin\RoleController::update
 * @see app/Http/Controllers/Admin/RoleController.php:120
 * @route '/admin/roles/{role}'
 */
        updateForm.patch = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
            action: update.url(args, {
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'PATCH',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'post',
        })
    
    update.form = updateForm
/**
* @see \App\Http\Controllers\Admin\RoleController::destroy
 * @see app/Http/Controllers/Admin/RoleController.php:148
 * @route '/admin/roles/{role}'
 */
export const destroy = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'delete'> => ({
    url: destroy.url(args, options),
    method: 'delete',
})

destroy.definition = {
    methods: ["delete"],
    url: '/admin/roles/{role}',
} satisfies RouteDefinition<["delete"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::destroy
 * @see app/Http/Controllers/Admin/RoleController.php:148
 * @route '/admin/roles/{role}'
 */
destroy.url = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions) => {
    if (typeof args === 'string' || typeof args === 'number') {
        args = { role: args }
    }

    
    if (Array.isArray(args)) {
        args = {
                    role: args[0],
                }
    }

    args = applyUrlDefaults(args)

    const parsedArgs = {
                        role: args.role,
                }

    return destroy.definition.url
            .replace('{role}', parsedArgs.role.toString())
            .replace(/\/+$/, '') + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::destroy
 * @see app/Http/Controllers/Admin/RoleController.php:148
 * @route '/admin/roles/{role}'
 */
destroy.delete = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'delete'> => ({
    url: destroy.url(args, options),
    method: 'delete',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::destroy
 * @see app/Http/Controllers/Admin/RoleController.php:148
 * @route '/admin/roles/{role}'
 */
    const destroyForm = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
        action: destroy.url(args, {
                    [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                        _method: 'DELETE',
                        ...(options?.query ?? options?.mergeQuery ?? {}),
                    }
                }),
        method: 'post',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::destroy
 * @see app/Http/Controllers/Admin/RoleController.php:148
 * @route '/admin/roles/{role}'
 */
        destroyForm.delete = (args: { role: string | number } | [role: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
            action: destroy.url(args, {
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'DELETE',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'post',
        })
    
    destroy.form = destroyForm
/**
* @see \App\Http\Controllers\Admin\RoleController::addOrUpdateInfo
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/add/update/info/{id?}'
 */
export const addOrUpdateInfo = (args?: { id?: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'post'> => ({
    url: addOrUpdateInfo.url(args, options),
    method: 'post',
})

addOrUpdateInfo.definition = {
    methods: ["post"],
    url: '/admin/role/add/update/info/{id?}',
} satisfies RouteDefinition<["post"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::addOrUpdateInfo
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/add/update/info/{id?}'
 */
addOrUpdateInfo.url = (args?: { id?: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions) => {
    if (typeof args === 'string' || typeof args === 'number') {
        args = { id: args }
    }

    
    if (Array.isArray(args)) {
        args = {
                    id: args[0],
                }
    }

    args = applyUrlDefaults(args)

    validateParameters(args, [
            "id",
        ])

    const parsedArgs = {
                        id: args?.id,
                }

    return addOrUpdateInfo.definition.url
            .replace('{id?}', parsedArgs.id?.toString() ?? '')
            .replace(/\/+$/, '') + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::addOrUpdateInfo
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/add/update/info/{id?}'
 */
addOrUpdateInfo.post = (args?: { id?: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'post'> => ({
    url: addOrUpdateInfo.url(args, options),
    method: 'post',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::addOrUpdateInfo
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/add/update/info/{id?}'
 */
    const addOrUpdateInfoForm = (args?: { id?: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
        action: addOrUpdateInfo.url(args, options),
        method: 'post',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::addOrUpdateInfo
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/add/update/info/{id?}'
 */
        addOrUpdateInfoForm.post = (args?: { id?: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
            action: addOrUpdateInfo.url(args, options),
            method: 'post',
        })
    
    addOrUpdateInfo.form = addOrUpdateInfoForm
/**
* @see \App\Http\Controllers\Admin\RoleController::dataInfoDelete
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/delete/{id}'
 */
export const dataInfoDelete = (args: { id: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'delete'> => ({
    url: dataInfoDelete.url(args, options),
    method: 'delete',
})

dataInfoDelete.definition = {
    methods: ["delete"],
    url: '/admin/role/delete/{id}',
} satisfies RouteDefinition<["delete"]>

/**
* @see \App\Http\Controllers\Admin\RoleController::dataInfoDelete
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/delete/{id}'
 */
dataInfoDelete.url = (args: { id: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions) => {
    if (typeof args === 'string' || typeof args === 'number') {
        args = { id: args }
    }

    
    if (Array.isArray(args)) {
        args = {
                    id: args[0],
                }
    }

    args = applyUrlDefaults(args)

    const parsedArgs = {
                        id: args.id,
                }

    return dataInfoDelete.definition.url
            .replace('{id}', parsedArgs.id.toString())
            .replace(/\/+$/, '') + queryParams(options)
}

/**
* @see \App\Http\Controllers\Admin\RoleController::dataInfoDelete
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/delete/{id}'
 */
dataInfoDelete.delete = (args: { id: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteDefinition<'delete'> => ({
    url: dataInfoDelete.url(args, options),
    method: 'delete',
})

    /**
* @see \App\Http\Controllers\Admin\RoleController::dataInfoDelete
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/delete/{id}'
 */
    const dataInfoDeleteForm = (args: { id: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
        action: dataInfoDelete.url(args, {
                    [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                        _method: 'DELETE',
                        ...(options?.query ?? options?.mergeQuery ?? {}),
                    }
                }),
        method: 'post',
    })

            /**
* @see \App\Http\Controllers\Admin\RoleController::dataInfoDelete
 * @see app/Http/Controllers/Admin/RoleController.php:0
 * @route '/admin/role/delete/{id}'
 */
        dataInfoDeleteForm.delete = (args: { id: string | number } | [id: string | number ] | string | number, options?: RouteQueryOptions): RouteFormDefinition<'post'> => ({
            action: dataInfoDelete.url(args, {
                        [options?.mergeQuery ? 'mergeQuery' : 'query']: {
                            _method: 'DELETE',
                            ...(options?.query ?? options?.mergeQuery ?? {}),
                        }
                    }),
            method: 'post',
        })
    
    dataInfoDelete.form = dataInfoDeleteForm
const RoleController = { index, create, store, show, edit, update, destroy, addOrUpdateInfo, dataInfoDelete }

export default RoleController