Skip to content

Commit

Permalink
chore(general): merge mve3 into main (#1446)
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]>

* 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

* fix: add missing config after solving merge conflicts

---------

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 Dec 30, 2024
1 parent 8512570 commit ebb445a
Show file tree
Hide file tree
Showing 328 changed files with 18,232 additions and 3,382 deletions.
8 changes: 8 additions & 0 deletions .config/dictionaries/project.dic
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ auditability
Autolayout
autorecalculates
autoresizing
autovalidate
backendpython
backgrounding
bech
Expand Down Expand Up @@ -51,12 +52,15 @@ chrono
ciphertext
ciphertexts
CIPs
CNFT
COCOAPODS
codegen
codepoints
collabs
commitlog
concatcp
coproposers
COSE
coti
coverallsapp
CQLSH
Expand Down Expand Up @@ -110,6 +114,7 @@ gethostname
Gitbook
gmtime
gradlew
Hackathons
headful
headlessui
HIDPI
Expand Down Expand Up @@ -286,6 +291,7 @@ testplan
testunit
thiserror
thollander
Timelapse
timelike
tkach
Toastify
Expand All @@ -296,13 +302,15 @@ tomjs
Traceback
traefik
trailings
tstr
TXNZD
txos
Typer
unawaited
unchunk
Unlogged
unmanaged
Unmarks
Unstaked
upskilling
UTXO
Expand Down
1 change: 1 addition & 0 deletions catalyst_voices/.gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
### Dart ###
# See https://www.dartlang.org/guides/libraries/private-files
devtools_options.yaml


# Generated files from code generation tools
Expand Down
20 changes: 10 additions & 10 deletions catalyst_voices/Earthfile
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,13 @@ builder:
DO flutter-ci+BOOTSTRAP

# Creates filtered OpenAPI spec
# Takes json file from openapi-filter from /packages/internal/catalyst_voices_services
# Takes json file from openapi-filter from /packages/internal/catalyst_voices_repositories
filter-openapi:
FROM node:18
WORKDIR /packages/internal/catalyst_voices_services
WORKDIR /packages/internal/catalyst_voices_repositories

COPY catalyst-gateway+build/doc/cat-gateway-api.json openapi/cat-gateway-api.json
COPY packages/internal/catalyst_voices_services/openapi-filters.json openapi-filters.json
COPY packages/internal/catalyst_voices_repositories/openapi-filters.json openapi-filters.json

RUN npm install -g openapi-format
RUN openapi-format openapi/cat-gateway-api.json -o openapi/filtered-openapi.json --filterFile openapi-filters.json --verbose
Expand All @@ -40,32 +40,32 @@ filter-openapi:
# It accepts [save_locally] ARG that when true place the artifacts in the
# proper folders
# It accepts [filter_openapi] ARG that when true filter the openapi spec
# using filters from /packages/internal/catalyst_voices_services/openapi-filters.json
# using filters from /packages/internal/catalyst_voices_repositories/openapi-filters.json
code-generator:
ARG save_locally=false
ARG filter_openapi=true
FROM +builder
LET gen_code_path = lib/generated/catalyst_gateway
LET local_gen_code_path = packages/internal/catalyst_voices_services/lib/generated/catalyst_gateway/
LET gen_code_path = lib/generated/api
LET local_gen_code_path = packages/internal/catalyst_voices_repositories/lib/generated/api/

RUN melos l10n
RUN melos build_runner

IF [ $save_locally = true ]
RUN find . \( -name "*.g.dart" -o -name "*.freezed.dart" -o -name "*.chopper.dart" -o -name "*.swagger.dart" -o -name "*.openapi.dart" -o -name "*.gen.dart" -o -name "catalyst_voices_localizations*.dart" -o -name "cat_gateway_api.*.swagger.*" \)
RUN find . \( -name "*.g.dart" -o -name "*.freezed.dart" -o -name "*.chopper.dart" -o -name "*.swagger.dart" -o -name "*.openapi.dart" -o -name "*.gen.dart" -o -name "catalyst_voices_localizations*.dart" -o -name "cat_gateway.*.swagger.*" \)

