|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | * replace usePostsList with useArticlesList to keep names coherent
* remove useIsMounted hook
* rewrite useRedirection hook
* add redirect in getStaticProps to avoid unecessary fetching
* move Pagination component in a noscript tag
* use hooks to refresh thematics and topics lists
* complete Cypress tests | 
| | 
| 
| 
| 
| 
| | * add useTopic and useTopicsList hooks to refresh data
* add a table of contents
* add Cypress tests | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * add a table of contents (however posts heading are
not included)
* rename posts list section title
* add a useThematic hook to refresh thematic contents
* add a useThematicLists hook to refresh thematics list
* add a `notIn` filter in thematics list fetcher to directly
remove unwanted thematics
* add Cypress tests | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * use rehype to update code blocks class names
* fix widget heading level (after a level 1 it should always be a level
2 and not 3)
* replace Spinner with LoadingPage and LoadingPageComments components to
keep layout coherent
* refactor useArticle and useComments hooks
* fix URLs in JSON LD schema
* add Cypress tests | 
| | 
| 
| 
| 
| 
| | * reduce the number of statements by grouping the messages
* remove LinkedIn from the widget (it is obviously not a repo and my CV
is already here, no need to link to an external site) | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | * move custom homepage components that does not require props to the
MDX file (links should not need to be translated here but where they
are defined)
* move SEO title and meta desc to MDX file
* make Page component the wrapper instead of using a React fragment
* fix MDX module types | 
| | 
| 
| 
| 
| 
| | * some nodes was missing in topicQuery
* a node was mispelled in topicsListQuery
* add tests for all topics fetchers | 
| | 
| 
| 
| 
| 
| | * some nodes was queried but missing in the Thematic type and
vice versa, it is now fixed
* add tests for all thematics fetchers | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The Typescript mapped types was useful for autocompletion in fetchers
but their are harder to maintain. I think it's better to keep each
query close to its fetcher to have a better understanding of the
fetched data. So I:
* colocate queries with their own fetcher
* colocate mutations with their own mutator
* remove Typescript mapped types for queries and mutations
* move data convertors inside graphql services
* rename most of data types and fetchers | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | * back-to-top test is not working: for some reasons, the link only
appears when manually scrolling
* search test has failure test: it seems the page meta is too long to
load
Anyway, the pages will be refactored and the e2e should also be
refactored. But the back to top test remains problematic... | 
| | 
| 
| 
| 
| 
| 
| | It does not make sense to re-export an existing object through a hook.
On some pages both the hook and the object was imported...
It is better to use the CONFIG (previously settings) object directly
and by doing it we avoid potential errors because of conditional hooks. | 
| | 
| 
| 
| 
| 
| 
| | * replace `isLoadingInitialData` with `isLoading` & `isRefreshing`
* rename `fallbackData` prop to `fallback`
* replace `setSize` return with a `loadMore` callback
* add tests | 
| | 
| 
| 
| 
| 
| | * `cover` prop is now expecting a ReactElement (NextImage)
* `meta` prop is now limited to a specific set of meta items
* add a `name` prop to add an accessible name to the figure element | 
| | 
| 
| 
| 
| 
| | * reuse Theme provider logic
* move DOM mutation from provider to hook
* add a script to init theme before page load | 
| | 
| 
| 
| 
| 
| 
| | To be honest, next-themes was working fine. However since I use a theme
provider for Prism code blocks, some code is duplicated between this
app and the library. So I prefer to use a custom Provider without the
options I don't need. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Since the local storage key is not meant to change between the
components, it should be set directly inside the app file. So
both the local storage and the data attribute should be handle
in a provider.
I also added a custom document because we need a script to
retrieve the stored value in local storage earlier to avoid
flashing on hydration. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | It makes it easier to change a route if needed and it avoid typo
mistakes.
I also refactored a bit the concerned files to be complient with the
new ESlint config. However, I should rewrite the pages to reduce
the number of statements. | 
| | |  | 
| | 
| 
| 
| 
| 
| | Using paths aliases starting with "@" can be confusing and can lead to
conflict with existings modules. I prefer to use relative paths to
avoid extra configuration in tools because of these aliases. | 
| | |  | 
| | 
| 
| 
| 
| | Sometimes a build can be successful but the page is not working, so
these tests allows me to check if the page is correctly loaded. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| | I also configure Jest to avoid conflicts between Cypress and Jest. | 
| | 
| 
| 
| 
| 
| | Since Next.js v12, Jest is already configured with the
next/jest package.
I also added a package to mock next/router. | 
|  |  |