Skip to content

Commit

Permalink
feat(cat-voices): document builder editing (#1442)
Browse files Browse the repository at this point in the history
* feat(cat-voices): In-page Information Cards (#1242)

* feat: add InPageInformationCard widget and campaign information model for displaying campaign details and status updates

* feat: update InPageInformationCard to dynamically display button text based on campaign stage and add corresponding localization entries

* fix: add missing line for better formatting in InPageInformationCard widget definition

* fix: spelling

* fix: import intl

* fix: theme in tests

* fix: add campaign date formatting utility and integrate it in information cards

* refactor: improve date formatting utility and integrate localized date handling in information cards

* fix: spelling

* fix: to early check if information is DateTimeMixin

---------

Co-authored-by: Damian Moliński <[email protected]>

* chore(general): merge main into mve3 (#1282)

* Feat: update testplan template (#1243)

* chore: update testplan

* fix

* fix

* fix

* fix

* fix: testplan template (#1245)

* feat(cat-gateway): Finliaze CIP36 Endpoint Cleanup (#1241)

* fix: api endpoint draft

Signed-off-by: bkioshn <[email protected]>

* fix: api health endpoint v1

Signed-off-by: bkioshn <[email protected]>

* fix: remove bad request from errorResponses

Signed-off-by: bkioshn <[email protected]>

* fix: add bad req to get /registration

Signed-off-by: bkioshn <[email protected]>

* fix: error logging

Signed-off-by: bkioshn <[email protected]>

* fix: remove validation error

Signed-off-by: bkioshn <[email protected]>

* fix: registration get error name

Signed-off-by: bkioshn <[email protected]>

* chore:format

Signed-off-by: bkioshn <[email protected]>

* fix: get json schema from openapi spec

Signed-off-by: bkioshn <[email protected]>

* fix: move schema utils

Signed-off-by: bkioshn <[email protected]>

* fix: optional field

Signed-off-by: bkioshn <[email protected]>

* fix: config key

Signed-off-by: bkioshn <[email protected]>

* fix: cat-gateway code gen

Signed-off-by: bkioshn <[email protected]>

* fix: api name in cat-voice

Signed-off-by: bkioshn <[email protected]>

* fix: cat-voice format

Signed-off-by: bkioshn <[email protected]>

* chore: fix spacing

Signed-off-by: bkioshn <[email protected]>

* chore: fix spacing

Signed-off-by: bkioshn <[email protected]>

* chore: change tag config description

* test: add test for default validator

* fix: add spectral ruleset

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Sort the spelling words, and use latest deny.toml

* fix(cat-gateway): Fix broken pre-push justfile target

* docs(cat-gateway): cleanup

* docs(cat-gateway): Fix API Groups and document them better

* docs(cat-gateway): Add documentation to the health/inspection endpoint

* docs(cat-gateway): Add descriptions for cardano/cip36/latest_registration/stake_addr

* docs(cat-gateway): Document stake key hash and vote key endpoints for cardano

* docs(cat-gateway): add documentation to config/frontend

* docs(cat-gateway): Add api docs for frontend schema

* docs(cat-gateway): Move legacy registration endpoints into the Legacy TAG.

* docs(cat-gateway): Remaining documentable entities documented

* fix: update openapi linter

Signed-off-by: bkioshn <[email protected]>

* docs(cat-gateway): Add more constraints to parameters and json bodies

* fix: openapi lint FUNCTION name

Signed-off-by: bkioshn <[email protected]>

* fix: CIP36 example and description

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): cleanup error handling, and add a global 429 response to all endpoints.

* fix: config endpoint example, desc, and return

Signed-off-by: bkioshn <[email protected]>

* chore: remove todo

Signed-off-by: bkioshn <[email protected]>

* fix: move config object

Signed-off-by: bkioshn <[email protected]>

* fix: move cip36 object

Signed-off-by: bkioshn <[email protected]>

* docs(cat-gateway): Add missing headers to responses

* docs(cat-gateway): Cleanup the rest of the documentation in the api

* fix(cat-gateway): Fix OpenAPI linting and add autogenerated api file for dart.

* refactor(cat-gateway): Better generalize the OpenAPI simple string type creation macro.

* fix(cat-gateway): Add APIKey and CatToken auth to some endpoints.  Add 401 and 403 common responses.

* fix(cat-gateway): Add universal 422 response to all endpoints, and try and make all endpoint validation use it.

* fix: add cardano stake address type

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): stake address type

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Refactor the RBAC Token auth, so it's easier to maintain.

* fix(cat-gateway): stake address name

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Add no auth and no-auth+rbac auth schemes

* fix(cat-gateway): format + stake addr example

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): code format

* fix(cat-gateway): openapi spectral example rules

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Move legacy registration endpoint under Legacy Tag

* fix(cat-gateway): Add Auth to all endpoints

* fix(docs): Remove obsolete lint config file

* fix(cat-gateway): Make config.toml match upstream

* docs(docs): update project dictionary

* feat(cat-gateway): add target to make it quick to check openapi lints locally

* fix(cat-gateway): Remove reference to hermes

* fix(cat-gateway): Add auth to rbac endpoints

* docs(cat-gateway): Add full docs for v1/votes/plan/account-votes

* docs(cat-gateway): Add example for ip address query argument

* fix(cat-gateway): Define and abstract Ed25519 Public Keys as hex encoded parameters

* fix(cat-gateway): Make sure string api types do not directly expose the internal string

* fix(cat-gateway): Make conversion from a Ed25519 pub key hex value to a Verifyingkey infallible

* fix(cat-gateway): Fix native asset response types

* docs(cat-gateway): fix comments

* fix(cat-gateway): Autogenerate flutter files

* fix(cat-gateway): Exclude legacy endpoints from needing api examples

* fix(cat-gateway): WIP improving cip36 endpoint docs

* fix(docs): Make targets to re-check the generated schema easy.

* fix: spectral ruleset for linting query params description

* feat: parameter rule

* fix: debug function

* docs(cat-gateway): Make schema lint accept description inside a schema in a query parameter

* fix(cat-gateway): remove debug logic from api docs lint

* fix(cat-gateway): Don't put expanded program into git

* Make error response comments consistent

* test(cat-gateway): Add local operation to easily expand macros in the service code

* fix(cat-gateway): CIP36 Structured endpoint

* fix: speling

* fix(rust): cleanup/normalize nonce validation

* fix(rust): code format

* Update catalyst-gateway/bin/src/service/common/types/cardano/cip19_shelley_address.rs

Co-authored-by: bkioshn <[email protected]>

* Update catalyst-gateway/bin/src/service/common/types/cardano/cip19_shelley_address.rs

Co-authored-by: bkioshn <[email protected]>

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>

* Revert "Merge branch 'mve3' into main"

This reverts commit 01db066, reversing
changes made to 3bf0ccf.

* fix(cat-voices): equatable lint issue fix (#1280)

* fix: resolve equatable lint issue

* fix: missing override

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: Stefano Cunego <[email protected]>
Co-authored-by: Steven Johnson <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>
Co-authored-by: Oleksandr Prokhorenko <[email protected]>

* feat(cat-voices): discovery page mve3 (#1281)

* Feat: update testplan template (#1243)

* chore: update testplan

* fix

* fix

* fix

* fix

* fix: testplan template (#1245)

* feat(cat-gateway): Finliaze CIP36 Endpoint Cleanup (#1241)

* fix: api endpoint draft

Signed-off-by: bkioshn <[email protected]>

* fix: api health endpoint v1

Signed-off-by: bkioshn <[email protected]>

* fix: remove bad request from errorResponses

Signed-off-by: bkioshn <[email protected]>

* fix: add bad req to get /registration

Signed-off-by: bkioshn <[email protected]>

* fix: error logging

Signed-off-by: bkioshn <[email protected]>

* fix: remove validation error

Signed-off-by: bkioshn <[email protected]>

* fix: registration get error name

Signed-off-by: bkioshn <[email protected]>

* chore:format

Signed-off-by: bkioshn <[email protected]>

* fix: get json schema from openapi spec

Signed-off-by: bkioshn <[email protected]>

* fix: move schema utils

Signed-off-by: bkioshn <[email protected]>

* fix: optional field

Signed-off-by: bkioshn <[email protected]>

* fix: config key

Signed-off-by: bkioshn <[email protected]>

* fix: cat-gateway code gen

Signed-off-by: bkioshn <[email protected]>

* fix: api name in cat-voice

Signed-off-by: bkioshn <[email protected]>

* fix: cat-voice format

Signed-off-by: bkioshn <[email protected]>

* chore: fix spacing

Signed-off-by: bkioshn <[email protected]>

* chore: fix spacing

Signed-off-by: bkioshn <[email protected]>

* chore: change tag config description

* test: add test for default validator

* fix: add spectral ruleset

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Sort the spelling words, and use latest deny.toml

* fix(cat-gateway): Fix broken pre-push justfile target

* docs(cat-gateway): cleanup

* docs(cat-gateway): Fix API Groups and document them better

* docs(cat-gateway): Add documentation to the health/inspection endpoint

* docs(cat-gateway): Add descriptions for cardano/cip36/latest_registration/stake_addr

* docs(cat-gateway): Document stake key hash and vote key endpoints for cardano

* docs(cat-gateway): add documentation to config/frontend

* docs(cat-gateway): Add api docs for frontend schema

* docs(cat-gateway): Move legacy registration endpoints into the Legacy TAG.

* docs(cat-gateway): Remaining documentable entities documented

* fix: update openapi linter

Signed-off-by: bkioshn <[email protected]>

* docs(cat-gateway): Add more constraints to parameters and json bodies

* fix: openapi lint FUNCTION name

Signed-off-by: bkioshn <[email protected]>

* fix: CIP36 example and description

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): cleanup error handling, and add a global 429 response to all endpoints.

* fix: config endpoint example, desc, and return

Signed-off-by: bkioshn <[email protected]>

* chore: remove todo

Signed-off-by: bkioshn <[email protected]>

* fix: move config object

Signed-off-by: bkioshn <[email protected]>

* fix: move cip36 object

Signed-off-by: bkioshn <[email protected]>

* docs(cat-gateway): Add missing headers to responses

* docs(cat-gateway): Cleanup the rest of the documentation in the api

* fix(cat-gateway): Fix OpenAPI linting and add autogenerated api file for dart.

* refactor(cat-gateway): Better generalize the OpenAPI simple string type creation macro.

* fix(cat-gateway): Add APIKey and CatToken auth to some endpoints.  Add 401 and 403 common responses.

* fix(cat-gateway): Add universal 422 response to all endpoints, and try and make all endpoint validation use it.

* fix: add cardano stake address type

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): stake address type

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Refactor the RBAC Token auth, so it's easier to maintain.

* fix(cat-gateway): stake address name

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Add no auth and no-auth+rbac auth schemes

* fix(cat-gateway): format + stake addr example

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): code format

* fix(cat-gateway): openapi spectral example rules

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Move legacy registration endpoint under Legacy Tag

* fix(cat-gateway): Add Auth to all endpoints

* fix(docs): Remove obsolete lint config file

* fix(cat-gateway): Make config.toml match upstream

* docs(docs): update project dictionary

* feat(cat-gateway): add target to make it quick to check openapi lints locally

* fix(cat-gateway): Remove reference to hermes

* fix(cat-gateway): Add auth to rbac endpoints

* docs(cat-gateway): Add full docs for v1/votes/plan/account-votes

* docs(cat-gateway): Add example for ip address query argument

* fix(cat-gateway): Define and abstract Ed25519 Public Keys as hex encoded parameters

* fix(cat-gateway): Make sure string api types do not directly expose the internal string

* fix(cat-gateway): Make conversion from a Ed25519 pub key hex value to a Verifyingkey infallible

* fix(cat-gateway): Fix native asset response types

* docs(cat-gateway): fix comments

* fix(cat-gateway): Autogenerate flutter files

* fix(cat-gateway): Exclude legacy endpoints from needing api examples

* fix(cat-gateway): WIP improving cip36 endpoint docs

* fix(docs): Make targets to re-check the generated schema easy.

* fix: spectral ruleset for linting query params description

* feat: parameter rule

* fix: debug function

* docs(cat-gateway): Make schema lint accept description inside a schema in a query parameter

* fix(cat-gateway): remove debug logic from api docs lint

* fix(cat-gateway): Don't put expanded program into git

* Make error response comments consistent

* test(cat-gateway): Add local operation to easily expand macros in the service code

* fix(cat-gateway): CIP36 Structured endpoint

* fix: speling

* fix(rust): cleanup/normalize nonce validation

* fix(rust): code format

* Update catalyst-gateway/bin/src/service/common/types/cardano/cip19_shelley_address.rs

Co-authored-by: bkioshn <[email protected]>

* Update catalyst-gateway/bin/src/service/common/types/cardano/cip19_shelley_address.rs

Co-authored-by: bkioshn <[email protected]>

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>

* feat: update segment names

* feat: add new discovery page

* feat: add empty state for proposals

* fix: rename

* feat: add proposals cubit

* feat: add tests

* chore: spelling

* chore: cleanup

* chore: cleanup

* chore: revert unwanted changes

* chore: revert merge conflicts

* fix: formatting

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: Stefano Cunego <[email protected]>
Co-authored-by: Steven Johnson <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>

* feat(cat-voices): campaign modal (#1289)

* refactor: remove onCancel function and define typedef for upload success

* feat: basic details dialog

* fix: header title color

* fix: modal constraints

* fix: details tile categories subtitle

* chore: dialog test data

* feat: dialog border

* feat: CampaignDetails bloc and models

* feat: header gradient overlay

* fix: modal background color

* refactor: rename LoadCampaign to LoadCampaignEvent

* refactor: update Campaign details dialog path

* feat: DiscoveryPage launched CampaignDetailsDialog

* feat: introduce CampaignRepository

* feat(cat-voices): Date & Time input widget  (#1224)

* feat: ui widget for date picker commponent

* feat: custom controller for date picker widget

* feat: adding validation to textfields

* feat: enhance date picker with improved validation and error handling messages

* feat: improve overlay management in date picker and enhance scroll controller handling in text fields

* fix: overlay switch between date and time

* chore: remove cached gitignore files

* fix: update OK button text in VoicesCalendarDatePicker for localization consistency

* feat: refactor date and time pickers to use DateTime for better consistency and state management across the application

* feat: implement new date and time picker modules with validation and controllers for better UI interaction

* fix: static-analytics

* refactor: date time text field (#1293)

* refactor: date time text field

* fix: doc reference

* feat: add date/time input formatting to date and time fields

* fix: late final in voices_date_field.dart

* fix: late final in voices_time_field.dart

* fix: formatting

---------

Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Damian Moliński <[email protected]>

* feat(cat-voices): admin preview tools (#1309)

* chore: rename in-page-card to campaign preview card, extract campaign status to catalyst_voices_models

* feat: add translations

* fix: typo

* feat: add admin preview tools

* feat: add views section to switch between auth user states

* chore: split into multiple files

* style: spelling

* fix: browser resize shouldn't reset the dialog offset

* chore: cleanup

* style: spelling

* feat(cat-voices): Campaign managment status UI (#1314)

* feat: campaign managment status

* fix: structure of the project

* fix: earthfile

* docs: adding docs for campaign enums

* fix: whitespacing

* refactor(cat-voices): Move UI models to view_model to models package (#1317)

* refactor: Move FundedProposal and PendingProposal to view_model package and introduce general Proposal in models package

* refactor: move coin formatting to inside models from view_models package

* refactor: move coin formatting to inside models from view_models package

* feat(cat-voices): vit ss endpoints generating (#1302)

* feat: vit-ss openapi specs + code generating

* chore: bump chopper and chopper_generator

* refactor: rename from vitss_openapi to vit

* fix: exclude openapi from spellchecking

* fix: missing cat_gateway_api

* refactor: rename generated/catalyst-gateway to generated/api + generated CatGatewayApi to CatGateway

* feat(cat-voices): Campaign info dialog on discovery (#1321)

* chore: rename in-page-card to campaign preview card, extract campaign status to catalyst_voices_models

* feat: add translations

* fix: typo

* feat: add admin preview tools

* feat: add views section to switch between auth user states

* chore: split into multiple files

* style: spelling

* fix: browser resize shouldn't reset the dialog offset

* chore: cleanup

* style: spelling

* feat: add border

* chore: reorganize members

* chore: rename campaign stage cart

* feat: add campaign info dialog on discovery page

* feat: calculate campaign stage

* fix: tests

* chore: add tests

* chore: cleanup

* feat: add campaign service

* fix: convert campaign info into simple class instead of enum

* fix: tests

* fix: campaign info state

* feat(cat-voices): admin tools events timer (#1323)

* chore: rename in-page-card to campaign preview card, extract campaign status to catalyst_voices_models

* feat: add translations

* fix: typo

* feat: add admin preview tools

* feat: add views section to switch between auth user states

* chore: split into multiple files

* style: spelling

* fix: browser resize shouldn't reset the dialog offset

* chore: cleanup

* style: spelling

* feat: add border

* chore: reorganize members

* chore: rename campaign stage cart

* feat: add campaign info dialog on discovery page

* feat: calculate campaign stage

* fix: tests

* chore: add tests

* chore: cleanup

* feat: implement timer logic

* feat: add campaign service

* fix: convert campaign info into simple class instead of enum

* fix: tests

* fix: campaign info state

* feat(cat-voices): Merge main into mve3 (#1334)

* Feat: update testplan template (#1243)

* chore: update testplan

* fix

* fix

* fix

* fix

* fix: testplan template (#1245)

* feat(cat-gateway): Finliaze CIP36 Endpoint Cleanup (#1241)

* fix: api endpoint draft

Signed-off-by: bkioshn <[email protected]>

* fix: api health endpoint v1

Signed-off-by: bkioshn <[email protected]>

* fix: remove bad request from errorResponses

Signed-off-by: bkioshn <[email protected]>

* fix: add bad req to get /registration

Signed-off-by: bkioshn <[email protected]>

* fix: error logging

Signed-off-by: bkioshn <[email protected]>

* fix: remove validation error

Signed-off-by: bkioshn <[email protected]>

* fix: registration get error name

Signed-off-by: bkioshn <[email protected]>

* chore:format

Signed-off-by: bkioshn <[email protected]>

* fix: get json schema from openapi spec

Signed-off-by: bkioshn <[email protected]>

* fix: move schema utils

Signed-off-by: bkioshn <[email protected]>

* fix: optional field

Signed-off-by: bkioshn <[email protected]>

* fix: config key

Signed-off-by: bkioshn <[email protected]>

* fix: cat-gateway code gen

Signed-off-by: bkioshn <[email protected]>

* fix: api name in cat-voice

Signed-off-by: bkioshn <[email protected]>

* fix: cat-voice format

Signed-off-by: bkioshn <[email protected]>

* chore: fix spacing

Signed-off-by: bkioshn <[email protected]>

* chore: fix spacing

Signed-off-by: bkioshn <[email protected]>

* chore: change tag config description

* test: add test for default validator

* fix: add spectral ruleset

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Sort the spelling words, and use latest deny.toml

* fix(cat-gateway): Fix broken pre-push justfile target

* docs(cat-gateway): cleanup

* docs(cat-gateway): Fix API Groups and document them better

* docs(cat-gateway): Add documentation to the health/inspection endpoint

* docs(cat-gateway): Add descriptions for cardano/cip36/latest_registration/stake_addr

* docs(cat-gateway): Document stake key hash and vote key endpoints for cardano

* docs(cat-gateway): add documentation to config/frontend

* docs(cat-gateway): Add api docs for frontend schema

* docs(cat-gateway): Move legacy registration endpoints into the Legacy TAG.

* docs(cat-gateway): Remaining documentable entities documented

* fix: update openapi linter

Signed-off-by: bkioshn <[email protected]>

* docs(cat-gateway): Add more constraints to parameters and json bodies

* fix: openapi lint FUNCTION name

Signed-off-by: bkioshn <[email protected]>

* fix: CIP36 example and description

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): cleanup error handling, and add a global 429 response to all endpoints.

* fix: config endpoint example, desc, and return

Signed-off-by: bkioshn <[email protected]>

* chore: remove todo

Signed-off-by: bkioshn <[email protected]>

* fix: move config object

Signed-off-by: bkioshn <[email protected]>

* fix: move cip36 object

Signed-off-by: bkioshn <[email protected]>

* docs(cat-gateway): Add missing headers to responses

* docs(cat-gateway): Cleanup the rest of the documentation in the api

* fix(cat-gateway): Fix OpenAPI linting and add autogenerated api file for dart.

* refactor(cat-gateway): Better generalize the OpenAPI simple string type creation macro.

* fix(cat-gateway): Add APIKey and CatToken auth to some endpoints.  Add 401 and 403 common responses.

* fix(cat-gateway): Add universal 422 response to all endpoints, and try and make all endpoint validation use it.

* fix: add cardano stake address type

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): stake address type

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Refactor the RBAC Token auth, so it's easier to maintain.

* fix(cat-gateway): stake address name

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Add no auth and no-auth+rbac auth schemes

* fix(cat-gateway): format + stake addr example

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): code format

* fix(cat-gateway): openapi spectral example rules

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): Move legacy registration endpoint under Legacy Tag

* fix(cat-gateway): Add Auth to all endpoints

* fix(docs): Remove obsolete lint config file

* fix(cat-gateway): Make config.toml match upstream

* docs(docs): update project dictionary

* feat(cat-gateway): add target to make it quick to check openapi lints locally

* fix(cat-gateway): Remove reference to hermes

* fix(cat-gateway): Add auth to rbac endpoints

* docs(cat-gateway): Add full docs for v1/votes/plan/account-votes

* docs(cat-gateway): Add example for ip address query argument

* fix(cat-gateway): Define and abstract Ed25519 Public Keys as hex encoded parameters

* fix(cat-gateway): Make sure string api types do not directly expose the internal string

* fix(cat-gateway): Make conversion from a Ed25519 pub key hex value to a Verifyingkey infallible

* fix(cat-gateway): Fix native asset response types

* docs(cat-gateway): fix comments

* fix(cat-gateway): Autogenerate flutter files

* fix(cat-gateway): Exclude legacy endpoints from needing api examples

* fix(cat-gateway): WIP improving cip36 endpoint docs

* fix(docs): Make targets to re-check the generated schema easy.

* fix: spectral ruleset for linting query params description

* feat: parameter rule

* fix: debug function

* docs(cat-gateway): Make schema lint accept description inside a schema in a query parameter

* fix(cat-gateway): remove debug logic from api docs lint

* fix(cat-gateway): Don't put expanded program into git

* Make error response comments consistent

* test(cat-gateway): Add local operation to easily expand macros in the service code

* fix(cat-gateway): CIP36 Structured endpoint

* fix: speling

* fix(rust): cleanup/normalize nonce validation

* fix(rust): code format

* Update catalyst-gateway/bin/src/service/common/types/cardano/cip19_shelley_address.rs

Co-authored-by: bkioshn <[email protected]>

* Update catalyst-gateway/bin/src/service/common/types/cardano/cip19_shelley_address.rs

Co-authored-by: bkioshn <[email protected]>

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>

* Revert "Merge branch 'mve3' into main"

This reverts commit 01db066, reversing
changes made to 3bf0ccf.

* fix(cat-voices): equatable lint issue fix (#1280)

* fix: resolve equatable lint issue

* fix: missing override

* fix(flutter/catalyst_key_derivation): Accept non extended public key for rbac (#1288)

* fix(flutter/catalyst_key_derivation): Accept non extended public key for rbac

* fix: unit tests

* chore: rename

* fix(dart/catalyst_cardano_serialization): remove key reference from RBAC, use local key ref instead (#1292)

* fix(dart/catalyst_cardano_serialization): remove key reference from RBAC, use local key ref

* fix: update RBAC issuer properties, catalyst users don't have any of these identifiable

* fix: payment key should refer to the first transaction output which is the change address

* chore: rename keyOffset to offset

* chore: bump version (#1297)

* fix(cat-gateway): Fix native asset indexing to be more flexible (#1150)

* refactor: rename schema to asset

* refactor: vector asset

* chore: rename asset fields

* refactor: object mapping structs

* chore: minor rename

* fix: update operation cql

* fix: schema version

* chore: change asset_id back to policy_id

* chore: find rename

* fix: schema version

* fix: i128

* feat: asset value from i128

* refactor: change &[u8] for asset name

* refactor: try from asset value

* fix: import

* chore: fmtfix

* Update catalyst-gateway/bin/src/db/index/block/txo/insert_txo_asset.rs

Co-authored-by: Steven Johnson <[email protected]>

* revert: i128 to bigint

* fix: unused import

* feat: api test

* chore: cspell fix

* chore: cspell fix

* chore: fmtfix

---------

Co-authored-by: Oleksandr Prokhorenko <[email protected]>
Co-authored-by: Steven Johnson <[email protected]>

* feat(docs): Document the key derivation path for Project Catalyst ED25519 Keys (#1300)

* feat(docs): Document the key derivation path for Project Catalyst ED25519 keys

* fix(docs): Fix and reference historical dates for accuracy

* fix(dart/catalyst_cardano_serialization): x509 distinguished name structure (#1290)

* fix: x509 distinguished name structure

Signed-off-by: bkioshn <[email protected]>

* fix: format

Signed-off-by: bkioshn <[email protected]>

* feat: make it possible to override ASN1 tag for subject alt name in the x509 cert

* fix: static analysis issue

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>

* feat: additional just functions for faster startup (#1310)

* fix(cat-voices): update key derivation path (#1301)

* fix(cat-voices): update key derivation path

* docs: add source

* chore: code cleanup

* docs: move relevant docs

* chore: extract account constant

Co-authored-by: Steven Johnson <[email protected]>

* chore: reformat

---------

Co-authored-by: Steven Johnson <[email protected]>

* fix: frb unexpected cfg (#1320)

Signed-off-by: bkioshn <[email protected]>

* fix(cat-gateway): bump `scylla` to v0.15.0 (#1316)

* refactor: initial

* fix: arc type

* fix: query iter

* fix: functions

* fix: final

* chore: fmtfix

* chore: remove lints

* chore: remove lint from database object

* chore: remove result wrapper

* feat(cat-gateway): Add a signed documents repository storage table in the Event DB (#1322)

* refactor(cat-gateway): Move unused schemas out of the main schema directory

* feat(cat-gateway): Add signed documents repository table to the postgresql DB.

* feat(cat-gateway): Add author, and more indexes to the signed docs repository table

* fix(cat-gateway): BYTEA not BLOB

* fix(cat-gateway): move unused migrations out of the migrations folder

* fix(cat-gateway): Fix comment annotations to refer to correct table

* fix(cat-gateway): fix index names in the comments

* feat(docs): Define signed document metadata fields (#1315)

* feat(docs): Define signed document metadata fields

* docs(docs): Fix spelling

* feat(cat-voices): Integration tests using flutter_driver (#1304)

* custom driver for integration tests

* feat: working voices test driver

* feat: creating internal lib for voices driver

* fix: remove unused import

* fix: check-spelling

* fix: static analysis

* fix: test file

* refactor: skiping test for know

* fix: adding packages to melos

* fix: whitespacing

* Update catalyst_voices/packages/libs/catalyst_cardano/catalyst_cardano/example/test_driver/app_test.dart

Co-authored-by: Dominik Toton <[email protected]>

* feat: add extension to driver

* fix: remove unused function

* fix: add files to gitignore

---------

Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: bkioshn <[email protected]>

* fix: importing proper menuitem

* fix: missing comma in cspell.json

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: Stefano Cunego <[email protected]>
Co-authored-by: Steven Johnson <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>
Co-authored-by: Oleksandr Prokhorenko <[email protected]>
Co-authored-by: Apisit Ritruengroj <[email protected]>
Co-authored-by: Dominik Toton <[email protected]>
Co-authored-by: Damian Moliński <[email protected]>

* feat(cat-voices):  Admin view for overall spaces menu (#1326)

* feat: overall spaces admin configuration

* feat: additional access control base on user roles

* fix: spelling

* fix: access controll state check

* fix: whitespace in dependecies.dart

* fix: missing trailling comma

* refactor: simplify account access in UserAccessGuard and AdminAccessGuard, add extension for session state handling

---------

Co-authored-by: Dominik Toton <[email protected]>

* feat(cat-voices): proposal editor template data flow (#1335)

* chore: remove workspace test data

* chore: workspace bloc

* refactor: use MarkdownString instead of DocumentJson

* feat: MarkdownCodec

* chore: markdown convert lib

* refactor: use MarkdownString

* feat: updating sections dynamically

* fix: section step title wrapping

* feat: ProposalSection

* feat: saving proposal step answer

* refactor: move WorkspaceBloc to app.dart

* chore: guidances

* chore: use const in constructor

* fix: workspace page event order

* refactor: rename MarkdownString to MarkdownData

* refactor: extract _mapProposalSection

* refactor(cat-voices): move api to repository package (#1336)

* refactor: move api to repository package

* refactor: move storage/crypto related classes to shared package

* refactor: rename VaultCryptoService to LocalCryptoService

* fix: melos build_runner script

* fix: justfile package comment

* fix: remove unused deps from services

* fix: bring back path dep

* chore: remove legacy documentation / code

* fix: readme formatting

* feat(cat-voices): admin tools mocked data (#1356)

* feat: add proposal service

* refactor: limit rebuilds in spaces shell page

* chore: cleanup code

* feat: sync available spaces in admin tools

* chore: cleanup

* feat: register with RBAC as proposer

* feat: use overlay for admin tools to show it above everything else

* chore: remove unused code

* feat: add admin tools cubit

* feat: override session state by admin tools

* chore: cleanup

* feat: update campaign info dialog to mock the campaign stage

* chore: cleanup dummy user service

* feat: mock proposals

* chore: code cleanup

* chore: cleanup and tests

* chore: cleanup

* chore: campaign info cubit tests

* chore: add tests for proposals cubit

* style: reformat code

* fix: tests

* chore: code review feedback

* chore: cleanup dummy user factory

* chore: simplify proposal view model

* Missing autofocus param (#1361)

Co-authored-by: Dominik Toton <[email protected]>

* feat(dart/catalyst_cardano_serialization): replace ulid by UUID in auth token (#1368)

* feat: replace ulid by uuid v7

* fix: encode uuid as bytes not as string

* feat: add cbor tag for uuid

* fix: missing scaffold for global snackbars (#1373)

* feat(dart/catalyst_cose): Catalyst COSE_SIGN support (#1374)

* refactor!: extract signer and verifier algorithms

* feat: add new COSE_SIGN1 implementation

* feat: add COSE_SIGN structure

* style: spelling

* fix: tests

* chore: code cleanup

* feat(cat-voices): Cached vault unlock state (#1372)

* feat: local storage

* refactor: local storage clear

* feat: add allowList to LocalStorage

* feat: SecureStorageVault accepts key with default value

* feat: MemoryStorage

* chore: export LocalStorage and MemoryStorage

* feat: TtlCache

* refactor: Delete keychain_metadata in favour of internal initialization value inside SecureStorageVault

* chore: fix previous commit files

* feat: keychain uses ttl cache for unlock

* feat: DependencyProvider instanceName properties

* fix: use effective key for secure storage cache

* feat: Add SecureStorageVaultCache

* fix: LocalTtlCache now extends from now only

* chore: make SecureStorageVaultCache private

* feat: vault active flag + extending unlocked state

* feat: extend last unlock expireDate state when vault becomes inactive

* feat: make unlockTtl a optional parameter

* feat: AppActiveStateListener and ActiveAware interface

* feat: UserService implements ActiveAware

* chore: do not sync isUnlocked when building stream

* fix: sync unlock state on stream watch

* fix: remove unnecessary import

* fix: failing tests

* docs: AppActiveStateListener

* chore: typo

* refactor: require storages FlutterSecureStorage/SharedPreferencesAsync to be more explicit about dependencies

* feat(cat-voices): app config model (#1378)

* feat: app config model

* feat: dynamic app config

* chore: missing AppConfig params

* fix: exclude generated files from analyze

* fix: exclude dart_tool from melos analyze script

* chore: formatting

* refactor: move json_converters to shared package

* fix: pubspec libs sorting

* feat(cat-voices): caching user (#1391)

* chore: wip

* feat: caching user model

* refactor: move json_converters to shared package

* feat: UserDto and AppConfigDto

* refactor: move Keychain to shared package

* refactor: simplify UserService. Expose only Accounts and User

* feat: lockable lastIsUnlocked

* fix: typos

* fix: typo

* refactor: reorder getUser/saveUser in UserRepository

* feat(cat-voices): setup campaign stage dates (#1396)

* feat: edit campaign stage dates

* chore: code cleanup

* fix: disable overscroll

* chore: cleanup code

* chore: cleanup

* feat(cat-voices): multi proposal workspace (#1409)

* refactor: rename WorkspacePage to WorkspaceEditorPage

* feat: workspace page

* refactor: rename WorkspaceEditor to ProposalEditor

* feat: Workspace header

* chore: workspace bloc/state in progress

* refactor: different test draft id

* feat: workspace page states widgets

* feat: workspace states selectors

* feat: Mocked workspace bloc

* docs: more todo-s

* refactor: rename ProposalEditor to ProposalBuilder

* fix: use ellipsis in search string

* refactor: Add public selectors widgets for workspace widgets

* chore: missing build_runner for repository, restore wrongly deleted file

* feat(cat-voices): proposal template models (#1363)

* draft for setup segment

* fix: delete unused files

* feat: dtos for properties

* feat:creating dtos for proposal schema

* feat: creating toModels

* feat: sort section/elements by xorder

* feat: adding missing toModels for definitions

* fix: delete unused property from element class

* feat: creating generic_proposal.json

* test: adding unit tests

* feat: range class for easier representation for max min values

* feat: adding proper from/to Json for proposal_builder class

* feat: change name of the files to make it more generic -document-

* feat: change name of the document property widget

* feat: adding equatable for classes

* chore: update chain follower

* feat: sortingBy order

* chore: revert merge conflicts

---------

Co-authored-by: Dominik Toton <[email protected]>

* chore: code cleanup

* feat(cat-voices): encode/decode cose documents (#1408)

* feat: addd melos build_runner_repository to justfile

* feat: update cose sign to support multiple different signatures and algs

* feat: add document manager that handles signed documents (COSE_SIGN)

* fix: kid should be encoded as Uint8List, not as string

* style: typo

* fix: collection equality

* chore: review feedback

* feat: add content type

* chore: rename document to binary document, export document manager

* chore: copyWith fix

* fix: json content type

* fix: put default alg in top-level headers if all signatures use the same alg

* chore: refactor reference uuid to give it a more meaningful name

* chore: get rid of equatable from SignedDocument interface

* fix: do not put alg in top-level protected headers for COSE_SIGN

* chore: update field name

* feat: add document node for identifying properties

* feat: add document that holds document builder values

* chore: convert document node id to a class

* chore: rename proposal builder to document builder

* chore: rename DocumentParser to BinaryDocumentParser

* chore: format

* chore: cleanup code

* chore: rename DocumentBuilder to Document

* chore: rename DocumentManager to SignedDocumentManager

* chore: code cleanup

* chore: simplify document parsing

* chore: cleanup json schema parsing

* chore: rename DocumentElement to DocumentProperty

* feat: editing property in document

* feat: enqueue document changes and render it in a section placeholder

* chore: todos

* fix: add missing config after solving merge conflicts

* chore: cleanup code, make fields optional

* feat: make default value optional object

* chore: extract properties parsing into converters, parse if-then-else condition

* chore: remove equatable from dtos, extract code to separate files

* chore: move sorting to model

* chore: add default value

* chore: add default value

* Revert "chore: add default value"

This reverts commit 019f6ff.

* chore: code cleanup

* chore: revert optional types

* chore: make optional type right

* chore: code cleanup

* chore: move converter

* chore: extract document editing into a document builder

* chore: cache builder

* chore: cleanup

---------

Signed-off-by: bkioshn <[email protected]>
Co-authored-by: Ryszard Schossler <[email protected]>
Co-authored-by: Damian Moliński <[email protected]>
Co-authored-by: Stefano Cunego <[email protected]>
Co-authored-by: Steven Johnson <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: bkioshn <[email protected]>
Co-authored-by: Apisit Ritreungroj <[email protected]>
Co-authored-by: Oleksandr Prokhorenko <[email protected]>
Co-authored-by: Apisit Ritruengroj <[email protected]>
  • Loading branch information
10 people authored Jan 2, 2025
1 parent 9c6b253 commit 44aa924
Show file tree
Hide file tree
Showing 34 changed files with 1,525 additions and 1,165 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import 'package:catalyst_voices_models/catalyst_voices_models.dart';
import 'package:catalyst_voices_view_models/catalyst_voices_view_models.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:flutter_quill/flutter_quill.dart';
import 'package:flutter_quill/flutter_quill.dart' as quill;

class ProposalBuilderRichTextStep extends StatefulWidget {
final RichTextStep step;
Expand Down Expand Up @@ -36,7 +36,8 @@ class _ProposalBuilderRichTextStepState
final markdownString = widget.step.initialData ?? const MarkdownData('');
final delta = markdown.encode(markdownString);

final document = delta.isNotEmpty ? Document.fromDelta(delta) : Document();
final document =
delta.isNotEmpty ? quill.Document.fromDelta(delta) : quill.Document();
final selectionOffset = document.length == 0 ? 0 : document.length - 1;

_controller = VoicesRichTextController(
Expand Down Expand Up @@ -76,7 +77,7 @@ class _ProposalBuilderRichTextStepState
);
}

void _saveDocument(Document document) {
void _saveDocument(quill.Document document) {
final delta = document.toDelta();
final markdownString = markdown.decode(delta);

Expand All @@ -90,7 +91,7 @@ class _ProposalBuilderRichTextStepState
context.read<ProposalBuilderBloc>().add(event);
}

bool _canEditDocument(Document document) {
bool _canEditDocument(quill.Document document) {
final sectionsController = SectionsControllerScope.of(context);

final ids = sectionsController.value.editStepsIds;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,24 @@
import 'package:catalyst_voices_models/catalyst_voices_models.dart';
import 'package:flutter/material.dart';

class DocumentPropertyWidget extends StatelessWidget {
final BaseDocumentDefinition definition;
const DocumentPropertyWidget({super.key, required this.definition});
/// Displays a [DocumentProperty] in editing (builder) mode.
class DocumentPropertyBuilderWidget extends StatelessWidget {
/// A single field of the document that belongs to a section.
final DocumentProperty property;

/// A callback that should be called with the latest [DocumentChange]
/// for the edited [property] when the user wants to save the changes.
final ValueChanged<DocumentChange> onChanged;

const DocumentPropertyBuilderWidget({
super.key,
required this.property,
required this.onChanged,
});

@override
Widget build(BuildContext context) {
return switch (definition) {
SegmentDefinition() => throw UnimplementedError(),
SectionDefinition() => throw UnimplementedError(),
return switch (property.schema.definition) {
SingleLineTextEntryDefinition() => throw UnimplementedError(),
SingleLineHttpsURLEntryDefinition() => throw UnimplementedError(),
MultiLineTextEntryDefinition() => throw UnimplementedError(),
Expand All @@ -29,6 +38,12 @@ class DocumentPropertyWidget extends StatelessWidget {
YesNoChoiceDefinition() => throw UnimplementedError(),
AgreementConfirmationDefinition() => throw UnimplementedError(),
SPDXLicenceOrUrlDefinition() => throw UnimplementedError(),

// unsupported
SegmentDefinition() || SectionDefinition() => throw UnsupportedError(
'${property.schema.definition} unsupported '
'by $DocumentPropertyBuilderWidget',
),
};
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
import 'package:catalyst_voices/widgets/document_builder/document_property_builder_widget.dart';
import 'package:catalyst_voices_models/catalyst_voices_models.dart';
import 'package:flutter/material.dart';

/// Displays a [DocumentSection] and it's properties in editing (builder) mode.
class DocumentSectionBuilderWidget extends StatefulWidget {
/// A section of the document that groups [DocumentProperty].
final DocumentSection section;

/// A callback that should be called with a list of [DocumentChange]
/// when the user wants to save the changes.
///
/// Sections should collect changes from underlying
/// [DocumentPropertyBuilderWidget], show "Save" button and only call
/// this callback when user wants to save the whole section.
final ValueChanged<List<DocumentChange>> onChanged;

const DocumentSectionBuilderWidget({
super.key,
required this.section,
required this.onChanged,
});

@override
State<DocumentSectionBuilderWidget> createState() =>
_DocumentSectionBuilderWidgetState();
}

class _DocumentSectionBuilderWidgetState
extends State<DocumentSectionBuilderWidget> {
late DocumentSection _editedSection;
late DocumentSectionBuilder _builder;
final _pendingChanges = <DocumentChange>[];

@override
void initState() {
super.initState();

_editedSection = widget.section;
_builder = _editedSection.toBuilder();
}

@override
void didUpdateWidget(DocumentSectionBuilderWidget oldWidget) {
super.didUpdateWidget(oldWidget);

if (oldWidget.section != widget.section) {
_editedSection = widget.section;
_builder = _editedSection.toBuilder();
_pendingChanges.clear();
}
}

@override
Widget build(BuildContext context) {
// TODO(dtscalac): implement the section layout, remove this placeholder
return Container(
padding: const EdgeInsets.all(12),
decoration: BoxDecoration(
border: Border.all(),
color: Colors.white,
),
child: Column(
children: [
for (final property in widget.section.properties)
Padding(
padding: const EdgeInsets.only(bottom: 8),
child: DocumentPropertyBuilderWidget(
property: property,
onChanged: _onChanged,
),
),
if (_pendingChanges.isNotEmpty)
Padding(
padding: const EdgeInsets.only(top: 16),
child: ElevatedButton(
onPressed: _onSave,
child: const Text('Save'),
),
),
],
),
);
}

void _onChanged(DocumentChange change) {
setState(() {
_builder.addChange(change);
_editedSection = _builder.build();
_pendingChanges.add(change);
});
}

void _onSave() {
widget.onChanged(List.of(_pendingChanges));

// ignore: unnecessary_lambdas
setState(() {
_pendingChanges.clear();
});
}
}
2 changes: 1 addition & 1 deletion catalyst_voices/melos.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,7 @@ scripts:
--depends-on="build_runner" \
--scope="catalyst_voices_repositories" -- \
dart run build_runner build --delete-conflicting-outputs \
--build-filter="lib/src/dto/*"
--build-filter="lib/src/dto/**"
description: |
Run `build_runner` in catalyst_voices_repositories package only in selected folders
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,12 @@ export 'campaign/campaign_category.dart';
export 'campaign/campaign_publish.dart';
export 'campaign/campaign_section.dart';
export 'crypto/lock_factor.dart';
export 'document_builder/document_builder.dart';
export 'document_builder/document_definitions.dart';
export 'document_builder/document_schema.dart';
export 'document/document.dart';
export 'document/document_builder.dart';
export 'document/document_change.dart';
export 'document/document_definitions.dart';
export 'document/document_node_id.dart';
export 'document/document_schema.dart';
export 'errors/errors.dart';
export 'file/voices_file.dart';
export 'markdown_data.dart';
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
import 'package:catalyst_voices_models/src/document/document_builder.dart';
import 'package:catalyst_voices_models/src/document/document_schema.dart';
import 'package:equatable/equatable.dart';

// TODO(dtscalac): tests

/// A class that represents the content described by a [DocumentSchema].
///
/// The document is immutable, in order to edit it make use
/// of [toBuilder] method and act on [DocumentBuilder] instance.
final class Document extends Equatable {
final DocumentSchema schema;
final List<DocumentSegment> segments;

/// The default constructor for the [Document].
const Document({
required this.schema,
required this.segments,
});

/// Creates a new [DocumentBuilder] from this document.
DocumentBuilder toBuilder() {
return DocumentBuilder.fromDocument(this);
}

@override
List<Object?> get props => [schema, segments];
}

/// A segment that groups multiple [DocumentSection]'s.
final class DocumentSegment extends Equatable {
/// The schema of the document segment.
final DocumentSchemaSegment schema;

/// The list of sections that group the [DocumentProperty].
final List<DocumentSection> sections;

/// The default constructor for the [DocumentSegment].
const DocumentSegment({
required this.schema,
required this.sections,
});

/// Creates a new [DocumentSegmentBuilder] from this segment.
DocumentSegmentBuilder toBuilder() {
return DocumentSegmentBuilder.fromSegment(this);
}

@override
List<Object?> get props => [schema, sections];
}

/// A section that groups multiple [DocumentProperty]'s.
final class DocumentSection extends Equatable {
/// The schema of the document section.
final DocumentSchemaSection schema;

/// The list of properties within this section.
final List<DocumentProperty> properties;

/// The default constructor for the [DocumentSection].
const DocumentSection({
required this.schema,
required this.properties,
});

/// Creates a new [DocumentSectionBuilder] from this section.
DocumentSectionBuilder toBuilder() {
return DocumentSectionBuilder.fromSection(this);
}

@override
List<Object?> get props => [schema, properties];
}

final class DocumentProperty extends Equatable {
/// The schema of the document property.
final DocumentSchemaProperty schema;

/// The current value this property holds.
final Object? value;

/// The default constructor for the [DocumentProperty].
const DocumentProperty({
required this.schema,
required this.value,
});

/// Creates a new [DocumentPropertyBuilder] from this property.
DocumentPropertyBuilder toBuilder() {
return DocumentPropertyBuilder.fromProperty(this);
}

@override
List<Object?> get props => [schema, value];
}
Loading

0 comments on commit 44aa924

Please sign in to comment.