FOR generated_file IN $(find . \( -name "*.g.dart" -o -name "*.freezed.dart" -o -name "*.chopper.dart" -o -name "*.swagger.dart" -o -name "*.openapi.dart" -o -name "*.gen.dart" -o -name "catalyst_voices_localizations*.dart" -o -name "cat_gateway_api.*.swagger.*" \))
SAVE ARTIFACT $generated_file AS LOCAL $generated_file
END
ELSE
SAVE ARTIFACT .
END
WORKDIR packages/internal/catalyst_voices_services
WORKDIR packages/internal/catalyst_voices_repositories

IF [ $filter_openapi = true ]
COPY +filter-openapi/filtered-openapi.json openapi/cat-gateway-api.json
COPY +filter-openapi/filtered-openapi.json openapi/cat-gateway.json
ELSE
COPY catalyst-gateway+build/doc/cat-gateway-api.json openapi/cat-gateway-api.json
COPY catalyst-gateway+build/doc/cat-gateway-api.json openapi/cat-gateway.json
END

DO flutter-ci+OPENAPI_CODE_GEN \
Expand Down
2 changes: 1 addition & 1 deletion catalyst_voices/apps/voices/integration_test/app_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ void main() async {
});

setUp(() async {
await registerDependencies();
await registerDependencies(config: const AppConfig());
router.go(const DiscoveryRoute().location);
});

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import 'package:catalyst_voices/app/view/app.dart';
import 'package:catalyst_voices/configs/bootstrap.dart';
import 'package:catalyst_voices/routes/routes.dart';
import 'package:catalyst_voices_models/catalyst_voices_models.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:go_router/go_router.dart';
import 'package:integration_test/integration_test.dart';
Expand All @@ -19,7 +20,7 @@ void main() async {
});

setUp(() async {
await registerDependencies();
await registerDependencies(config: const AppConfig());
router.go(const DiscoveryRoute().location);
});

