@tacc/core-styles 0.11.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (427) hide show
  1. package/README.md +107 -85
  2. package/dist/branding_logos.css +1 -1
  3. package/dist/components/README.css +1 -1
  4. package/dist/components/admonition/demo.css +1 -0
  5. package/dist/components/admonition.css +1 -0
  6. package/dist/components/align/demo.css +1 -0
  7. package/dist/components/align.css +1 -0
  8. package/dist/components/bootstrap/bootstrap--form.demo.css +1 -0
  9. package/dist/components/bootstrap/bootstrap--modal.demo.css +1 -0
  10. package/dist/components/bootstrap/demo.css +1 -0
  11. package/dist/components/bootstrap.container.css +1 -1
  12. package/dist/components/bootstrap.css +1 -1
  13. package/dist/components/bootstrap.figure.css +1 -1
  14. package/dist/components/bootstrap.form.css +1 -1
  15. package/dist/components/bootstrap.modal.css +1 -1
  16. package/dist/components/bootstrap.pagination.css +1 -1
  17. package/dist/components/c-button/demo.css +1 -0
  18. package/dist/components/c-button.css +1 -1
  19. package/dist/components/c-callout.css +1 -1
  20. package/dist/components/c-card/c-card--frontera.demo.css +1 -0
  21. package/dist/components/c-card/c-card.demo.css +1 -0
  22. package/dist/components/c-card--frontera-about-page.css +1 -0
  23. package/dist/components/c-card.css +1 -1
  24. package/dist/components/c-card.selectors.css +1 -0
  25. package/dist/components/c-data-list.css +1 -1
  26. package/dist/components/c-footer.css +1 -1
  27. package/dist/components/c-form.css +1 -0
  28. package/dist/components/c-image-map.css +1 -1
  29. package/dist/components/c-image-map.skin.css +1 -1
  30. package/dist/components/c-image-map.structure.css +1 -1
  31. package/dist/components/c-message/demo.css +1 -0
  32. package/dist/components/c-message.css +1 -1
  33. package/dist/components/c-message.portal.css +1 -0
  34. package/dist/components/c-nav.css +1 -1
  35. package/dist/components/c-page.css +1 -1
  36. package/dist/components/c-recognition.css +1 -1
  37. package/dist/components/c-see-all-link.css +1 -1
  38. package/dist/components/c-show-more.css +1 -1
  39. package/dist/components/cortal.icon.css +1 -1
  40. package/dist/components/cortal.icon.font.css +1 -1
  41. package/dist/components/demo.css +1 -0
  42. package/dist/components/django-cms-forms.css +1 -0
  43. package/dist/components/django-cms-forms.hacks.css +1 -0
  44. package/dist/components/mui.tabs.css +1 -0
  45. package/dist/components/tacc-docs.css +1 -0
  46. package/dist/core-styles.base.css +4 -0
  47. package/dist/core-styles.cms.css +2 -0
  48. package/dist/core-styles.demo.css +2 -0
  49. package/dist/core-styles.docs.css +2 -0
  50. package/dist/core-styles.header.css +2 -0
  51. package/dist/core-styles.portal.css +2 -0
  52. package/dist/core-styles.settings.css +3 -0
  53. package/dist/elements/README.css +1 -1
  54. package/dist/elements/bootstrap.css +1 -1
  55. package/dist/elements/c-card.selectors.css +1 -0
  56. package/dist/elements/demo.css +1 -0
  57. package/dist/elements/form.cms.css +1 -1
  58. package/dist/elements/headings/demo.css +1 -0
  59. package/dist/elements/headings--cms.css +1 -0
  60. package/dist/elements/html-elements/demo.css +1 -0
  61. package/dist/elements/html-elements.cms.css +1 -1
  62. package/dist/elements/html-elements.css +1 -0
  63. package/dist/elements/html-elements.docs.css +1 -0
  64. package/dist/elements/links.css +1 -1
  65. package/dist/elements/monospace.css +1 -0
  66. package/dist/elements/root.css +1 -0
  67. package/dist/elements/sticky-footer.css +1 -0
  68. package/dist/elements/table--basic.css +1 -1
  69. package/dist/elements/table--nested.css +1 -1
  70. package/dist/elements/table.cms.css +1 -0
  71. package/dist/elements/table.css +1 -1
  72. package/dist/elements/table.selectors.css +1 -0
  73. package/dist/elements/tacc-search-bar.css +1 -1
  74. package/dist/fonts/BentonSans-Black.otf +0 -0
  75. package/dist/fonts/BentonSans-RegularItalic.otf +0 -0
  76. package/dist/fractal.server.refresh.css +1 -1
  77. package/dist/generics/README.css +1 -1
  78. package/dist/generics/fonts.css +1 -1
  79. package/dist/objects/README.css +1 -1
  80. package/dist/objects/o-fixed-header-table/demo.css +1 -0
  81. package/dist/objects/o-fixed-header-table.css +1 -1
  82. package/dist/objects/o-flex-item-table-wrap/demo.css +1 -0
  83. package/dist/objects/o-flex-item-table-wrap.css +1 -1
  84. package/dist/objects/o-float-content.css +1 -1
  85. package/dist/objects/o-grid.css +1 -1
  86. package/dist/objects/o-offset-content.css +1 -1
  87. package/dist/objects/o-section/demo.css +1 -0
  88. package/dist/objects/o-section.css +1 -1
  89. package/dist/objects/o-section.selectors.css +1 -0
  90. package/dist/objects/o-site.css +1 -1
  91. package/dist/objects/o-table-wrap/demo.basic.css +1 -0
  92. package/dist/objects/o-table-wrap/demo.extra.css +1 -0
  93. package/dist/objects/o-table-wrap/example.flexible-horz.css +1 -0
  94. package/dist/objects/o-table-wrap/example.overflow-hidden.css +1 -0
  95. package/dist/objects/o-table-wrap/example.overflow-scroll.css +1 -0
  96. package/dist/objects/o-table-wrap/o-table-wrap--flexible-horz.css +1 -0
  97. package/dist/objects/o-table-wrap/o-table-wrap--flexible-vert.css +1 -0
  98. package/dist/objects/o-table-wrap/o-table-wrap--overflow-hidden.css +1 -0
  99. package/dist/objects/o-table-wrap/o-table-wrap--overflow-scroll-extra.css +1 -0
  100. package/dist/objects/o-table-wrap/o-table-wrap--overflow-scroll.css +1 -0
  101. package/dist/objects/o-table-wrap.css +1 -0
  102. package/dist/settings/README.css +1 -1
  103. package/dist/settings/border.css +1 -1
  104. package/dist/settings/color.css +1 -1
  105. package/dist/settings/demo.css +1 -0
  106. package/dist/settings/font/demo-family.css +1 -0
  107. package/dist/settings/font/demo-size.css +1 -0
  108. package/dist/settings/font/demo-style.css +1 -0
  109. package/dist/settings/font/demo-weight.css +1 -0
  110. package/dist/settings/font--cms.css +1 -0
  111. package/dist/settings/font--docs.css +1 -0
  112. package/dist/settings/font--portal.css +1 -0
  113. package/dist/settings/font.css +1 -1
  114. package/dist/settings/max-width.css +1 -1
  115. package/dist/settings/space.css +1 -1
  116. package/dist/tools/README.css +1 -1
  117. package/dist/tools/media-queries.css +1 -1
  118. package/dist/tools/selectors.common.css +1 -0
  119. package/dist/tools/selectors.css +1 -0
  120. package/dist/tools/selectors.monospace.css +1 -0
  121. package/dist/tools/x-article-link.css +1 -1
  122. package/dist/tools/x-center.css +1 -1
  123. package/dist/tools/x-fake-border.css +1 -1
  124. package/dist/tools/x-grid.css +1 -1
  125. package/dist/tools/x-layout.css +1 -1
  126. package/dist/tools/x-link.css +1 -1
  127. package/dist/tools/x-mailto-text-replace.css +1 -1
  128. package/dist/tools/x-overlay.css +1 -1
  129. package/dist/tools/x-truncate.css +1 -1
  130. package/dist/trumps/README.css +1 -1
  131. package/dist/trumps/demo.css +1 -0
  132. package/dist/trumps/s-affixed-input-wrapper.css +1 -1
  133. package/dist/trumps/s-article-list.css +1 -1
  134. package/dist/trumps/s-article-preview.css +1 -1
  135. package/dist/trumps/s-blockquote.css +1 -1
  136. package/dist/trumps/s-breadcrumbs.css +1 -1
  137. package/dist/trumps/s-cms-nav.css +1 -1
  138. package/dist/trumps/s-document.css +1 -1
  139. package/dist/trumps/s-footer.css +1 -1
  140. package/dist/trumps/s-guide-doc.css +1 -1
  141. package/dist/trumps/s-header.bootstrap.css +1 -0
  142. package/dist/trumps/s-header.css +1 -1
  143. package/dist/trumps/s-inline-dl.css +1 -1
  144. package/dist/trumps/s-irregular-links.css +1 -1
  145. package/dist/trumps/s-paragraph-table.css +1 -0
  146. package/dist/trumps/s-portal-nav.css +1 -1
  147. package/dist/trumps/s-style-guide.css +1 -1
  148. package/dist/trumps/s-system-specs.css +1 -1
  149. package/dist/trumps/tacc-search-bar.css +1 -1
  150. package/dist/trumps/u-empty.css +1 -1
  151. package/dist/trumps/u-hide.css +1 -1
  152. package/dist/trumps/u-mailto-text-replace.css +1 -1
  153. package/dist/trumps/u-nested-text-content.css +1 -1
  154. package/docs/index.md +13 -5
  155. package/docs/shortcuts/tables.md +7 -0
  156. package/fractal.config.js +56 -17
  157. package/package.json +12 -9
  158. package/src/.postcssrc.base.yml +12 -2
  159. package/src/bin/build.js +0 -1
  160. package/src/lib/_imports/_partials/blockquote.hbs +5 -0
  161. package/src/lib/_imports/_partials/figure.hbs +15 -0
  162. package/src/lib/_imports/_partials/img.hbs +5 -0
  163. package/src/lib/_imports/_partials/loremipsum-paragraphs.hbs +15 -0
  164. package/src/lib/_imports/_partials/text-and-link-no-href.hbs +1 -0
  165. package/src/lib/_imports/_partials/text-of-one-paragraph-long.hbs +1 -0
  166. package/src/lib/_imports/_partials/text-of-one-paragraph-medium.hbs +1 -0
  167. package/src/lib/_imports/_partials/text-of-one-paragraph-short.hbs +1 -0
  168. package/src/lib/_imports/_partials/text-of-one-paragraph-with-tags.hbs +1 -0
  169. package/src/lib/_imports/_partials/text-of-one-sentence.hbs +1 -0
  170. package/src/lib/_imports/_preview.hbs +111 -40
  171. package/src/lib/_imports/branding_logos.css +0 -2
  172. package/src/lib/_imports/components/admonition/admonition.hbs +39 -0
  173. package/src/lib/_imports/components/admonition/config.yml +2 -0
  174. package/src/lib/_imports/components/admonition/demo.css +5 -0
  175. package/src/lib/_imports/components/admonition/readme.md +14 -0
  176. package/src/lib/_imports/components/admonition.css +35 -0
  177. package/src/lib/_imports/components/align/align.hbs +51 -0
  178. package/src/lib/_imports/components/align/config.yml +3 -0
  179. package/src/lib/_imports/components/align/demo.css +7 -0
  180. package/src/lib/_imports/components/align/readme.md +31 -0
  181. package/src/lib/_imports/components/align.css +33 -0
  182. package/src/lib/_imports/components/bootstrap/bootstrap--container.hbs +1 -1
  183. package/src/lib/_imports/components/bootstrap/bootstrap--modal.hbs +1 -1
  184. package/src/lib/_imports/components/bootstrap/bootstrap--modal.readme.md +4 -0
  185. package/src/lib/_imports/components/bootstrap/config.yml +3 -7
  186. package/src/lib/_imports/components/bootstrap/{docs.css → demo.css} +2 -2
  187. package/src/lib/_imports/components/bootstrap.container.css +0 -1
  188. package/src/lib/_imports/components/bootstrap.form.css +0 -1
  189. package/src/lib/_imports/components/bootstrap.modal.css +3 -0
  190. package/src/lib/_imports/components/c-button/{docs.css → demo.css} +0 -5
  191. package/src/lib/_imports/components/c-button.css +9 -1
  192. package/src/lib/_imports/components/c-card/_c-card--many-variable.hbs +107 -0
  193. package/src/lib/_imports/components/c-card/_c-card--one-image.hbs +6 -0
  194. package/src/lib/_imports/components/c-card/_c-card--one-plain.hbs +4 -0
  195. package/src/lib/_imports/components/c-card/_c-card--one-standard.hbs +15 -0
  196. package/src/lib/_imports/components/c-card/_c-card--one-transparent.hbs +4 -0
  197. package/src/lib/_imports/components/c-card/_c-card--one-with-grid.hbs +26 -0
  198. package/src/lib/_imports/components/c-card/c-card--frontera.demo.css +5 -0
  199. package/src/lib/_imports/components/{c-card.html → c-card/c-card--frontera.hbs} +7 -6
  200. package/src/lib/_imports/components/c-card/c-card--frontera.readme.md +5 -0
  201. package/src/lib/_imports/components/c-card/c-card.demo.css +11 -0
  202. package/src/lib/_imports/components/c-card/c-card.hbs +36 -0
  203. package/src/lib/_imports/components/c-card/c-card.readme.md +33 -0
  204. package/src/lib/_imports/components/c-card/config.yml +23 -0
  205. package/src/lib/_imports/components/c-card--frontera-about-page.css +48 -0
  206. package/src/lib/_imports/components/c-card.css +165 -34
  207. package/src/lib/_imports/components/c-card.selectors.css +38 -0
  208. package/src/lib/_imports/components/c-data-list/config.yml +9 -0
  209. package/src/lib/_imports/components/c-data-list/description-list/config.yml +68 -0
  210. package/src/lib/_imports/components/c-data-list/description-list/description-list.hbs +4 -0
  211. package/src/lib/_imports/components/c-data-list/description-list/readme.md +8 -0
  212. package/src/lib/_imports/components/c-data-list/readme.md +8 -0
  213. package/src/lib/_imports/components/c-data-list/table/config.yml +68 -0
  214. package/src/lib/_imports/components/c-data-list/table/readme.md +12 -0
  215. package/src/lib/_imports/components/c-data-list/table/table.hbs +4 -0
  216. package/src/lib/_imports/components/c-data-list.css +125 -46
  217. package/src/lib/_imports/components/c-footer.css +3 -50
  218. package/src/lib/_imports/components/c-form/c-form.hbs +365 -0
  219. package/src/lib/_imports/components/c-form/config.yml +3 -0
  220. package/src/lib/_imports/components/c-form/readme.md +14 -0
  221. package/src/lib/_imports/components/c-form/toggle-field-errors.js +101 -0
  222. package/src/lib/_imports/components/c-form/toggle-required-fields.js +85 -0
  223. package/src/lib/_imports/components/c-form.css +176 -0
  224. package/src/lib/_imports/components/c-message/_c-message--classes.hbs +5 -0
  225. package/src/lib/_imports/components/c-message/_c-message--intro.hbs +1 -0
  226. package/src/lib/_imports/components/c-message/_c-message--single.hbs +3 -0
  227. package/src/lib/_imports/components/c-message/c-message--scope.hbs +15 -0
  228. package/src/lib/_imports/components/c-message/c-message--scope.readme.md +14 -0
  229. package/src/lib/_imports/components/c-message/c-message--type.hbs +15 -0
  230. package/src/lib/_imports/components/c-message/c-message--type.readme.md +12 -0
  231. package/src/lib/_imports/components/c-message/c-message.hbs +1 -0
  232. package/src/lib/_imports/components/c-message/config.yml +35 -0
  233. package/src/lib/_imports/components/c-message/demo.css +12 -0
  234. package/src/lib/_imports/components/c-message/readme.md +1 -0
  235. package/src/lib/_imports/components/c-message.css +97 -31
  236. package/src/lib/_imports/components/c-message.portal.css +5 -0
  237. package/src/lib/_imports/components/cortal.icon.css +54 -6
  238. package/src/lib/_imports/components/demo.css +40 -0
  239. package/src/lib/_imports/components/django-cms-forms/config.yml +6 -0
  240. package/src/lib/_imports/components/django-cms-forms/django-cms-forms.hbs +407 -0
  241. package/src/lib/_imports/components/django-cms-forms/readme.md +20 -0
  242. package/src/lib/_imports/components/django-cms-forms.css +187 -0
  243. package/src/lib/_imports/components/django-cms-forms.hacks.css +59 -0
  244. package/src/lib/_imports/components/mui.tabs.css +30 -0
  245. package/src/lib/_imports/components/tacc-docs/config.yml +3 -0
  246. package/src/lib/_imports/components/tacc-docs/readme.md +23 -0
  247. package/src/lib/_imports/components/tacc-docs/tacc-docs.hbs +43 -0
  248. package/src/lib/_imports/components/tacc-docs.css +11 -0
  249. package/src/lib/_imports/core-styles.base.css +49 -0
  250. package/src/lib/_imports/core-styles.cms.css +46 -0
  251. package/src/lib/_imports/core-styles.demo.css +23 -0
  252. package/src/lib/_imports/core-styles.docs.css +36 -0
  253. package/src/lib/_imports/core-styles.header.css +37 -0
  254. package/src/lib/_imports/core-styles.portal.css +28 -0
  255. package/src/lib/_imports/core-styles.settings.css +9 -0
  256. package/src/lib/_imports/elements/demo.css +92 -0
  257. package/src/lib/_imports/elements/dl/dl.hbs +6 -0
  258. package/src/lib/_imports/elements/form.cms/readme.md +16 -0
  259. package/src/lib/_imports/elements/form.cms.css +5 -23
  260. package/src/lib/_imports/elements/headings/config.yml +15 -0
  261. package/src/lib/_imports/elements/headings/demo.css +10 -0
  262. package/src/lib/_imports/elements/headings/headings--cms.hbs +18 -0
  263. package/src/lib/_imports/elements/headings/headings.hbs +12 -0
  264. package/src/lib/_imports/elements/headings/readme.md +12 -0
  265. package/src/lib/_imports/elements/headings--cms.css +70 -0
  266. package/src/lib/_imports/elements/html-elements/config.yml +12 -0
  267. package/src/lib/_imports/elements/html-elements/demo.css +5 -0
  268. package/src/lib/_imports/elements/html-elements/html-elements.hbs +83 -0
  269. package/src/lib/_imports/elements/html-elements/readme.md +1 -0
  270. package/src/lib/_imports/elements/html-elements.cms.css +44 -165
  271. package/src/lib/_imports/elements/html-elements.css +97 -0
  272. package/src/lib/_imports/elements/html-elements.docs.css +6 -0
  273. package/src/lib/_imports/elements/links/links.hbs +7 -1
  274. package/src/lib/_imports/elements/links.css +7 -3
  275. package/src/lib/_imports/elements/monospace/config.yml +12 -0
  276. package/src/lib/_imports/elements/monospace/monospace.hbs +60 -0
  277. package/src/lib/_imports/elements/monospace.css +95 -0
  278. package/src/lib/_imports/elements/root.css +41 -0
  279. package/src/lib/_imports/elements/sticky-footer.css +6 -0
  280. package/src/lib/_imports/elements/table/config.yml +123 -6
  281. package/src/lib/_imports/elements/table/table--via-paragraphs.hbs +22 -0
  282. package/src/lib/_imports/elements/table/table--via-paragraphs.readme.md +17 -0
  283. package/src/lib/_imports/elements/table/table.hbs +19 -3
  284. package/src/lib/_imports/elements/table--basic.css +49 -22
  285. package/src/lib/_imports/elements/table--nested.css +16 -5
  286. package/src/lib/_imports/elements/table.cms.css +22 -0
  287. package/src/lib/_imports/elements/table.selectors.css +3 -0
  288. package/src/lib/_imports/generics/fonts.css +21 -7
  289. package/src/lib/_imports/objects/o-fixed-header-table/config.yml +62 -0
  290. package/src/lib/_imports/objects/o-fixed-header-table/demo.css +17 -0
  291. package/src/lib/_imports/objects/o-fixed-header-table/o-fixed-header-table.hbs +16 -0
  292. package/src/lib/_imports/objects/o-fixed-header-table/readme.md +22 -0
  293. package/src/lib/_imports/objects/o-fixed-header-table.css +1 -27
  294. package/src/lib/_imports/objects/o-flex-item-table-wrap/config.yml +27 -0
  295. package/src/lib/_imports/objects/o-flex-item-table-wrap/demo.css +7 -0
  296. package/src/lib/_imports/objects/o-flex-item-table-wrap/o-flex-item-table-wrap.hbs +7 -0
  297. package/src/lib/_imports/objects/o-flex-item-table-wrap/readme.md +22 -0
  298. package/src/lib/_imports/objects/o-flex-item-table-wrap.css +0 -34
  299. package/src/lib/_imports/objects/o-float-content.css +0 -1
  300. package/src/lib/_imports/objects/o-grid.css +7 -0
  301. package/src/lib/_imports/objects/o-offset-content.css +16 -17
  302. package/src/lib/_imports/objects/o-section/_o-section--usage.hbs +1 -0
  303. package/src/lib/_imports/objects/o-section/config.yml +18 -0
  304. package/src/lib/_imports/objects/o-section/demo.css +8 -0
  305. package/src/lib/_imports/objects/o-section/o-section.hbs +57 -0
  306. package/src/lib/_imports/objects/o-section/readme.md +32 -0
  307. package/src/lib/_imports/objects/o-section.css +59 -104
  308. package/src/lib/_imports/objects/o-section.selectors.css +20 -0
  309. package/src/lib/_imports/objects/o-site.css +1 -0
  310. package/src/lib/_imports/objects/o-table-wrap/config.yml +84 -0
  311. package/src/lib/_imports/objects/o-table-wrap/demo.basic.css +18 -0
  312. package/src/lib/_imports/objects/o-table-wrap/demo.extra.css +31 -0
  313. package/src/lib/_imports/objects/o-table-wrap/example.flexible-horz.css +23 -0
  314. package/src/lib/_imports/objects/o-table-wrap/example.overflow-hidden.css +7 -0
  315. package/src/lib/_imports/objects/o-table-wrap/example.overflow-scroll.css +7 -0
  316. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--flexible-horz.css +4 -0
  317. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--flexible-horz.hbs +5 -0
  318. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--flexible-horz.readme.md +20 -0
  319. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--flexible-vert.css +3 -0
  320. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--flexible-vert.hbs +5 -0
  321. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--flexible-vert.readme.md +18 -0
  322. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-hidden.css +3 -0
  323. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-hidden.hbs +5 -0
  324. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-hidden.readme.md +14 -0
  325. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-scroll-extra.css +2 -0
  326. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-scroll-extra.hbs +18 -0
  327. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-scroll-extra.readme.md +18 -0
  328. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-scroll.css +5 -0
  329. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-scroll.hbs +5 -0
  330. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap--overflow-scroll.readme.md +20 -0
  331. package/src/lib/_imports/objects/o-table-wrap/o-table-wrap.hbs +11 -0
  332. package/src/lib/_imports/objects/o-table-wrap/readme.md +24 -0
  333. package/src/lib/_imports/objects/o-table-wrap.css +5 -0
  334. package/src/lib/_imports/settings/_settings.config.yml +2 -0
  335. package/src/lib/_imports/settings/color.css +51 -11
  336. package/src/lib/_imports/settings/demo.css +5 -0
  337. package/src/lib/_imports/settings/font/_font--family.hbs +13 -0
  338. package/src/lib/_imports/settings/font/_font--size.hbs +5 -0
  339. package/src/lib/_imports/settings/font/_font--weight.hbs +33 -0
  340. package/src/lib/_imports/settings/font/config.yml +16 -0
  341. package/src/lib/_imports/settings/font/demo-family.css +10 -0
  342. package/src/lib/_imports/settings/font/demo-size.css +11 -0
  343. package/src/lib/_imports/settings/font/demo-style.css +2 -0
  344. package/src/lib/_imports/settings/font/demo-weight.css +20 -0
  345. package/src/lib/_imports/settings/font/font.hbs +39 -0
  346. package/src/lib/_imports/settings/font/readme.md +8 -0
  347. package/src/lib/_imports/settings/font--cms.css +17 -0
  348. package/src/lib/_imports/settings/font--docs.css +18 -0
  349. package/src/lib/_imports/settings/font--portal.css +17 -0
  350. package/src/lib/_imports/settings/font.css +11 -20
  351. package/src/lib/_imports/settings/space.css +6 -2
  352. package/src/lib/_imports/tools/selectors.common.css +13 -0
  353. package/src/lib/_imports/tools/selectors.css +20 -0
  354. package/src/lib/_imports/tools/selectors.monospace.css +64 -0
  355. package/src/lib/_imports/tools/x-link/readme.md +1 -0
  356. package/src/lib/_imports/tools/x-link/x-link.hbs +2 -0
  357. package/src/lib/_imports/tools/x-link.css +7 -3
  358. package/src/lib/_imports/{elements/links/docs.css → trumps/demo.css} +3 -2
  359. package/src/lib/_imports/trumps/s-affixed-input-wrapper/config.yml +3 -4
  360. package/src/lib/_imports/trumps/s-affixed-input-wrapper/s-affixed-input-wrapper.hbs +26 -24
  361. package/src/lib/_imports/trumps/s-affixed-input-wrapper.css +9 -11
  362. package/src/lib/_imports/trumps/s-blockquote/readme.md +12 -0
  363. package/src/lib/_imports/trumps/s-blockquote/s-blockquote.hbs +4 -0
  364. package/src/lib/_imports/trumps/s-blockquote.css +3 -25
  365. package/src/lib/_imports/trumps/s-breadcrumbs.css +18 -10
  366. package/src/lib/_imports/trumps/s-cms-nav.css +11 -0
  367. package/src/lib/_imports/trumps/s-guide-doc.css +0 -39
  368. package/src/lib/_imports/trumps/s-header.bootstrap.css +30 -0
  369. package/src/lib/_imports/trumps/s-header.css +2 -1
  370. package/src/lib/_imports/trumps/s-inline-dl.css +1 -0
  371. package/src/lib/_imports/trumps/s-irregular-links/config.yml +0 -7
  372. package/src/lib/_imports/trumps/s-irregular-links/s-irregular-links.hbs +15 -3
  373. package/src/lib/_imports/trumps/s-paragraph-table/config.yml +7 -0
  374. package/src/lib/_imports/trumps/s-paragraph-table/readme.md +17 -0
  375. package/src/lib/_imports/trumps/s-paragraph-table/s-paragraph-table.hbs +7 -0
  376. package/src/lib/_imports/trumps/s-paragraph-table.css +3 -0
  377. package/src/lib/_imports/trumps/s-portal-nav.css +11 -1
  378. package/src/lib/_imports/trumps/u-empty.css +4 -0
  379. package/src/lib/_imports/trumps/u-mailto-text-replace/config.yml +0 -3
  380. package/src/lib/_imports/trumps/u-mailto-text-replace/readme.md +1 -1
  381. package/src/lib/fonts/BentonSans-Black.otf +0 -0
  382. package/src/lib/fonts/BentonSans-RegularItalic.otf +0 -0
  383. package/dist/components/bootstrap/bootstrap--form.docs.css +0 -1
  384. package/dist/components/bootstrap/bootstrap--modal.docs.css +0 -1
  385. package/dist/components/bootstrap/bootstrap.modal/docs.css +0 -1
  386. package/dist/components/bootstrap/docs.css +0 -1
  387. package/dist/components/bootstrap/portal/bootstrap.form/docs.css +0 -1
  388. package/dist/components/bootstrap--container.css +0 -1
  389. package/dist/components/bootstrap--form/docs.css +0 -1
  390. package/dist/components/bootstrap--form.css +0 -1
  391. package/dist/components/bootstrap--modal/docs.css +0 -1
  392. package/dist/components/bootstrap--modal.css +0 -1
  393. package/dist/components/bootstrap.form/docs.css +0 -1
  394. package/dist/components/bootstrap.modal/docs.css +0 -1
  395. package/dist/components/c-button/docs.css +0 -1
  396. package/dist/elements/links/docs.css +0 -1
  397. package/dist/elements/table/docs.css +0 -1
  398. package/dist/elements/table/table.docs.css +0 -1
  399. package/dist/elements/table copy.css +0 -1
  400. package/dist/fonts/fonts/BentonSans-Bold.otf +0 -0
  401. package/dist/fonts/fonts/BentonSans-Medium.otf +0 -0
  402. package/dist/fonts/fonts/BentonSans-MediumItalic.otf +0 -0
  403. package/dist/fonts/fonts/BentonSans-Regular.otf +0 -0
  404. package/dist/fractal.server.css +0 -1
  405. package/dist/fractal.server.reload.css +0 -1
  406. package/dist/tools/x-link/docs.css +0 -1
  407. package/dist/trumps/icon.css +0 -1
  408. package/dist/trumps/icon.fonts.css +0 -1
  409. package/src/lib/_imports/_partials/bootstrap.css.hbs +0 -1
  410. package/src/lib/_imports/_partials/bootstrap.js.hbs +0 -2
  411. package/src/lib/_imports/_partials/cms.css.hbs +0 -3
  412. package/src/lib/_imports/_partials/css.hbs +0 -27
  413. package/src/lib/_imports/_partials/loremipsum.hbs +0 -18
  414. package/src/lib/_imports/_partials/text-of-one-paragraph.hbs +0 -1
  415. package/src/lib/_imports/_preview.bootstrap-cms.hbs +0 -5
  416. package/src/lib/_imports/_preview.bootstrap.hbs +0 -5
  417. package/src/lib/_imports/_preview.cms.hbs +0 -3
  418. package/src/lib/_imports/components/c-data-list.html +0 -131
  419. package/src/lib/_imports/elements/links/config.yml +0 -3
  420. package/src/lib/_imports/objects/o-section.html +0 -134
  421. package/src/lib/_imports/tools/x-link/docs.css +0 -6
  422. package/src/lib/_imports/trumps/icon.css +0 -31
  423. package/src/lib/_imports/trumps/icon.fonts.css +0 -316
  424. /package/src/lib/_imports/components/bootstrap/{bootstrap--form.docs.css → bootstrap--form.demo.css} +0 -0
  425. /package/src/lib/_imports/components/bootstrap/{bootstrap--modal.docs.css → bootstrap--modal.demo.css} +0 -0
  426. /package/src/lib/_imports/elements/table/{table--paragraph.readme.md → table--with-paragraphs.readme.md} +0 -0
  427. /package/src/lib/_imports/trumps/s-affixed-input-wrapper/{readme.md → README.md} +0 -0
