-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
A simple UI component for display the conversational novel
- Loading branch information
Showing
7 changed files
with
396 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
<?php | ||
/** | ||
* PHP Chat UI (0.0.1) | ||
* | ||
* A UI component for conversational novel community | ||
* | ||
* Date: 30 Aug, 2021 | ||
* | ||
* Author: Charlie Tang Hoong | ||
*/ | ||
class ChatUI | ||
{ | ||
public $roles; | ||
public $lines; | ||
public $dialogue; | ||
function __construct($data='') | ||
{ | ||
$chat['casts'] = 0; | ||
$chat['dialog'] = 0; | ||
$chat['roles'] = []; | ||
$chat['lines'] = []; | ||
$rolesData = strstr($data, "---", true); | ||
$linesData = strstr($data, "---"); | ||
// structure roles | ||
$rolesArray = array_values(array_filter(explode(PHP_EOL,$rolesData))); | ||
$chat['casts'] = count($rolesArray); | ||
foreach($rolesArray as $roleKey => $roleVal) | ||
{ | ||
$tempCast = []; | ||
$tempArray = explode(":",$roleVal); | ||
list($name, ,$img) = $tempArray; | ||
$tempCast['name'] = $name; | ||
$tempCast['img'] = $img; | ||
array_push($chat['roles'],$tempCast); | ||
} | ||
// structure lines | ||
$linesArray = array_values(array_filter(explode(PHP_EOL,$linesData))); | ||
foreach($linesArray as $lineKey => $lineVal) | ||
{ | ||
if($lineVal != '---') | ||
{ | ||
$chat['dialog'] = $chat['dialog'] + 1; | ||
$tempLine = []; | ||
$tempArray = explode(":",$lineVal); | ||
list($name, $sentence) = $tempArray; | ||
$tempLine['name'] = $name; | ||
$tempLine['sentence'] = $sentence; | ||
array_push($chat['lines'],$tempLine); | ||
} | ||
} | ||
// var_dump($chat); | ||
$this->dialogue = $chat; | ||
} | ||
public function read(){ | ||
$tempHtml = ''; | ||
foreach($this->dialogue['lines'] as $dialogue) | ||
{ | ||
switch($dialogue['name']) | ||
{ | ||
case 'Narator': | ||
$tempHtml .= $this->role_narator($dialogue); | ||
break; | ||
case $this->dialogue['roles'][0]['name']: | ||
$tempHtml .= $this->role_rightSide($dialogue); | ||
break; | ||
default: | ||
$tempHtml .= $this->role_leftSide($dialogue); | ||
break; | ||
} | ||
} | ||
return $tempHtml; | ||
} | ||
private function role_narator($dialogue) | ||
{ | ||
$tempHtml = '<p class="comment">'.$dialogue['sentence'].'</p>'; | ||
return $tempHtml; | ||
} | ||
private function role_leftSide($dialogue) | ||
{ | ||
$tempHtml = '<div class="imessage">'; | ||
$tempHtml .= '<div class="chat-name chat-name-them">'; | ||
$tempHtml .= '<img class="chat-header" src="'.$this->loadChatHeaderImg($dialogue['name']).'">'.$dialogue['name']; | ||
$tempHtml .= '</div>'; | ||
$tempHtml .= '<p class="from-them">'.$dialogue['sentence'].'</p>'; | ||
$tempHtml .= '</div>'; | ||
return $tempHtml; | ||
} | ||
private function role_rightSide($dialogue) | ||
{ | ||
$tempHtml = '<div class="imessage">'; | ||
$tempHtml .= '<div class="chat-name chat-name-me">'; | ||
$tempHtml .= $dialogue['name'].'<img class="chat-header" src="'.$this->loadChatHeaderImg($dialogue['name']).'">'; | ||
$tempHtml .= '</div>'; | ||
$tempHtml .= '<p class="from-me">'.$dialogue['sentence'].'</p>'; | ||
$tempHtml .= '</div>'; | ||
return $tempHtml; | ||
} | ||
private function loadChatHeaderImg($castName) | ||
{ | ||
foreach($this->dialogue['roles'] as $cast) | ||
{ | ||
if($cast['name'] == $castName) | ||
{ | ||
return $cast['img']; | ||
} | ||
} | ||
} | ||
} // EOF | ||
?> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,36 @@ | ||
# PHP Chat UI | ||
PHP Class for simulate conversation dialog | ||
PHP Class for simulate conversation dialog. | ||
|
||
A UI component for conversational novel community. | ||
|
||
Author: Tang Hoong | ||
|
||
# Screenshot | ||
|
||
data:image/s3,"s3://crabby-images/8f5ac/8f5accb4d40491e2837a7b2ffef62a49a4d486ed" alt="" | ||
|
||
# Description | ||
Just dump the string format which same as sample.txt then ChatUIClass will render them perfect and nice. | ||
|
||
# How | ||
Follow the format from sample.txt: | ||
``` | ||
Snake: https://i.imgur.com/FEiFVeO.png | ||
--- | ||
Narator: Once upon a time... | ||
Snake: Wanna eat apple 苹果 🍎🍎🍎? | ||
``` | ||
then | ||
``` | ||
include 'ChatUIClass.php'; | ||
$sample = file_get_contents('./sample.txt'); | ||
$dialogue = new ChatUI($sample); | ||
echo $dialogue->read(); | ||
``` | ||
become | ||
|
||
data:image/s3,"s3://crabby-images/568c9/568c994d4f851ed2705b8f8783d5bf69206b5fe0" alt="" | ||
|
||
# Resources refer from: | ||
|
||
[Codepen IMessage css](https://codepen.io/AllThingsSmitty/pen/jommGQ?editors=1000) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,206 @@ | ||
.imessage { | ||
background-color: #fff; | ||
/* border: 1px solid #e5e5ea; */ | ||
border-radius: 0.25rem; | ||
display: flex; | ||
flex-direction: column; | ||
font-family: "SanFrancisco"; | ||
font-size: 1.25rem; | ||
margin: 0 auto 1rem; | ||
max-width: 600px; | ||
padding: 0.5rem 1.5rem; | ||
} | ||
|
||
.imessage p { | ||
border-radius: 1.15rem; | ||
line-height: 1.25; | ||
max-width: 75%; | ||
padding: 0.5rem .875rem; | ||
position: relative; | ||
word-wrap: break-word; | ||
} | ||
|
||
.imessage p::before, | ||
.imessage p::after { | ||
bottom: -0.1rem; | ||
content: ""; | ||
height: 1rem; | ||
position: absolute; | ||
} | ||
|
||
p.from-me { | ||
align-self: flex-end; | ||
background-color: #248bf5; | ||
color: #fff; | ||
} | ||
|
||
p.from-me::before { | ||
border-bottom-left-radius: 0.8rem 0.7rem; | ||
border-right: 1rem solid #248bf5; | ||
right: -0.35rem; | ||
transform: translate(0, -0.1rem); | ||
} | ||
|
||
p.from-me::after { | ||
background-color: #fff; | ||
border-bottom-left-radius: 0.5rem; | ||
right: -40px; | ||
transform:translate(-30px, -2px); | ||
width: 10px; | ||
} | ||
|
||
p[class^="from-"] { | ||
margin: 0.5rem 0; | ||
width: fit-content; | ||
} | ||
|
||
p.from-me ~ p.from-me { | ||
margin: 0.25rem 0 0; | ||
} | ||
|
||
p.from-me ~ p.from-me:not(:last-child) { | ||
margin: 0.25rem 0 0; | ||
} | ||
|
||
p.from-me ~ p.from-me:last-child { | ||
margin-bottom: 0.5rem; | ||
} | ||
|
||
p.from-them { | ||
align-items: flex-start; | ||
background-color: #e5e5ea; | ||
color: #000; | ||
} | ||
|
||
p.from-them:before { | ||
border-bottom-right-radius: 0.8rem 0.7rem; | ||
border-left: 1rem solid #e5e5ea; | ||
left: -0.35rem; | ||
transform: translate(0, -0.1rem); | ||
} | ||
|
||
p.from-them::after { | ||
background-color: #fff; | ||
border-bottom-right-radius: 0.5rem; | ||
left: 20px; | ||
transform: translate(-30px, -2px); | ||
width: 10px; | ||
} | ||
|
||
p[class^="from-"].emoji { | ||
background: none; | ||
font-size: 2.5rem; | ||
} | ||
|
||
p[class^="from-"].emoji::before { | ||
content: none; | ||
} | ||
|
||
.no-tail::before { | ||
display: none; | ||
} | ||
|
||
.margin-b_none { | ||
margin-bottom: 0 !important; | ||
} | ||
|
||
.margin-b_one { | ||
margin-bottom: 1rem !important; | ||
} | ||
|
||
.margin-t_one { | ||
margin-top: 1rem !important; | ||
} | ||
|
||
|
||
/* general styling */ | ||
@font-face { | ||
font-family: "SanFrancisco"; | ||
src: | ||
url("https://cdn.rawgit.com/AllThingsSmitty/fonts/25983b71/SanFrancisco/sanfranciscodisplay-regular-webfont.woff2") format("woff2"), | ||
url("https://cdn.rawgit.com/AllThingsSmitty/fonts/25983b71/SanFrancisco/sanfranciscodisplay-regular-webfont.woff") format("woff"); | ||
} | ||
|
||
body { | ||
font-family: -apple-system, | ||
BlinkMacSystemFont, | ||
"Segoe UI", | ||
Roboto, | ||
Oxygen-Sans, | ||
Ubuntu, | ||
Cantarell, | ||
"Helvetica Neue", | ||
sans-serif; | ||
font-weight: normal; | ||
margin: 0; | ||
} | ||
|
||
.container { | ||
margin: 0 auto; | ||
max-width: 600px; | ||
padding: 1rem; | ||
} | ||
|
||
h1 { | ||
font-weight: normal; | ||
margin-bottom: 0.5rem; | ||
} | ||
|
||
h2 { | ||
border-bottom: 1px solid #e5e5ea; | ||
color: #666; | ||
font-weight: normal; | ||
margin-top: 0; | ||
padding-bottom: 1.5rem; | ||
} | ||
|
||
.comment { | ||
color: #222; | ||
font-size: 1.25rem; | ||
line-height: 1.5; | ||
margin-bottom: 1.25rem; | ||
max-width: 100%; | ||
padding: 0; | ||
} | ||
|
||
@media screen and (max-width: 800px) { | ||
body { | ||
margin: 0 0.5rem; | ||
} | ||
|
||
.container { | ||
padding: 0.5rem; | ||
} | ||
|
||
.imessage { | ||
font-size: 1.05rem; | ||
margin: 0 auto 1rem; | ||
max-width: 600px; | ||
padding: 0.25rem 0.875rem; | ||
} | ||
|
||
.imessage p { | ||
margin: 0.5rem 0; | ||
} | ||
} | ||
|
||
|
||
/* chat-header */ | ||
.imessage .chat-header { | ||
border-radius: 30px; | ||
width: 20px; | ||
height: 20px; | ||
margin: 3px; | ||
} | ||
.imessage .chat-name{ | ||
font-weight: bold; | ||
display: flex; | ||
align-items: center; | ||
} | ||
.imessage .chat-name-me{ | ||
text-align: right; | ||
justify-content: flex-end; | ||
} | ||
.imessage .chat-name-them{ | ||
text-align: left; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
<?php | ||
include 'ChatUIClass.php'; | ||
$sample = file_get_contents('./sample.txt'); | ||
?> | ||
|
||
|
||
<!DOCTYPE html> | ||
<!--[if lt IE 7]> <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]--> | ||
<!--[if IE 7]> <html class="no-js lt-ie9 lt-ie8"> <![endif]--> | ||
<!--[if IE 8]> <html class="no-js lt-ie9"> <![endif]--> | ||
<!--[if gt IE 8]> <html class="no-js"> <!--<![endif]--> | ||
<html> | ||
<head> | ||
<meta charset="utf-8"> | ||
<meta http-equiv="X-UA-Compatible" content="IE=edge"> | ||
<title>Text soap</title> | ||
<meta name="description" content=""> | ||
<meta name="viewport" content="width=device-width, initial-scale=1"> | ||
<link rel="stylesheet" href="imessage.css"> | ||
</head> | ||
<body> | ||
<div class="container" id="chatUI"> | ||
<h1>Text Soap</h1> | ||
<?php | ||
$dialogue = new ChatUI($sample); | ||
echo $dialogue->read(); | ||
?> | ||
</div> | ||
</body> | ||
</html> |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.