Expand Down
24 changes: 18 additions & 6 deletions catalyst_voices/apps/voices/lib/app/view/app.dart
Original file line number Diff line number Diff line change
Expand Up @@ -38,14 +38,26 @@ class _AppState extends State<App> {

List<BlocProvider> _multiBlocProviders() {
return [
BlocProvider<AuthenticationBloc>(
create: (_) => Dependencies.instance.get<AuthenticationBloc>(),
),
BlocProvider<LoginBloc>(
create: (_) => Dependencies.instance.get<LoginBloc>(),
BlocProvider<AdminToolsCubit>(
create: (_) => Dependencies.instance.get<AdminToolsCubit>(),
),
BlocProvider<SessionCubit>(
create: (_) => Dependencies.instance.get(),
create: (_) => Dependencies.instance.get<SessionCubit>(),
),
BlocProvider<ProposalsCubit>(
create: (_) => Dependencies.instance.get<ProposalsCubit>(),
),
BlocProvider<CampaignInfoCubit>(
create: (_) => Dependencies.instance.get<CampaignInfoCubit>(),
),
BlocProvider<CampaignBuilderCubit>(
create: (_) => Dependencies.instance.get<CampaignBuilderCubit>(),
),
BlocProvider<WorkspaceBloc>(
create: (context) => Dependencies.instance.get<WorkspaceBloc>(),
),
BlocProvider<ProposalBuilderBloc>(
create: (context) => Dependencies.instance.get<ProposalBuilderBloc>(),
),
];
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import 'package:catalyst_voices/dependency/dependencies.dart';
import 'package:catalyst_voices_services/catalyst_voices_services.dart';
import 'package:flutter/material.dart';

/// Observes application lifecycle and updates any dependencies that are
/// interested in app state.
class AppActiveStateListener extends StatefulWidget {
final Widget child;

const AppActiveStateListener({
super.key,
required this.child,
});

@override
State<AppActiveStateListener> createState() => _AppActiveStateListenerState();
}

class _AppActiveStateListenerState extends State<AppActiveStateListener> {
late final AppLifecycleListener _listener;

@override
void initState() {
super.initState();
_listener = AppLifecycleListener(
onResume: _handleResumed,
onInactive: _handleInactive,
);
}

@override
void dispose() {
_listener.dispose();
super.dispose();
}

@override
Widget build(BuildContext context) {
return widget.child;
}

Future<void> _handleResumed() async {
Dependencies.instance.get<UserService>().isActive = true;
}

Future<void> _handleInactive() async {
Dependencies.instance.get<UserService>().isActive = false;
}
}
13 changes: 10 additions & 3 deletions catalyst_voices/apps/voices/lib/app/view/app_content.dart
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import 'package:catalyst_voices/app/view/app_active_state_listener.dart';
import 'package:catalyst_voices/app/view/app_precache_image_assets.dart';
import 'package:catalyst_voices/app/view/app_session_listener.dart';
import 'package:catalyst_voices_brands/catalyst_voices_brands.dart';
Expand Down Expand Up @@ -51,9 +52,15 @@ class AppContentState extends State<AppContent> {
brightness: Brightness.dark,
),
builder: (context, child) {
return GlobalPrecacheImages(
child: GlobalSessionListener(
child: child ?? const SizedBox.shrink(),
return Scaffold(
primary: false,
backgroundColor: Colors.transparent,
body: AppActiveStateListener(
child: GlobalPrecacheImages(
child: GlobalSessionListener(
child: child ?? const SizedBox.shrink(),
),
),
),
);
},
Expand Down
60 changes: 60 additions & 0 deletions catalyst_voices/apps/voices/lib/common/codecs/markdown_codec.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
import 'dart:convert';

import 'package:catalyst_voices_models/catalyst_voices_models.dart';
import 'package:flutter_quill/quill_delta.dart';
import 'package:markdown/markdown.dart' as md;
import 'package:markdown_quill/markdown_quill.dart';

// Note.
// This codec is here because it depends on flutter_quill which is heavy
// package with lots different dependencies which we don't want to have in
// other packages.
//
// If we could have just Delta package it would be preferred to live in
// models/shared package
const markdown = MarkdownCodec();

final _mdDocument = md.Document();
final _mdToDelta = MarkdownToDelta(markdownDocument: _mdDocument);
final _deltaToMd = DeltaToMarkdown(
customContentHandler: DeltaToMarkdown.escapeSpecialCharactersRelaxed,
);

final class MarkdownCodec extends Codec<MarkdownData, Delta> {
const MarkdownCodec();

@override
Converter<Delta, MarkdownData> get decoder => const MarkdownEncoder();

@override
Converter<MarkdownData, Delta> get encoder => const MarkdownDecoder();
}

class MarkdownDecoder extends Converter<MarkdownData, Delta> {
const MarkdownDecoder();

@override
Delta convert(MarkdownData input) {
if (input.data.isEmpty) {
return Delta();
}

return _mdToDelta.convert(input.data);
}
}

class MarkdownEncoder extends Converter<Delta, MarkdownData> {
const MarkdownEncoder();

@override
MarkdownData convert(Delta input) {
if (input.isEmpty) {
return const MarkdownData('');
}

final data = _deltaToMd.convert(input);
final trimmed = data.trim();

return MarkdownData(trimmed);
}
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import 'package:catalyst_voices_assets/catalyst_voices_assets.dart';
import 'package:catalyst_voices_localization/generated/catalyst_voices_localizations.dart';
import 'package:catalyst_voices_view_models/catalyst_voices_view_models.dart';
import 'package:catalyst_voices_models/catalyst_voices_models.dart';

extension GuidanceExt on GuidanceType {
String localizedType(VoicesLocalizations localizations) => switch (this) {
Expand Down
7 changes: 7 additions & 0 deletions catalyst_voices/apps/voices/lib/common/ext/map_ext.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
extension MapFilterExtension<K, V> on Map<K, V> {
Map<K, V> useKeys(List<K> keys) {
return Map.fromEntries(
entries.where((entry) => keys.contains(entry.key)),
);
}
}
10 changes: 10 additions & 0 deletions catalyst_voices/apps/voices/lib/common/ext/time_of_day_ext.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import 'package:flutter/material.dart';

extension TimeOfDayExt on TimeOfDay {
String get formatted {
final hour = this.hour.toString().padLeft(2, '0');
final minute = this.minute.toString().padLeft(2, '0');

return '$hour:$minute';
}
}
Loading

0 comments on commit ebb445a

Please sign in to comment.