מדיה ויקי:CD-config.js

מתוך ויקיפדיה, האנציקלופדיה החופשית

הערה: לאחר הפרסום, ייתכן שיהיה צורך לנקות את זיכרון המטמון (cache) של הדפדפן כדי להבחין בשינויים.

  • פיירפוקס / ספארי: להחזיק את המקש Shift בעת לחיצה על טעינה מחדש (Reload) או ללחוץ על צירוף המקשים Ctrl-F5 או Ctrl-R (במחשב מק: ⌘-R).
  • גוגל כרום: ללחוץ על צירוף המקשים Ctrl-Shift-R (במחשב מק: ⌘-Shift-R).
  • אינטרנט אקספלורר / אדג': להחזיק את המקש Ctrl בעת לחיצה על רענן (Refresh) או ללחוץ על צירוף המקשים Ctrl-F5.
  • אופרה: ללחוץ על Ctrl-F5.
/**
 * This file was assembled automatically from the configuration at
 * https://github.com/jwbth/convenient-discussions/tree/master/config/w-he.js by running
 * "node buildConfigs". The configuration might get outdated as the script evolves, so it's best
 * to keep it up to date by checking for the documentation updates from time to time. See the
 * documentation at
 * https://commons.wikimedia.org/wiki/Special:MyLanguage/User:Jack_who_built_the_house/Convenient_Discussions#Configuring_for_a_wiki.
 */

// <nowiki>