@@ -0,0 +1,407 @@
1
+ <p class="c-message c-message--scope-global">
2
+ This component is maintained simuiltaneously with <a href="{{path '../detail/c-form' }}" target="_parent">C Form</code></a> and should look identical. Eventually, the two should have a single source of truth. To learn more, read <a href="https://confluence.tacc.utexas.edu/x/vJd9E" target="_blank">(Confluence) APCD - Form Markup &amp; Styles</a>.
3
+ </p>
4
+ <div class="forms">
5
+
6
+ <h3 class="title">Title of Form</h3>
7
+ <div class="description">
8
+ I describe the form, but not very well.
9
+ </div>
10
+
11
+ <div class="form-wrapper">
12
+ <form action="" method="POST" enctype="multipart/form-data">
13
+ <div class="form-errors" style="display:none;">
14
+ <ul class="errorlist">
15
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
16
+ </ul>
17
+ </div>
18
+
19
+ <div class="field-wrapper textinput required">
20
+ <div class="field-errors" style="display:none;">
21
+ <ul class="errorlist">
22
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
23
+ </ul>
24
+ </div>
25
+
26
+ <label for="name">
27
+ Name<span class="asterisk">*</span>
28
+ </label>
29
+
30
+ <input
31
+ type="text"
32
+ name="name"
33
+ required=""
34
+ placeholder="Your name"
35
+ class="textinput"
36
+ id="name"
37
+ />
38
+
39
+ <div id="help-text-name" class="help-text">
40
+ We use this to identify your submission.
41
+ </div>
42
+ </div>
43
+
44
+ <div class="field-wrapper select">
45
+ <div class="field-errors" style="display:none;">
46
+ <ul class="errorlist">
47
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
48
+ </ul>
49
+ </div>
50
+
51
+ <label for="favorite-fruit">Favorite Fruit</label>
52
+
53
+ <select name="favorite-fruit" class="choicefield" id="favorite-fruit">
54
+ <option value="" selected="">
55
+ Please select an option
56
+ </option>
57
+ <option value="Apple">Apple</option>
58
+ <option value="Banana">Banana</option>
59
+ <option value="Cherry">Cherry</option>
60
+ <option value="Durian">Durian</option>
61
+ <option value="Other">Other</option>
62
+ <option value="Whatever">Whatever</option>
63
+ </select>
64
+
65
+ <div id="help-text-favorite-fruit" class="help-text">
66
+ Choose your favorite fruit.
67
+ </div>
68
+ </div>
69
+
70
+ <div class="field-wrapper timeinput">
71
+ <div class="field-errors" style="display:none;">
72
+ <ul class="errorlist">
73
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
74
+ </ul>
75
+ </div>
76
+
77
+ <label for="wake-up-time">Wake Up Time</label>
78
+
79
+ <input
80
+ type="time"
81
+ name="wake-up-time"
82
+ class="timeinput"
83
+ id="wake-up-time"
84
+ />
85
+
86
+ <div id="help-text-wake-up-time" class="help-text">
87
+ We use this to know when to wake you up.
88
+ </div>
89
+ </div>
90
+
91
+ <div class="field-wrapper radioselect">
92
+ <div class="field-errors" style="display:none;">
93
+ <ul class="errorlist">
94
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
95
+ </ul>
96
+ </div>
97
+
98
+ <label for="radio-stations_0">Radio stations</label>
99
+
100
+ <ul id="radio-stations" class="radioselect">
101
+ <li>
102
+ <label for="radio-stations_0">
103
+ <input
104
+ type="radio"
105
+ name="radio-stations"
106
+ value="LX 1234"
107
+ class="radioselect"
108
+ id="radio-stations_0"
109
+ />
110
+ LX 1234
111
+ </label>
112
+ </li>
113
+ <li>
114
+ <label for="radio-stations_1">
115
+ <input
116
+ type="radio"
117
+ name="radio-stations"
118
+ value="LOVE 45"
119
+ class="radioselect"
120
+ id="radio-stations_1"
121
+ />
122
+ LOVE 45
123
+ </label>
124
+ </li>
125
+ <li>
126
+ <label for="radio-stations_2">
127
+ <input
128
+ type="radio"
129
+ name="radio-stations"
130
+ value="OLD 555"
131
+ class="radioselect"
132
+ id="radio-stations_2"
133
+ />
134
+ OLD 555
135
+ </label>
136
+ </li>
137
+ </ul>
138
+
139
+ <div id="help-text-radio-stations" class="help-text">
140
+ Which radio stations do you prefer?
141
+ </div>
142
+ </div>
143
+
144
+ <div class="field-wrapper checkboxinput">
145
+ <div class="field-errors" style="display:none;">
146
+ <ul class="errorlist">
147
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
148
+ </ul>
149
+ </div>
150
+
151
+ <input
152
+ type="checkbox"
153
+ name="checking-out"
154
+ class="booleanfield"
155
+ id="checking-out"
156
+ />
157
+
158
+ <label for="checking-out">Checking Out?</label>
159
+
160
+ <div id="help-text-checking-out" class="help-text">
161
+ Are you checking out today?
162
+ </div>
163
+ </div>
164
+
165
+ <div class="field-wrapper checkboxselectmultiple">
166
+ <div class="field-errors" style="display:none;">
167
+ <ul class="errorlist">
168
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
169
+ </ul>
170
+ </div>
171
+
172
+ <label>
173
+ Which fish do you want?
174
+ </label>
175
+
176
+ <ul id="which-fish-do-you-want" class="checkboxselectmultiple">
177
+ <li>
178
+ <label for="which-fish-do-you-want_0">
179
+ <input
180
+ type="checkbox"
181
+ name="which-fish-do-you-want"
182
+ value="one fish"
183
+ class="checkboxselectmultiple"
184
+ id="which-fish-do-you-want_0"
185
+ />
186
+ one fish
187
+ </label>
188
+ </li>
189
+ <li>
190
+ <label for="which-fish-do-you-want_1">
191
+ <input
192
+ type="checkbox"
193
+ name="which-fish-do-you-want"
194
+ value="two fish"
195
+ class="checkboxselectmultiple"
196
+ id="which-fish-do-you-want_1"
197
+ />
198
+ two fish
199
+ </label>
200
+ </li>
201
+ <li>
202
+ <label for="which-fish-do-you-want_2">
203
+ <input
204
+ type="checkbox"
205
+ name="which-fish-do-you-want"
206
+ value="red fish"
207
+ class="checkboxselectmultiple"
208
+ id="which-fish-do-you-want_2"
209
+ />
210
+ red fish
211
+ </label>
212
+ </li>
213
+ <li>
214
+ <label for="which-fish-do-you-want_3">
215
+ <input
216
+ type="checkbox"
217
+ name="which-fish-do-you-want"
218
+ value="blue fish"
219
+ class="checkboxselectmultiple"
220
+ id="which-fish-do-you-want_3"
221
+ />
222
+ blue fish
223
+ </label>
224
+ </li>
225
+ <li>
226
+ <label for="which-fish-do-you-want_4">
227
+ <input
228
+ type="checkbox"
229
+ name="which-fish-do-you-want"
230
+ value="all the fish"
231
+ class="checkboxselectmultiple"
232
+ id="which-fish-do-you-want_4"
233
+ />
234
+ all the fish
235
+ </label>
236
+ </li>
237
+ </ul>
238
+ </div>
239
+
240
+ <div class="field-wrapper select">
241
+ <div class="field-errors" style="display:none;">
242
+ <ul class="errorlist">
243
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
244
+ </ul>
245
+ </div>
246
+
247
+ <label for="hangry-time">Hangry Time</label>
248
+
249
+ <select name="hangry-time" class="choicefield" id="hangry-time">
250
+ <option value="" selected="">
251
+ Please select an option
252
+ </option>
253
+ <option value="Morning">Morning</option>
254
+ <option value="Noon">Noon</option>
255
+ <option value="Afternoon">Afternoon</option>
256
+ <option value="Evening">Evening</option>
257
+ <option value="Night">Night</option>
258
+ <option value="Midnight">Midnight</option>
259
+ </select>
260
+
261
+ <div id="help-text-hangry-time" class="help-text">
262
+ At which time of day do you get hangry?
263
+ </div>
264
+ </div>
265
+
266
+ <div class="field-wrapper textarea">
267
+ <div class="field-errors" style="display:none;">
268
+ <ul class="errorlist">
269
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
270
+ </ul>
271
+ </div>
272
+
273
+ <label for="life-story">Life Story</label>
274
+
275
+ <textarea
276
+ name="life-story"
277
+ cols="40"
278
+ rows="10"
279
+ class="textarea"
280
+ id="life-story"
281
+ ></textarea>
282
+
283
+ <div id="help-text-life-story" class="help-text">
284
+ Go on, tell me everything.
285
+ </div>
286
+ </div>
287
+
288
+ <div class="field-wrapper dateinput">
289
+ <div class="field-errors" style="display:none;">
290
+ <ul class="errorlist">
291
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
292
+ </ul>
293
+ </div>
294
+
295
+ <label for="what-day-is-it">What day is it?</label>
296
+
297
+ <input
298
+ type="date"
299
+ name="what-day-is-it"
300
+ class="dateinput"
301
+ id="what-day-is-it"
302
+ />
303
+
304
+ <div id="help-text-what-day-is-it" class="help-text">
305
+ Please enter today's date.
306
+ </div>
307
+ </div>
308
+
309
+ <div class="field-wrapper clearablefileinput">
310
+ <div class="field-errors" style="display:none;">
311
+ <ul class="errorlist">
312
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
313
+ </ul>
314
+ </div>
315
+
316
+ <label for="your-favorite-picture">Your favorite picture</label>
317
+
318
+ <input
319
+ type="file"
320
+ name="your-favorite-picture"
321
+ class="filefield"
322
+ id="your-favorite-picture"
323
+ />
324
+
325
+ <div id="help-text-your-favorite-picture" class="help-text">
326
+ Upload your favorite image.
327
+ <small>
328
+ Supported types:
329
+ <code>.jpeg</code>,<code>.jpg</code>,<code>.gif</code>,<code>.png</code>
330
+ </small>
331
+ </div>
332
+ </div>
333
+
334
+ <div class="field-wrapper recaptchav2checkbox required">
335
+ <div class="field-errors" style="display:none;">
336
+ <ul class="errorlist">
337
+ <li>Sample <strong>form</strong> error. <a href="#">Link.</a></li>
338
+ </ul>
339
+ </div>
340
+
341
+ <label for="recaptcha_g9y93gP8">
342
+ Are you a robot?<span class="asterisk">*</span>
343
+ </label>
344
+
345
+ <script src="https://www.google.com/recaptcha/api.js"></script>
346
+ <script type="text/javascript">
347
+ // Submit function to be called, after reCAPTCHA was successful. var
348
+ onSubmit_9e32f28ccb9545109ff6ae891f9af324 = function(token){" "}
349
+ {console.log("reCAPTCHA validated for 'data-widget-uuid=\"9e32f28ccb9545109ff6ae891f9af324\"'")};
350
+ </script>
351
+ <div class="g-recaptcha" data-sitekey="6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI" required="" id="recaptcha_g9y93gP8" data-widget-uuid="9e32f28ccb9545109ff6ae891f9af324" data-callback="onSubmit_9e32f28ccb9545109ff6ae891f9af324" data-size="normal"></div>
352
+ </div>
353
+
354
+ <div class="button-wrapper submit">
355
+ <button class="form-button" type="submit" value="Submit">
356
+ Submit
357
+ </button>
358
+ <button id="toggle-field-errors" class="form-button" type="button">
359
+ Toggle Field Errors
360
+ </button>
361
+ <button id="toggle-required-fields" class="form-button" type="button">
362
+ Toggle Required Fields
363
+ </button>
364
+ </div>
365
+ </form>
366
+ </div>
367
+
368
+ </div>
369
+
370
+ <script type="module">
371
+ import toggleFieldErrors from '{{ path "/components/raw/c-form/toggle-field-errors.js" }}';
372
+
373
+ document.addEventListener('DOMContentLoaded', () => {
374
+ const toggle = document.getElementById('toggle-field-errors');
375
+ const scope = document.querySelector('div.forms');
376
+
377
+ toggle.addEventListener('click', () => {
378
+ toggleFieldErrors( scope, '.field-errors, .form-errors');
379
+ });
380
+ });
381
+ </script>
382
+ <script type="module">
383
+ import toggleRequiredFields from '{{ path "/components/raw/c-form/toggle-required-fields.js" }}';
384
+
385
+ document.addEventListener('DOMContentLoaded', () => {
386
+ const toggle = document.getElementById('toggle-required-fields');
387
+ const form = toggle.closest('form');
388
+
389
+ toggle.addEventListener('click', () => {
390
+ toggleRequiredFields( form, 'field-wrapper', 'required', {
391
+ shouldScrollToFirst: true
392
+ });
393
+ });
394
+ });
395
+ </script>
396
+ <script type="module">
397
+ document.addEventListener('DOMContentLoaded', () => {
398
+ const form = document.querySelector('form');
399
+
400
+ form.addEventListener('submit', event => {
401
+ event.preventDefault();
402
+
403
+ /* TODO: Show success message on form */
404
+ alert('Form was not submitted, because this is an incomplete demo.');
405
+ });
406
+ });
407
+ </script>
@@ -0,0 +1,20 @@
1
+ To style forms built by [Django CMS forms][djcms-forms].
2
+
3
+ > **⚠️ Important**
4
+ >
5
+ > **Only** intended for [Django CMS forms][djcms-forms]. To style a form **not** using that plugin, use [TACC form component]({{path './c-form' }}).
6
+
7
+ > **ⓘ Notice**
8
+ >
9
+ > Most of the markup can be seen at [template][djcms-forms-tpl]. Some of the classes and markup come from [Django form field widgets][django-form-widgets].
10
+
11
+ [djcms-forms]: https://pypi.org/project/djangocms-forms-maintained/ "DjangoCMS-Forms (Maintained)"
12
+ [djcms-forms-tpl]: https://github.com/avryhof/djangocms-forms/blob/ab38b22/djangocms_forms/templates/djangocms_forms/form_template/default.html "DjangoCMS Forms (Maintained) Template"
13
+ [django-form-widgets]: https://docs.djangoproject.com/en/2.2/ref/forms/widgets/ "Django Form Widgets"
14
+
15
+ <script>
16
+ /* To open external links in new window */
17
+ Array.from(document.links)
18
+ .filter(link => link.hostname != window.location.hostname)
19
+ .forEach(link => link.target = '_blank');
20
+ </script>
@@ -0,0 +1,187 @@
1
+ @import url("../components/c-button.css");
2
+ @import url("../components/c-message.css");
3
+ @import url('../tools/x-link.css');
4
+
5
+ @import url("./django-cms-forms.hacks.css");
6
+
7
+
8
+
9
+ /* Title & Description */
10
+
11
+ .description {
12
+ margin-block: 25px;
13
+ }
14
+
15
+
16
+
17
+ /* Help Text */
18
+
19
+ .help-text {
20
+ font-size: var(--global-font-size--small);
21
+ font-style: italic;
22
+ }
23
+ :not(
24
+ ul, /* FAQ: Lists already have margin-bottom */
25
+ label /* FAQ: Labels already have margin-bottom */
26
+ ) + .help-text {
27
+ margin-top: 0.3em; /* mimic Bootstrap _reboot.css label margin-bottom */
28
+ }
29
+ /* To prevent help text font-style from affecting any tags */
30
+ /* FAQ: Help text can contain inline elements like <samp> */
31
+ /* FAQ: Help text can be (ab)used to add headings between form fields */
32
+ .help-text > :not(details, a, samp) {
33
+ font-style: initial;
34
+ }
35
+
36
+
37
+
38
+ /* Fields */
39
+
40
+ .field-wrapper {
41
+ margin-bottom: 2rem; /* mimic <p> `margin-bottom` */
42
+ }
43
+
44
+ .field-wrapper:not(.checkboxinput) {
45
+ display: flex;
46
+ flex-direction: column;
47
+ }
48
+ .field-wrapper:not(.checkboxinput) > .field-errors {
49
+ order: 1; /* i.e. move to end */
50
+ }
51
+
52
+ .field-wrapper.checkboxinput {
53
+ display: inline-grid;
54
+
55
+ column-gap: 0.5em;
56
+ align-items: center;
57
+ grid-template-columns: min-content auto; /* shrink input, let label extend */
58
+ grid-template-areas:
59
+ 'error _____'
60
+ 'input label'
61
+ 'notes notes';
62
+ }
63
+ .field-wrapper.checkboxinput .field-errors { grid-area: error; }
64
+ .field-wrapper.checkboxinput input { grid-area: input; }
65
+ .field-wrapper.checkboxinput label { grid-area: label; }
66
+ .field-wrapper.checkboxinput .help-text { grid-area: notes; }
67
+ .field-wrapper.checkboxinput label {
68
+ margin-bottom: 0; /* overwrite forms.css label */
69
+ }
70
+
71
+ ul.radioselect label,
72
+ ul.checkboxselectmultiple label {
73
+ display: flex;
74
+ gap: 0.5em;
75
+ align-items: center;
76
+ font-weight: revert; /* undo html-elements.cms.css */
77
+ }
78
+ ul.radioselect li:last-child label,
79
+ ul.checkboxselectmultiple li:last-child label {
80
+ margin-bottom: 0; /* overwrite forms.css label */
81
+ }
82
+
83
+ /* Field: Required, Asterisk, Important */
84
+
85
+ .field-wrapper .asterisk {
86
+ margin-left: 0.5em;
87
+ }
88
+ .field-wrapper.required .asterisk {
89
+ color: var(--global-color-danger--dark);
90
+ }
91
+ .field-wrapper:not(.required) .asterisk
92
+ /* NOTE: Manual markup ONLY; form plugin can't render non-required asterisk */ {
93
+ color: var(--global-color-warning--dark);
94
+ }
95
+ /* To replace asterisk character with text */
96
+ .field-wrapper .asterisk {
97
+ width: 0;
98
+ display: inline-block;
99
+ visibility: hidden;
100
+ line-height: 0;
101
+ }
102
+ .field-wrapper .asterisk::after {
103
+ visibility: visible;
104
+ line-height: initial;
105
+ }
106
+ .field-wrapper.required .asterisk::after {
107
+ content: '(required)';
108
+ }
109
+ .field-wrapper:not(.required) .asterisk::after
110
+ /* NOTE: Manual markup ONLY; form plugin can't render non-required asterisk */ {
111
+ content: '(important)';
112
+ }
113
+
114
+
115
+
116
+ /* Errors */
117
+
118
+ .field-errors ul {
119
+ margin-top: 1rem; /* mimic ul margin-bottom */
120
+ }
121
+ .form-errors ul,
122
+ .field-errors ul {
123
+ margin-bottom: 0; /* overwrite ul margin-bottom */
124
+ }
125
+ .form-errors {
126
+ margin-bottom: 1rem; /* mimic ul margin-bottom */
127
+ }
128
+
129
+ .form-errors ul,
130
+ .field-errors ul {
131
+ list-style: none;
132
+ padding-inline: 0;
133
+ }
134
+
135
+ .form-errors {
136
+ @extend .c-message;
137
+ @extend .c-message--type-error;
138
+ @extend .c-message--scope-section;
139
+ @extend .c-message--type-error.c-message--scope-section;
140
+ }
141
+ .field-errors li {
142
+ @extend .c-message;
143
+ @extend .c-message--type-error;
144
+ @extend .c-message--scope-inline;
145
+ }
146
+
147
+
148
+
149
+ /* Lists */
150
+
151
+ ul.radioselect,
152
+ ul.checkboxselectmultiple {
153
+ list-style: none;
154
+
155
+ padding-left: 0;
156
+ }
157
+
158
+
159
+
160
+ /* Layout */
161
+
162
+ .button-wrapper {
163
+ margin-top: 35px;
164
+ }
165
+
166
+
167
+
168
+ /* Button */
169
+
170
+ /* To style obvious buttons that neglect class */
171
+ .button-wrapper button[type="submit"] {
172
+ @extend .c-button;
173
+ @extend .c-button--primary;
174
+ }
175
+
176
+ .form-button {
177
+ @extend .c-button;
178
+ }
179
+ .form-button[type="submit"] {
180
+ @extend .c-button--primary;
181
+ }
182
+ .form-button:where(:not([type="submit"], [type="reset"])) {
183
+ @extend .c-button--secondary;
184
+ }
185
+ .form-button[type="reset"] {
186
+ @extend .c-button--tertiary;
187
+ }
@@ -0,0 +1,59 @@
1
+ /*
2
+ Django CMS Form Hacks
3
+
4
+ Render temporary messages to warn users and admins about unsupported feature(s) of the Django CMS Form plugin.
5
+
6
+ Reference:
7
+
8
+ - [FP-1808](https://jira.tacc.utexas.edu/browse/FP-1808)
9
+
10
+ Styleguide Components.DjangoCMS.Forms.Hacks
11
+ */
12
+ @custom-selector :--cms-logged-in .cms-ready;
13
+ @custom-selector :--cms-edit-mode [class*="cms-structure-mode-"];
14
+ /* TACC/Core-CMS#531: When merged, import and extend `.c-message(...)` */
15
+ /* @import url("@tacc/core-styles/src/lib/_imports/components/c-message.css"); */
16
+
17
+ @custom-selector :--problem-field
18
+ .field-wrapper.checkboxselectmultiple.required;
19
+
20
+ /* HACK: Messages about a required multi-checkbox field */
21
+ :--problem-field > label::after {
22
+ display: block;
23
+ margin-top: 0.5em;
24
+
25
+ /* To override styles inherited from `django-cms-forms.css` */
26
+ font-weight: normal;
27
+
28
+ /* To mimic c-message */
29
+ /* https://github.com/TACC/tup-ui/blob/main/libs/core-styles/src/lib/_imports/components/c-message.css */
30
+ padding: 15px 20px;
31
+ border: var(--global-border--thick);
32
+ font-size: var(--global-font-size--small);
33
+ /* TACC/Core-CMS#531: When merged, import and extend `.c-message(...)` */
34
+ /* @extend .c-message; */
35
+ }
36
+ /* To give error to admin */
37
+ html:--cms-edit-mode :--problem-field > label::after {
38
+ content: 'A multi checkbox field that is required is not well implemented. Do not require this field or replace it with multiple required Yes/No radio fields.';
39
+
40
+ /* To mimic c-message c-message-error */
41
+ /* https://github.com/TACC/tup-ui/blob/main/libs/core-styles/src/lib/_imports/components/c-message.css */
42
+ color: var(--global-color-danger--dark);
43
+ background-color: var(--global-color-danger--weak);
44
+ border-color: var(--global-color-danger--normal);
45
+ /* TACC/Core-CMS#531: When merged, import and extend `.c-message(...)` */
46
+ /* @extend .c-message--error; */
47
+ }
48
+ /* To give warning to user */
49
+ html:not(:--cms-edit-mode) :--problem-field > label::after {
50
+ content: 'This field is not well implemented. Select all boxes to bypass the error with this field.';
51
+
52
+ /* To mimic c-message c-message-warning */
53
+ /* https://github.com/TACC/tup-ui/blob/main/libs/core-styles/src/lib/_imports/components/c-message.css */
54
+ color: var(--global-color-warning--dark);
55
+ background-color: var(--global-color-warning--weak);
56
+ border-color: var(--global-color-warning--normal);
57
+ /* TACC/Core-CMS#531: When merged, import and extend `.c-message(...)` */
58
+ /* @extend .c-message--warning; */
59
+ }