Skip to content

Commit

Permalink
Customize codeblock and inline code font family (#122)
Browse files Browse the repository at this point in the history
  • Loading branch information
tomekzaw authored Jan 16, 2024
1 parent eafc739 commit cf149c4
Show file tree
Hide file tree
Showing 7 changed files with 61 additions and 18 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,10 @@ public class MarkdownStyle {
private final float mQuoteBorderWidth;
private final float mQuoteMarginLeft;
private final float mQuotePaddingLeft;
private final String mCodeFontFamily;
private final int mCodeColor;
private final int mCodeBackgroundColor;
private final String mPreFontFamily;
private final int mPreColor;
private final int mPreBackgroundColor;
private final int mMentionHereBackgroundColor;
Expand All @@ -34,8 +36,10 @@ public MarkdownStyle(@NonNull ReadableMap map, @NonNull Context context) {
mQuoteBorderWidth = parseFloat(map, "quote", "borderWidth");
mQuoteMarginLeft = parseFloat(map, "quote", "marginLeft");
mQuotePaddingLeft = parseFloat(map, "quote", "paddingLeft");
mCodeFontFamily = parseString(map, "code", "fontFamily");
mCodeColor = parseColor(map, "code", "color", context);
mCodeBackgroundColor = parseColor(map, "code", "backgroundColor", context);
mPreFontFamily = parseString(map, "pre", "fontFamily");
mPreColor = parseColor(map, "pre", "color", context);
mPreBackgroundColor = parseColor(map, "pre", "backgroundColor", context);
mMentionHereBackgroundColor = parseColor(map, "mentionHere", "backgroundColor", context);
Expand Down Expand Up @@ -63,6 +67,12 @@ private static float parseFloat(@NonNull ReadableMap map, @NonNull String key, @
return (float) value;
}

private static String parseString(@NonNull ReadableMap map, @NonNull String key, @NonNull String prop) {
ReadableMap style = map.getMap(key);
Objects.requireNonNull(style);
return style.getString(prop);
}

public int getSyntaxColor() {
return mSyntaxColor;
}
Expand Down Expand Up @@ -91,6 +101,10 @@ public float getQuotePaddingLeft() {
return mQuotePaddingLeft;
}

public String getCodeFontFamily() {
return mCodeFontFamily;
}

public int getCodeColor() {
return mCodeColor;
}
Expand All @@ -99,6 +113,10 @@ public int getCodeBackgroundColor() {
return mCodeBackgroundColor;
}

public String getPreFontFamily() {
return mPreFontFamily;
}

public int getPreColor() {
return mPreColor;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -108,10 +108,18 @@ private Object makeLinkColorSpan() {
return new ForegroundColorSpan(mMarkdownStyle.getLinkColor());
}

private Object makeCodeFontFamilySpan() {
return new TypefaceSpan(mMarkdownStyle.getCodeFontFamily());
}

private Object makeCodeColorSpan() {
return new ForegroundColorSpan(mMarkdownStyle.getCodeColor());
}

private Object makePreFontFamilySpan() {
return new TypefaceSpan(mMarkdownStyle.getPreFontFamily());
}

private Object makePreColorSpan() {
return new ForegroundColorSpan(mMarkdownStyle.getPreColor());
}
Expand Down Expand Up @@ -209,12 +217,12 @@ private void applyRange(SpannableStringBuilder ssb, String type, int start, int
setSpan(ssb, makeLinkColorSpan(), start, end);
break;
case "code":
setSpan(ssb, makeMonospaceSpan(), start, end);
setSpan(ssb, makeCodeFontFamilySpan(), start, end);
setSpan(ssb, makeCodeColorSpan(), start, end);
setSpan(ssb, makeCodeBackgroundSpan(), start, end);
break;
case "pre":
setSpan(ssb, makeMonospaceSpan(), start, end);
setSpan(ssb, makePreFontFamilySpan(), start, end);
setSpan(ssb, makePreColorSpan(), start, end);
setSpan(ssb, makePreBackgroundSpan(), start, end);
break;
Expand Down
2 changes: 2 additions & 0 deletions ios/RCTMarkdownStyle.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,10 @@
@property (nonatomic) CGFloat quoteBorderWidth;
@property (nonatomic) CGFloat quoteMarginLeft;
@property (nonatomic) CGFloat quotePaddingLeft;
@property (nonatomic, nonnull) NSString *codeFontFamily;
@property (nonatomic, nonnull) UIColor *codeColor;
@property (nonatomic, nonnull) UIColor *codeBackgroundColor;
@property (nonatomic, nonnull) NSString *preFontFamily;
@property (nonatomic, nonnull) UIColor *preColor;
@property (nonatomic, nonnull) UIColor *preBackgroundColor;
@property (nonatomic, nonnull) UIColor *mentionHereBackgroundColor;
Expand Down
4 changes: 4 additions & 0 deletions ios/RCTMarkdownStyle.mm
Original file line number Diff line number Diff line change
Expand Up @@ -24,9 +24,11 @@ - (instancetype)initWithStruct:(const facebook::react::MarkdownTextInputDecorato
_quoteMarginLeft = style.quote.marginLeft;
_quotePaddingLeft = style.quote.paddingLeft;

_codeFontFamily = RCTNSStringFromString(style.code.fontFamily);
_codeColor = RCTUIColorFromSharedColor(style.code.color);
_codeBackgroundColor = RCTUIColorFromSharedColor(style.code.backgroundColor);

_preFontFamily = RCTNSStringFromString(style.pre.fontFamily);
_preColor = RCTUIColorFromSharedColor(style.pre.color);
_preBackgroundColor = RCTUIColorFromSharedColor(style.pre.backgroundColor);

Expand Down Expand Up @@ -54,9 +56,11 @@ - (instancetype)initWithDictionary:(nonnull NSDictionary *)json
_quoteMarginLeft = [json[@"quote"][@"marginLeft"] floatValue];
_quotePaddingLeft = [json[@"quote"][@"paddingLeft"] floatValue];

_codeFontFamily = [RCTConvert NSString:json[@"code"][@"fontFamily"]];
_codeColor = [RCTConvert UIColor:json[@"code"][@"color"]];
_codeBackgroundColor = [RCTConvert UIColor:json[@"code"][@"backgroundColor"]];

_preFontFamily = [RCTConvert NSString:json[@"pre"][@"fontFamily"]];
_preColor = [RCTConvert UIColor:json[@"pre"][@"color"]];
_preBackgroundColor = [RCTConvert UIColor:json[@"pre"][@"backgroundColor"]];

Expand Down
32 changes: 17 additions & 15 deletions ios/RCTMarkdownUtils.mm
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
#import <react-native-live-markdown/RCTMarkdownUtils.h>
#import <react/debug/react_native_assert.h>
#import <React/RCTAssert.h>
#import <React/RCTFont.h>
#import <JavaScriptCore/JavaScriptCore.h>

@implementation RCTMarkdownUtils {
Expand Down Expand Up @@ -63,24 +64,25 @@ - (NSAttributedString *)parseMarkdown:(nullable NSAttributedString *)input
NSUInteger length = [item[2] unsignedIntegerValue];
NSRange range = NSMakeRange(location, length);

if ([type isEqualToString:@"bold"] || [type isEqualToString:@"mention"] || [type isEqualToString:@"h1"] || [type isEqualToString:@"mention-user"] || [type isEqualToString:@"syntax"] || [type isEqualToString:@"italic"] || [type isEqualToString:@"code"] || [type isEqualToString:@"pre"] || [type isEqualToString:@"h1"]) {
if ([type isEqualToString:@"bold"] || [type isEqualToString:@"mention"] || [type isEqualToString:@"mention-user"] || [type isEqualToString:@"syntax"] || [type isEqualToString:@"italic"] || [type isEqualToString:@"code"] || [type isEqualToString:@"pre"] || [type isEqualToString:@"h1"]) {
UIFont *font = [attributedString attribute:NSFontAttributeName atIndex:location effectiveRange:NULL];
UIFontDescriptor *fontDescriptor = [font fontDescriptor];
UIFontDescriptorSymbolicTraits traits = fontDescriptor.symbolicTraits;
if ([type isEqualToString:@"bold"] || [type isEqualToString:@"mention"] || [type isEqualToString:@"h1"] || [type isEqualToString:@"mention-user"] || [type isEqualToString:@"syntax"]) {
traits |= UIFontDescriptorTraitBold;
if ([type isEqualToString:@"bold"] || [type isEqualToString:@"mention"] || [type isEqualToString:@"mention-user"] || [type isEqualToString:@"syntax"]) {
font = [RCTFont updateFont:font withWeight:@"bold"];
} else if ([type isEqualToString:@"italic"]) {
traits |= UIFontDescriptorTraitItalic;
} else if ([type isEqualToString:@"code"] || [type isEqualToString:@"pre"]) {
traits |= UIFontDescriptorTraitMonoSpace;
font = [RCTFont updateFont:font withStyle:@"italic"];
} else if ([type isEqualToString:@"code"]) {
font = [RCTFont updateFont:font withFamily:_markdownStyle.codeFontFamily];
} else if ([type isEqualToString:@"pre"]) {
font = [RCTFont updateFont:font withFamily:_markdownStyle.preFontFamily];
} else if ([type isEqualToString:@"h1"]) {
font = [RCTFont updateFont:font withFamily:nil
size:[NSNumber numberWithFloat:_markdownStyle.h1FontSize]
weight:@"bold"
style:nil
variant:nil
scaleMultiplier:0];
}
UIFontDescriptor *newFontDescriptor = [fontDescriptor fontDescriptorWithSymbolicTraits:traits];
CGFloat size = 0; // Passing 0 to size keeps the existing size
if ([type isEqualToString:@"h1"]) {
size = _markdownStyle.h1FontSize;
}
UIFont *newFont = [UIFont fontWithDescriptor:newFontDescriptor size:size];
[attributedString addAttribute:NSFontAttributeName value:newFont range:range];
[attributedString addAttribute:NSFontAttributeName value:font range:range];
}

if ([type isEqualToString:@"syntax"]) {
Expand Down
9 changes: 8 additions & 1 deletion src/MarkdownTextInput.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,15 @@
import { StyleSheet, TextInput, processColor } from 'react-native';
import { Platform, StyleSheet, TextInput, processColor } from 'react-native';

import type { MarkdownStyle } from './MarkdownTextInputDecoratorViewNativeComponent';
import MarkdownTextInputDecoratorViewNativeComponent from './MarkdownTextInputDecoratorViewNativeComponent';
import React from 'react';
import type { TextInputProps } from 'react-native';

const FONT_FAMILY_MONOSPACE = Platform.select({
ios: 'Courier',
default: 'monospace',
});

function makeDefaultMarkdownStyle(): MarkdownStyle {
return {
syntax: {
Expand All @@ -23,10 +28,12 @@ function makeDefaultMarkdownStyle(): MarkdownStyle {
paddingLeft: 6,
},
code: {
fontFamily: FONT_FAMILY_MONOSPACE,
color: 'black',
backgroundColor: 'lightgray',
},
pre: {
fontFamily: FONT_FAMILY_MONOSPACE,
color: 'black',
backgroundColor: 'lightgray',
},
Expand Down
2 changes: 2 additions & 0 deletions src/MarkdownTextInputDecoratorViewNativeComponent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,12 @@ export interface MarkdownStyle {
paddingLeft: Float;
};
code: {
fontFamily: string;
color: ColorValue;
backgroundColor: ColorValue;
};
pre: {
fontFamily: string;
color: ColorValue;
backgroundColor: ColorValue;
};
Expand Down

0 comments on commit cf149c4

Please sign in to comment.