Skip to content

Commit

Permalink
Feature / add tc-ready resource support (#7603)
Browse files Browse the repository at this point in the history
* Add support for tc-ready resources only

* Add support for tc-ready resources only

* Add support for tc-ready resources only to build script and resource downloads

* Fixes to bundle the tc-ready resources

* added checkbox for tcReady searching.

* update locales

* update locales in tools

* tweak css for checkbox for tcReady searching.

* reverse logic for tcReady searching.

* update resources

* force resources on build

---------

Co-authored-by: PhotoNomad0 <bruce.mclean@unfoldingword.org>
  • Loading branch information
PhotoNomad0 and PhotoNomad0 authored Dec 11, 2024
1 parent e7a0c0c commit 944dc38
Show file tree
Hide file tree
Showing 234 changed files with 6,909 additions and 72,247 deletions.
18 changes: 9 additions & 9 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@
"string-punctuation-tokenizer": "^2.2.0",
"sudo-prompt": "6.2.1",
"tc-electron-env": "0.10.0",
"tc-source-content-updater": "1.4.29",
"tc-source-content-updater": "1.4.32",
"tc-strings": "0.1.7",
"tc-tool": "4.1.0",
"tc-ui-toolkit": "6.2.9",
Expand Down
183 changes: 143 additions & 40 deletions scripts/resources/updateResources.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const {
} = require('tc-source-content-updater');
const packagefile = require('../../package.json');
const UpdateResourcesHelpers = require('./updateResourcesHelpers');
const { DOOR43_CATALOG, CN_CATALOG } = require("tc-source-content-updater/lib/helpers/apiHelpers");
const { DOOR43_CATALOG, CN_CATALOG, UNFOLDING_WORD } = require("tc-source-content-updater/lib/helpers/apiHelpers");
const zipResourcesContent = require('./zipHelpers').zipResourcesContent;

// TRICKY: with multi owner support of resources for now we want to restrict the bundled resources to these owners
Expand All @@ -28,9 +28,11 @@ const TWL_PATH = 'translationHelps/translationWordsLinks';
const TA_PATH = 'translationHelps/translationAcademy';
const TN_PATH = 'translationHelps/translationNotes';

const DOOR43_DEPRECATED = true;

let okToZip = false;
let unfoldingWordOrg = false
let preProd = false
let unfoldingWordOrg = false;
let preProd = false;

/**
* remove load-after resources from updateList so no duplicate fetches
Expand Down Expand Up @@ -60,6 +62,89 @@ function cleanUpLoadAfterResources(updateList) {
}
}

function isCoreResource(item) {
const isOriginal = (item.languageId === 'el-x-koine' && item.resourceId === 'ugnt') ||
(item.languageId === 'hbo' && item.resourceId === 'uhb');

if (!isOriginal) { // skip over any uw repos that are not original langs
const isEnglish = (item.languageId === 'en');

if (!isEnglish) { // skip over any filterOrg repos that are not english
return false;
}

const coreRes = isAlignedBible(item) || isOtherResource(item);
return coreRes;
}
return true;
}

function isBibleResource(item) {
const subject = item.subject;
const isBible = subject.toUpperCase().includes('BIBLE');
return isBible;
}

function isOtherResource(item) {
const notBible = !isBibleResource(item);
return notBible;
}

function isKeyLanguageResource(item, keyLanguages) {
const isKeyLanguage = keyLanguages.includes(item.languageId);
let keep = false;

if (isKeyLanguage) {
keep = isCoreResource(item) || isAlignedBibleOrOtherResource(item);
}
return keep;
}

function isAlignedBibleOrOtherResource(item) {
return isAlignedBible(item) || isOtherResource(item);
}

function isAlignedBible(item) {
const match = 'Aligned_Bible'.toUpperCase();
const subject = item.subject;

if (subject.toUpperCase() === match) {
return true;
}
return false;
}

/**
* strip list down to minimal resources if in filterOrg, original language and optionally English
* @param {object} sourceContentUpdater
* @param {string} filterOrg
* @param {string[]} updateList
* @param {boolean} addEnglishRes
*/
function getNeededResources(sourceContentUpdater, updateList, keyLanguages) {
for (const item of sourceContentUpdater.updatedCatalogResources) {
let keep = false;

switch (item.owner) {
case DOOR43_CATALOG:
keep = isCoreResource(item);
break;

case UNFOLDING_WORD:
keep = isCoreResource(item) || isAlignedBible(item) || isKeyLanguageResource(item, keyLanguages);
break;

default: // other orgs
keep = isAlignedBible(item) || isKeyLanguageResource(item, keyLanguages);
break;
}

if (keep) {
updateList.push(item);
}
}
}

/**
* find resources to update
* @param {String} languages - languages to update resources
Expand All @@ -82,42 +167,41 @@ const updateResources = async (languages, resourcesPath, allAlignedBibles, uWori

const localResourceList = apiHelpers.getLocalResourceList(resourcesPath);
checkForBrokenResources(localResourceList, resourcesPath);
const filterByOwner_ = [...filterByOwner];

let filterByOwner_ = [...filterByOwner];
const _UW = uWoriginalLanguage || unfoldingWordOrg;

if (_UW) {
filterByOwner_.push(UNFOLDING_WORD);
}

if (DOOR43_DEPRECATED) { // turn off the owner filtering if DOOR43_DEPRECATED
filterByOwner_ = null;
}

const latestManifestKey = { Bible: { 'usfm-js': USFMJS_VERSION } };
const config = {
filterByOwner: filterByOwner_,
latestManifestKey,
// ignoreDoor43Catalog: DOOR43_DEPRECATED, /// perhaps eventually we can completely ignore
topic: 'tc-ready',
};

if (filterByOwner_?.length) { // if not empty list
config.filterByOwner = filterByOwner_;
}

if (preProd) {
config.stage = STAGE.PRE_PROD
config.stage = STAGE.PRE_PROD;
}

okToZip = true;

await sourceContentUpdater.getLatestResources(localResourceList, config)
.then(async () => {
let updateList = [];
console.log(`Updated resources count is ${sourceContentUpdater.updatedCatalogResources?.length}`)

if (_UW) {
for (const item of sourceContentUpdater.updatedCatalogResources) {
if (!unfoldingWordOrg && item.owner === UNFOLDING_WORD) {
const isOriginal = (item.languageId === 'el-x-koine' && item.resourceId === 'ugnt') ||
(item.languageId === 'hbo' && item.resourceId === 'uhb');

if (!isOriginal) { // skip over any uw repos that are not original langs
continue;
}
}

updateList.push(item);
}
getNeededResources(sourceContentUpdater, updateList, languages);
} else {
updateList = sourceContentUpdater.updatedCatalogResources;
}
Expand Down Expand Up @@ -394,29 +478,48 @@ function validateResources(resourcesPath) {
errors += `\nLexicons are invalid`;
}

const _validateResources = {
'Door43-Catalog': [
'el-x-koine/bibles/ugnt',
'el-x-koine/translationHelps/translationWords',
'en/bibles/ult',
'en/bibles/ust',
'/hbo/bibles/uhb',
'hbo/translationHelps/translationWords',
],
'unfoldingWord': [
'el-x-koine/bibles/ugnt',
'/hbo/bibles/uhb',
],
const BASE_REQUIRED_RESOURCES_DOOR43 = [
'el-x-koine/bibles/ugnt',
'el-x-koine/translationHelps/translationWords',
'en/bibles/ult',
'en/bibles/ust',
'hbo/bibles/uhb',
'hbo/translationHelps/translationWords',
];

const BASE_ORIG_LANG_RESOURCES_DOOR43 = [
'el-x-koine/bibles/ugnt',
'el-x-koine/translationHelps/translationWords',
'en/bibles/ult',
'hbo/bibles/uhb',
'hbo/translationHelps/translationWords',
];

const BASE_REQUIRED_RESOURCES_UW = [
'el-x-koine/bibles/ugnt',
'en/translationHelps/translationAcademy',
'en/translationHelps/translationNotes',
'en/translationHelps/translationWords',
'en/translationHelps/translationWordsLinks',
'en/bibles/ult',
'en/bibles/ust',
'hbo/bibles/uhb',
];

const BASE_REQUIRED_RESOURCES_FOR_OTHER_OWNERS = [
'el-x-koine/bibles/ugnt',
'hbo/bibles/uhb',
];

const _validateResources = { 'Door43-Catalog': BASE_REQUIRED_RESOURCES_DOOR43 };

if (DOOR43_DEPRECATED) {
_validateResources.unfoldingWord = BASE_REQUIRED_RESOURCES_UW;
_validateResources['Door43-Catalog'] = BASE_ORIG_LANG_RESOURCES_DOOR43;
} else if (unfoldingWordOrg) {
_validateResources.unfoldingWord = BASE_REQUIRED_RESOURCES_FOR_OTHER_OWNERS;
};

if (unfoldingWordOrg) {
const _unfoldingWord = _validateResources.unfoldingWord
const unfoldingWord = {
..._validateResources['Door43-Catalog'],
..._unfoldingWord
}
}

for (const owner of Object.keys(_validateResources)) {
const resourcePaths_ = _validateResources[owner];

Expand Down
13 changes: 10 additions & 3 deletions src/js/actions/SourceContentUpdatesActions.js
Original file line number Diff line number Diff line change
Expand Up @@ -138,10 +138,11 @@ function getDownloadErrorList(errors, translate) {
* Downloads source content updates using the tc-source-content-updater.
* @param {array} resourcesToDownload - list of resources to be downloaded.
* @param {boolean} refreshUpdates
* @param {boolean} preRelease
* @param {boolean} preRelease - if true include pre-release content
* @param {boolean} notTcReady - if true include content not tcReady
* @returns {(function(*, *): Promise<void>)}
*/
export function downloadSourceContentUpdates(resourcesToDownload, refreshUpdates = false, preRelease = false) {
export function downloadSourceContentUpdates(resourcesToDownload, refreshUpdates = false, preRelease = false, notTcReady = false) {
return (async (dispatch, getState) => {
const translate = getTranslate(getState());
const toolName = getCurrentToolName(getState());
Expand Down Expand Up @@ -435,8 +436,9 @@ export const deletePreReleaseResources = (resourcesFolder) => ((dispatch, getSta
* @param {function} closeSourceContentDialog - Hacky workaround to close the
* source content dialog in the AppMenu state.
* @param {boolean} preRelease - if true include pre-release content
* @param {boolean} tcReady - if true include only tcReady content
*/
export function getListOfSourceContentToUpdate(closeSourceContentDialog, preRelease = false) {
export function getListOfSourceContentToUpdate(closeSourceContentDialog, preRelease = false, tcReady = true) {
return (async (dispatch, getState) => {
const translate = getTranslate(getState());
dispatch(resetSourceContentUpdatesReducer());
Expand All @@ -452,6 +454,11 @@ export function getListOfSourceContentToUpdate(closeSourceContentDialog, preRele
DCS_BASE_URL,
};

if (tcReady) {
config.ignoreDoor43Catalog = true;
config.topic = 'tc-ready';
}

await SourceContentUpdater.getLatestResources(localResourceList, config)
.then(resources => {
dispatch(closeAlertDialog());
Expand Down
Loading

0 comments on commit 944dc38

Please sign in to comment.