(function () {

function unique(item, pos, arr) {
  return arr.indexOf(item) === pos;
}

function getStrings() {
  const requests = [mw.config.get('wgUserLanguage'), mw.config.get('wgContentLanguage')]
    .filter(unique)
    .filter(function (lang) {
      return lang !== 'en';
    })
    .map((lang) => mw.loader.getScript('https://commons.wikimedia.org/w/index.php?title=User:Jack_who_built_the_house/convenientDiscussions-i18n/' + lang + '.js&action=raw&ctype=text/javascript'));
  // We assume it's OK to fall back to English if the translation is unavailable for any reason.
  return Promise.all(requests).catch(function () {});
}

window.convenientDiscussions = window.convenientDiscussions || {};
if (convenientDiscussions.config) return;


/* BEGINNING OF THE CONFIGURATION */

convenientDiscussions.config = {
  messages: {
    'sun': "א'",
    'mon': "ב'",
    'tue': "ג'",
    'wed': "ד'",
    'thu': "ה'",
    'fri': "ו'",
    'sat': "ש'",
    'sunday': "יום א'",
    'monday': "יום ב'",
    'tuesday': "יום ג'",
    'wednesday': "יום ד'",
    'thursday': "יום ה'",
    'friday': "יום ו',",
    'saturday': "שבת",
    'jan': "ינו'",
    'feb': "פבר'",
    'mar': "מרץ",
    'apr': "אפר'",
    'may': "מאי",
    'jun': "יוני",
    'jul': "יולי",
    'aug': "אוג'",
    'sep': "ספט'",
    'oct': "אוקט'",
    'nov': "נוב'",
    'dec': "דצמ'",
    'january': 'ינואר',
    'february': 'פברואר',
    'march': 'מרץ',
    'april': 'אפריל',
    'may_long': 'מאי',
    'june': 'יוני',
    'july': 'יולי',
    'august': 'אוגוסט',
    'september': 'ספטמבר',
    'october': 'אוקטובר',
    'november': 'נובמבר',
    'december': 'דצמבר',
    'january-gen': 'בינואר',
    'february-gen': 'בפברואר',
    'march-gen': 'במרץ',
    'april-gen': 'באפריל',
    'may-gen': 'במאי',
    'june-gen': 'ביוני',
    'july-gen': 'ביולי',
    'august-gen': 'באוגוסט',
    'september-gen': 'בספטמבר',
    'october-gen': 'באוקטובר',
    'november-gen': 'בנובמבר',
    'december-gen': 'בדצמבר',
    'parentheses': '($1)',
    'parentheses-start': '(',
    'parentheses-end': ')',
    'word-separator': ' ',
    'comma-separator': ', ',
    'colon-separator': ':',
  },

  contribsPage: 'מיוחד:תרומות',

  localTimezoneOffset: null,

  customTalkNamespaces: [4],

  pageWhitelist: null,

  pageBlacklist: [/\/פתיח/],

  archivePaths: [/\/ארכיון/],

  pagesWithoutArchives: [],

  idleFragments: [],

  defaultIndentationChar: ':',

  spaceAfterIndentationChars: true,

  indentationCharMode: 'mimic',

  /**
   * Text that is removed from the end of the comment text and transferred to the beginning of the
   * signature text when editing a comment.
   *
   * `'` is in the end alone so that normal markup in the end of comments doesn't get removed - like
   * this:
   * ```
   * ''Reply in italics.'' [signature]
   * ```
   * Here, `''` is not a part of the signature.
   *
   * End the regexp with `$`.
   *
   * @type {RegExp}
   * @default /(?:\s+>+)?(?:[·•\-–—―~/→⇒\s]|&amp;mdash;|&amp;ndash;|&amp;rarr;|&amp;middot;|&amp;nbsp;|&amp;#32;)*\(?'*$/
   */
  // signaturePrefixRegexp: /(?:\s+>+)?(?:[·•\-–—―~/→⇒\s]|&mdash;|&ndash;|&rarr;|&middot;|&nbsp;|&#32;)*\(?'*$/,

  /**
   * Unchangable text (usually user talk page link) at the end of Mediawiki:Signature (visible text,
   * not wikitext). End the regexp with `$`.
   *
   * @type {?RegExp}
   * @default null
   */
  // signatureEndingRegexp: null,

  tagName: 'דיונים נוחים',

  /**
   * Script code name. Used, for example, for the `source` parameter of the thank request: {@link
   * https://www.mediawiki.org/wiki/Extension:Thanks#API_documentation}.
   *
   * @type {string}
   * @default 'convenient-discussions'
   */
  // scriptCodeName: 'convenient-discussions',

  /**
   * Prefix for the script options saved to the MediaWiki server in addition to the standard
   * `userjs-`.
   *
   * @type {string}
   * @default 'convenientDiscussions'
   */
  // optionsPrefix: 'convenientDiscussions',

  /**
   * Wikilink to the script's page. Used in the watchlist and, if there is no tag, in summary.
   *
   * @type {string}
   * @default 'c:User:JWBTH/CD'
   */
  // scriptPageWikilink: 'c:User:JWBTH/CD',

  unsignedTemplates: ['לא חתם', 'שכח לחתום', 'אלמ'],

  /**
   * Name of the class that the unsigned templates set to its container element.
   *
   * @type {string}
   */
  unsignedClass: 'autosigned',

  // pairQuoteTemplates: [
  //  [],
  //  [],
  // ],

  smallDivTemplate: null,

  paragraphTemplates: ['ש'],

  quoteFormatting: ["{{ציטוטון|1=", "}}\n"],

  /**
   * Blocks with classes listed here wont't be considered legit comment timestamp containers. They
   * can still be parts of comments; for the way to prevent certain elements from becoming comment
   * parts, see {@link module:defaultConfig.checkForCustomForeignComponents}.
   *
   * When it comes to the wikitext, all lines containing these classes are ignored.
   *
   * @type {string[]}
   * @default []
   */
  // elementsToExcludeClasses: [],

  templatesToExclude: [],

  /**
   * All lines containing these patterns will be ignored when searching for comments in the
   * wikitext.
   *
   * @type {RegExp[]}
   * @default []
   */
  // commentAntipatterns: [],

  /**
   * Regexps for strings that should be cut out of comment beginnings (not considered parts of
   * them). This is in addition to {@link module:cd~convenientDiscussions.g.BAD_COMMENT_BEGINNINGS}.
   * They begin with `^` and usually end with ` *\n*` or ` *\n*(?=[*:#])`.
   *
   * @type {RegExp[]}
   * @default []
   */
  // customBadCommentBeginnings: [],

   /**
   * Regexps for strings that should be kept in the section endings when adding a reply or
   * subsection (so that this reply or subsection is added _before_ them, not after). Usually begin
   * with `\n+`. The default value will keep HTML comments placed after an empty line in the section
   * endings.
   *
   * @type {RegExp[]}
   * @default <pre class="prettyprint source"><code>[
   *   /\n{2,}(?:&lt;!--[^]*?--&gt;\s*)+$/,
   * ]</code></pre>
   */
  // keepInSectionEnding: [
  //  /\n{2,}(?:<!--[^]*?-->\s*)+$/,
  // ],

  signatureScanLimit: 127,

  /**
   * Classes of elements that should be ignored when extracting headline text.
   *
   * @type {string[]}
   * @default []
   */
  // foreignElementsInHeadlinesClasses: [],

  /**
   * Selectors of floating elements. This is needed to display the comment's underlay and overlay
   * correctly. You can also add the `cd-floating` class to such elements. You can also add the
   * `cd-ignoreFloating` class to floating elements that never intersect comments but end up in
   * `convenientDiscussions.g.specialElements.floating` to help performance.
   *
   * @type {string[]}
   * @default []
   */
  // customFloatingElementsSelectors: [],

  /**
   * Names of the closed discussion templates. They can be single templates like {@link
   * https://en.wikipedia.org/wiki/Template:Closed} or pair templates like {@link
   * https://ru.wikipedia.org/wiki/Template:Закрыто} / {@link
   * https://ru.wikipedia.org/wiki/Template:Конец_закрытой_секции}. Include the closing part of the
   * pair templates in the second array, and the rest of the templates in the first array. These
   * templates are ignored when searching for a place to insert a comment in the wikitext.
   *
   * @type {Array.<Array.<string>>}
   * @default <pre class="prettyprint source"><code>[
   *   [],
   *   [],
   * ]</code></pre>
   */
  // closedDiscussionTemplates: [
  //   [],
  //   [],
  // ],

  /**
   * Classes of elements that are wrapped around closed discussions.
   *
   * @type {string[]}
   * @default []
   */
  // closedDiscussionClasses: [],

  /**
   * Classes of elements that shouldn't be highlighted.
   *
   * @type {string[]}
   * @default []
   */
  // customUnhighlightableElementsClasses: [],

  /**
   * Selectors of links (buttons) that are used to add topics on this wiki.
   *
   * @type {string[]}
   * @default []
   */
  // customAddTopicLinkSelectors: [],

  defaultInsertButtons: [
    ['{{א|' + '+}}'],
    ['{{תב|+}}'],
    ['{{+}}'],
    ['[[+]]'],
    ['{{ציטוטון|+}}'],
    ['{{בעד}} +'],
    ['{{נגד}} +'],
    ['{{בעלי ידע|+}}'],
    ['{{אלמ}}+'],
    ['{{לא חתם|+}}'],
    ['{{ש}}+'],
    ['{{לפני התנגשות}} +'],
    ['{{אחרי התנגשות}} +'],
    ['{{תודה רבה}}+'],
    ['{{בוצע}}+'],
    ['{{טופל}}+'],
    ['<code>+</code>', '<code />'],
    ['<nowiki>+</nowiki>', '<nowiki />'],
    ['<' + 'syntaxhighlight lang="+"></syntaxhighlight>', '<' + 'syntaxhighlight />'],
    ['<small>+</small>', '<small />'],
  ],

  /**
   * Data url of the script logo.
   *
   * @type {string}
   * @default
   * ''
   */
  // logoDataUrl: '',

  // logoWidth: '324px',

  // logoHeight: '40px',

  /**
   * How many characters should a comment have to be considered long. Comments having more
   * characters will need confirmation to be sent.
   *
   * @type {number}
   * @default 10000
   */
  // longCommentThreshold: 10000,

  /**
   * Lower limit of the number of bytes to be added to the page to deem an edit a new comment.
   *
   * @type {number}
   * @default 50
   */
  // bytesToDeemComment: 50,

  /**
   * Upper limit of the length of a comment to put its whole content in the edit summary.
   *
   * @type {number}
   * @default 50
   */
  // summaryCommentTextLengthLimit: 50,

  /**
   * Regular expression matching the names of the pages where an sending empty comment shouldn't be
   * confirmed (e.g., voting pages).
   *
   * @type {?RegExp}
   * @default null
   */
  // noConfirmPostEmptyCommentPageRegexp: null,

  /**
   * String to be put into a regular expression for matching indentation characters.
   *
   * @type {?string}
   * @default '\\n*([:*#]*) *'
   */
  // indentationCharsPattern: '\\n*([:*#]*) *',

  undoTexts: ['ביטול', 'בוטל', 'שחזור', 'שוחזר'],

  /**
   * Object specifying messages to be displayed when the user enters text that matches a pattern.
   *
   * @typedef {object} Reaction
   * @property {RegExp} pattern Pattern to match.
   * @property {string} message Message displayed to the user.
   * @property {string} name Latin letters, digits, `-`.
   * @property {string} [type='notice'] For example, `notice`.
   * @property {Function} [checkFunc] If the function returns false, no message is displayed.
   */

  /**
   * Custom reactions.
   *
   * @type {Reaction[]}
   * @default []
   */
  // customTextReactions: [],

  /**
   * @typedef {object} Module
   * @property {string} name Name of the module.
   * @property {Function} [checkFunc] Function that must return true for the module to be loaded (if
   *   it is present).
   */

  /**
   * Load these modules on comment form creation. See {@link module:defaultConfig~Module} for the
   * object structure. If `checkFunc` is set, the module will be loaded if the condition is met.
   *
   * @type {Module[]}
   * @default []
   */
  // customCommentFormModules: [],

  /**
   * Function that transforms the automatically generated summary text.
   *
   * @type {?Function}
   * @kind function
   * @param {string} summary
   * @returns {string}
   * @default null
   */
  // transformSummary: null,
  
	outdentTemplates: [
    	"שבירה"
	],
  /**
   * Function that makes custom alterations to the comment code before it is processed and
   * submitted. See also {@link module:defaultConfig.postTransformCode}.
   *
   * @type {?Function}
   * @kind function
   * @param {string} code
   * @param {CommentForm} commentForm
   * @returns {string}
   * @default null
   */
  // preTransformCode: null,

  /**
   * Function that makes custom alterations to the comment code after it is processed and before it
   * is submitted. (An example would be adding a closer template to all the closures by a user with
   * the closer flag which is a requirement in Russian Wikipedia.) See also {@link
   * module:defaultConfig.preTransformCode}.
   *
   * @type {?Function}
   * @kind function
   * @param {string} code
   * @param {CommentForm} commentForm
   * @returns {string}
   * @default null
   */
  // postTransformCode: null,

  /**
   * Function that returns `true` for nodes that are not parts of comments and should terminate the
   * comment part collecting. These rules often need correspoding rules in {@link
   * module:defaultConfig.customBadCommentBeginnings}.
   *
   * The second parameter is a "context", i.e., a collection of classes, functions, and other
   * properties that perform the tasks we need in the current context (window or worker).
   *
   * @type {?Function}
   * @kind function
   * @param {Node} node
   * @param {object} context
   * @returns {boolean}
   * @default null
   */
  // checkForCustomForeignComponents: null,

  /**
   * Function that returns `true` if new topics are placed on top of the page.
   *
   * @type {?Function}
   * @kind function
   * @param {string} title
   * @param {string} code
   * @returns {boolean}
   * @default null
   */
  // areNewTopicsOnTop: null,

  getMoveSourcePageCode: function (targetPageWikilink, signature, timestamp) {
    return `{{הועבר|ל=${targetPageWikilink}}} ${signature}`;
  },

  getMoveTargetPageCode: function (targetPageWikilink, signature) {
    return [`{{הועבר|מ=${targetPageWikilink}}} ${signature}`,
            `{{הועבר|סוף}}`];
  },

  /**
   * Code that creates an anchor on the page.
   *
   * @param {string} anchor
   * @returns {string}
   * @default <pre class="prettyprint source"><code>function (anchor) {
   *   return '&lt;span id="' + anchor + '>&lt;/span>';
   * }</code></pre>
   */
  // getAnchorCode: function (anchor) {
  //   return '<span id="' + anchor + '></span>';
  // },
  
  mentionRequiresLeadingSpace: false,
};

/* END OF THE CONFIGURATION */


if (!convenientDiscussions.isRunning) {
  convenientDiscussions.getStringsPromise = getStrings();
  mw.loader.getScript('https://commons.wikimedia.org/w/index.php?title=User:Jack_who_built_the_house/convenientDiscussions.js&action=raw&ctype=text/javascript')
    .catch(function (e) {
      console.warn('Couldn\'t load Convenient Discussions.', e);
    });
}

}());

// </nowiki>