From 41a73f432d40b4b875c8d00935bd3b6b3a91c0ad Mon Sep 17 00:00:00 2001 From: Pavel Pachkovsky Date: Fri, 28 Apr 2023 10:40:55 -0600 Subject: [PATCH] add input_value_deprecation flag --- app/assets/javascripts/graphiql/rails/graphiql_show.js | 7 ++++++- app/views/graphiql/rails/editors/show.html.erb | 3 ++- lib/graphiql/rails/config.rb | 5 +++-- readme.md | 2 +- 4 files changed, 12 insertions(+), 5 deletions(-) diff --git a/app/assets/javascripts/graphiql/rails/graphiql_show.js b/app/assets/javascripts/graphiql/rails/graphiql_show.js index 6b5129c..8092db3 100644 --- a/app/assets/javascripts/graphiql/rails/graphiql_show.js +++ b/app/assets/javascripts/graphiql/rails/graphiql_show.js @@ -77,7 +77,12 @@ document.addEventListener("DOMContentLoaded", function(event) { // Render into the body. - var elementProps = { fetcher: graphQLFetcher, defaultQuery: defaultQuery, headerEditorEnabled: graphiqlContainer.dataset.headerEditorEnabled === 'true' }; + var elementProps = { + fetcher: graphQLFetcher, + defaultQuery: defaultQuery, + headerEditorEnabled: graphiqlContainer.dataset.headerEditorEnabled === 'true', + inputValueDeprecation: graphiqlContainer.dataset.inputValueDeprecation === 'true', + }; Object.assign(elementProps, { query: parameters.query, variables: parameters.variables }) if (queryParams === 'true') { diff --git a/app/views/graphiql/rails/editors/show.html.erb b/app/views/graphiql/rails/editors/show.html.erb index 1a39642..c2fdf94 100644 --- a/app/views/graphiql/rails/editors/show.html.erb +++ b/app/views/graphiql/rails/editors/show.html.erb @@ -13,7 +13,8 @@ logo: GraphiQL::Rails.config.logo, headers: GraphiQL::Rails.config.resolve_headers(self), query_params: GraphiQL::Rails.config.query_params, - header_editor_enabled: GraphiQL::Rails.config.header_editor_enabled + header_editor_enabled: GraphiQL::Rails.config.header_editor_enabled, + input_value_deprecation: GraphiQL::Rails.config.input_value_deprecation } %> diff --git a/lib/graphiql/rails/config.rb b/lib/graphiql/rails/config.rb index f25b70f..e4c9581 100644 --- a/lib/graphiql/rails/config.rb +++ b/lib/graphiql/rails/config.rb @@ -7,7 +7,7 @@ class Config # @return [Hash Proc>] Keys are headers to include in GraphQL requests, values are `->(view_context) { ... }` procs to determin values attr_accessor :headers - attr_accessor :query_params, :initial_query, :csrf, :title, :logo, :header_editor_enabled + attr_accessor :query_params, :initial_query, :csrf, :title, :logo, :header_editor_enabled, :input_value_deprecation DEFAULT_HEADERS = { 'Content-Type' => ->(_) { 'application/json' }, @@ -17,13 +17,14 @@ class Config "X-CSRF-Token" => -> (view_context) { view_context.form_authenticity_token } } - def initialize(query_params: false, initial_query: nil, title: nil, logo: nil, csrf: true, headers: DEFAULT_HEADERS) + def initialize(query_params: false, initial_query: nil, title: nil, logo: nil, csrf: true, headers: DEFAULT_HEADERS, input_value_deprecation: false) @query_params = query_params @headers = headers.dup @initial_query = initial_query @title = title @logo = logo @csrf = csrf + @input_value_deprecation = input_value_deprecation end # Call defined procs, add CSRF token if specified diff --git a/readme.md b/readme.md index 961edba..738e32f 100644 --- a/readme.md +++ b/readme.md @@ -63,7 +63,7 @@ You can override `GraphiQL::Rails.config` values in an initializer (eg, `config/ - `csrf` (boolean, default `true`): include `X-CSRF-Token` in GraphiQL's HTTP requests - `header_editor_enabled` (boolean, default `false`): if provided, the header editor will be rendered - `headers` (hash, `String => Proc`): procs to fetch header values for GraphiQL's HTTP requests, in the form `(view_context) -> { ... }`. For example: - +- `input_value_deprecation` (boolean, default `false`): if provided, the deprecated arguments will be rendered ```ruby GraphiQL::Rails.config.headers['Authorization'] = -> (context) { "bearer #{context.cookies['_graphql_token']}" }