mediawiki-extensions-Discus.../tests/qunit
Bartosz Dziewoński 8e44b43df0 Split off ThreadItemSet from CommentParser
Goal:
-----
Finishing the work from Iadb7757debe000025e52770ca51ebcf24ca8ee66
by changing CommentParser::parse() to return a data object, instead of
the whole parser.

Changes:
--------
ThreadItemSet.php:
ThreadItemSet.js:
* New data class to access the results of parsing a discussion. Most
  methods and properties are moved from CommentParser with no changes.

CommentParser.php:
Parser.js:
* parse() returns a new ThreadItemSet.
* Remove methods moved to ThreadItemSet.
* Placeholder headings are generated slightly differently, as we process
  things in a different order.
* Grouping threads and computing IDs/names is no longer lazy. We always
  needed IDs/names anyway.
* computeId() explicitly uses a ThreadItemSet to check the existing IDs
  when de-duplicating.

controller.js:
* Move the code for turning some nodes annotated by CommentFormatter
  into a ThreadItemSet (previously a Parser) from controller#init to
  ThreadItemSet.static.newFromAnnotatedNodes, and rewrite it to handle
  assigning parents/replies and recalculating legacy IDs more nicely.
* mw.dt.pageThreads is now a ThreadItemSet.

Change-Id: I49bfe019aa460651447fd383f73eafa9d7180a92
2022-02-21 16:22:32 +00:00
..
.eslintrc.json eslint: Lint root folder with server rules 2021-10-07 17:37:52 +01:00
index.js Fix skipping to the end of paragraph, now it considers nested tags 2021-01-18 18:20:20 +00:00
modifier.test.js Split off ThreadItemSet from CommentParser 2022-02-21 16:22:32 +00:00
parser.test.js Split off ThreadItemSet from CommentParser 2022-02-21 16:22:32 +00:00
testUtils.js Split off ThreadItemSet from CommentParser 2022-02-21 16:22:32 +00:00
ThreadItem.test.js Change CommentParser into a service 2022-02-19 19:51:57 +01:00
utils.test.js Change CommentParser into a service 2022-02-19 19:51:57 +01:00